gioenums.h 74 KB

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