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 gobject.Enums;
26 
27 private import glib.Str;
28 private import glib.c.functions;
29 private import gobject.c.functions;
30 public  import gobject.c.types;
31 
32 
33 /** */
34 public struct Enums
35 {
36 
37 	/**
38 	 * This function is meant to be called from the `complete_type_info`
39 	 * function of a #GTypePlugin implementation, as in the following
40 	 * example:
41 	 *
42 	 * |[<!-- language="C" -->
43 	 * static void
44 	 * my_enum_complete_type_info (GTypePlugin     *plugin,
45 	 * GType            g_type,
46 	 * GTypeInfo       *info,
47 	 * GTypeValueTable *value_table)
48 	 * {
49 	 * static const GEnumValue values[] = {
50 	 * { MY_ENUM_FOO, "MY_ENUM_FOO", "foo" },
51 	 * { MY_ENUM_BAR, "MY_ENUM_BAR", "bar" },
52 	 * { 0, NULL, NULL }
53 	 * };
54 	 *
55 	 * g_enum_complete_type_info (type, info, values);
56 	 * }
57 	 * ]|
58 	 *
59 	 * Params:
60 	 *     gEnumType = the type identifier of the type being completed
61 	 *     info = the #GTypeInfo struct to be filled in
62 	 *     constValues = An array of #GEnumValue structs for the possible
63 	 *         enumeration values. The array is terminated by a struct with all
64 	 *         members being 0.
65 	 */
66 	public static void completeTypeInfo(GType gEnumType, out GTypeInfo info, GEnumValue* constValues)
67 	{
68 		g_enum_complete_type_info(gEnumType, &info, constValues);
69 	}
70 
71 	/**
72 	 * Returns the #GEnumValue for a value.
73 	 *
74 	 * Params:
75 	 *     enumClass = a #GEnumClass
76 	 *     value = the value to look up
77 	 *
78 	 * Returns: the #GEnumValue for @value, or %NULL
79 	 *     if @value is not a member of the enumeration
80 	 */
81 	public static GEnumValue* getValue(GEnumClass* enumClass, int value)
82 	{
83 		return g_enum_get_value(enumClass, value);
84 	}
85 
86 	/**
87 	 * Looks up a #GEnumValue by name.
88 	 *
89 	 * Params:
90 	 *     enumClass = a #GEnumClass
91 	 *     name = the name to look up
92 	 *
93 	 * Returns: the #GEnumValue with name @name,
94 	 *     or %NULL if the enumeration doesn't have a member
95 	 *     with that name
96 	 */
97 	public static GEnumValue* getValueByName(GEnumClass* enumClass, string name)
98 	{
99 		return g_enum_get_value_by_name(enumClass, Str.toStringz(name));
100 	}
101 
102 	/**
103 	 * Looks up a #GEnumValue by nickname.
104 	 *
105 	 * Params:
106 	 *     enumClass = a #GEnumClass
107 	 *     nick = the nickname to look up
108 	 *
109 	 * Returns: the #GEnumValue with nickname @nick,
110 	 *     or %NULL if the enumeration doesn't have a member
111 	 *     with that nickname
112 	 */
113 	public static GEnumValue* getValueByNick(GEnumClass* enumClass, string nick)
114 	{
115 		return g_enum_get_value_by_nick(enumClass, Str.toStringz(nick));
116 	}
117 
118 	/**
119 	 * Registers a new static enumeration type with the name @name.
120 	 *
121 	 * It is normally more convenient to let [glib-mkenums][glib-mkenums],
122 	 * generate a my_enum_get_type() function from a usual C enumeration
123 	 * definition  than to write one yourself using g_enum_register_static().
124 	 *
125 	 * Params:
126 	 *     name = A nul-terminated string used as the name of the new type.
127 	 *     constStaticValues = An array of #GEnumValue structs for the possible
128 	 *         enumeration values. The array is terminated by a struct with all
129 	 *         members being 0. GObject keeps a reference to the data, so it cannot
130 	 *         be stack-allocated.
131 	 *
132 	 * Returns: The new type identifier.
133 	 */
134 	public static GType registerStatic(string name, GEnumValue* constStaticValues)
135 	{
136 		return g_enum_register_static(Str.toStringz(name), constStaticValues);
137 	}
138 
139 	/**
140 	 * Pretty-prints @value in the form of the enum’s name.
141 	 *
142 	 * This is intended to be used for debugging purposes. The format of the output
143 	 * may change in the future.
144 	 *
145 	 * Params:
146 	 *     gEnumType = the type identifier of a #GEnumClass type
147 	 *     value = the value
148 	 *
149 	 * Returns: a newly-allocated text string
150 	 *
151 	 * Since: 2.54
152 	 */
153 	public static string enumToString(GType gEnumType, int value)
154 	{
155 		auto retStr = g_enum_to_string(gEnumType, value);
156 
157 		scope(exit) Str.freeString(retStr);
158 		return Str.toString(retStr);
159 	}
160 
161 	/**
162 	 * Pretty-prints @value in the form of the flag names separated by ` | ` and
163 	 * sorted. Any extra bits will be shown at the end as a hexadecimal number.
164 	 *
165 	 * This is intended to be used for debugging purposes. The format of the output
166 	 * may change in the future.
167 	 *
168 	 * Params:
169 	 *     flagsType = the type identifier of a #GFlagsClass type
170 	 *     value = the value
171 	 *
172 	 * Returns: a newly-allocated text string
173 	 *
174 	 * Since: 2.54
175 	 */
176 	public static string flagsToString(GType flagsType, uint value)
177 	{
178 		auto retStr = g_flags_to_string(flagsType, value);
179 
180 		scope(exit) Str.freeString(retStr);
181 		return Str.toString(retStr);
182 	}
183 }