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.Rectangle; 26 27 private import atk.c.functions; 28 public import atk.c.types; 29 private import glib.MemorySlice; 30 private import gtkd.Loader; 31 32 33 /** 34 * A data structure for holding a rectangle. Those coordinates are 35 * relative to the component top-level parent. 36 */ 37 public final class Rectangle 38 { 39 /** the main Gtk struct */ 40 protected AtkRectangle* atkRectangle; 41 protected bool ownedRef; 42 43 /** Get the main Gtk struct */ 44 public AtkRectangle* getRectangleStruct(bool transferOwnership = false) 45 { 46 if (transferOwnership) 47 ownedRef = false; 48 return atkRectangle; 49 } 50 51 /** the main Gtk struct as a void* */ 52 protected void* getStruct() 53 { 54 return cast(void*)atkRectangle; 55 } 56 57 /** 58 * Sets our main struct and passes it to the parent class. 59 */ 60 public this (AtkRectangle* atkRectangle, bool ownedRef = false) 61 { 62 this.atkRectangle = atkRectangle; 63 this.ownedRef = ownedRef; 64 } 65 66 ~this () 67 { 68 if ( Linker.isLoaded(LIBRARY_ATK) && ownedRef ) 69 sliceFree(atkRectangle); 70 } 71 72 73 /** 74 * X coordinate of the left side of the rectangle. 75 */ 76 public @property int x() 77 { 78 return atkRectangle.x; 79 } 80 81 /** Ditto */ 82 public @property void x(int value) 83 { 84 atkRectangle.x = value; 85 } 86 87 /** 88 * Y coordinate of the top side of the rectangle. 89 */ 90 public @property int y() 91 { 92 return atkRectangle.y; 93 } 94 95 /** Ditto */ 96 public @property void y(int value) 97 { 98 atkRectangle.y = value; 99 } 100 101 /** 102 * width of the rectangle. 103 */ 104 public @property int width() 105 { 106 return atkRectangle.width; 107 } 108 109 /** Ditto */ 110 public @property void width(int value) 111 { 112 atkRectangle.width = value; 113 } 114 115 /** 116 * height of the rectangle. 117 */ 118 public @property int height() 119 { 120 return atkRectangle.height; 121 } 122 123 /** Ditto */ 124 public @property void height(int value) 125 { 126 atkRectangle.height = value; 127 } 128 129 /** */ 130 public static GType getType() 131 { 132 return atk_rectangle_get_type(); 133 } 134 }