gioenums.h 70 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904
  1. /* GIO - GLib Input, Output and Streaming Library
  2. *
  3. * Copyright (C) 2006-2007 Red Hat, Inc.
  4. *
  5. * This library is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU Lesser General Public
  7. * License as published by the Free Software Foundation; either
  8. * version 2 of the License, or (at your option) any later version.
  9. *
  10. * This library 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 GNU
  13. * Lesser General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU Lesser General
  16. * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
  17. *
  18. * Author: Alexander Larsson <alexl@redhat.com>
  19. */
  20. #ifndef __GIO_ENUMS_H__
  21. #define __GIO_ENUMS_H__
  22. #if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION)
  23. #error "Only <gio/gio.h> can be included directly."
  24. #endif
  25. #include <glib-object.h>
  26. G_BEGIN_DECLS
  27. /**
  28. * GAppInfoCreateFlags:
  29. * @G_APP_INFO_CREATE_NONE: No flags.
  30. * @G_APP_INFO_CREATE_NEEDS_TERMINAL: Application opens in a terminal window.
  31. * @G_APP_INFO_CREATE_SUPPORTS_URIS: Application supports URI arguments.
  32. * @G_APP_INFO_CREATE_SUPPORTS_STARTUP_NOTIFICATION: Application supports startup notification. Since 2.26
  33. *
  34. * Flags used when creating a #GAppInfo.
  35. */
  36. typedef enum {
  37. G_APP_INFO_CREATE_NONE = 0, /*< nick=none >*/
  38. G_APP_INFO_CREATE_NEEDS_TERMINAL = (1 << 0), /*< nick=needs-terminal >*/
  39. G_APP_INFO_CREATE_SUPPORTS_URIS = (1 << 1), /*< nick=supports-uris >*/
  40. G_APP_INFO_CREATE_SUPPORTS_STARTUP_NOTIFICATION = (1 << 2) /*< nick=supports-startup-notification >*/
  41. } GAppInfoCreateFlags;
  42. /**
  43. * GConverterFlags:
  44. * @G_CONVERTER_NO_FLAGS: No flags.
  45. * @G_CONVERTER_INPUT_AT_END: At end of input data
  46. * @G_CONVERTER_FLUSH: Flush data
  47. *
  48. * Flags used when calling a g_converter_convert().
  49. *
  50. * Since: 2.24
  51. */
  52. typedef enum {
  53. G_CONVERTER_NO_FLAGS = 0, /*< nick=none >*/
  54. G_CONVERTER_INPUT_AT_END = (1 << 0), /*< nick=input-at-end >*/
  55. G_CONVERTER_FLUSH = (1 << 1) /*< nick=flush >*/
  56. } GConverterFlags;
  57. /**
  58. * GConverterResult:
  59. * @G_CONVERTER_ERROR: There was an error during conversion.
  60. * @G_CONVERTER_CONVERTED: Some data was consumed or produced
  61. * @G_CONVERTER_FINISHED: The conversion is finished
  62. * @G_CONVERTER_FLUSHED: Flushing is finished
  63. *
  64. * Results returned from g_converter_convert().
  65. *
  66. * Since: 2.24
  67. */
  68. typedef enum {
  69. G_CONVERTER_ERROR = 0, /*< nick=error >*/
  70. G_CONVERTER_CONVERTED = 1, /*< nick=converted >*/
  71. G_CONVERTER_FINISHED = 2, /*< nick=finished >*/
  72. G_CONVERTER_FLUSHED = 3 /*< nick=flushed >*/
  73. } GConverterResult;
  74. /**
  75. * GDataStreamByteOrder:
  76. * @G_DATA_STREAM_BYTE_ORDER_BIG_ENDIAN: Selects Big Endian byte order.
  77. * @G_DATA_STREAM_BYTE_ORDER_LITTLE_ENDIAN: Selects Little Endian byte order.
  78. * @G_DATA_STREAM_BYTE_ORDER_HOST_ENDIAN: Selects endianness based on host machine's architecture.
  79. *
  80. * #GDataStreamByteOrder is used to ensure proper endianness of streaming data sources
  81. * across various machine architectures.
  82. *
  83. **/
  84. typedef enum {
  85. G_DATA_STREAM_BYTE_ORDER_BIG_ENDIAN,
  86. G_DATA_STREAM_BYTE_ORDER_LITTLE_ENDIAN,
  87. G_DATA_STREAM_BYTE_ORDER_HOST_ENDIAN
  88. } GDataStreamByteOrder;
  89. /**
  90. * GDataStreamNewlineType:
  91. * @G_DATA_STREAM_NEWLINE_TYPE_LF: Selects "LF" line endings, common on most modern UNIX platforms.
  92. * @G_DATA_STREAM_NEWLINE_TYPE_CR: Selects "CR" line endings.
  93. * @G_DATA_STREAM_NEWLINE_TYPE_CR_LF: Selects "CR, LF" line ending, common on Microsoft Windows.
  94. * @G_DATA_STREAM_NEWLINE_TYPE_ANY: Automatically try to handle any line ending type.
  95. *
  96. * #GDataStreamNewlineType is used when checking for or setting the line endings for a given file.
  97. **/
  98. typedef enum {
  99. G_DATA_STREAM_NEWLINE_TYPE_LF,
  100. G_DATA_STREAM_NEWLINE_TYPE_CR,
  101. G_DATA_STREAM_NEWLINE_TYPE_CR_LF,
  102. G_DATA_STREAM_NEWLINE_TYPE_ANY
  103. } GDataStreamNewlineType;
  104. /**
  105. * GFileAttributeType:
  106. * @G_FILE_ATTRIBUTE_TYPE_INVALID: indicates an invalid or uninitalized type.
  107. * @G_FILE_ATTRIBUTE_TYPE_STRING: a null terminated UTF8 string.
  108. * @G_FILE_ATTRIBUTE_TYPE_BYTE_STRING: a zero terminated string of non-zero bytes.
  109. * @G_FILE_ATTRIBUTE_TYPE_BOOLEAN: a boolean value.
  110. * @G_FILE_ATTRIBUTE_TYPE_UINT32: an unsigned 4-byte/32-bit integer.
  111. * @G_FILE_ATTRIBUTE_TYPE_INT32: a signed 4-byte/32-bit integer.
  112. * @G_FILE_ATTRIBUTE_TYPE_UINT64: an unsigned 8-byte/64-bit integer.
  113. * @G_FILE_ATTRIBUTE_TYPE_INT64: a signed 8-byte/64-bit integer.
  114. * @G_FILE_ATTRIBUTE_TYPE_OBJECT: a #GObject.
  115. * @G_FILE_ATTRIBUTE_TYPE_STRINGV: a %NULL terminated char **. Since 2.22
  116. *
  117. * The data types for file attributes.
  118. **/
  119. typedef enum {
  120. G_FILE_ATTRIBUTE_TYPE_INVALID = 0,
  121. G_FILE_ATTRIBUTE_TYPE_STRING,
  122. G_FILE_ATTRIBUTE_TYPE_BYTE_STRING, /* zero terminated string of non-zero bytes */
  123. G_FILE_ATTRIBUTE_TYPE_BOOLEAN,
  124. G_FILE_ATTRIBUTE_TYPE_UINT32,
  125. G_FILE_ATTRIBUTE_TYPE_INT32,
  126. G_FILE_ATTRIBUTE_TYPE_UINT64,
  127. G_FILE_ATTRIBUTE_TYPE_INT64,
  128. G_FILE_ATTRIBUTE_TYPE_OBJECT,
  129. G_FILE_ATTRIBUTE_TYPE_STRINGV
  130. } GFileAttributeType;
  131. /**
  132. * GFileAttributeInfoFlags:
  133. * @G_FILE_ATTRIBUTE_INFO_NONE: no flags set.
  134. * @G_FILE_ATTRIBUTE_INFO_COPY_WITH_FILE: copy the attribute values when the file is copied.
  135. * @G_FILE_ATTRIBUTE_INFO_COPY_WHEN_MOVED: copy the attribute values when the file is moved.
  136. *
  137. * Flags specifying the behaviour of an attribute.
  138. **/
  139. typedef enum {
  140. G_FILE_ATTRIBUTE_INFO_NONE = 0,
  141. G_FILE_ATTRIBUTE_INFO_COPY_WITH_FILE = (1 << 0),
  142. G_FILE_ATTRIBUTE_INFO_COPY_WHEN_MOVED = (1 << 1)
  143. } GFileAttributeInfoFlags;
  144. /**
  145. * GFileAttributeStatus:
  146. * @G_FILE_ATTRIBUTE_STATUS_UNSET: Attribute value is unset (empty).
  147. * @G_FILE_ATTRIBUTE_STATUS_SET: Attribute value is set.
  148. * @G_FILE_ATTRIBUTE_STATUS_ERROR_SETTING: Indicates an error in setting the value.
  149. *
  150. * Used by g_file_set_attributes_from_info() when setting file attributes.
  151. **/
  152. typedef enum {
  153. G_FILE_ATTRIBUTE_STATUS_UNSET = 0,
  154. G_FILE_ATTRIBUTE_STATUS_SET,
  155. G_FILE_ATTRIBUTE_STATUS_ERROR_SETTING
  156. } GFileAttributeStatus;
  157. /**
  158. * GFileQueryInfoFlags:
  159. * @G_FILE_QUERY_INFO_NONE: No flags set.
  160. * @G_FILE_QUERY_INFO_NOFOLLOW_SYMLINKS: Don't follow symlinks.
  161. *
  162. * Flags used when querying a #GFileInfo.
  163. */
  164. typedef enum {
  165. G_FILE_QUERY_INFO_NONE = 0,
  166. G_FILE_QUERY_INFO_NOFOLLOW_SYMLINKS = (1 << 0) /*< nick=nofollow-symlinks >*/
  167. } GFileQueryInfoFlags;
  168. /**
  169. * GFileCreateFlags:
  170. * @G_FILE_CREATE_NONE: No flags set.
  171. * @G_FILE_CREATE_PRIVATE: Create a file that can only be
  172. * accessed by the current user.
  173. * @G_FILE_CREATE_REPLACE_DESTINATION: Replace the destination
  174. * as if it didn't exist before. Don't try to keep any old
  175. * permissions, replace instead of following links. This
  176. * is generally useful if you're doing a "copy over"
  177. * rather than a "save new version of" replace operation.
  178. * You can think of it as "unlink destination" before
  179. * writing to it, although the implementation may not
  180. * be exactly like that. Since 2.20
  181. *
  182. * Flags used when an operation may create a file.
  183. */
  184. typedef enum {
  185. G_FILE_CREATE_NONE = 0,
  186. G_FILE_CREATE_PRIVATE = (1 << 0),
  187. G_FILE_CREATE_REPLACE_DESTINATION = (1 << 1)
  188. } GFileCreateFlags;
  189. /**
  190. * GFileMeasureFlags:
  191. * @G_FILE_MEASURE_NONE: No flags set.
  192. * @G_FILE_MEASURE_REPORT_ANY_ERROR: Report any error encountered
  193. * while traversing the directory tree. Normally errors are only
  194. * reported for the toplevel file.
  195. * @G_FILE_MEASURE_APPARENT_SIZE: Tally usage based on apparent file
  196. * sizes. Normally, the block-size is used, if available, as this is a
  197. * more accurate representation of disk space used.
  198. * Compare with `du --apparent-size`.
  199. * @G_FILE_MEASURE_NO_XDEV: Do not cross mount point boundaries.
  200. * Compare with `du -x`.
  201. *
  202. * Flags that can be used with g_file_measure_disk_usage().
  203. *
  204. * Since: 2.38
  205. **/
  206. typedef enum {
  207. G_FILE_MEASURE_NONE = 0,
  208. G_FILE_MEASURE_REPORT_ANY_ERROR = (1 << 1),
  209. G_FILE_MEASURE_APPARENT_SIZE = (1 << 2),
  210. G_FILE_MEASURE_NO_XDEV = (1 << 3)
  211. } GFileMeasureFlags;
  212. /**
  213. * GMountMountFlags:
  214. * @G_MOUNT_MOUNT_NONE: No flags set.
  215. *
  216. * Flags used when mounting a mount.
  217. */
  218. typedef enum /*< flags >*/ {
  219. G_MOUNT_MOUNT_NONE = 0
  220. } GMountMountFlags;
  221. /**
  222. * GMountUnmountFlags:
  223. * @G_MOUNT_UNMOUNT_NONE: No flags set.
  224. * @G_MOUNT_UNMOUNT_FORCE: Unmount even if there are outstanding
  225. * file operations on the mount.
  226. *
  227. * Flags used when an unmounting a mount.
  228. */
  229. typedef enum {
  230. G_MOUNT_UNMOUNT_NONE = 0,
  231. G_MOUNT_UNMOUNT_FORCE = (1 << 0)
  232. } GMountUnmountFlags;
  233. /**
  234. * GDriveStartFlags:
  235. * @G_DRIVE_START_NONE: No flags set.
  236. *
  237. * Flags used when starting a drive.
  238. *
  239. * Since: 2.22
  240. */
  241. typedef enum /*< flags >*/ {
  242. G_DRIVE_START_NONE = 0
  243. } GDriveStartFlags;
  244. /**
  245. * GDriveStartStopType:
  246. * @G_DRIVE_START_STOP_TYPE_UNKNOWN: Unknown or drive doesn't support
  247. * start/stop.
  248. * @G_DRIVE_START_STOP_TYPE_SHUTDOWN: The stop method will physically
  249. * shut down the drive and e.g. power down the port the drive is
  250. * attached to.
  251. * @G_DRIVE_START_STOP_TYPE_NETWORK: The start/stop methods are used
  252. * for connecting/disconnect to the drive over the network.
  253. * @G_DRIVE_START_STOP_TYPE_MULTIDISK: The start/stop methods will
  254. * assemble/disassemble a virtual drive from several physical
  255. * drives.
  256. * @G_DRIVE_START_STOP_TYPE_PASSWORD: The start/stop methods will
  257. * unlock/lock the disk (for example using the ATA <quote>SECURITY
  258. * UNLOCK DEVICE</quote> command)
  259. *
  260. * Enumeration describing how a drive can be started/stopped.
  261. *
  262. * Since: 2.22
  263. */
  264. typedef enum {
  265. G_DRIVE_START_STOP_TYPE_UNKNOWN,
  266. G_DRIVE_START_STOP_TYPE_SHUTDOWN,
  267. G_DRIVE_START_STOP_TYPE_NETWORK,
  268. G_DRIVE_START_STOP_TYPE_MULTIDISK,
  269. G_DRIVE_START_STOP_TYPE_PASSWORD
  270. } GDriveStartStopType;
  271. /**
  272. * GFileCopyFlags:
  273. * @G_FILE_COPY_NONE: No flags set.
  274. * @G_FILE_COPY_OVERWRITE: Overwrite any existing files
  275. * @G_FILE_COPY_BACKUP: Make a backup of any existing files.
  276. * @G_FILE_COPY_NOFOLLOW_SYMLINKS: Don't follow symlinks.
  277. * @G_FILE_COPY_ALL_METADATA: Copy all file metadata instead of just default set used for copy (see #GFileInfo).
  278. * @G_FILE_COPY_NO_FALLBACK_FOR_MOVE: Don't use copy and delete fallback if native move not supported.
  279. * @G_FILE_COPY_TARGET_DEFAULT_PERMS: Leaves target file with default perms, instead of setting the source file perms.
  280. *
  281. * Flags used when copying or moving files.
  282. */
  283. typedef enum {
  284. G_FILE_COPY_NONE = 0, /*< nick=none >*/
  285. G_FILE_COPY_OVERWRITE = (1 << 0),
  286. G_FILE_COPY_BACKUP = (1 << 1),
  287. G_FILE_COPY_NOFOLLOW_SYMLINKS = (1 << 2),
  288. G_FILE_COPY_ALL_METADATA = (1 << 3),
  289. G_FILE_COPY_NO_FALLBACK_FOR_MOVE = (1 << 4),
  290. G_FILE_COPY_TARGET_DEFAULT_PERMS = (1 << 5)
  291. } GFileCopyFlags;
  292. /**
  293. * GFileMonitorFlags:
  294. * @G_FILE_MONITOR_NONE: No flags set.
  295. * @G_FILE_MONITOR_WATCH_MOUNTS: Watch for mount events.
  296. * @G_FILE_MONITOR_SEND_MOVED: Pair DELETED and CREATED events caused
  297. * by file renames (moves) and send a single G_FILE_MONITOR_EVENT_MOVED
  298. * event instead (NB: not supported on all backends; the default
  299. * behaviour -without specifying this flag- is to send single DELETED
  300. * and CREATED events). Deprecated since 2.44: use
  301. * %G_FILE_MONITOR_WATCH_MOVES instead.
  302. * @G_FILE_MONITOR_WATCH_HARD_LINKS: Watch for changes to the file made
  303. * via another hard link. Since 2.36.
  304. * @G_FILE_MONITOR_WATCH_MOVES: Watch for rename operations on a
  305. * monitored directory. This causes %G_FILE_MONITOR_EVENT_RENAMED,
  306. * %G_FILE_MONITOR_EVENT_MOVED_IN and %G_FILE_MONITOR_EVENT_MOVED_OUT
  307. * events to be emitted when possible. Since: 2.44.
  308. *
  309. * Flags used to set what a #GFileMonitor will watch for.
  310. */
  311. typedef enum {
  312. G_FILE_MONITOR_NONE = 0,
  313. G_FILE_MONITOR_WATCH_MOUNTS = (1 << 0),
  314. G_FILE_MONITOR_SEND_MOVED = (1 << 1),
  315. G_FILE_MONITOR_WATCH_HARD_LINKS = (1 << 2),
  316. G_FILE_MONITOR_WATCH_MOVES = (1 << 3)
  317. } GFileMonitorFlags;
  318. /**
  319. * GFileType:
  320. * @G_FILE_TYPE_UNKNOWN: File's type is unknown.
  321. * @G_FILE_TYPE_REGULAR: File handle represents a regular file.
  322. * @G_FILE_TYPE_DIRECTORY: File handle represents a directory.
  323. * @G_FILE_TYPE_SYMBOLIC_LINK: File handle represents a symbolic link
  324. * (Unix systems).
  325. * @G_FILE_TYPE_SPECIAL: File is a "special" file, such as a socket, fifo,
  326. * block device, or character device.
  327. * @G_FILE_TYPE_SHORTCUT: File is a shortcut (Windows systems).
  328. * @G_FILE_TYPE_MOUNTABLE: File is a mountable location.
  329. *
  330. * Indicates the file's on-disk type.
  331. **/
  332. typedef enum {
  333. G_FILE_TYPE_UNKNOWN = 0,
  334. G_FILE_TYPE_REGULAR,
  335. G_FILE_TYPE_DIRECTORY,
  336. G_FILE_TYPE_SYMBOLIC_LINK,
  337. G_FILE_TYPE_SPECIAL, /* socket, fifo, blockdev, chardev */
  338. G_FILE_TYPE_SHORTCUT,
  339. G_FILE_TYPE_MOUNTABLE
  340. } GFileType;
  341. /**
  342. * GFilesystemPreviewType:
  343. * @G_FILESYSTEM_PREVIEW_TYPE_IF_ALWAYS: Only preview files if user has explicitly requested it.
  344. * @G_FILESYSTEM_PREVIEW_TYPE_IF_LOCAL: Preview files if user has requested preview of "local" files.
  345. * @G_FILESYSTEM_PREVIEW_TYPE_NEVER: Never preview files.
  346. *
  347. * Indicates a hint from the file system whether files should be
  348. * previewed in a file manager. Returned as the value of the key
  349. * #G_FILE_ATTRIBUTE_FILESYSTEM_USE_PREVIEW.
  350. **/
  351. typedef enum {
  352. G_FILESYSTEM_PREVIEW_TYPE_IF_ALWAYS = 0,
  353. G_FILESYSTEM_PREVIEW_TYPE_IF_LOCAL,
  354. G_FILESYSTEM_PREVIEW_TYPE_NEVER
  355. } GFilesystemPreviewType;
  356. /**
  357. * GFileMonitorEvent:
  358. * @G_FILE_MONITOR_EVENT_CHANGED: a file changed.
  359. * @G_FILE_MONITOR_EVENT_CHANGES_DONE_HINT: a hint that this was probably the last change in a set of changes.
  360. * @G_FILE_MONITOR_EVENT_DELETED: a file was deleted.
  361. * @G_FILE_MONITOR_EVENT_CREATED: a file was created.
  362. * @G_FILE_MONITOR_EVENT_ATTRIBUTE_CHANGED: a file attribute was changed.
  363. * @G_FILE_MONITOR_EVENT_PRE_UNMOUNT: the file location will soon be unmounted.
  364. * @G_FILE_MONITOR_EVENT_UNMOUNTED: the file location was unmounted.
  365. * @G_FILE_MONITOR_EVENT_MOVED: the file was moved -- only sent if the
  366. * (deprecated) %G_FILE_MONITOR_SEND_MOVED flag is set
  367. * @G_FILE_MONITOR_EVENT_RENAMED: the file was renamed within the
  368. * current directory -- only sent if the %G_FILE_MONITOR_WATCH_MOVES
  369. * flag is set. Since: 2.44.
  370. * @G_FILE_MONITOR_EVENT_MOVED_IN: the file was moved into the
  371. * monitored directory from another location -- only sent if the
  372. * %G_FILE_MONITOR_WATCH_MOVES flag is set. Since: 2.44.
  373. * @G_FILE_MONITOR_EVENT_MOVED_OUT: the file was moved out of the
  374. * monitored directory to another location -- only sent if the
  375. * %G_FILE_MONITOR_WATCH_MOVES flag is set. Since: 2.44
  376. *
  377. * Specifies what type of event a monitor event is.
  378. **/
  379. typedef enum {
  380. G_FILE_MONITOR_EVENT_CHANGED,
  381. G_FILE_MONITOR_EVENT_CHANGES_DONE_HINT,
  382. G_FILE_MONITOR_EVENT_DELETED,
  383. G_FILE_MONITOR_EVENT_CREATED,
  384. G_FILE_MONITOR_EVENT_ATTRIBUTE_CHANGED,
  385. G_FILE_MONITOR_EVENT_PRE_UNMOUNT,
  386. G_FILE_MONITOR_EVENT_UNMOUNTED,
  387. G_FILE_MONITOR_EVENT_MOVED,
  388. G_FILE_MONITOR_EVENT_RENAMED,
  389. G_FILE_MONITOR_EVENT_MOVED_IN,
  390. G_FILE_MONITOR_EVENT_MOVED_OUT
  391. } GFileMonitorEvent;
  392. /* This enumeration conflicts with GIOError in giochannel.h. However,
  393. * that is only used as a return value in some deprecated functions.
  394. * So, we reuse the same prefix for the enumeration values, but call
  395. * the actual enumeration (which is rarely used) GIOErrorEnum.
  396. */
  397. /**
  398. * GIOErrorEnum:
  399. * @G_IO_ERROR_FAILED: Generic error condition for when an operation fails
  400. * and no more specific #GIOErrorEnum value is defined.
  401. * @G_IO_ERROR_NOT_FOUND: File not found.
  402. * @G_IO_ERROR_EXISTS: File already exists.
  403. * @G_IO_ERROR_IS_DIRECTORY: File is a directory.
  404. * @G_IO_ERROR_NOT_DIRECTORY: File is not a directory.
  405. * @G_IO_ERROR_NOT_EMPTY: File is a directory that isn't empty.
  406. * @G_IO_ERROR_NOT_REGULAR_FILE: File is not a regular file.
  407. * @G_IO_ERROR_NOT_SYMBOLIC_LINK: File is not a symbolic link.
  408. * @G_IO_ERROR_NOT_MOUNTABLE_FILE: File cannot be mounted.
  409. * @G_IO_ERROR_FILENAME_TOO_LONG: Filename is too many characters.
  410. * @G_IO_ERROR_INVALID_FILENAME: Filename is invalid or contains invalid characters.
  411. * @G_IO_ERROR_TOO_MANY_LINKS: File contains too many symbolic links.
  412. * @G_IO_ERROR_NO_SPACE: No space left on drive.
  413. * @G_IO_ERROR_INVALID_ARGUMENT: Invalid argument.
  414. * @G_IO_ERROR_PERMISSION_DENIED: Permission denied.
  415. * @G_IO_ERROR_NOT_SUPPORTED: Operation (or one of its parameters) not supported
  416. * @G_IO_ERROR_NOT_MOUNTED: File isn't mounted.
  417. * @G_IO_ERROR_ALREADY_MOUNTED: File is already mounted.
  418. * @G_IO_ERROR_CLOSED: File was closed.
  419. * @G_IO_ERROR_CANCELLED: Operation was cancelled. See #GCancellable.
  420. * @G_IO_ERROR_PENDING: Operations are still pending.
  421. * @G_IO_ERROR_READ_ONLY: File is read only.
  422. * @G_IO_ERROR_CANT_CREATE_BACKUP: Backup couldn't be created.
  423. * @G_IO_ERROR_WRONG_ETAG: File's Entity Tag was incorrect.
  424. * @G_IO_ERROR_TIMED_OUT: Operation timed out.
  425. * @G_IO_ERROR_WOULD_RECURSE: Operation would be recursive.
  426. * @G_IO_ERROR_BUSY: File is busy.
  427. * @G_IO_ERROR_WOULD_BLOCK: Operation would block.
  428. * @G_IO_ERROR_HOST_NOT_FOUND: Host couldn't be found (remote operations).
  429. * @G_IO_ERROR_WOULD_MERGE: Operation would merge files.
  430. * @G_IO_ERROR_FAILED_HANDLED: Operation failed and a helper program has
  431. * already interacted with the user. Do not display any error dialog.
  432. * @G_IO_ERROR_TOO_MANY_OPEN_FILES: The current process has too many files
  433. * open and can't open any more. Duplicate descriptors do count toward
  434. * this limit. Since 2.20
  435. * @G_IO_ERROR_NOT_INITIALIZED: The object has not been initialized. Since 2.22
  436. * @G_IO_ERROR_ADDRESS_IN_USE: The requested address is already in use. Since 2.22
  437. * @G_IO_ERROR_PARTIAL_INPUT: Need more input to finish operation. Since 2.24
  438. * @G_IO_ERROR_INVALID_DATA: The input data was invalid. Since 2.24
  439. * @G_IO_ERROR_DBUS_ERROR: A remote object generated an error that
  440. * doesn't correspond to a locally registered #GError error
  441. * domain. Use g_dbus_error_get_remote_error() to extract the D-Bus
  442. * error name and g_dbus_error_strip_remote_error() to fix up the
  443. * message so it matches what was received on the wire. Since 2.26.
  444. * @G_IO_ERROR_HOST_UNREACHABLE: Host unreachable. Since 2.26
  445. * @G_IO_ERROR_NETWORK_UNREACHABLE: Network unreachable. Since 2.26
  446. * @G_IO_ERROR_CONNECTION_REFUSED: Connection refused. Since 2.26
  447. * @G_IO_ERROR_PROXY_FAILED: Connection to proxy server failed. Since 2.26
  448. * @G_IO_ERROR_PROXY_AUTH_FAILED: Proxy authentication failed. Since 2.26
  449. * @G_IO_ERROR_PROXY_NEED_AUTH: Proxy server needs authentication. Since 2.26
  450. * @G_IO_ERROR_PROXY_NOT_ALLOWED: Proxy connection is not allowed by ruleset.
  451. * Since 2.26
  452. * @G_IO_ERROR_BROKEN_PIPE: Broken pipe. Since 2.36
  453. * @G_IO_ERROR_CONNECTION_CLOSED: Connection closed by peer. Note that this
  454. * is the same code as %G_IO_ERROR_BROKEN_PIPE; before 2.44 some
  455. * "connection closed" errors returned %G_IO_ERROR_BROKEN_PIPE, but others
  456. * returned %G_IO_ERROR_FAILED. Now they should all return the same
  457. * value, which has this more logical name. Since 2.44.
  458. * @G_IO_ERROR_NOT_CONNECTED: Transport endpoint is not connected. Since 2.44
  459. * @G_IO_ERROR_MESSAGE_TOO_LARGE: Message too large. Since 2.48.
  460. *
  461. * Error codes returned by GIO functions.
  462. *
  463. * Note that this domain may be extended in future GLib releases. In
  464. * general, new error codes either only apply to new APIs, or else
  465. * replace %G_IO_ERROR_FAILED in cases that were not explicitly
  466. * distinguished before. You should therefore avoid writing code like
  467. * |[<!-- language="C" -->
  468. * if (g_error_matches (error, G_IO_ERROR, G_IO_ERROR_FAILED))
  469. * {
  470. * // Assume that this is EPRINTERONFIRE
  471. * ...
  472. * }
  473. * ]|
  474. * but should instead treat all unrecognized error codes the same as
  475. * #G_IO_ERROR_FAILED.
  476. **/
  477. typedef enum {
  478. G_IO_ERROR_FAILED,
  479. G_IO_ERROR_NOT_FOUND,
  480. G_IO_ERROR_EXISTS,
  481. G_IO_ERROR_IS_DIRECTORY,
  482. G_IO_ERROR_NOT_DIRECTORY,
  483. G_IO_ERROR_NOT_EMPTY,
  484. G_IO_ERROR_NOT_REGULAR_FILE,
  485. G_IO_ERROR_NOT_SYMBOLIC_LINK,
  486. G_IO_ERROR_NOT_MOUNTABLE_FILE,
  487. G_IO_ERROR_FILENAME_TOO_LONG,
  488. G_IO_ERROR_INVALID_FILENAME,
  489. G_IO_ERROR_TOO_MANY_LINKS,
  490. G_IO_ERROR_NO_SPACE,
  491. G_IO_ERROR_INVALID_ARGUMENT,
  492. G_IO_ERROR_PERMISSION_DENIED,
  493. G_IO_ERROR_NOT_SUPPORTED,
  494. G_IO_ERROR_NOT_MOUNTED,
  495. G_IO_ERROR_ALREADY_MOUNTED,
  496. G_IO_ERROR_CLOSED,
  497. G_IO_ERROR_CANCELLED,
  498. G_IO_ERROR_PENDING,
  499. G_IO_ERROR_READ_ONLY,
  500. G_IO_ERROR_CANT_CREATE_BACKUP,
  501. G_IO_ERROR_WRONG_ETAG,
  502. G_IO_ERROR_TIMED_OUT,
  503. G_IO_ERROR_WOULD_RECURSE,
  504. G_IO_ERROR_BUSY,
  505. G_IO_ERROR_WOULD_BLOCK,
  506. G_IO_ERROR_HOST_NOT_FOUND,
  507. G_IO_ERROR_WOULD_MERGE,
  508. G_IO_ERROR_FAILED_HANDLED,
  509. G_IO_ERROR_TOO_MANY_OPEN_FILES,
  510. G_IO_ERROR_NOT_INITIALIZED,
  511. G_IO_ERROR_ADDRESS_IN_USE,
  512. G_IO_ERROR_PARTIAL_INPUT,
  513. G_IO_ERROR_INVALID_DATA,
  514. G_IO_ERROR_DBUS_ERROR,
  515. G_IO_ERROR_HOST_UNREACHABLE,
  516. G_IO_ERROR_NETWORK_UNREACHABLE,
  517. G_IO_ERROR_CONNECTION_REFUSED,
  518. G_IO_ERROR_PROXY_FAILED,
  519. G_IO_ERROR_PROXY_AUTH_FAILED,
  520. G_IO_ERROR_PROXY_NEED_AUTH,
  521. G_IO_ERROR_PROXY_NOT_ALLOWED,
  522. G_IO_ERROR_BROKEN_PIPE,
  523. G_IO_ERROR_CONNECTION_CLOSED = G_IO_ERROR_BROKEN_PIPE,
  524. G_IO_ERROR_NOT_CONNECTED,
  525. G_IO_ERROR_MESSAGE_TOO_LARGE
  526. } GIOErrorEnum;
  527. /**
  528. * GAskPasswordFlags:
  529. * @G_ASK_PASSWORD_NEED_PASSWORD: operation requires a password.
  530. * @G_ASK_PASSWORD_NEED_USERNAME: operation requires a username.
  531. * @G_ASK_PASSWORD_NEED_DOMAIN: operation requires a domain.
  532. * @G_ASK_PASSWORD_SAVING_SUPPORTED: operation supports saving settings.
  533. * @G_ASK_PASSWORD_ANONYMOUS_SUPPORTED: operation supports anonymous users.
  534. *
  535. * #GAskPasswordFlags are used to request specific information from the
  536. * user, or to notify the user of their choices in an authentication
  537. * situation.
  538. **/
  539. typedef enum {
  540. G_ASK_PASSWORD_NEED_PASSWORD = (1 << 0),
  541. G_ASK_PASSWORD_NEED_USERNAME = (1 << 1),
  542. G_ASK_PASSWORD_NEED_DOMAIN = (1 << 2),
  543. G_ASK_PASSWORD_SAVING_SUPPORTED = (1 << 3),
  544. G_ASK_PASSWORD_ANONYMOUS_SUPPORTED = (1 << 4)
  545. } GAskPasswordFlags;
  546. /**
  547. * GPasswordSave:
  548. * @G_PASSWORD_SAVE_NEVER: never save a password.
  549. * @G_PASSWORD_SAVE_FOR_SESSION: save a password for the session.
  550. * @G_PASSWORD_SAVE_PERMANENTLY: save a password permanently.
  551. *
  552. * #GPasswordSave is used to indicate the lifespan of a saved password.
  553. *
  554. * #Gvfs stores passwords in the Gnome keyring when this flag allows it
  555. * to, and later retrieves it again from there.
  556. **/
  557. typedef enum {
  558. G_PASSWORD_SAVE_NEVER,
  559. G_PASSWORD_SAVE_FOR_SESSION,
  560. G_PASSWORD_SAVE_PERMANENTLY
  561. } GPasswordSave;
  562. /**
  563. * GMountOperationResult:
  564. * @G_MOUNT_OPERATION_HANDLED: The request was fulfilled and the
  565. * user specified data is now available
  566. * @G_MOUNT_OPERATION_ABORTED: The user requested the mount operation
  567. * to be aborted
  568. * @G_MOUNT_OPERATION_UNHANDLED: The request was unhandled (i.e. not
  569. * implemented)
  570. *
  571. * #GMountOperationResult is returned as a result when a request for
  572. * information is send by the mounting operation.
  573. **/
  574. typedef enum {
  575. G_MOUNT_OPERATION_HANDLED,
  576. G_MOUNT_OPERATION_ABORTED,
  577. G_MOUNT_OPERATION_UNHANDLED
  578. } GMountOperationResult;
  579. /**
  580. * GOutputStreamSpliceFlags:
  581. * @G_OUTPUT_STREAM_SPLICE_NONE: Do not close either stream.
  582. * @G_OUTPUT_STREAM_SPLICE_CLOSE_SOURCE: Close the source stream after
  583. * the splice.
  584. * @G_OUTPUT_STREAM_SPLICE_CLOSE_TARGET: Close the target stream after
  585. * the splice.
  586. *
  587. * GOutputStreamSpliceFlags determine how streams should be spliced.
  588. **/
  589. typedef enum {
  590. G_OUTPUT_STREAM_SPLICE_NONE = 0,
  591. G_OUTPUT_STREAM_SPLICE_CLOSE_SOURCE = (1 << 0),
  592. G_OUTPUT_STREAM_SPLICE_CLOSE_TARGET = (1 << 1)
  593. } GOutputStreamSpliceFlags;
  594. /**
  595. * GIOStreamSpliceFlags:
  596. * @G_IO_STREAM_SPLICE_NONE: Do not close either stream.
  597. * @G_IO_STREAM_SPLICE_CLOSE_STREAM1: Close the first stream after
  598. * the splice.
  599. * @G_IO_STREAM_SPLICE_CLOSE_STREAM2: Close the second stream after
  600. * the splice.
  601. * @G_IO_STREAM_SPLICE_WAIT_FOR_BOTH: Wait for both splice operations to finish
  602. * before calling the callback.
  603. *
  604. * GIOStreamSpliceFlags determine how streams should be spliced.
  605. *
  606. * Since: 2.28
  607. **/
  608. typedef enum {
  609. G_IO_STREAM_SPLICE_NONE = 0,
  610. G_IO_STREAM_SPLICE_CLOSE_STREAM1 = (1 << 0),
  611. G_IO_STREAM_SPLICE_CLOSE_STREAM2 = (1 << 1),
  612. G_IO_STREAM_SPLICE_WAIT_FOR_BOTH = (1 << 2)
  613. } GIOStreamSpliceFlags;
  614. /**
  615. * GEmblemOrigin:
  616. * @G_EMBLEM_ORIGIN_UNKNOWN: Emblem of unknown origin
  617. * @G_EMBLEM_ORIGIN_DEVICE: Emblem adds device-specific information
  618. * @G_EMBLEM_ORIGIN_LIVEMETADATA: Emblem depicts live metadata, such as "readonly"
  619. * @G_EMBLEM_ORIGIN_TAG: Emblem comes from a user-defined tag, e.g. set by nautilus (in the future)
  620. *
  621. * GEmblemOrigin is used to add information about the origin of the emblem
  622. * to #GEmblem.
  623. *
  624. * Since: 2.18
  625. */
  626. typedef enum {
  627. G_EMBLEM_ORIGIN_UNKNOWN,
  628. G_EMBLEM_ORIGIN_DEVICE,
  629. G_EMBLEM_ORIGIN_LIVEMETADATA,
  630. G_EMBLEM_ORIGIN_TAG
  631. } GEmblemOrigin;
  632. /**
  633. * GResolverError:
  634. * @G_RESOLVER_ERROR_NOT_FOUND: the requested name/address/service was not
  635. * found
  636. * @G_RESOLVER_ERROR_TEMPORARY_FAILURE: the requested information could not
  637. * be looked up due to a network error or similar problem
  638. * @G_RESOLVER_ERROR_INTERNAL: unknown error
  639. *
  640. * An error code used with %G_RESOLVER_ERROR in a #GError returned
  641. * from a #GResolver routine.
  642. *
  643. * Since: 2.22
  644. */
  645. typedef enum {
  646. G_RESOLVER_ERROR_NOT_FOUND,
  647. G_RESOLVER_ERROR_TEMPORARY_FAILURE,
  648. G_RESOLVER_ERROR_INTERNAL
  649. } GResolverError;
  650. /**
  651. * GResolverRecordType:
  652. * @G_RESOLVER_RECORD_SRV: lookup DNS SRV records for a domain
  653. * @G_RESOLVER_RECORD_MX: lookup DNS MX records for a domain
  654. * @G_RESOLVER_RECORD_TXT: lookup DNS TXT records for a name
  655. * @G_RESOLVER_RECORD_SOA: lookup DNS SOA records for a zone
  656. * @G_RESOLVER_RECORD_NS: lookup DNS NS records for a domain
  657. *
  658. * The type of record that g_resolver_lookup_records() or
  659. * g_resolver_lookup_records_async() should retrieve. The records are returned
  660. * as lists of #GVariant tuples. Each record type has different values in
  661. * the variant tuples returned.
  662. *
  663. * %G_RESOLVER_RECORD_SRV records are returned as variants with the signature
  664. * '(qqqs)', containing a guint16 with the priority, a guint16 with the
  665. * weight, a guint16 with the port, and a string of the hostname.
  666. *
  667. * %G_RESOLVER_RECORD_MX records are returned as variants with the signature
  668. * '(qs)', representing a guint16 with the preference, and a string containing
  669. * the mail exchanger hostname.
  670. *
  671. * %G_RESOLVER_RECORD_TXT records are returned as variants with the signature
  672. * '(as)', representing an array of the strings in the text record.
  673. *
  674. * %G_RESOLVER_RECORD_SOA records are returned as variants with the signature
  675. * '(ssuuuuu)', representing a string containing the primary name server, a
  676. * string containing the administrator, the serial as a guint32, the refresh
  677. * interval as guint32, the retry interval as a guint32, the expire timeout
  678. * as a guint32, and the ttl as a guint32.
  679. *
  680. * %G_RESOLVER_RECORD_NS records are returned as variants with the signature
  681. * '(s)', representing a string of the hostname of the name server.
  682. *
  683. * Since: 2.34
  684. */
  685. typedef enum {
  686. G_RESOLVER_RECORD_SRV = 1,
  687. G_RESOLVER_RECORD_MX,
  688. G_RESOLVER_RECORD_TXT,
  689. G_RESOLVER_RECORD_SOA,
  690. G_RESOLVER_RECORD_NS
  691. } GResolverRecordType;
  692. /**
  693. * GResourceError:
  694. * @G_RESOURCE_ERROR_NOT_FOUND: no file was found at the requested path
  695. * @G_RESOURCE_ERROR_INTERNAL: unknown error
  696. *
  697. * An error code used with %G_RESOURCE_ERROR in a #GError returned
  698. * from a #GResource routine.
  699. *
  700. * Since: 2.32
  701. */
  702. typedef enum {
  703. G_RESOURCE_ERROR_NOT_FOUND,
  704. G_RESOURCE_ERROR_INTERNAL
  705. } GResourceError;
  706. /**
  707. * GResourceFlags:
  708. * @G_RESOURCE_FLAGS_NONE: No flags set.
  709. * @G_RESOURCE_FLAGS_COMPRESSED: The file is compressed.
  710. *
  711. * GResourceFlags give information about a particular file inside a resource
  712. * bundle.
  713. *
  714. * Since: 2.32
  715. **/
  716. typedef enum {
  717. G_RESOURCE_FLAGS_NONE = 0,
  718. G_RESOURCE_FLAGS_COMPRESSED = (1<<0)
  719. } GResourceFlags;
  720. /**
  721. * GResourceLookupFlags:
  722. * @G_RESOURCE_LOOKUP_FLAGS_NONE: No flags set.
  723. *
  724. * GResourceLookupFlags determine how resource path lookups are handled.
  725. *
  726. * Since: 2.32
  727. **/
  728. typedef enum /*< flags >*/ {
  729. G_RESOURCE_LOOKUP_FLAGS_NONE = 0
  730. } GResourceLookupFlags;
  731. /**
  732. * GSocketFamily:
  733. * @G_SOCKET_FAMILY_INVALID: no address family
  734. * @G_SOCKET_FAMILY_IPV4: the IPv4 family
  735. * @G_SOCKET_FAMILY_IPV6: the IPv6 family
  736. * @G_SOCKET_FAMILY_UNIX: the UNIX domain family
  737. *
  738. * The protocol family of a #GSocketAddress. (These values are
  739. * identical to the system defines %AF_INET, %AF_INET6 and %AF_UNIX,
  740. * if available.)
  741. *
  742. * Since: 2.22
  743. */
  744. typedef enum {
  745. G_SOCKET_FAMILY_INVALID,
  746. G_SOCKET_FAMILY_UNIX = GLIB_SYSDEF_AF_UNIX,
  747. G_SOCKET_FAMILY_IPV4 = GLIB_SYSDEF_AF_INET,
  748. G_SOCKET_FAMILY_IPV6 = GLIB_SYSDEF_AF_INET6
  749. } GSocketFamily;
  750. /**
  751. * GSocketType:
  752. * @G_SOCKET_TYPE_INVALID: Type unknown or wrong
  753. * @G_SOCKET_TYPE_STREAM: Reliable connection-based byte streams (e.g. TCP).
  754. * @G_SOCKET_TYPE_DATAGRAM: Connectionless, unreliable datagram passing.
  755. * (e.g. UDP)
  756. * @G_SOCKET_TYPE_SEQPACKET: Reliable connection-based passing of datagrams
  757. * of fixed maximum length (e.g. SCTP).
  758. *
  759. * Flags used when creating a #GSocket. Some protocols may not implement
  760. * all the socket types.
  761. *
  762. * Since: 2.22
  763. */
  764. typedef enum
  765. {
  766. G_SOCKET_TYPE_INVALID,
  767. G_SOCKET_TYPE_STREAM,
  768. G_SOCKET_TYPE_DATAGRAM,
  769. G_SOCKET_TYPE_SEQPACKET
  770. } GSocketType;
  771. /**
  772. * GSocketMsgFlags:
  773. * @G_SOCKET_MSG_NONE: No flags.
  774. * @G_SOCKET_MSG_OOB: Request to send/receive out of band data.
  775. * @G_SOCKET_MSG_PEEK: Read data from the socket without removing it from
  776. * the queue.
  777. * @G_SOCKET_MSG_DONTROUTE: Don't use a gateway to send out the packet,
  778. * only send to hosts on directly connected networks.
  779. *
  780. * Flags used in g_socket_receive_message() and g_socket_send_message().
  781. * The flags listed in the enum are some commonly available flags, but the
  782. * values used for them are the same as on the platform, and any other flags
  783. * are passed in/out as is. So to use a platform specific flag, just include
  784. * the right system header and pass in the flag.
  785. *
  786. * Since: 2.22
  787. */
  788. typedef enum /*< flags >*/
  789. {
  790. G_SOCKET_MSG_NONE,
  791. G_SOCKET_MSG_OOB = GLIB_SYSDEF_MSG_OOB,
  792. G_SOCKET_MSG_PEEK = GLIB_SYSDEF_MSG_PEEK,
  793. G_SOCKET_MSG_DONTROUTE = GLIB_SYSDEF_MSG_DONTROUTE
  794. } GSocketMsgFlags;
  795. /**
  796. * GSocketProtocol:
  797. * @G_SOCKET_PROTOCOL_UNKNOWN: The protocol type is unknown
  798. * @G_SOCKET_PROTOCOL_DEFAULT: The default protocol for the family/type
  799. * @G_SOCKET_PROTOCOL_TCP: TCP over IP
  800. * @G_SOCKET_PROTOCOL_UDP: UDP over IP
  801. * @G_SOCKET_PROTOCOL_SCTP: SCTP over IP
  802. *
  803. * A protocol identifier is specified when creating a #GSocket, which is a
  804. * family/type specific identifier, where 0 means the default protocol for
  805. * the particular family/type.
  806. *
  807. * This enum contains a set of commonly available and used protocols. You
  808. * can also pass any other identifiers handled by the platform in order to
  809. * use protocols not listed here.
  810. *
  811. * Since: 2.22
  812. */
  813. typedef enum {
  814. G_SOCKET_PROTOCOL_UNKNOWN = -1,
  815. G_SOCKET_PROTOCOL_DEFAULT = 0,
  816. G_SOCKET_PROTOCOL_TCP = 6,
  817. G_SOCKET_PROTOCOL_UDP = 17,
  818. G_SOCKET_PROTOCOL_SCTP = 132
  819. } GSocketProtocol;
  820. /**
  821. * GZlibCompressorFormat:
  822. * @G_ZLIB_COMPRESSOR_FORMAT_ZLIB: deflate compression with zlib header
  823. * @G_ZLIB_COMPRESSOR_FORMAT_GZIP: gzip file format
  824. * @G_ZLIB_COMPRESSOR_FORMAT_RAW: deflate compression with no header
  825. *
  826. * Used to select the type of data format to use for #GZlibDecompressor
  827. * and #GZlibCompressor.
  828. *
  829. * Since: 2.24
  830. */
  831. typedef enum {
  832. G_ZLIB_COMPRESSOR_FORMAT_ZLIB,
  833. G_ZLIB_COMPRESSOR_FORMAT_GZIP,
  834. G_ZLIB_COMPRESSOR_FORMAT_RAW
  835. } GZlibCompressorFormat;
  836. /**
  837. * GUnixSocketAddressType:
  838. * @G_UNIX_SOCKET_ADDRESS_INVALID: invalid
  839. * @G_UNIX_SOCKET_ADDRESS_ANONYMOUS: anonymous
  840. * @G_UNIX_SOCKET_ADDRESS_PATH: a filesystem path
  841. * @G_UNIX_SOCKET_ADDRESS_ABSTRACT: an abstract name
  842. * @G_UNIX_SOCKET_ADDRESS_ABSTRACT_PADDED: an abstract name, 0-padded
  843. * to the full length of a unix socket name
  844. *
  845. * The type of name used by a #GUnixSocketAddress.
  846. * %G_UNIX_SOCKET_ADDRESS_PATH indicates a traditional unix domain
  847. * socket bound to a filesystem path. %G_UNIX_SOCKET_ADDRESS_ANONYMOUS
  848. * indicates a socket not bound to any name (eg, a client-side socket,
  849. * or a socket created with socketpair()).
  850. *
  851. * For abstract sockets, there are two incompatible ways of naming
  852. * them; the man pages suggest using the entire `struct sockaddr_un`
  853. * as the name, padding the unused parts of the %sun_path field with
  854. * zeroes; this corresponds to %G_UNIX_SOCKET_ADDRESS_ABSTRACT_PADDED.
  855. * However, many programs instead just use a portion of %sun_path, and
  856. * pass an appropriate smaller length to bind() or connect(). This is
  857. * %G_UNIX_SOCKET_ADDRESS_ABSTRACT.
  858. *
  859. * Since: 2.26
  860. */
  861. typedef enum {
  862. G_UNIX_SOCKET_ADDRESS_INVALID,
  863. G_UNIX_SOCKET_ADDRESS_ANONYMOUS,
  864. G_UNIX_SOCKET_ADDRESS_PATH,
  865. G_UNIX_SOCKET_ADDRESS_ABSTRACT,
  866. G_UNIX_SOCKET_ADDRESS_ABSTRACT_PADDED
  867. } GUnixSocketAddressType;
  868. /**
  869. * GBusType:
  870. * @G_BUS_TYPE_STARTER: An alias for the message bus that activated the process, if any.
  871. * @G_BUS_TYPE_NONE: Not a message bus.
  872. * @G_BUS_TYPE_SYSTEM: The system-wide message bus.
  873. * @G_BUS_TYPE_SESSION: The login session message bus.
  874. *
  875. * An enumeration for well-known message buses.
  876. *
  877. * Since: 2.26
  878. */
  879. typedef enum
  880. {
  881. G_BUS_TYPE_STARTER = -1,
  882. G_BUS_TYPE_NONE = 0,
  883. G_BUS_TYPE_SYSTEM = 1,
  884. G_BUS_TYPE_SESSION = 2
  885. } GBusType;
  886. /**
  887. * GBusNameOwnerFlags:
  888. * @G_BUS_NAME_OWNER_FLAGS_NONE: No flags set.
  889. * @G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT: Allow another message bus connection to claim the name.
  890. * @G_BUS_NAME_OWNER_FLAGS_REPLACE: If another message bus connection owns the name and have
  891. * specified #G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT, then take the name from the other connection.
  892. *
  893. * Flags used in g_bus_own_name().
  894. *
  895. * Since: 2.26
  896. */
  897. typedef enum
  898. {
  899. G_BUS_NAME_OWNER_FLAGS_NONE = 0, /*< nick=none >*/
  900. G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT = (1<<0), /*< nick=allow-replacement >*/
  901. G_BUS_NAME_OWNER_FLAGS_REPLACE = (1<<1) /*< nick=replace >*/
  902. } GBusNameOwnerFlags;
  903. /**
  904. * GBusNameWatcherFlags:
  905. * @G_BUS_NAME_WATCHER_FLAGS_NONE: No flags set.
  906. * @G_BUS_NAME_WATCHER_FLAGS_AUTO_START: If no-one owns the name when
  907. * beginning to watch the name, ask the bus to launch an owner for the
  908. * name.
  909. *
  910. * Flags used in g_bus_watch_name().
  911. *
  912. * Since: 2.26
  913. */
  914. typedef enum
  915. {
  916. G_BUS_NAME_WATCHER_FLAGS_NONE = 0,
  917. G_BUS_NAME_WATCHER_FLAGS_AUTO_START = (1<<0)
  918. } GBusNameWatcherFlags;
  919. /**
  920. * GDBusProxyFlags:
  921. * @G_DBUS_PROXY_FLAGS_NONE: No flags set.
  922. * @G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES: Don't load properties.
  923. * @G_DBUS_PROXY_FLAGS_DO_NOT_CONNECT_SIGNALS: Don't connect to signals on the remote object.
  924. * @G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START: If the proxy is for a well-known name,
  925. * do not ask the bus to launch an owner during proxy initialization or a method call.
  926. * This flag is only meaningful in proxies for well-known names.
  927. * @G_DBUS_PROXY_FLAGS_GET_INVALIDATED_PROPERTIES: If set, the property value for any <emphasis>invalidated property</emphasis> will be (asynchronously) retrieved upon receiving the <ulink url="http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-properties">PropertiesChanged</ulink> D-Bus signal and the property will not cause emission of the #GDBusProxy::g-properties-changed signal. When the value is received the #GDBusProxy::g-properties-changed signal is emitted for the property along with the retrieved value. Since 2.32.
  928. * @G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START_AT_CONSTRUCTION: If the proxy is for a well-known name,
  929. * do not ask the bus to launch an owner during proxy initialization, but allow it to be
  930. * autostarted by a method call. This flag is only meaningful in proxies for well-known names,
  931. * and only if %G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START is not also specified.
  932. *
  933. * Flags used when constructing an instance of a #GDBusProxy derived class.
  934. *
  935. * Since: 2.26
  936. */
  937. typedef enum
  938. {
  939. G_DBUS_PROXY_FLAGS_NONE = 0,
  940. G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES = (1<<0),
  941. G_DBUS_PROXY_FLAGS_DO_NOT_CONNECT_SIGNALS = (1<<1),
  942. G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START = (1<<2),
  943. G_DBUS_PROXY_FLAGS_GET_INVALIDATED_PROPERTIES = (1<<3),
  944. G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START_AT_CONSTRUCTION = (1<<4)
  945. } GDBusProxyFlags;
  946. /**
  947. * GDBusError:
  948. * @G_DBUS_ERROR_FAILED:
  949. * A generic error; "something went wrong" - see the error message for
  950. * more.
  951. * @G_DBUS_ERROR_NO_MEMORY:
  952. * There was not enough memory to complete an operation.
  953. * @G_DBUS_ERROR_SERVICE_UNKNOWN:
  954. * The bus doesn't know how to launch a service to supply the bus name
  955. * you wanted.
  956. * @G_DBUS_ERROR_NAME_HAS_NO_OWNER:
  957. * The bus name you referenced doesn't exist (i.e. no application owns
  958. * it).
  959. * @G_DBUS_ERROR_NO_REPLY:
  960. * No reply to a message expecting one, usually means a timeout occurred.
  961. * @G_DBUS_ERROR_IO_ERROR:
  962. * Something went wrong reading or writing to a socket, for example.
  963. * @G_DBUS_ERROR_BAD_ADDRESS:
  964. * A D-Bus bus address was malformed.
  965. * @G_DBUS_ERROR_NOT_SUPPORTED:
  966. * Requested operation isn't supported (like ENOSYS on UNIX).
  967. * @G_DBUS_ERROR_LIMITS_EXCEEDED:
  968. * Some limited resource is exhausted.
  969. * @G_DBUS_ERROR_ACCESS_DENIED:
  970. * Security restrictions don't allow doing what you're trying to do.
  971. * @G_DBUS_ERROR_AUTH_FAILED:
  972. * Authentication didn't work.
  973. * @G_DBUS_ERROR_NO_SERVER:
  974. * Unable to connect to server (probably caused by ECONNREFUSED on a
  975. * socket).
  976. * @G_DBUS_ERROR_TIMEOUT:
  977. * Certain timeout errors, possibly ETIMEDOUT on a socket. Note that
  978. * %G_DBUS_ERROR_NO_REPLY is used for message reply timeouts. Warning:
  979. * this is confusingly-named given that %G_DBUS_ERROR_TIMED_OUT also
  980. * exists. We can't fix it for compatibility reasons so just be
  981. * careful.
  982. * @G_DBUS_ERROR_NO_NETWORK:
  983. * No network access (probably ENETUNREACH on a socket).
  984. * @G_DBUS_ERROR_ADDRESS_IN_USE:
  985. * Can't bind a socket since its address is in use (i.e. EADDRINUSE).
  986. * @G_DBUS_ERROR_DISCONNECTED:
  987. * The connection is disconnected and you're trying to use it.
  988. * @G_DBUS_ERROR_INVALID_ARGS:
  989. * Invalid arguments passed to a method call.
  990. * @G_DBUS_ERROR_FILE_NOT_FOUND:
  991. * Missing file.
  992. * @G_DBUS_ERROR_FILE_EXISTS:
  993. * Existing file and the operation you're using does not silently overwrite.
  994. * @G_DBUS_ERROR_UNKNOWN_METHOD:
  995. * Method name you invoked isn't known by the object you invoked it on.
  996. * @G_DBUS_ERROR_UNKNOWN_OBJECT:
  997. * Object you invoked a method on isn't known. Since 2.42
  998. * @G_DBUS_ERROR_UNKNOWN_INTERFACE:
  999. * Interface you invoked a method on isn't known by the object. Since 2.42
  1000. * @G_DBUS_ERROR_UNKNOWN_PROPERTY:
  1001. * Property you tried to access isn't known by the object. Since 2.42
  1002. * @G_DBUS_ERROR_PROPERTY_READ_ONLY:
  1003. * Property you tried to set is read-only. Since 2.42
  1004. * @G_DBUS_ERROR_TIMED_OUT:
  1005. * Certain timeout errors, e.g. while starting a service. Warning: this is
  1006. * confusingly-named given that %G_DBUS_ERROR_TIMEOUT also exists. We
  1007. * can't fix it for compatibility reasons so just be careful.
  1008. * @G_DBUS_ERROR_MATCH_RULE_NOT_FOUND:
  1009. * Tried to remove or modify a match rule that didn't exist.
  1010. * @G_DBUS_ERROR_MATCH_RULE_INVALID:
  1011. * The match rule isn't syntactically valid.
  1012. * @G_DBUS_ERROR_SPAWN_EXEC_FAILED:
  1013. * While starting a new process, the exec() call failed.
  1014. * @G_DBUS_ERROR_SPAWN_FORK_FAILED:
  1015. * While starting a new process, the fork() call failed.
  1016. * @G_DBUS_ERROR_SPAWN_CHILD_EXITED:
  1017. * While starting a new process, the child exited with a status code.
  1018. * @G_DBUS_ERROR_SPAWN_CHILD_SIGNALED:
  1019. * While starting a new process, the child exited on a signal.
  1020. * @G_DBUS_ERROR_SPAWN_FAILED:
  1021. * While starting a new process, something went wrong.
  1022. * @G_DBUS_ERROR_SPAWN_SETUP_FAILED:
  1023. * We failed to setup the environment correctly.
  1024. * @G_DBUS_ERROR_SPAWN_CONFIG_INVALID:
  1025. * We failed to setup the config parser correctly.
  1026. * @G_DBUS_ERROR_SPAWN_SERVICE_INVALID:
  1027. * Bus name was not valid.
  1028. * @G_DBUS_ERROR_SPAWN_SERVICE_NOT_FOUND:
  1029. * Service file not found in system-services directory.
  1030. * @G_DBUS_ERROR_SPAWN_PERMISSIONS_INVALID:
  1031. * Permissions are incorrect on the setuid helper.
  1032. * @G_DBUS_ERROR_SPAWN_FILE_INVALID:
  1033. * Service file invalid (Name, User or Exec missing).
  1034. * @G_DBUS_ERROR_SPAWN_NO_MEMORY:
  1035. * Tried to get a UNIX process ID and it wasn't available.
  1036. * @G_DBUS_ERROR_UNIX_PROCESS_ID_UNKNOWN:
  1037. * Tried to get a UNIX process ID and it wasn't available.
  1038. * @G_DBUS_ERROR_INVALID_SIGNATURE:
  1039. * A type signature is not valid.
  1040. * @G_DBUS_ERROR_INVALID_FILE_CONTENT:
  1041. * A file contains invalid syntax or is otherwise broken.
  1042. * @G_DBUS_ERROR_SELINUX_SECURITY_CONTEXT_UNKNOWN:
  1043. * Asked for SELinux security context and it wasn't available.
  1044. * @G_DBUS_ERROR_ADT_AUDIT_DATA_UNKNOWN:
  1045. * Asked for ADT audit data and it wasn't available.
  1046. * @G_DBUS_ERROR_OBJECT_PATH_IN_USE:
  1047. * There's already an object with the requested object path.
  1048. *
  1049. * Error codes for the %G_DBUS_ERROR error domain.
  1050. *
  1051. * Since: 2.26
  1052. */
  1053. typedef enum
  1054. {
  1055. /* Well-known errors in the org.freedesktop.DBus.Error namespace */
  1056. G_DBUS_ERROR_FAILED, /* org.freedesktop.DBus.Error.Failed */
  1057. G_DBUS_ERROR_NO_MEMORY, /* org.freedesktop.DBus.Error.NoMemory */
  1058. G_DBUS_ERROR_SERVICE_UNKNOWN, /* org.freedesktop.DBus.Error.ServiceUnknown */
  1059. G_DBUS_ERROR_NAME_HAS_NO_OWNER, /* org.freedesktop.DBus.Error.NameHasNoOwner */
  1060. G_DBUS_ERROR_NO_REPLY, /* org.freedesktop.DBus.Error.NoReply */
  1061. G_DBUS_ERROR_IO_ERROR, /* org.freedesktop.DBus.Error.IOError */
  1062. G_DBUS_ERROR_BAD_ADDRESS, /* org.freedesktop.DBus.Error.BadAddress */
  1063. G_DBUS_ERROR_NOT_SUPPORTED, /* org.freedesktop.DBus.Error.NotSupported */
  1064. G_DBUS_ERROR_LIMITS_EXCEEDED, /* org.freedesktop.DBus.Error.LimitsExceeded */
  1065. G_DBUS_ERROR_ACCESS_DENIED, /* org.freedesktop.DBus.Error.AccessDenied */
  1066. G_DBUS_ERROR_AUTH_FAILED, /* org.freedesktop.DBus.Error.AuthFailed */
  1067. G_DBUS_ERROR_NO_SERVER, /* org.freedesktop.DBus.Error.NoServer */
  1068. G_DBUS_ERROR_TIMEOUT, /* org.freedesktop.DBus.Error.Timeout */
  1069. G_DBUS_ERROR_NO_NETWORK, /* org.freedesktop.DBus.Error.NoNetwork */
  1070. G_DBUS_ERROR_ADDRESS_IN_USE, /* org.freedesktop.DBus.Error.AddressInUse */
  1071. G_DBUS_ERROR_DISCONNECTED, /* org.freedesktop.DBus.Error.Disconnected */
  1072. G_DBUS_ERROR_INVALID_ARGS, /* org.freedesktop.DBus.Error.InvalidArgs */
  1073. G_DBUS_ERROR_FILE_NOT_FOUND, /* org.freedesktop.DBus.Error.FileNotFound */
  1074. G_DBUS_ERROR_FILE_EXISTS, /* org.freedesktop.DBus.Error.FileExists */
  1075. G_DBUS_ERROR_UNKNOWN_METHOD, /* org.freedesktop.DBus.Error.UnknownMethod */
  1076. G_DBUS_ERROR_TIMED_OUT, /* org.freedesktop.DBus.Error.TimedOut */
  1077. G_DBUS_ERROR_MATCH_RULE_NOT_FOUND, /* org.freedesktop.DBus.Error.MatchRuleNotFound */
  1078. G_DBUS_ERROR_MATCH_RULE_INVALID, /* org.freedesktop.DBus.Error.MatchRuleInvalid */
  1079. G_DBUS_ERROR_SPAWN_EXEC_FAILED, /* org.freedesktop.DBus.Error.Spawn.ExecFailed */
  1080. G_DBUS_ERROR_SPAWN_FORK_FAILED, /* org.freedesktop.DBus.Error.Spawn.ForkFailed */
  1081. G_DBUS_ERROR_SPAWN_CHILD_EXITED, /* org.freedesktop.DBus.Error.Spawn.ChildExited */
  1082. G_DBUS_ERROR_SPAWN_CHILD_SIGNALED, /* org.freedesktop.DBus.Error.Spawn.ChildSignaled */
  1083. G_DBUS_ERROR_SPAWN_FAILED, /* org.freedesktop.DBus.Error.Spawn.Failed */
  1084. G_DBUS_ERROR_SPAWN_SETUP_FAILED, /* org.freedesktop.DBus.Error.Spawn.FailedToSetup */
  1085. G_DBUS_ERROR_SPAWN_CONFIG_INVALID, /* org.freedesktop.DBus.Error.Spawn.ConfigInvalid */
  1086. G_DBUS_ERROR_SPAWN_SERVICE_INVALID, /* org.freedesktop.DBus.Error.Spawn.ServiceNotValid */
  1087. G_DBUS_ERROR_SPAWN_SERVICE_NOT_FOUND, /* org.freedesktop.DBus.Error.Spawn.ServiceNotFound */
  1088. G_DBUS_ERROR_SPAWN_PERMISSIONS_INVALID, /* org.freedesktop.DBus.Error.Spawn.PermissionsInvalid */
  1089. G_DBUS_ERROR_SPAWN_FILE_INVALID, /* org.freedesktop.DBus.Error.Spawn.FileInvalid */
  1090. G_DBUS_ERROR_SPAWN_NO_MEMORY, /* org.freedesktop.DBus.Error.Spawn.NoMemory */
  1091. G_DBUS_ERROR_UNIX_PROCESS_ID_UNKNOWN, /* org.freedesktop.DBus.Error.UnixProcessIdUnknown */
  1092. G_DBUS_ERROR_INVALID_SIGNATURE, /* org.freedesktop.DBus.Error.InvalidSignature */
  1093. G_DBUS_ERROR_INVALID_FILE_CONTENT, /* org.freedesktop.DBus.Error.InvalidFileContent */
  1094. G_DBUS_ERROR_SELINUX_SECURITY_CONTEXT_UNKNOWN, /* org.freedesktop.DBus.Error.SELinuxSecurityContextUnknown */
  1095. G_DBUS_ERROR_ADT_AUDIT_DATA_UNKNOWN, /* org.freedesktop.DBus.Error.AdtAuditDataUnknown */
  1096. G_DBUS_ERROR_OBJECT_PATH_IN_USE, /* org.freedesktop.DBus.Error.ObjectPathInUse */
  1097. G_DBUS_ERROR_UNKNOWN_OBJECT, /* org.freedesktop.DBus.Error.UnknownObject */
  1098. G_DBUS_ERROR_UNKNOWN_INTERFACE, /* org.freedesktop.DBus.Error.UnknownInterface */
  1099. G_DBUS_ERROR_UNKNOWN_PROPERTY, /* org.freedesktop.DBus.Error.UnknownProperty */
  1100. G_DBUS_ERROR_PROPERTY_READ_ONLY /* org.freedesktop.DBus.Error.PropertyReadOnly */
  1101. } GDBusError;
  1102. /* Remember to update g_dbus_error_quark() in gdbuserror.c if you extend this enumeration */
  1103. /**
  1104. * GDBusConnectionFlags:
  1105. * @G_DBUS_CONNECTION_FLAGS_NONE: No flags set.
  1106. * @G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT: Perform authentication against server.
  1107. * @G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_SERVER: Perform authentication against client.
  1108. * @G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_ALLOW_ANONYMOUS: When
  1109. * authenticating as a server, allow the anonymous authentication
  1110. * method.
  1111. * @G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION: Pass this flag if connecting to a peer that is a
  1112. * message bus. This means that the Hello() method will be invoked as part of the connection setup.
  1113. * @G_DBUS_CONNECTION_FLAGS_DELAY_MESSAGE_PROCESSING: If set, processing of D-Bus messages is
  1114. * delayed until g_dbus_connection_start_message_processing() is called.
  1115. *
  1116. * Flags used when creating a new #GDBusConnection.
  1117. *
  1118. * Since: 2.26
  1119. */
  1120. typedef enum {
  1121. G_DBUS_CONNECTION_FLAGS_NONE = 0,
  1122. G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT = (1<<0),
  1123. G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_SERVER = (1<<1),
  1124. G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_ALLOW_ANONYMOUS = (1<<2),
  1125. G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION = (1<<3),
  1126. G_DBUS_CONNECTION_FLAGS_DELAY_MESSAGE_PROCESSING = (1<<4)
  1127. } GDBusConnectionFlags;
  1128. /**
  1129. * GDBusCapabilityFlags:
  1130. * @G_DBUS_CAPABILITY_FLAGS_NONE: No flags set.
  1131. * @G_DBUS_CAPABILITY_FLAGS_UNIX_FD_PASSING: The connection
  1132. * supports exchanging UNIX file descriptors with the remote peer.
  1133. *
  1134. * Capabilities negotiated with the remote peer.
  1135. *
  1136. * Since: 2.26
  1137. */
  1138. typedef enum {
  1139. G_DBUS_CAPABILITY_FLAGS_NONE = 0,
  1140. G_DBUS_CAPABILITY_FLAGS_UNIX_FD_PASSING = (1<<0)
  1141. } GDBusCapabilityFlags;
  1142. /**
  1143. * GDBusCallFlags:
  1144. * @G_DBUS_CALL_FLAGS_NONE: No flags set.
  1145. * @G_DBUS_CALL_FLAGS_NO_AUTO_START: The bus must not launch
  1146. * an owner for the destination name in response to this method
  1147. * invocation.
  1148. * @G_DBUS_CALL_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION: the caller is prepared to
  1149. * wait for interactive authorization. Since 2.46.
  1150. *
  1151. * Flags used in g_dbus_connection_call() and similar APIs.
  1152. *
  1153. * Since: 2.26
  1154. */
  1155. typedef enum {
  1156. G_DBUS_CALL_FLAGS_NONE = 0,
  1157. G_DBUS_CALL_FLAGS_NO_AUTO_START = (1<<0),
  1158. G_DBUS_CALL_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION = (1<<1)
  1159. } GDBusCallFlags;
  1160. /* (1<<31) is reserved for internal use by GDBusConnection, do not use it. */
  1161. /**
  1162. * GDBusMessageType:
  1163. * @G_DBUS_MESSAGE_TYPE_INVALID: Message is of invalid type.
  1164. * @G_DBUS_MESSAGE_TYPE_METHOD_CALL: Method call.
  1165. * @G_DBUS_MESSAGE_TYPE_METHOD_RETURN: Method reply.
  1166. * @G_DBUS_MESSAGE_TYPE_ERROR: Error reply.
  1167. * @G_DBUS_MESSAGE_TYPE_SIGNAL: Signal emission.
  1168. *
  1169. * Message types used in #GDBusMessage.
  1170. *
  1171. * Since: 2.26
  1172. */
  1173. typedef enum {
  1174. G_DBUS_MESSAGE_TYPE_INVALID,
  1175. G_DBUS_MESSAGE_TYPE_METHOD_CALL,
  1176. G_DBUS_MESSAGE_TYPE_METHOD_RETURN,
  1177. G_DBUS_MESSAGE_TYPE_ERROR,
  1178. G_DBUS_MESSAGE_TYPE_SIGNAL
  1179. } GDBusMessageType;
  1180. /**
  1181. * GDBusMessageFlags:
  1182. * @G_DBUS_MESSAGE_FLAGS_NONE: No flags set.
  1183. * @G_DBUS_MESSAGE_FLAGS_NO_REPLY_EXPECTED: A reply is not expected.
  1184. * @G_DBUS_MESSAGE_FLAGS_NO_AUTO_START: The bus must not launch an
  1185. * owner for the destination name in response to this message.
  1186. * @G_DBUS_MESSAGE_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION: If set on a method
  1187. * call, this flag means that the caller is prepared to wait for interactive
  1188. * authorization. Since 2.46.
  1189. *
  1190. * Message flags used in #GDBusMessage.
  1191. *
  1192. * Since: 2.26
  1193. */
  1194. typedef enum {
  1195. G_DBUS_MESSAGE_FLAGS_NONE = 0,
  1196. G_DBUS_MESSAGE_FLAGS_NO_REPLY_EXPECTED = (1<<0),
  1197. G_DBUS_MESSAGE_FLAGS_NO_AUTO_START = (1<<1),
  1198. G_DBUS_MESSAGE_FLAGS_ALLOW_INTERACTIVE_AUTHORIZATION = (1<<2)
  1199. } GDBusMessageFlags;
  1200. /**
  1201. * GDBusMessageHeaderField:
  1202. * @G_DBUS_MESSAGE_HEADER_FIELD_INVALID: Not a valid header field.
  1203. * @G_DBUS_MESSAGE_HEADER_FIELD_PATH: The object path.
  1204. * @G_DBUS_MESSAGE_HEADER_FIELD_INTERFACE: The interface name.
  1205. * @G_DBUS_MESSAGE_HEADER_FIELD_MEMBER: The method or signal name.
  1206. * @G_DBUS_MESSAGE_HEADER_FIELD_ERROR_NAME: The name of the error that occurred.
  1207. * @G_DBUS_MESSAGE_HEADER_FIELD_REPLY_SERIAL: The serial number the message is a reply to.
  1208. * @G_DBUS_MESSAGE_HEADER_FIELD_DESTINATION: The name the message is intended for.
  1209. * @G_DBUS_MESSAGE_HEADER_FIELD_SENDER: Unique name of the sender of the message (filled in by the bus).
  1210. * @G_DBUS_MESSAGE_HEADER_FIELD_SIGNATURE: The signature of the message body.
  1211. * @G_DBUS_MESSAGE_HEADER_FIELD_NUM_UNIX_FDS: The number of UNIX file descriptors that accompany the message.
  1212. *
  1213. * Header fields used in #GDBusMessage.
  1214. *
  1215. * Since: 2.26
  1216. */
  1217. typedef enum {
  1218. G_DBUS_MESSAGE_HEADER_FIELD_INVALID,
  1219. G_DBUS_MESSAGE_HEADER_FIELD_PATH,
  1220. G_DBUS_MESSAGE_HEADER_FIELD_INTERFACE,
  1221. G_DBUS_MESSAGE_HEADER_FIELD_MEMBER,
  1222. G_DBUS_MESSAGE_HEADER_FIELD_ERROR_NAME,
  1223. G_DBUS_MESSAGE_HEADER_FIELD_REPLY_SERIAL,
  1224. G_DBUS_MESSAGE_HEADER_FIELD_DESTINATION,
  1225. G_DBUS_MESSAGE_HEADER_FIELD_SENDER,
  1226. G_DBUS_MESSAGE_HEADER_FIELD_SIGNATURE,
  1227. G_DBUS_MESSAGE_HEADER_FIELD_NUM_UNIX_FDS
  1228. } GDBusMessageHeaderField;
  1229. /**
  1230. * GDBusPropertyInfoFlags:
  1231. * @G_DBUS_PROPERTY_INFO_FLAGS_NONE: No flags set.
  1232. * @G_DBUS_PROPERTY_INFO_FLAGS_READABLE: Property is readable.
  1233. * @G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE: Property is writable.
  1234. *
  1235. * Flags describing the access control of a D-Bus property.
  1236. *
  1237. * Since: 2.26
  1238. */
  1239. typedef enum
  1240. {
  1241. G_DBUS_PROPERTY_INFO_FLAGS_NONE = 0,
  1242. G_DBUS_PROPERTY_INFO_FLAGS_READABLE = (1<<0),
  1243. G_DBUS_PROPERTY_INFO_FLAGS_WRITABLE = (1<<1)
  1244. } GDBusPropertyInfoFlags;
  1245. /**
  1246. * GDBusSubtreeFlags:
  1247. * @G_DBUS_SUBTREE_FLAGS_NONE: No flags set.
  1248. * @G_DBUS_SUBTREE_FLAGS_DISPATCH_TO_UNENUMERATED_NODES: Method calls to objects not in the enumerated range
  1249. * will still be dispatched. This is useful if you want
  1250. * to dynamically spawn objects in the subtree.
  1251. *
  1252. * Flags passed to g_dbus_connection_register_subtree().
  1253. *
  1254. * Since: 2.26
  1255. */
  1256. typedef enum
  1257. {
  1258. G_DBUS_SUBTREE_FLAGS_NONE = 0,
  1259. G_DBUS_SUBTREE_FLAGS_DISPATCH_TO_UNENUMERATED_NODES = (1<<0)
  1260. } GDBusSubtreeFlags;
  1261. /**
  1262. * GDBusServerFlags:
  1263. * @G_DBUS_SERVER_FLAGS_NONE: No flags set.
  1264. * @G_DBUS_SERVER_FLAGS_RUN_IN_THREAD: All #GDBusServer::new-connection
  1265. * signals will run in separated dedicated threads (see signal for
  1266. * details).
  1267. * @G_DBUS_SERVER_FLAGS_AUTHENTICATION_ALLOW_ANONYMOUS: Allow the anonymous
  1268. * authentication method.
  1269. *
  1270. * Flags used when creating a #GDBusServer.
  1271. *
  1272. * Since: 2.26
  1273. */
  1274. typedef enum
  1275. {
  1276. G_DBUS_SERVER_FLAGS_NONE = 0,
  1277. G_DBUS_SERVER_FLAGS_RUN_IN_THREAD = (1<<0),
  1278. G_DBUS_SERVER_FLAGS_AUTHENTICATION_ALLOW_ANONYMOUS = (1<<1)
  1279. } GDBusServerFlags;
  1280. /**
  1281. * GDBusSignalFlags:
  1282. * @G_DBUS_SIGNAL_FLAGS_NONE: No flags set.
  1283. * @G_DBUS_SIGNAL_FLAGS_NO_MATCH_RULE: Don't actually send the AddMatch
  1284. * D-Bus call for this signal subscription. This gives you more control
  1285. * over which match rules you add (but you must add them manually).
  1286. * @G_DBUS_SIGNAL_FLAGS_MATCH_ARG0_NAMESPACE: Match first arguments that
  1287. * contain a bus or interface name with the given namespace.
  1288. * @G_DBUS_SIGNAL_FLAGS_MATCH_ARG0_PATH: Match first arguments that
  1289. * contain an object path that is either equivalent to the given path,
  1290. * or one of the paths is a subpath of the other.
  1291. *
  1292. * Flags used when subscribing to signals via g_dbus_connection_signal_subscribe().
  1293. *
  1294. * Since: 2.26
  1295. */
  1296. typedef enum /*< flags >*/
  1297. {
  1298. G_DBUS_SIGNAL_FLAGS_NONE = 0,
  1299. G_DBUS_SIGNAL_FLAGS_NO_MATCH_RULE = (1<<0),
  1300. G_DBUS_SIGNAL_FLAGS_MATCH_ARG0_NAMESPACE = (1<<1),
  1301. G_DBUS_SIGNAL_FLAGS_MATCH_ARG0_PATH = (1<<2)
  1302. } GDBusSignalFlags;
  1303. /**
  1304. * GDBusSendMessageFlags:
  1305. * @G_DBUS_SEND_MESSAGE_FLAGS_NONE: No flags set.
  1306. * @G_DBUS_SEND_MESSAGE_FLAGS_PRESERVE_SERIAL: Do not automatically
  1307. * assign a serial number from the #GDBusConnection object when
  1308. * sending a message.
  1309. *
  1310. * Flags used when sending #GDBusMessages on a #GDBusConnection.
  1311. *
  1312. * Since: 2.26
  1313. */
  1314. typedef enum
  1315. {
  1316. G_DBUS_SEND_MESSAGE_FLAGS_NONE = 0,
  1317. G_DBUS_SEND_MESSAGE_FLAGS_PRESERVE_SERIAL = (1<<0)
  1318. } GDBusSendMessageFlags;
  1319. /* (1<<31) is reserved for internal use by GDBusConnection, do not use it. */
  1320. /**
  1321. * GCredentialsType:
  1322. * @G_CREDENTIALS_TYPE_INVALID: Indicates an invalid native credential type.
  1323. * @G_CREDENTIALS_TYPE_LINUX_UCRED: The native credentials type is a struct ucred.
  1324. * @G_CREDENTIALS_TYPE_FREEBSD_CMSGCRED: The native credentials type is a struct cmsgcred.
  1325. * @G_CREDENTIALS_TYPE_OPENBSD_SOCKPEERCRED: The native credentials type is a struct sockpeercred. Added in 2.30.
  1326. * @G_CREDENTIALS_TYPE_SOLARIS_UCRED: The native credentials type is a ucred_t. Added in 2.40.
  1327. * @G_CREDENTIALS_TYPE_NETBSD_UNPCBID: The native credentials type is a struct unpcbid.
  1328. *
  1329. * Enumeration describing different kinds of native credential types.
  1330. *
  1331. * Since: 2.26
  1332. */
  1333. typedef enum
  1334. {
  1335. G_CREDENTIALS_TYPE_INVALID,
  1336. G_CREDENTIALS_TYPE_LINUX_UCRED,
  1337. G_CREDENTIALS_TYPE_FREEBSD_CMSGCRED,
  1338. G_CREDENTIALS_TYPE_OPENBSD_SOCKPEERCRED,
  1339. G_CREDENTIALS_TYPE_SOLARIS_UCRED,
  1340. G_CREDENTIALS_TYPE_NETBSD_UNPCBID
  1341. } GCredentialsType;
  1342. /**
  1343. * GDBusMessageByteOrder:
  1344. * @G_DBUS_MESSAGE_BYTE_ORDER_BIG_ENDIAN: The byte order is big endian.
  1345. * @G_DBUS_MESSAGE_BYTE_ORDER_LITTLE_ENDIAN: The byte order is little endian.
  1346. *
  1347. * Enumeration used to describe the byte order of a D-Bus message.
  1348. *
  1349. * Since: 2.26
  1350. */
  1351. typedef enum
  1352. {
  1353. G_DBUS_MESSAGE_BYTE_ORDER_BIG_ENDIAN = 'B',
  1354. G_DBUS_MESSAGE_BYTE_ORDER_LITTLE_ENDIAN = 'l'
  1355. } GDBusMessageByteOrder;
  1356. /**
  1357. * GApplicationFlags:
  1358. * @G_APPLICATION_FLAGS_NONE: Default
  1359. * @G_APPLICATION_IS_SERVICE: Run as a service. In this mode, registration
  1360. * fails if the service is already running, and the application
  1361. * will initially wait up to 10 seconds for an initial activation
  1362. * message to arrive.
  1363. * @G_APPLICATION_IS_LAUNCHER: Don't try to become the primary instance.
  1364. * @G_APPLICATION_HANDLES_OPEN: This application handles opening files (in
  1365. * the primary instance). Note that this flag only affects the default
  1366. * implementation of local_command_line(), and has no effect if
  1367. * %G_APPLICATION_HANDLES_COMMAND_LINE is given.
  1368. * See g_application_run() for details.
  1369. * @G_APPLICATION_HANDLES_COMMAND_LINE: This application handles command line
  1370. * arguments (in the primary instance). Note that this flag only affect
  1371. * the default implementation of local_command_line().
  1372. * See g_application_run() for details.
  1373. * @G_APPLICATION_SEND_ENVIRONMENT: Send the environment of the
  1374. * launching process to the primary instance. Set this flag if your
  1375. * application is expected to behave differently depending on certain
  1376. * environment variables. For instance, an editor might be expected
  1377. * to use the `GIT_COMMITTER_NAME` environment variable
  1378. * when editing a git commit message. The environment is available
  1379. * to the #GApplication::command-line signal handler, via
  1380. * g_application_command_line_getenv().
  1381. * @G_APPLICATION_NON_UNIQUE: Make no attempts to do any of the typical
  1382. * single-instance application negotiation, even if the application
  1383. * ID is given. The application neither attempts to become the
  1384. * owner of the application ID nor does it check if an existing
  1385. * owner already exists. Everything occurs in the local process.
  1386. * Since: 2.30.
  1387. * @G_APPLICATION_CAN_OVERRIDE_APP_ID: Allow users to override the
  1388. * application ID from the command line with `--gapplication-app-id`.
  1389. * Since: 2.48
  1390. *
  1391. * Flags used to define the behaviour of a #GApplication.
  1392. *
  1393. * Since: 2.28
  1394. **/
  1395. typedef enum
  1396. {
  1397. G_APPLICATION_FLAGS_NONE,
  1398. G_APPLICATION_IS_SERVICE = (1 << 0),
  1399. G_APPLICATION_IS_LAUNCHER = (1 << 1),
  1400. G_APPLICATION_HANDLES_OPEN = (1 << 2),
  1401. G_APPLICATION_HANDLES_COMMAND_LINE = (1 << 3),
  1402. G_APPLICATION_SEND_ENVIRONMENT = (1 << 4),
  1403. G_APPLICATION_NON_UNIQUE = (1 << 5),
  1404. G_APPLICATION_CAN_OVERRIDE_APP_ID = (1 << 6)
  1405. } GApplicationFlags;
  1406. /**
  1407. * GTlsError:
  1408. * @G_TLS_ERROR_UNAVAILABLE: No TLS provider is available
  1409. * @G_TLS_ERROR_MISC: Miscellaneous TLS error
  1410. * @G_TLS_ERROR_BAD_CERTIFICATE: A certificate could not be parsed
  1411. * @G_TLS_ERROR_NOT_TLS: The TLS handshake failed because the
  1412. * peer does not seem to be a TLS server.
  1413. * @G_TLS_ERROR_HANDSHAKE: The TLS handshake failed because the
  1414. * peer's certificate was not acceptable.
  1415. * @G_TLS_ERROR_CERTIFICATE_REQUIRED: The TLS handshake failed because
  1416. * the server requested a client-side certificate, but none was
  1417. * provided. See g_tls_connection_set_certificate().
  1418. * @G_TLS_ERROR_EOF: The TLS connection was closed without proper
  1419. * notice, which may indicate an attack. See
  1420. * g_tls_connection_set_require_close_notify().
  1421. *
  1422. * An error code used with %G_TLS_ERROR in a #GError returned from a
  1423. * TLS-related routine.
  1424. *
  1425. * Since: 2.28
  1426. */
  1427. typedef enum {
  1428. G_TLS_ERROR_UNAVAILABLE,
  1429. G_TLS_ERROR_MISC,
  1430. G_TLS_ERROR_BAD_CERTIFICATE,
  1431. G_TLS_ERROR_NOT_TLS,
  1432. G_TLS_ERROR_HANDSHAKE,
  1433. G_TLS_ERROR_CERTIFICATE_REQUIRED,
  1434. G_TLS_ERROR_EOF
  1435. } GTlsError;
  1436. /**
  1437. * GTlsCertificateFlags:
  1438. * @G_TLS_CERTIFICATE_UNKNOWN_CA: The signing certificate authority is
  1439. * not known.
  1440. * @G_TLS_CERTIFICATE_BAD_IDENTITY: The certificate does not match the
  1441. * expected identity of the site that it was retrieved from.
  1442. * @G_TLS_CERTIFICATE_NOT_ACTIVATED: The certificate's activation time
  1443. * is still in the future
  1444. * @G_TLS_CERTIFICATE_EXPIRED: The certificate has expired
  1445. * @G_TLS_CERTIFICATE_REVOKED: The certificate has been revoked
  1446. * according to the #GTlsConnection's certificate revocation list.
  1447. * @G_TLS_CERTIFICATE_INSECURE: The certificate's algorithm is
  1448. * considered insecure.
  1449. * @G_TLS_CERTIFICATE_GENERIC_ERROR: Some other error occurred validating
  1450. * the certificate
  1451. * @G_TLS_CERTIFICATE_VALIDATE_ALL: the combination of all of the above
  1452. * flags
  1453. *
  1454. * A set of flags describing TLS certification validation. This can be
  1455. * used to set which validation steps to perform (eg, with
  1456. * g_tls_client_connection_set_validation_flags()), or to describe why
  1457. * a particular certificate was rejected (eg, in
  1458. * #GTlsConnection::accept-certificate).
  1459. *
  1460. * Since: 2.28
  1461. */
  1462. typedef enum {
  1463. G_TLS_CERTIFICATE_UNKNOWN_CA = (1 << 0),
  1464. G_TLS_CERTIFICATE_BAD_IDENTITY = (1 << 1),
  1465. G_TLS_CERTIFICATE_NOT_ACTIVATED = (1 << 2),
  1466. G_TLS_CERTIFICATE_EXPIRED = (1 << 3),
  1467. G_TLS_CERTIFICATE_REVOKED = (1 << 4),
  1468. G_TLS_CERTIFICATE_INSECURE = (1 << 5),
  1469. G_TLS_CERTIFICATE_GENERIC_ERROR = (1 << 6),
  1470. G_TLS_CERTIFICATE_VALIDATE_ALL = 0x007f
  1471. } GTlsCertificateFlags;
  1472. /**
  1473. * GTlsAuthenticationMode:
  1474. * @G_TLS_AUTHENTICATION_NONE: client authentication not required
  1475. * @G_TLS_AUTHENTICATION_REQUESTED: client authentication is requested
  1476. * @G_TLS_AUTHENTICATION_REQUIRED: client authentication is required
  1477. *
  1478. * The client authentication mode for a #GTlsServerConnection.
  1479. *
  1480. * Since: 2.28
  1481. */
  1482. typedef enum {
  1483. G_TLS_AUTHENTICATION_NONE,
  1484. G_TLS_AUTHENTICATION_REQUESTED,
  1485. G_TLS_AUTHENTICATION_REQUIRED
  1486. } GTlsAuthenticationMode;
  1487. /**
  1488. * GTlsRehandshakeMode:
  1489. * @G_TLS_REHANDSHAKE_NEVER: Never allow rehandshaking
  1490. * @G_TLS_REHANDSHAKE_SAFELY: Allow safe rehandshaking only
  1491. * @G_TLS_REHANDSHAKE_UNSAFELY: Allow unsafe rehandshaking
  1492. *
  1493. * When to allow rehandshaking. See
  1494. * g_tls_connection_set_rehandshake_mode().
  1495. *
  1496. * Since: 2.28
  1497. */
  1498. typedef enum {
  1499. G_TLS_REHANDSHAKE_NEVER,
  1500. G_TLS_REHANDSHAKE_SAFELY,
  1501. G_TLS_REHANDSHAKE_UNSAFELY
  1502. } GTlsRehandshakeMode;
  1503. /**
  1504. * GTlsPasswordFlags:
  1505. * @G_TLS_PASSWORD_NONE: No flags
  1506. * @G_TLS_PASSWORD_RETRY: The password was wrong, and the user should retry.
  1507. * @G_TLS_PASSWORD_MANY_TRIES: Hint to the user that the password has been
  1508. * wrong many times, and the user may not have many chances left.
  1509. * @G_TLS_PASSWORD_FINAL_TRY: Hint to the user that this is the last try to get
  1510. * this password right.
  1511. *
  1512. * Various flags for the password.
  1513. *
  1514. * Since: 2.30
  1515. */
  1516. typedef enum _GTlsPasswordFlags
  1517. {
  1518. G_TLS_PASSWORD_NONE = 0,
  1519. G_TLS_PASSWORD_RETRY = 1 << 1,
  1520. G_TLS_PASSWORD_MANY_TRIES = 1 << 2,
  1521. G_TLS_PASSWORD_FINAL_TRY = 1 << 3
  1522. } GTlsPasswordFlags;
  1523. /**
  1524. * GTlsInteractionResult:
  1525. * @G_TLS_INTERACTION_UNHANDLED: The interaction was unhandled (i.e. not
  1526. * implemented).
  1527. * @G_TLS_INTERACTION_HANDLED: The interaction completed, and resulting data
  1528. * is available.
  1529. * @G_TLS_INTERACTION_FAILED: The interaction has failed, or was cancelled.
  1530. * and the operation should be aborted.
  1531. *
  1532. * #GTlsInteractionResult is returned by various functions in #GTlsInteraction
  1533. * when finishing an interaction request.
  1534. *
  1535. * Since: 2.30
  1536. */
  1537. typedef enum {
  1538. G_TLS_INTERACTION_UNHANDLED,
  1539. G_TLS_INTERACTION_HANDLED,
  1540. G_TLS_INTERACTION_FAILED
  1541. } GTlsInteractionResult;
  1542. /**
  1543. * GDBusInterfaceSkeletonFlags:
  1544. * @G_DBUS_INTERFACE_SKELETON_FLAGS_NONE: No flags set.
  1545. * @G_DBUS_INTERFACE_SKELETON_FLAGS_HANDLE_METHOD_INVOCATIONS_IN_THREAD: Each method invocation is handled in
  1546. * a thread dedicated to the invocation. This means that the method implementation can use blocking IO
  1547. * without blocking any other part of the process. It also means that the method implementation must
  1548. * use locking to access data structures used by other threads.
  1549. *
  1550. * Flags describing the behavior of a #GDBusInterfaceSkeleton instance.
  1551. *
  1552. * Since: 2.30
  1553. */
  1554. typedef enum
  1555. {
  1556. G_DBUS_INTERFACE_SKELETON_FLAGS_NONE = 0,
  1557. G_DBUS_INTERFACE_SKELETON_FLAGS_HANDLE_METHOD_INVOCATIONS_IN_THREAD = (1<<0)
  1558. } GDBusInterfaceSkeletonFlags;
  1559. /**
  1560. * GDBusObjectManagerClientFlags:
  1561. * @G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_NONE: No flags set.
  1562. * @G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_DO_NOT_AUTO_START: If not set and the
  1563. * manager is for a well-known name, then request the bus to launch
  1564. * an owner for the name if no-one owns the name. This flag can only
  1565. * be used in managers for well-known names.
  1566. *
  1567. * Flags used when constructing a #GDBusObjectManagerClient.
  1568. *
  1569. * Since: 2.30
  1570. */
  1571. typedef enum
  1572. {
  1573. G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_NONE = 0,
  1574. G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_DO_NOT_AUTO_START = (1<<0)
  1575. } GDBusObjectManagerClientFlags;
  1576. /**
  1577. * GTlsDatabaseVerifyFlags:
  1578. * @G_TLS_DATABASE_VERIFY_NONE: No verification flags
  1579. *
  1580. * Flags for g_tls_database_verify_chain().
  1581. *
  1582. * Since: 2.30
  1583. */
  1584. typedef enum /*< flags >*/ {
  1585. G_TLS_DATABASE_VERIFY_NONE = 0
  1586. } GTlsDatabaseVerifyFlags;
  1587. /**
  1588. * GTlsDatabaseLookupFlags:
  1589. * @G_TLS_DATABASE_LOOKUP_NONE: No lookup flags
  1590. * @G_TLS_DATABASE_LOOKUP_KEYPAIR: Restrict lookup to certificates that have
  1591. * a private key.
  1592. *
  1593. * Flags for g_tls_database_lookup_certificate_handle(),
  1594. * g_tls_database_lookup_certificate_issuer(),
  1595. * and g_tls_database_lookup_certificates_issued_by().
  1596. *
  1597. * Since: 2.30
  1598. */
  1599. typedef enum {
  1600. G_TLS_DATABASE_LOOKUP_NONE = 0,
  1601. G_TLS_DATABASE_LOOKUP_KEYPAIR = 1
  1602. } GTlsDatabaseLookupFlags;
  1603. /**
  1604. * GTlsCertificateRequestFlags:
  1605. * @G_TLS_CERTIFICATE_REQUEST_NONE: No flags
  1606. *
  1607. * Flags for g_tls_interaction_request_certificate(),
  1608. * g_tls_interaction_request_certificate_async(), and
  1609. * g_tls_interaction_invoke_request_certificate().
  1610. *
  1611. * Since: 2.40
  1612. */
  1613. typedef enum {
  1614. G_TLS_CERTIFICATE_REQUEST_NONE = 0
  1615. } GTlsCertificateRequestFlags;
  1616. /**
  1617. * GIOModuleScopeFlags:
  1618. * @G_IO_MODULE_SCOPE_NONE: No module scan flags
  1619. * @G_IO_MODULE_SCOPE_BLOCK_DUPLICATES: When using this scope to load or
  1620. * scan modules, automatically block a modules which has the same base
  1621. * basename as previously loaded module.
  1622. *
  1623. * Flags for use with g_io_module_scope_new().
  1624. *
  1625. * Since: 2.30
  1626. */
  1627. typedef enum {
  1628. G_IO_MODULE_SCOPE_NONE,
  1629. G_IO_MODULE_SCOPE_BLOCK_DUPLICATES
  1630. } GIOModuleScopeFlags;
  1631. /**
  1632. * GSocketClientEvent:
  1633. * @G_SOCKET_CLIENT_RESOLVING: The client is doing a DNS lookup.
  1634. * @G_SOCKET_CLIENT_RESOLVED: The client has completed a DNS lookup.
  1635. * @G_SOCKET_CLIENT_CONNECTING: The client is connecting to a remote
  1636. * host (either a proxy or the destination server).
  1637. * @G_SOCKET_CLIENT_CONNECTED: The client has connected to a remote
  1638. * host.
  1639. * @G_SOCKET_CLIENT_PROXY_NEGOTIATING: The client is negotiating
  1640. * with a proxy to connect to the destination server.
  1641. * @G_SOCKET_CLIENT_PROXY_NEGOTIATED: The client has negotiated
  1642. * with the proxy server.
  1643. * @G_SOCKET_CLIENT_TLS_HANDSHAKING: The client is performing a
  1644. * TLS handshake.
  1645. * @G_SOCKET_CLIENT_TLS_HANDSHAKED: The client has performed a
  1646. * TLS handshake.
  1647. * @G_SOCKET_CLIENT_COMPLETE: The client is done with a particular
  1648. * #GSocketConnectable.
  1649. *
  1650. * Describes an event occurring on a #GSocketClient. See the
  1651. * #GSocketClient::event signal for more details.
  1652. *
  1653. * Additional values may be added to this type in the future.
  1654. *
  1655. * Since: 2.32
  1656. */
  1657. typedef enum {
  1658. G_SOCKET_CLIENT_RESOLVING,
  1659. G_SOCKET_CLIENT_RESOLVED,
  1660. G_SOCKET_CLIENT_CONNECTING,
  1661. G_SOCKET_CLIENT_CONNECTED,
  1662. G_SOCKET_CLIENT_PROXY_NEGOTIATING,
  1663. G_SOCKET_CLIENT_PROXY_NEGOTIATED,
  1664. G_SOCKET_CLIENT_TLS_HANDSHAKING,
  1665. G_SOCKET_CLIENT_TLS_HANDSHAKED,
  1666. G_SOCKET_CLIENT_COMPLETE
  1667. } GSocketClientEvent;
  1668. /**
  1669. * GSocketListenerEvent:
  1670. * @G_SOCKET_LISTENER_BINDING: The listener is about to bind a socket.
  1671. * @G_SOCKET_LISTENER_BOUND: The listener has bound a socket.
  1672. * @G_SOCKET_LISTENER_LISTENING: The listener is about to start
  1673. * listening on this socket.
  1674. * @G_SOCKET_LISTENER_LISTENED: The listener is now listening on
  1675. * this socket.
  1676. *
  1677. * Describes an event occurring on a #GSocketListener. See the
  1678. * #GSocketListener::event signal for more details.
  1679. *
  1680. * Additional values may be added to this type in the future.
  1681. *
  1682. * Since: 2.46
  1683. */
  1684. typedef enum {
  1685. G_SOCKET_LISTENER_BINDING,
  1686. G_SOCKET_LISTENER_BOUND,
  1687. G_SOCKET_LISTENER_LISTENING,
  1688. G_SOCKET_LISTENER_LISTENED
  1689. } GSocketListenerEvent;
  1690. /**
  1691. * GTestDBusFlags:
  1692. * @G_TEST_DBUS_NONE: No flags.
  1693. *
  1694. * Flags to define future #GTestDBus behaviour.
  1695. *
  1696. * Since: 2.34
  1697. */
  1698. typedef enum /*< flags >*/ {
  1699. G_TEST_DBUS_NONE = 0
  1700. } GTestDBusFlags;
  1701. /**
  1702. * GSubprocessFlags:
  1703. * @G_SUBPROCESS_FLAGS_NONE: No flags.
  1704. * @G_SUBPROCESS_FLAGS_STDIN_PIPE: create a pipe for the stdin of the
  1705. * spawned process that can be accessed with
  1706. * g_subprocess_get_stdin_pipe().
  1707. * @G_SUBPROCESS_FLAGS_STDIN_INHERIT: stdin is inherited from the
  1708. * calling process.
  1709. * @G_SUBPROCESS_FLAGS_STDOUT_PIPE: create a pipe for the stdout of the
  1710. * spawned process that can be accessed with
  1711. * g_subprocess_get_stdout_pipe().
  1712. * @G_SUBPROCESS_FLAGS_STDOUT_SILENCE: silence the stdout of the spawned
  1713. * process (ie: redirect to /dev/null).
  1714. * @G_SUBPROCESS_FLAGS_STDERR_PIPE: create a pipe for the stderr of the
  1715. * spawned process that can be accessed with
  1716. * g_subprocess_get_stderr_pipe().
  1717. * @G_SUBPROCESS_FLAGS_STDERR_SILENCE: silence the stderr of the spawned
  1718. * process (ie: redirect to /dev/null).
  1719. * @G_SUBPROCESS_FLAGS_STDERR_MERGE: merge the stderr of the spawned
  1720. * process with whatever the stdout happens to be. This is a good way
  1721. * of directing both streams to a common log file, for example.
  1722. * @G_SUBPROCESS_FLAGS_INHERIT_FDS: spawned processes will inherit the
  1723. * file descriptors of their parent, unless those descriptors have
  1724. * been explicitly marked as close-on-exec. This flag has no effect
  1725. * over the "standard" file descriptors (stdin, stdout, stderr).
  1726. *
  1727. * Flags to define the behaviour of a #GSubprocess.
  1728. *
  1729. * Note that the default for stdin is to redirect from /dev/null. For
  1730. * stdout and stderr the default are for them to inherit the
  1731. * corresponding descriptor from the calling process.
  1732. *
  1733. * Note that it is a programmer error to mix 'incompatible' flags. For
  1734. * example, you may not request both %G_SUBPROCESS_FLAGS_STDOUT_PIPE and
  1735. * %G_SUBPROCESS_FLAGS_STDOUT_SILENCE.
  1736. *
  1737. * Since: 2.40
  1738. **/
  1739. typedef enum {
  1740. G_SUBPROCESS_FLAGS_NONE = 0,
  1741. G_SUBPROCESS_FLAGS_STDIN_PIPE = (1u << 0),
  1742. G_SUBPROCESS_FLAGS_STDIN_INHERIT = (1u << 1),
  1743. G_SUBPROCESS_FLAGS_STDOUT_PIPE = (1u << 2),
  1744. G_SUBPROCESS_FLAGS_STDOUT_SILENCE = (1u << 3),
  1745. G_SUBPROCESS_FLAGS_STDERR_PIPE = (1u << 4),
  1746. G_SUBPROCESS_FLAGS_STDERR_SILENCE = (1u << 5),
  1747. G_SUBPROCESS_FLAGS_STDERR_MERGE = (1u << 6),
  1748. G_SUBPROCESS_FLAGS_INHERIT_FDS = (1u << 7)
  1749. } GSubprocessFlags;
  1750. /**
  1751. * GNotificationPriority:
  1752. * @G_NOTIFICATION_PRIORITY_LOW: for notifications that do not require
  1753. * immediate attention - typically used for contextual background
  1754. * information, such as contact birthdays or local weather
  1755. * @G_NOTIFICATION_PRIORITY_NORMAL: the default priority, to be used for the
  1756. * majority of notifications (for example email messages, software updates,
  1757. * completed download/sync operations)
  1758. * @G_NOTIFICATION_PRIORITY_HIGH: for events that require more attention,
  1759. * usually because responses are time-sensitive (for example chat and SMS
  1760. * messages or alarms)
  1761. * @G_NOTIFICATION_PRIORITY_URGENT: for urgent notifications, or notifications
  1762. * that require a response in a short space of time (for example phone calls
  1763. * or emergency warnings)
  1764. *
  1765. * Priority levels for #GNotifications.
  1766. *
  1767. * Since: 2.42
  1768. */
  1769. typedef enum {
  1770. G_NOTIFICATION_PRIORITY_NORMAL,
  1771. G_NOTIFICATION_PRIORITY_LOW,
  1772. G_NOTIFICATION_PRIORITY_HIGH,
  1773. G_NOTIFICATION_PRIORITY_URGENT
  1774. } GNotificationPriority;
  1775. /**
  1776. * GNetworkConnectivity:
  1777. * @G_NETWORK_CONNECTIVITY_LOCAL: The host is not configured with a
  1778. * route to the Internet; it may or may not be connected to a local
  1779. * network.
  1780. * @G_NETWORK_CONNECTIVITY_LIMITED: The host is connected to a network, but
  1781. * does not appear to be able to reach the full Internet, perhaps
  1782. * due to upstream network problems.
  1783. * @G_NETWORK_CONNECTIVITY_PORTAL: The host is behind a captive portal and
  1784. * cannot reach the full Internet.
  1785. * @G_NETWORK_CONNECTIVITY_FULL: The host is connected to a network, and
  1786. * appears to be able to reach the full Internet.
  1787. *
  1788. * The host's network connectivity state, as reported by #GNetworkMonitor.
  1789. *
  1790. * Since: 2.44
  1791. */
  1792. typedef enum {
  1793. G_NETWORK_CONNECTIVITY_LOCAL = 1,
  1794. G_NETWORK_CONNECTIVITY_LIMITED = 2,
  1795. G_NETWORK_CONNECTIVITY_PORTAL = 3,
  1796. G_NETWORK_CONNECTIVITY_FULL = 4
  1797. } GNetworkConnectivity;
  1798. G_END_DECLS
  1799. #endif /* __GIO_ENUMS_H__ */