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 gio.DBusAnnotationInfo; 26 27 private import glib.Str; 28 private import gobject.ObjectG; 29 private import gtkc.gio; 30 public import gtkc.giotypes; 31 private import gtkd.Loader; 32 33 34 /** 35 * Information about an annotation. 36 * 37 * Since: 2.26 38 */ 39 public class DBusAnnotationInfo 40 { 41 /** the main Gtk struct */ 42 protected GDBusAnnotationInfo* gDBusAnnotationInfo; 43 protected bool ownedRef; 44 45 /** Get the main Gtk struct */ 46 public GDBusAnnotationInfo* getDBusAnnotationInfoStruct(bool transferOwnership = false) 47 { 48 if (transferOwnership) 49 ownedRef = false; 50 return gDBusAnnotationInfo; 51 } 52 53 /** the main Gtk struct as a void* */ 54 protected void* getStruct() 55 { 56 return cast(void*)gDBusAnnotationInfo; 57 } 58 59 /** 60 * Sets our main struct and passes it to the parent class. 61 */ 62 public this (GDBusAnnotationInfo* gDBusAnnotationInfo, bool ownedRef = false) 63 { 64 this.gDBusAnnotationInfo = gDBusAnnotationInfo; 65 this.ownedRef = ownedRef; 66 } 67 68 ~this () 69 { 70 if ( Linker.isLoaded(LIBRARY_GIO) && ownedRef ) 71 g_dbus_annotation_info_unref(gDBusAnnotationInfo); 72 } 73 74 /** 75 * Looks up the value of an annotation. 76 * 77 * The cost of this function is O(n) in number of annotations. 78 * 79 * Params: 80 * annotations = A %NULL-terminated array of annotations or %NULL. 81 * name = The name of the annotation to look up. 82 * 83 * Return: The value or %NULL if not found. Do not free, it is owned by @annotations. 84 * 85 * Since: 2.26 86 */ 87 public static string lookup(DBusAnnotationInfo[] annotations, string name) 88 { 89 GDBusAnnotationInfo*[] annotationsArray = new GDBusAnnotationInfo*[annotations.length+1]; 90 for ( int i = 0; i < annotations.length ; i++ ) 91 { 92 annotationsArray[i] = annotations[i].getDBusAnnotationInfoStruct(); 93 } 94 annotationsArray[$-1] = null; 95 96 return Str.toString(g_dbus_annotation_info_lookup(annotationsArray.ptr, Str.toStringz(name))); 97 } 98 99 /** 100 */ 101 102 /** */ 103 public static GType getType() 104 { 105 return g_dbus_annotation_info_get_type(); 106 } 107 108 /** 109 * If @info is statically allocated does nothing. Otherwise increases 110 * the reference count. 111 * 112 * Returns: The same @info. 113 * 114 * Since: 2.26 115 */ 116 public DBusAnnotationInfo doref() 117 { 118 auto p = g_dbus_annotation_info_ref(gDBusAnnotationInfo); 119 120 if(p is null) 121 { 122 return null; 123 } 124 125 return ObjectG.getDObject!(DBusAnnotationInfo)(cast(GDBusAnnotationInfo*) p, true); 126 } 127 128 /** 129 * If @info is statically allocated, does nothing. Otherwise decreases 130 * the reference count of @info. When its reference count drops to 0, 131 * the memory used is freed. 132 * 133 * Since: 2.26 134 */ 135 public void unref() 136 { 137 g_dbus_annotation_info_unref(gDBusAnnotationInfo); 138 } 139 }