1 /* 2 * This file is part of gtkD. 3 * 4 * gtkD is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU Lesser General Public License 6 * as published by the Free Software Foundation; either version 3 7 * of the License, or (at your option) any later version, with 8 * some exceptions, please read the COPYING file. 9 * 10 * gtkD is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU Lesser General Public License for more details. 14 * 15 * You should have received a copy of the GNU Lesser General Public License 16 * along with gtkD; if not, write to the Free Software 17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA 18 */ 19 20 // generated automatically - do not change 21 // find conversion definition on APILookup.txt 22 // implement new conversion functionalities on the wrap.utils pakage 23 24 25 module atk.TableIF; 26 27 private import atk.ObjectAtk; 28 private import atk.c.functions; 29 public import atk.c.types; 30 private import glib.Str; 31 private import glib.c.functions; 32 private import gobject.ObjectG; 33 private import gobject.Signals; 34 private import std.algorithm; 35 36 37 /** 38 * #AtkTable should be implemented by components which present 39 * elements ordered via rows and columns. It may also be used to 40 * present tree-structured information if the nodes of the trees can 41 * be said to contain multiple "columns". Individual elements of an 42 * #AtkTable are typically referred to as "cells". Those cells should 43 * implement the interface #AtkTableCell, but #Atk doesn't require 44 * them to be direct children of the current #AtkTable. They can be 45 * grand-children, grand-grand-children etc. #AtkTable provides the 46 * API needed to get a individual cell based on the row and column 47 * numbers. 48 * 49 * Children of #AtkTable are frequently "lightweight" objects, that 50 * is, they may not have backing widgets in the host UI toolkit. They 51 * are therefore often transient. 52 * 53 * Since tables are often very complex, #AtkTable includes provision 54 * for offering simplified summary information, as well as row and 55 * column headers and captions. Headers and captions are #AtkObjects 56 * which may implement other interfaces (#AtkText, #AtkImage, etc.) as 57 * appropriate. #AtkTable summaries may themselves be (simplified) 58 * #AtkTables, etc. 59 * 60 * Note for implementors: in the past, #AtkTable required that all the 61 * cells should be direct children of #AtkTable, and provided some 62 * index based methods to request the cells. The practice showed that 63 * that forcing made #AtkTable implementation complex, and hard to 64 * expose other kind of children, like rows or captions. Right now, 65 * index-based methods are deprecated. 66 */ 67 public interface TableIF{ 68 /** Get the main Gtk struct */ 69 public AtkTable* getTableStruct(bool transferOwnership = false); 70 71 /** the main Gtk struct as a void* */ 72 protected void* getStruct(); 73 74 75 /** */ 76 public static GType getType() 77 { 78 return atk_table_get_type(); 79 } 80 81 /** 82 * Adds the specified @column to the selection. 83 * 84 * Params: 85 * column = a #gint representing a column in @table 86 * 87 * Returns: a gboolean representing if the column was successfully added to 88 * the selection, or 0 if value does not implement this interface. 89 */ 90 public bool addColumnSelection(int column); 91 92 /** 93 * Adds the specified @row to the selection. 94 * 95 * Params: 96 * row = a #gint representing a row in @table 97 * 98 * Returns: a gboolean representing if row was successfully added to selection, 99 * or 0 if value does not implement this interface. 100 */ 101 public bool addRowSelection(int row); 102 103 /** 104 * Gets the caption for the @table. 105 * 106 * Returns: a AtkObject* representing the 107 * table caption, or %NULL if value does not implement this interface. 108 */ 109 public ObjectAtk getCaption(); 110 111 /** 112 * Gets a #gint representing the column at the specified @index_. 113 * 114 * Deprecated: Since 2.12. 115 * 116 * Params: 117 * index = a #gint representing an index in @table 118 * 119 * Returns: a gint representing the column at the specified index, 120 * or -1 if the table does not implement this method. 121 */ 122 public int getColumnAtIndex(int index); 123 124 /** 125 * Gets the description text of the specified @column in the table 126 * 127 * Params: 128 * column = a #gint representing a column in @table 129 * 130 * Returns: a gchar* representing the column description, or %NULL 131 * if value does not implement this interface. 132 */ 133 public string getColumnDescription(int column); 134 135 /** 136 * Gets the number of columns occupied by the accessible object 137 * at the specified @row and @column in the @table. 138 * 139 * Params: 140 * row = a #gint representing a row in @table 141 * column = a #gint representing a column in @table 142 * 143 * Returns: a gint representing the column extent at specified position, or 0 144 * if value does not implement this interface. 145 */ 146 public int getColumnExtentAt(int row, int column); 147 148 /** 149 * Gets the column header of a specified column in an accessible table. 150 * 151 * Params: 152 * column = a #gint representing a column in the table 153 * 154 * Returns: a AtkObject* representing the 155 * specified column header, or %NULL if value does not implement this 156 * interface. 157 */ 158 public ObjectAtk getColumnHeader(int column); 159 160 /** 161 * Gets a #gint representing the index at the specified @row and 162 * @column. 163 * 164 * Deprecated: Since 2.12. Use atk_table_ref_at() in order to get the 165 * accessible that represents the cell at (@row, @column) 166 * 167 * Params: 168 * row = a #gint representing a row in @table 169 * column = a #gint representing a column in @table 170 * 171 * Returns: a #gint representing the index at specified position. 172 * The value -1 is returned if the object at row,column is not a child 173 * of table or table does not implement this interface. 174 */ 175 public int getIndexAt(int row, int column); 176 177 /** 178 * Gets the number of columns in the table. 179 * 180 * Returns: a gint representing the number of columns, or 0 181 * if value does not implement this interface. 182 */ 183 public int getNColumns(); 184 185 /** 186 * Gets the number of rows in the table. 187 * 188 * Returns: a gint representing the number of rows, or 0 189 * if value does not implement this interface. 190 */ 191 public int getNRows(); 192 193 /** 194 * Gets a #gint representing the row at the specified @index_. 195 * 196 * Deprecated: since 2.12. 197 * 198 * Params: 199 * index = a #gint representing an index in @table 200 * 201 * Returns: a gint representing the row at the specified index, 202 * or -1 if the table does not implement this method. 203 */ 204 public int getRowAtIndex(int index); 205 206 /** 207 * Gets the description text of the specified row in the table 208 * 209 * Params: 210 * row = a #gint representing a row in @table 211 * 212 * Returns: a gchar* representing the row description, or 213 * %NULL if value does not implement this interface. 214 */ 215 public string getRowDescription(int row); 216 217 /** 218 * Gets the number of rows occupied by the accessible object 219 * at a specified @row and @column in the @table. 220 * 221 * Params: 222 * row = a #gint representing a row in @table 223 * column = a #gint representing a column in @table 224 * 225 * Returns: a gint representing the row extent at specified position, or 0 226 * if value does not implement this interface. 227 */ 228 public int getRowExtentAt(int row, int column); 229 230 /** 231 * Gets the row header of a specified row in an accessible table. 232 * 233 * Params: 234 * row = a #gint representing a row in the table 235 * 236 * Returns: a AtkObject* representing the 237 * specified row header, or %NULL if value does not implement this 238 * interface. 239 */ 240 public ObjectAtk getRowHeader(int row); 241 242 /** 243 * Gets the selected columns of the table by initializing **selected with 244 * the selected column numbers. This array should be freed by the caller. 245 * 246 * Params: 247 * selected = a #gint** that is to contain the selected columns numbers 248 * 249 * Returns: a gint representing the number of selected columns, 250 * or %0 if value does not implement this interface. 251 */ 252 public int getSelectedColumns(int** selected); 253 254 /** 255 * Gets the selected rows of the table by initializing **selected with 256 * the selected row numbers. This array should be freed by the caller. 257 * 258 * Params: 259 * selected = a #gint** that is to contain the selected row numbers 260 * 261 * Returns: a gint representing the number of selected rows, 262 * or zero if value does not implement this interface. 263 */ 264 public int getSelectedRows(int** selected); 265 266 /** 267 * Gets the summary description of the table. 268 * 269 * Returns: a AtkObject* representing a summary description 270 * of the table, or zero if value does not implement this interface. 271 */ 272 public ObjectAtk getSummary(); 273 274 /** 275 * Gets a boolean value indicating whether the specified @column 276 * is selected 277 * 278 * Params: 279 * column = a #gint representing a column in @table 280 * 281 * Returns: a gboolean representing if the column is selected, or 0 282 * if value does not implement this interface. 283 */ 284 public bool isColumnSelected(int column); 285 286 /** 287 * Gets a boolean value indicating whether the specified @row 288 * is selected 289 * 290 * Params: 291 * row = a #gint representing a row in @table 292 * 293 * Returns: a gboolean representing if the row is selected, or 0 294 * if value does not implement this interface. 295 */ 296 public bool isRowSelected(int row); 297 298 /** 299 * Gets a boolean value indicating whether the accessible object 300 * at the specified @row and @column is selected 301 * 302 * Params: 303 * row = a #gint representing a row in @table 304 * column = a #gint representing a column in @table 305 * 306 * Returns: a gboolean representing if the cell is selected, or 0 307 * if value does not implement this interface. 308 */ 309 public bool isSelected(int row, int column); 310 311 /** 312 * Get a reference to the table cell at @row, @column. This cell 313 * should implement the interface #AtkTableCell 314 * 315 * Params: 316 * row = a #gint representing a row in @table 317 * column = a #gint representing a column in @table 318 * 319 * Returns: an #AtkObject representing the referred 320 * to accessible 321 */ 322 public ObjectAtk refAt(int row, int column); 323 324 /** 325 * Adds the specified @column to the selection. 326 * 327 * Params: 328 * column = a #gint representing a column in @table 329 * 330 * Returns: a gboolean representing if the column was successfully removed from 331 * the selection, or 0 if value does not implement this interface. 332 */ 333 public bool removeColumnSelection(int column); 334 335 /** 336 * Removes the specified @row from the selection. 337 * 338 * Params: 339 * row = a #gint representing a row in @table 340 * 341 * Returns: a gboolean representing if the row was successfully removed from 342 * the selection, or 0 if value does not implement this interface. 343 */ 344 public bool removeRowSelection(int row); 345 346 /** 347 * Sets the caption for the table. 348 * 349 * Params: 350 * caption = a #AtkObject representing the caption to set for @table 351 */ 352 public void setCaption(ObjectAtk caption); 353 354 /** 355 * Sets the description text for the specified @column of the @table. 356 * 357 * Params: 358 * column = a #gint representing a column in @table 359 * description = a #gchar representing the description text 360 * to set for the specified @column of the @table 361 */ 362 public void setColumnDescription(int column, string description); 363 364 /** 365 * Sets the specified column header to @header. 366 * 367 * Params: 368 * column = a #gint representing a column in @table 369 * header = an #AtkTable 370 */ 371 public void setColumnHeader(int column, ObjectAtk header); 372 373 /** 374 * Sets the description text for the specified @row of @table. 375 * 376 * Params: 377 * row = a #gint representing a row in @table 378 * description = a #gchar representing the description text 379 * to set for the specified @row of @table 380 */ 381 public void setRowDescription(int row, string description); 382 383 /** 384 * Sets the specified row header to @header. 385 * 386 * Params: 387 * row = a #gint representing a row in @table 388 * header = an #AtkTable 389 */ 390 public void setRowHeader(int row, ObjectAtk header); 391 392 /** 393 * Sets the summary description of the table. 394 * 395 * Params: 396 * accessible = an #AtkObject representing the summary description 397 * to set for @table 398 */ 399 public void setSummary(ObjectAtk accessible); 400 401 /** 402 * The "column-deleted" signal is emitted by an object which 403 * implements the AtkTable interface when a column is deleted. 404 * 405 * Params: 406 * arg1 = The index of the first column deleted. 407 * arg2 = The number of columns deleted. 408 */ 409 gulong addOnColumnDeleted(void delegate(int, int, TableIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0); 410 411 /** 412 * The "column-inserted" signal is emitted by an object which 413 * implements the AtkTable interface when a column is inserted. 414 * 415 * Params: 416 * arg1 = The index of the column inserted. 417 * arg2 = The number of colums inserted. 418 */ 419 gulong addOnColumnInserted(void delegate(int, int, TableIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0); 420 421 /** 422 * The "column-reordered" signal is emitted by an object which 423 * implements the AtkTable interface when the columns are 424 * reordered. 425 */ 426 gulong addOnColumnReordered(void delegate(TableIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0); 427 428 /** 429 * The "model-changed" signal is emitted by an object which 430 * implements the AtkTable interface when the model displayed by 431 * the table changes. 432 */ 433 gulong addOnModelChanged(void delegate(TableIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0); 434 435 /** 436 * The "row-deleted" signal is emitted by an object which 437 * implements the AtkTable interface when a row is deleted. 438 * 439 * Params: 440 * arg1 = The index of the first row deleted. 441 * arg2 = The number of rows deleted. 442 */ 443 gulong addOnRowDeleted(void delegate(int, int, TableIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0); 444 445 /** 446 * The "row-inserted" signal is emitted by an object which 447 * implements the AtkTable interface when a row is inserted. 448 * 449 * Params: 450 * arg1 = The index of the first row inserted. 451 * arg2 = The number of rows inserted. 452 */ 453 gulong addOnRowInserted(void delegate(int, int, TableIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0); 454 455 /** 456 * The "row-reordered" signal is emitted by an object which 457 * implements the AtkTable interface when the rows are 458 * reordered. 459 */ 460 gulong addOnRowReordered(void delegate(TableIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0); 461 }