! B X      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghij k l m n o p q r!s!t!u!v!w!x!y!z!{!|!}!~"""""""""""""""""""""""""""""""""""""""""""#############$$$$$$$$$$$$$$$$$$$$$$$$$%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%&&&&&&' ' ' ' ' '(()))))*********** +!+"+#+$,%,&,',(,),*,+,,,-,.,/,0,1,2,3,4-5-6-7-8-9-:-;-<-=->-?-@-A-B-C.D.E.F.G.H.I.J.K.L.M.N.O/P/Q/R/S/T/U/V/W/X/Y/Z/[/\/]/^/_/`/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u/v/w0x0y1z1{1|1}1~1112222222222222233444444444444556677888888888888888888899::::::::::::::;;<<==>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> > > > > >>>>>>>>>>>>>>>>>>> >!>">#>$>%>&>'>(>)>*>+>,>->.>/>0>1>2>3>4>5>6>7>8>9>:>;><>=>>>?>@>A>B>C>D>E>F>G>H>I>J>K>L>M>N>O>P>Q>R>S>T>U>V>W>X>Y>Z>[>\>]>^>_>`>a>b>c>d>e>f>g>h>i>j>k>l>m>n>o>p>q>r>s>t>u>v>w>x>y>z>{>|>}>~>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>77777777777777777777777777777?????????????????????????????????????????????? ? ? ? ?  !"#$%&'(@)@*@+@,@-@.@/@0@1@2@3@4@5@6@7@8@9@:@;@<@=@>@?@@@A@B@C@D@E@F@G@H@I@J@K@L@M@N@O@P@Q@R@S@T@U@V@W@X@Y@Z@[@\@]@^@_@`@a@b@c@d@e@f@g@h@i@j@k@l@m@n@o@p@q@r@s@t@u@v@w@x@y@z@{@|@}@~@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ @ @ @ @@@@@@@@@@@@@@@@@@@ @!@"@#@$@%@&@'@(@)@*@+@,@-@.@/@0@1@2@3@4@5@6@7@8@9@:@;@<@=@>@?@@@A@B@C@D@E@F@G@H@I@J@K@L@M@N@O@P@Q@R@S@T@U@V@W@X@Y@Z@[@\@]@^@_@`@a@b@c@d@e@f@g@h@i@j@k@l@m@n@o@p@q@r@s@t@u@v@w@x@y@z@{@|@}@~@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ @ @ @ @@@@@@@@@@@@@@@@@@@ @!@"@#@$@%@&@'@(@)@*@+@,@-@.@/@0@1@2@3@4@5@6@7@8@9@:@;@<@=@>@?@@@A@B@C@D@E@F@G@H@I@J@K@L@M@N@O@P@Q@R@S@T@U@V@W@X@Y@Z@[@\@]@^@_@`@a@b@c@d@e@f@g@h@i@j@k@l@m@n@o@p@q@r@s@t@u@v@w@x@y@z@{@|@}@~@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ @ @ @ @@@@@@@@@@@@@@@@@@@ ;!;";#;$;%;&;';(;);*;+;,;-;.;/;0;1;2;3;4;5;6;7;8;9;:;;;<;=;>;?;@;A;B;C;D;E;FAGAHAIAJAKALAMANAOAPAQBRBSBTBUBVBWBXBYBZB[B\B]B^B_B`BaBbBcBdBeBfBgBhBiBjBkBlBmBnBoBpBqBrBsBtBuBvBwBxByBzB{B|B}B~BBBBBBBBBBBBBBBBBBBBBCCCCCCCCCCCCCDDDDDDDDDDDDDDDDDD            EEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEE E E E E EEEEEEEEEEEEEEEEEEE E!E"E#E$E%E&E'E(E)E*E+E,E-E.E/E0E1E2E3E4E5E6E7E8E9E:E;E<E=E>E?E@EAEBECEDEEEFEGEHEIEJEKELEMENEOEPEQERESFTFUFVFWFXFYFZF[F\F]F^F_F`FaFbFcFdFeFfFgFhFiFjFkFlFmFnFoFpFqFrFsFtFuFvFwFxFyFzF{F|F}F~FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F !F "F #F $F %F &F 'F (F )F *F +F ,F -F .F /F 0F 1F 2F 3F 4F 5F 6F 7F 8F 9F :F ;F <F =F >F ?F @F AF BF CF DF EF FF GF HF IF JF KF LF MF NF OF PF QF RF SF TF UF VF WF XF YF ZF [F \F ]F ^F _F `F aF bF cF dF eF fF gF hF iF jF kF lF mF nF oF pF qF rF sF tF uF vF wF xF yF zF {F |F }F ~F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F !F "F #F $F %F &F 'F (F )F *F +F ,F -F .F /F 0F 1F 2F 3F 4F 5F 6F 7F 8F 9F :F ;F <F =F >F ?F @F AF BF CF DF EF FF GF HF IF JF KF LF MF NF OF PF QF RF SF TF UF VF WF XF YF ZF [F \F ]G ^G _G `G aG bG cG dG eG fG gG hG iG jG kG lG mG nG oG pG qG rG sG tG uG vG wG xG yG zG {G |G }G ~G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G !G "G #G $G %G &G 'G (G )G *G +G ,G -G .G /G 0G 1G 2G 3G 4G 5G 6G 7G 8G 9G :G ;G <G =G >G ?G @G AG BG CG DG EG FG GG HG IG JG KG LG MG NG OG PG QG RG SG TG UG VG WG XG YG ZG [G \G ]G ^G _G `G aG bG cG dG eG fG gG hG iG jG kG lG mG nG oG pG qG rG sG tG uG vG wG xG yG zG {G |G }G ~G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = < < < < < < < < < < < < < < < < < < < < < < < 9 9 9 9 9 !9 "9 #9 $9 %9 &9 '9 (6 )6 *6 +6 ,6 -6 .6 /6 06 16 26 36 46 56 66 76 86 96 :6 ;6 <6 =6 >5 ?5 @5 A5 B5 C5 D5 E5 F5 G3 H3 I3 J3 K3 L3 M3 N3 O3 P3 Q3 R3 S3 T3 U3 V3 W3 X3 Y3 Z3 [3 \3 ]3 ^3 _3 `3 a3 b3 c3 d3 e3 f3 g3 h3 i3 j3 k3 l3 m3 n3 o3 p3 q3 r3 s3 t3 u3 v3 w3 x3 y3 z3 {3 |0 }0 ~0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( H H H H H H H H H H H H H H H H H H H H H H H H H H H H H H                                               I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I !I "I #I $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ;J <J =J >J ?J @J AJ BJ CJ DJ EJ FJ GJ HJ IJ JJ KJ LJ MJ NJ OJ PJ QJ RJ SJ TJ UJ VK WKN7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a  struct initialized to zero.    7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero." !"#$%&'()*+,-./01  !"#$%&'()*+,-./ ,-+)*./"#$% !(&'! !"#$%&'()*+,-./017Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^4 Construct a 2 struct initialized to zero.6.Frees the resources allocated to a mutex with 7.(This function should not be used with a 2$ that has been statically allocated.Calling 60 on a locked mutex leads to undefined behaviour. Sine: 2.327 Initializes a 2 so that it can be used.This function is useful to initialize a mutex that has been allocated on the stack, or as part of a larger structure. It is not necessary to initialize a mutex that has been statically allocated.C code i typedef struct { GMutex m; ... } Blob; Blob *b; b = g_new (Blob, 1); g_mutex_init (&b->m);To undo the effect of 7' when a mutex is no longer needed, use 6.Calling 7 on an already initialized 2 leads to undefined behaviour.8Locks mutex. If mutexJ is already locked by another thread, the current thread will block until mutex! is unlocked by the other thread.2R is neither guaranteed to be recursive nor to be non-recursive. As such, calling 8 on a 2y that has already been locked by the same thread results in undefined behaviour (including but not limited to deadlocks).9Tries to lock mutex. If mutex= is already locked by another thread, it immediately returns  X. Otherwise it locks mutex and returns  Y.2R is neither guaranteed to be recursive nor to be non-recursive. As such, calling 8 on a 2 that has already been locked by the same thread results in undefined behaviour (including but not limited to deadlocks or arbitrary return values).:Unlocks mutex$. If another thread is blocked in a 8 call for mutex(, it will become unblocked and can lock mutex itself.Calling :R on a mutex that is not locked by the current thread leads to undefined behaviour.23 Z [ \ ] ^456mutex: an initialized 2 7mutex: an uninitialized 2 8mutex: a 2 9mutex: a 2 Returns:  Y if mutex could be locked :mutex: a 2 ;< 23456789: 23456789:23 Z [ \ ] ^456789:;<7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^@Creates a new =+ corresponding to the type string given by  typeString. It is appropriate to call J on the return value.QIt is a programmer error to call this function with an invalid type string. Use GL if you are unsure.AFConstructs the type corresponding to an array of elements of the type type.It is appropriate to call J on the return value.BKConstructs the type corresponding to a dictionary entry with a key of type key and a value of type value.It is appropriate to call J on the return value.CFConstructs the type corresponding to a maybe instance containing type type or Nothing.It is appropriate to call J on the return value.D"Constructs a new tuple type, from items.length is the number of items in items, or -1 to indicate that items is  _ -terminated.It is appropriate to call J on the return value.EMakes a copy of a =. It is appropriate to call J on the return value. type may not be  _.FCReturns a newly-allocated copy of the type string corresponding to typeE. The returned string is nul-terminated. It is appropriate to call GM on the return value.G6Determines the element type of an array or maybe type.9This function may only be used with array or maybe types.H Compares type1 and type2 for equality. Only returns  Yk if the types are exactly equal. Even if one type is an indefinite type and the other is a subtype of it,  XY will be returned if they are not exactly equal. If you want to check for subtypes, use S.The argument types of type1 and type2 are only  gconstpointer to allow use with NO@ without function pointer casting. For both arguments, a valid = must be provided.ICDetermines the first item type of a tuple or dictionary entry type.vThis function may only be used with tuple or dictionary entry types, but must not be used with the generic tuple type G_VARIANT_TYPE_TUPLE.IIn the case of a dictionary entry type, this returns the type of the key. _ is returned in case of type being G_VARIANT_TYPE_UNIT.This call, together with XF provides an iterator interface over tuple and dictionary entry types.JFrees a = that was allocated with E, @4 or one of the container type constructor functions.In the case that type is  _, this function does nothing. Since 2.24KAReturns the length of the type string corresponding to the given type]. This function must be used to determine the valid extent of the memory region returned by g_variant_type_peek_string().LHashes type.The argument type of type is only  gconstpointer to allow use with NO, without function pointer casting. A valid = must be provided.MDetermines if the given type8 is an array type. This is true if the type string for type starts with an 'a'.This function returns  YN for any indefinite type for which every definite subtype is an array type -- G_VARIANT_TYPE_ARRAY, for example.NDetermines if the given type is a basic type.YBasic types are booleans, bytes, integers, doubles, strings, object paths and signatures.?Only a basic type may be used as the key of a dictionary entry.This function returns  X! for all indefinite types except G_VARIANT_TYPE_BASIC.ODetermines if the given type is a container type.]Container types are any array, maybe, tuple, or dictionary entry types plus the variant type.This function returns  YL for any indefinite type for which every definite subtype is a container -- G_VARIANT_TYPE_ARRAY, for example.PDetermines if the given type" is definite (ie: not indefinite).iA type is definite if its type string does not contain any indefinite type characters ('*', '?', or 'r').A  `U instance may not have an indefinite type, so calling this function on the result of PQ will always result in  YC being returned. Calling this function on an indefinite type like G_VARIANT_TYPE_ARRAY, however, will result in  X being returned.QDetermines if the given typeB is a dictionary entry type. This is true if the type string for type starts with a '{'.This function returns  YX for any indefinite type for which every definite subtype is a dictionary entry type -- G_VARIANT_TYPE_DICT_ENTRY, for example.RDetermines if the given type7 is a maybe type. This is true if the type string for type starts with an 'm'.This function returns  YM for any indefinite type for which every definite subtype is a maybe type -- G_VARIANT_TYPE_MAYBE, for example.S Checks if type is a subtype of  supertype.This function returns  Y if type is a subtype of  supertypet. All types are considered to be subtypes of themselves. Aside from that, only indefinite types can have subtypes.TDetermines if the given type7 is a tuple type. This is true if the type string for type starts with a '(' or if type is G_VARIANT_TYPE_TUPLE.This function returns  YM for any indefinite type for which every definite subtype is a tuple type -- G_VARIANT_TYPE_TUPLE, for example.UDetermines if the given type is the variant type.V3Determines the key type of a dictionary entry type.This function may only be used with a dictionary entry type. Other than the additional restriction, this call is equivalent to I.WMDetermines the number of items contained in a tuple or dictionary entry type.vThis function may only be used with tuple or dictionary entry types, but must not be used with the generic tuple type G_VARIANT_TYPE_TUPLE.KIn the case of a dictionary entry type, this function will always return 2.XBDetermines the next item type of a tuple or dictionary entry type.type* must be the result of a previous call to I or X.If called on the key type of a dictionary entry then this call returns the value type. If called on the value type of a dictionary entry then this call returns  _. For tuples,  _ is returned when type is the last item in a tuple.Y5Determines the value type of a dictionary entry type.<This function may only be used with a dictionary entry type.Z3No description available in the introspection data.[ Checks if  typeStringF is a valid GVariant type string. This call is equivalent to calling GRA and confirming that the following character is a nul terminator.\=Scan for a single complete and valid GVariant type string in string. The memory pointed to by limit( (or bytes beyond it) is never accessed.!If a valid type string is found, endptrZ is updated to point to the first character past the end of the string that was found and  Y is returned.-If there is no valid type string starting at string,, or if the type string does not end before limit then  X is returned.HFor the simple case of checking if a string is a valid type string, see GL.?=> a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~?@ typeString: a valid GVariant type string Returns: a new = Aelement: a = Returns: a new array = Since 2.24 Bkey : a basic = value: a = Returns: a new dictionary entry = Since 2.24 Celement: a = Returns: a new maybe = Since 2.24 Ditems: an array of  GVariantTypes, one for each item Returns: a new tuple = Since 2.24 Etype: a = Returns: a new = Since 2.24 Ftype: a = Returns: the corresponding type string Since 2.24 Gtype: an array or maybe = Returns: the element type of type Since 2.24 Htype1: a = type2: a = Returns:  Y if type1 and type2 are exactly equal Since 2.24 Itype: a tuple or dictionary entry = Returns: the first item type of type, or  _ Since 2.24 Jtype: a =, or  _ Ktype: a = Returns:, the length of the corresponding type string Since 2.24 Ltype: a = Returns: the hash value Since 2.24 Mtype: a = Returns:  Y if type is an array type Since 2.24 Ntype: a = Returns:  Y if type is a basic type Since 2.24 Otype: a = Returns:  Y if type is a container type Since 2.24 Ptype: a = Returns:  Y if type is definite Since 2.24 Qtype: a = Returns:  Y if type is a dictionary entry type Since 2.24 Rtype: a = Returns:  Y if type is a maybe type Since 2.24 Stype: a =  supertype: a = Returns:  Y if type is a subtype of  supertype Since 2.24 Ttype: a = Returns:  Y if type is a tuple type Since 2.24 Utype: a = Returns:  Y if type is the variant type Since 2.24 Vtype: a dictionary entry = Returns:% the key type of the dictionary entry Since 2.24 Wtype: a tuple or dictionary entry = Returns: the number of items in type Since 2.24 Xtype: a = from a previous call Returns: the next = after type, or  _ Since 2.24 Ytype: a dictionary entry = Returns:' the value type of the dictionary entry Since 2.24 Z[ typeString: a pointer to any string Returns:  Y if  typeString! is exactly one valid type string Since 2.24 \string: a pointer to any string limit : the end of string, or  _ Returns:  Y" if a valid type string was found ] =>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\ =>?ZEFGHIJKLMNOPQRSTUVW@ABCDX[\Y>=> a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ a( Allocates and initialises a new ^.You should call ip on the return value when it is no longer needed. The memory will not be automatically freed by any other call.*In some cases it may be easier to place a ^F directly on the stack of the calling function and initialise it with g_variant_dict_init()2. This is particularly useful when you are using ^ to construct a  `.b(&Releases all memory associated with a ^ without freeing the ^ structure itself.>It typically only makes sense to do this on a stack-allocated ^i if you want to abort building the value part-way through. This function need not be called if you call dW and it also doesn't need to be called on dicts allocated with g_variant_dict_new (see i for that).;It is valid to call this function on either an initialised ^: or one that was previously cleared by an earlier call to bC but it is not valid to call this function on uninitialised memory.c( Checks if key exists in dict.d(Returns the current value of dict as a  ` of type G_VARIANT_TYPE_VARDICT, clearing it in the process.It is not permissible to use dictf in any way after this call except for reference counting operations (in the case of a heap-allocated ^) or by reinitialising it with g_variant_dict_init()" (in the case of stack-allocated).e(!Inserts (or replaces) a key in a ^.value is consumed if it is floating.f(Looks up a value in a ^.If key is not found in  dictionary,  _ is returned.The  expectedTypeO string specifies what type of value is expected. If the value associated with key has a different type then  _ is returned.LIf the key is found and the value has the correct type, it is returned. If  expectedType was specified then any non- _" return value will have this type.g(!Increases the reference count on dict.#Don't call this on stack-allocated ^% instances or bad things will happen.h(.Removes a key and its associated value from a ^.i(!Decreases the reference count on dict.XIn the event that there are no more references, releases all memory associated with the ^.#Don't call this on stack-allocated ^% instances or bad things will happen.^_  `afromAsv: the  `+ with which to initialise the dictionary Returns: a ^ bdict: a ^ cdict: a ^ key&: the key to lookup in the dictionary Returns:  Y if key is in dict ddict: a ^ Returns: a new, floating,  ` edict: a ^ key : the key to insert a value for value: the value to insert fdict: a ^ key&: the key to lookup in the dictionary  expectedType: a S, or  _ Returns:% the value of the dictionary key, or  _ gdict: a heap-allocated ^ Returns: a new reference to dict hdict: a ^ key: the key to remove Returns:  Y" if the key was found and removed idict: a heap-allocated ^ j ^_`abcdefghi ^_`bcdefaghi^_  `abcdefghij7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^n Allocates and initialises a new k.You should call tp on the return value when it is no longer needed. The memory will not be automatically freed by any other call.&In most cases it is easier to place a kF directly on the stack of the calling function and initialise it with g_variant_builder_init().oAdds value to builder.It is an error to call this function in any way that would create an inconsistent value to be constructed. Some examples of this are putting different types of items into an array, putting the wrong types or number of items in a tuple, putting more than one value into a variant, etc.If value is a floating reference (see PT), the builder instance takes ownership of value.p)Closes the subcontainer inside the given builder, that was opened by the most recent call to r.It is an error to call this function in any way that would create an inconsistent value to be constructed (ie: too few values added to the subcontainer).q;Ends the builder process and returns the constructed value.It is not permissible to use builderf in any way after this call except for reference counting operations (in the case of a heap-allocated k) or by reinitialising it with g_variant_builder_init()m (in the case of stack-allocated). This means that for the stack-allocated builders there is no need to call g_variant_builder_clear() after the call to q.It is an error to call this function in any way that would create an inconsistent value to be constructed (ie: insufficient number of items added to a container with a specific number of children required). It is also an error to call this function if the builder was created with an indefinite array or maybe type and no children have been added; in this case it is impossible to infer the type of the empty array.r&Opens a subcontainer inside the given builder/. When done adding items to the subcontainer, p must be called.It is an error to call this function in any way that would cause an inconsistent value to be constructed (ie: adding too many values or a value of an incorrect type).s!Increases the reference count on builder.#Don't call this on stack-allocated k% instances or bad things will happen.t!Decreases the reference count on builder.XIn the event that there are no more references, releases all memory associated with the k.#Don't call this on stack-allocated k% instances or bad things will happen.kl mntype: a container type Returns: a k obuilder: a k value: a  ` pbuilder: a k qbuilder: a k Returns: a new, floating,  ` rbuilder: a k type: a S sbuilder: a k allocated by n Returns: a new reference to builder tbuilder: a k allocated by n u klmnopqrst klmopqnrstkl mnopqrstu7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ y%Removes all keys and values from the v and decreases its reference count by one. If keys and/or values are dynamically allocated, you should either free them first or create the v using g_tree_new_full()t. In the latter case the destroy functions you supplied will be called on all keys and values before destroying the v.zGets the height of a v.If the v, contains no nodes, the height is 0. If the va contains only one root node the height is 1. If the root node has children the height is 2, etc.{ Inserts a key/value pair into a v.'If the given key already exists in the vD its corresponding value is set to the new value. If you supplied a valueDestroyFunc when creating the v@, the old value is freed using that function. If you supplied a keyDestroyFunc when creating the v., the passed key is freed using that function.The tree is automatically 'balanced' as new key/value pairs are added, so that the distance from the root to every leaf is as small as possible.|7Gets the value corresponding to the given key. Since a v is automatically balanced as key/value pairs are added, key lookup is O(log n) (where n is the number of key/value pairs in the tree).}Looks up a key in the v, returning the original key and the associated value. This is useful if you need to free the memory allocated for the original key, for example before calling .~Gets the number of nodes in a v. Removes a key/value pair from a v.If the v was created using g_tree_new_full(), the key and value are freed using the supplied destroy functions, otherwise you have to make sure that any dynamically allocated values are freed yourself. If the key does not exist in the v, the function does nothing.#Inserts a new key and value into a v similar to {:. The difference is that if the key already exists in the v5, it gets replaced by the new key. If you supplied a valueDestroyFunc when creating the v@, the old value is freed using that function. If you supplied a keyDestroyFunc when creating the v+, the old key is freed using that function.The tree is automatically 'balanced' as new key/value pairs are added, so that the distance from the root to every leaf is as small as possible..Removes a key and its associated value from a v5 without calling the key and value destroy functions.!If the key does not exist in the v, the function does nothing."Decrements the reference count of tree by one. If the reference count drops to 0, all keys and values will be destroyed (if destroy functions were specified) and all memory allocated by tree will be released.1It is safe to call this function from any thread.vw xytree: a v ztree: a v Returns: the height of tree {tree: a v key: the key to insert value%: the value corresponding to the key |tree: a v key: the key to look up Returns:( the value corresponding to the key, or  _ if the key was not found }tree: a v  lookupKey: the key to look up origKey: returns the original key value,: returns the value associated with the key Returns:  Y if the key was found in the v ~tree: a v Returns: the number of nodes in tree tree: a v key: the key to remove Returns:  YI if the key was found (prior to 2.8, this function returned nothing) tree: a v key: the key to insert value%: the value corresponding to the key tree: a v key: the key to remove Returns:  YI if the key was found (prior to 2.8, this function returned nothing) tree: a v vwxyz{|}~ vwxyz{|}~vw xyz{|}~ 7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.Returns the height of a .lNote that execution of this function is of O(N) complexity where N denotes the number of items on the stack.$Returns the element at the top of a  which may be  _.Pops a piece of memory off a . Pushes a piece of memory onto a . stackP: a  Returns: the height of the stack stackP: a  Returns:% the element at the top of the stack stackP: a  Returns:% the element at the top of the stack stackP: a  dataP+: the piece of memory to push on the stack  7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^6Resumes a timer that has previously been stopped with . + must be called before using this function./Destroys a timer, freeing associated resources.If timerT has been started but not stopped, obtains the time since the timer was started. If timer has been stopped, obtains the elapsed time between the time it was started and the time it was stopped. The return value is the number of seconds elapsed, including any fractional part. The  microseconds& out parameter is essentially useless.,This function is useless; it's fine to call 9 on an already-started timer to reset the start time, so  serves no purpose.,Marks a start time, so that future calls to  will report the time since  was called.  g_timer_new()8 automatically marks the start time, so no need to call & immediately after creating the timer.Marks an end time, so calls to E will return the difference between this end time and the start time. timer: a . timer: a  to destroy. timer: a .  microseconds: return location for the fractional part of seconds elapsed, in microseconds (that is, the total number of microseconds elapsed, modulo 1000000), or  _ Returns:T seconds elapsed as a floating point value, including any fractional part. timer: a . timer: a . timer: a .  7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Waits until thread finishes, i.e. the function func, as given to g_thread_new() , returns or GU is called. If thread has already terminated, then  returns immediately.4Any thread can wait for any other thread by calling ", not just its 'creator'. Calling $ from multiple threads for the same thread leads to undefined behaviour.The value returned by func or given to GU is returned by this function.) consumes the reference to the passed-in thread. This will usually cause the 2 struct and associated resources to be freed. Use O to obtain an extra reference if you want to keep the GThread alive beyond the  call.  Increase the reference count on thread.  Decrease the reference count on thread4, possibly freeing all resources associated with it./Note that each thread holds a reference to its b while it is running, so it is safe to drop your own reference to it if you don't need it anymore.3No description available in the introspection data.Terminates the current thread.*If another thread is waiting for us using 2 then the waiting thread will be woken up and get retval as the return value of .Calling GU with a parameter retval is equivalent to returning retval from the function func, as given to g_thread_new().You must only call GU. from a thread that you created yourself with g_thread_new(){ or related APIs. You must not call this function from a thread created with another threading library or or from within a JV.This function returns the { corresponding to the current thread. Note that this function does not increase the reference count of the returned struct.This function will return a  even for threads that were not created by GLib (i.e. those created by other threading APIs). This may be useful for thread identification purposes (i.e. comparisons) but you must not use GLib functions (such as ) on these threads.[Causes the calling thread to voluntarily relinquish the CPU, so that other threads can run.DThis function is often used as a method to make busy wait less evil. thread: a  Returns: the return value of the thread thread: a  Returns: a new reference to thread thread: a  retval": the return value of this thread Returns: the ! representing the current thread  7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.TInternal function for gtester to free test log messages, no ABI guarantees provided.VInternal function for gtester to decode test log messages, no ABI guarantees provided.   7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^'Frees all strings contained within the . After calling L it is not safe to access any of the strings which were contained within it."Frees all memory allocated by the . After calling L it is not safe to access any of the strings which were contained within it.Adds a copy of string to the <. It returns a pointer to the new copy of the string in the . The characters in the string can be changed, if necessary, though you should not change anything after the end of the string.Unlike G, this function does not check for duplicates. Also strings added with  will not be searched by  when looking for duplicates.Adds a copy of string to the 7, unless the same string has already been added to the  with . This function is useful if you need to copy a large number of strings but do not want to waste space storing duplicates. But you must remember that there may be several pointers to the same string, and so any changes made to the strings should be done very carefully. Note that 2 will not return a pointer to a string added with , even if they do match.Adds a copy of the first len bytes of string to the . The copy is nul-terminated.aSince this function does not stop at nul bytes, it is the caller's responsibility to ensure that string has at least len addressable bytes.The characters in the returned string can be changed, if necessary, though you should not change anything after the end of the string. chunk: a  chunk: a  chunk: a  string: the string to add Returns: a pointer to the copy of string within the  chunk: a  string: the string to add Returns:* a pointer to the new or existing copy of string within the  chunk: a  string: bytes to insert len: number of bytes of string8 to insert, or -1 to insert a nul-terminated string Returns: a pointer to the copy of string within the    7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.>     <     <     =     7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.8Frees the resources allocated to a recursive mutex with .(This function should not be used with a $ that has been statically allocated.Calling : on a locked recursive mutex leads to undefined behaviour. Sine: 2.32 Initializes a  so that it can be used.This function is useful to initialize a recursive mutex that has been allocated on the stack, or as part of a larger structure.WIt is not necessary to initialise a recursive mutex that has been statically allocated.C code p typedef struct { GRecMutex m; ... } Blob; Blob *b; b = g_new (Blob, 1); g_rec_mutex_init (&b->m);Calling  on an already initialized  leads to undefined behaviour.To undo the effect of 1 when a recursive mutex is no longer needed, use . Locks recMutex. If recMutexJ is already locked by another thread, the current thread will block until recMutex% is unlocked by the other thread. If recMutex> is already locked by the current thread, the 'lock count' of recMutexr is increased. The mutex will only become available again when it is unlocked as many times as it has been locked. Tries to lock recMutex. If recMutex= is already locked by another thread, it immediately returns  X. Otherwise it locks recMutex and returns  Y. Unlocks recMutex$. If another thread is blocked in a  call for recMutex(, it will become unblocked and can lock recMutex itself.Calling \ on a recursive mutex that is not locked by the current thread leads to undefined behaviour. recMutex: an initialized  recMutex: an uninitialized  recMutex: a  recMutex: a  Returns:  Y if recMutex could be locked recMutex: a   !    !7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^%Returns the next random gdouble from rand_+ equally distributed over the range [0..1).&Returns the next random gdouble from rand_% equally distributed over the range [begin..end).'#Frees the memory allocated for the ".(Returns the next random guint32 from rand_0 equally distributed over the range [0..2^32-1].)Returns the next random gint32 from rand_% equally distributed over the range [begin..end-1].*.Sets the seed for the random number generator " to seed.+Initializes the random number generator by an array of longs. Array can be of arbitrary size, though only the first 624 values are taken. This function is useful if you have many low entropy seeds, or if you require more then 32 bits of actual entropy for your application."# $%rand_: a " Returns: a random number &rand_: a " begin%: lower closed bound of the interval end#: upper open bound of the interval Returns: a random number 'rand_: a " (rand_: a " Returns: a random number )rand_: a " begin%: lower closed bound of the interval end#: upper open bound of the interval Returns: a random number *rand_: a " seed6: a value to reinitialize the random number generator +rand_: a " seed: array to initialize with  seedLength: length of array , "#$%&'()*+ "#$%&'()*+"# $%&'()*+,7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ / Construct a - struct initialized to zero.1-Frees the resources allocated to a lock with 2.(This function should not be used with a -$ that has been statically allocated.Calling 1= when any thread holds the lock leads to undefined behaviour. Sine: 2.322 Initializes a - so that it can be used.This function is useful to initialize a lock that has been allocated on the stack, or as part of a larger structure. It is not necessary to initialise a reader-writer lock that has been statically allocated.C code l typedef struct { GRWLock l; ... } Blob; Blob *b; b = g_new (Blob, 1); g_rw_lock_init (&b->l);To undo the effect of 2& when a lock is no longer needed, use 1.Calling 2 on an already initialized - leads to undefined behaviour.3 Obtain a read lock on rwLock6. If another thread currently holds the write lock on rwLock^ or blocks waiting for it, the current thread will block. Read locks can be taken recursively.mIt is implementation-defined how many threads are allowed to hold read locks on the same lock simultaneously.4 Tries to obtain a read lock on rwLock and returns  YB if the read lock was successfully obtained. Otherwise it returns  X.5 Release a read lock on rwLock.Calling 5O on a lock that is not held by the current thread leads to undefined behaviour.6 Obtain a write lock on rwLock6. If any thread already holds a read or write lock on rwLockT, the current thread will block until all other threads have dropped their locks on rwLock.7  Tries to obtain a write lock on rwLock4. If any other thread holds a read or write lock on rwLock, it immediately returns  X. Otherwise it locks rwLock and returns  Y.8 Release a write lock on rwLock.Calling 8O on a lock that is not held by the current thread leads to undefined behaviour.-. /01rwLock: an initialized - 2rwLock: an uninitialized - 3rwLock: a - 4rwLock: a - Returns:  Y if rwLock could be locked 5rwLock: a - 6rwLock: a - 7rwLock: a - Returns:  Y if rwLock could be locked 8rwLock: a - 9: -./012345678 -./012345678-. /0123456789:7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^= Construct a ; struct initialized to zero. ;< =>?@ABCDE ;<=>?@ABC ;<=>BCA?@ ;< =>?@ABCDE7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^OCreates a new L structure.P Returns the W of loop.Q:Checks to see if the main loop is currently being run via T.RStops a L from running. Any calls to T for the loop will return.9Note that sources that have already been dispatched when R" is called will still be executed.S#Increases the reference count on a L object by one.TRuns a main loop until RG is called on the loop. If this is called for the thread of the loop's WF, it will process events from the loop, otherwise it will simply wait.U#Decreases the reference count on a LT object by one. If the result is zero, free the loop and free all associated memory.LM NOcontext: a W (if  _%, the default context will be used).  isRunning : set to  YP to indicate that the loop is running. This is not very important since calling T will set this to  Y anyway. Returns: a new L. Ploop: a L. Returns: the W of loop Qloop: a L. Returns:  Y) if the mainloop is currently being run. Rloop: a L Sloop: a L Returns: loop Tloop: a L Uloop: a L V LMNOPQRSTU LMNPQORSTULM NOPQRSTUV7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ZGets the digest from checksum* as a raw binary array and places it into buffer9. The size of the digest depends on the type of checksum.(Once this function has been called, the W- is closed and can no longer be updated with AX.['Gets the HMAC as an hexadecimal string.'Once this function has been called the W can no longer be updated with ]..The hexadecimal characters will be lower case.\-Atomically decrements the reference count of hmac by one.If the reference count drops to 0, all keys and values will be destroyed, and all memory allocated by the hash table is released. This function is MT-safe and may be called from any thread. Frees the memory allocated for hmac.]Feeds data into an existing W.%The HMAC must still be open, that is [ or Z must not have been called on hmac. WX YZhmac: a W buffer: output buffer  digestLenA: an inout parameter. The caller initializes it to the size of buffer6. After the call it contains the length of the digest [hmac: a W Returns: the hexadecimal representation of the HMAC. The returned string is owned by the HMAC and should not be modified or freed. \hmac: a W ]hmac: a W data&: buffer used to compute the checksum ^WXYZ[\]WXYZ[\] WX YZ[\]^7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^a Construct a _ struct initialized to zero.c=Initializes a key/value pair iterator and associates it with  hashTableY. Modifying the hash table after calling this function invalidates the returned iterator.C code  GHashTableIter iter; gpointer key, value; g_hash_table_iter_init (&iter, hash_table); while (g_hash_table_iter_next (&iter, &key, &value)) { // do something with key and value }d Advances iter` and retrieves the key and/or value that are now pointed to as a result of this advancement. If  X is returned, key and value/ are not set, and the iterator becomes invalid.eTRemoves the key/value pair currently pointed to by the iterator from its associated NO. Can only be called after d returned  YB, and cannot be called more than once for the same key/value pair.If the NO was created using g_hash_table_new_full(), the key and value are freed using the supplied destroy functions, otherwise you have to make sure that any dynamically allocated values are freed yourself.%It is safe to continue iterating the NO afterward:C code x while (g_hash_table_iter_next (&iter, &key, &value)) { if (condition) g_hash_table_iter_remove (&iter); }fLReplaces the value currently pointed to by the iterator from its associated NO. Can only be called after d returned  Y.If you supplied a valueDestroyFunc when creating the NO-, the old value is freed using that function.gTRemoves the key/value pair currently pointed to by the iterator from its associated NOP, without calling the key and value destroy functions. Can only be called after d returned  YB, and cannot be called more than once for the same key/value pair._` abciter: an uninitialized _  hashTable: a NO diter: an initialized _ Returns:  X if the end of the NO has been reached. eiter: an initialized _ fiter: an initialized _ value: the value to replace with giter: an initialized _ hi _`abcdefg _`abcdefg_` abcdefghi 7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^m;Closes the directory and deallocates all related resources.n9Retrieves the name of another entry in the directory, or  _. The order of entries returned from this function is not defined, and may vary by file system or other operating-system dependent factors. _@ may also be returned in case of errors. On Unix, you can check errno to find out if  _" was returned because of an error.`On Unix, the '.' and '..' entries are omitted, and the returned name is in the on-disk encoding.gOn Windows, as is true of all GLib functions which operate on filenames, the returned name is in UTF-8.o-Resets the given directory. The next call to n# will return the first entry again.pVCreates a subdirectory in the preferred directory for temporary files (as returned by GY).tmplt should be a string in the GLib file name encoding containing a sequence of six 'X' characters, as the parameter to GZ. However, unlike these functions, the template should only be a basename, no directory components are allowed. If template is  _, a default template is used.Note that in contrast to G[ (and  mkdtemp()) tmpl? is not modified, and might thus be a read-only literal string. jk lmdir: a j * created by  g_dir_open() ndir: a j * created by  g_dir_open() Returns: The entry's name or  _h if there are no more entries. The return value is owned by GLib and must not be modified or freed. odir: a j * created by  g_dir_open() ptmpl): Template for directory name, as in G[, basename only, or  _ for a default template Returns:< The actual name used. This string should be freed with GM] when not needed any longer and is is in the GLib file name encoding. In case of errors,  _ is returned and error will be set.  (Can throw \]) qjklmnopjklmpno jk lmnopq!7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^t Construct a r struct initialized to zero.vIf threads are waiting for cond;, all of them are unblocked. If no threads are waiting for cond, this function has no effect. It is good practice to lock the same mutex as the waiting threads while calling this function, though not required.w #Frees the resources allocated to a r with x.(This function should not be used with a r$ that has been statically allocated.Calling w for a r< on which threads are blocking leads to undefined behaviour.x Initialises a r so that it can be used.(This function is useful to initialise a r] that has been allocated as part of a larger structure. It is not necessary to initialise a r$ that has been statically allocated.To undo the effect of x when a r is no longer needed, use w.Calling x on an already-initialised r leads to undefined behaviour.yIf threads are waiting for condC, at least one of them is unblocked. If no threads are waiting for cond, this function has no effect. It is good practice to hold the same lock as the waiting thread while calling this function, though not required.zAtomically releases mutex and waits until cond+ is signalled. When this function returns, mutex1 is locked again and owned by the calling thread.UWhen using condition variables, it is possible that a spurious wakeup may occur (ie: z returns even though yS was not called). It's also possible that a stolen wakeup may occur. This is when y( is called, but another thread acquires mutexR before this thread and modifies the state of the program in such a way that when z< is able to return, the expected condition is no longer met.For this reason, z; must always be used in a loop. See the documentation for r for a complete example.{ Waits until either cond is signalled or endTime has passed.As with z it is possible that a spurious or stolen wakeup could occur. For that reason, waiting on a condition variable should always be in a loop, based on an explicitly-checked predicate. Y] is returned if the condition variable was signalled (or in the case of a spurious wakeup).  X is returned if endTime has passed.The following code shows how to correctly perform a timed wait on a condition variable (extending the example presented in the documentation for r):C code  gpointer pop_data_timed (void) { gint64 end_time; gpointer data; g_mutex_lock (&data_mutex); end_time = g_get_monotonic_time () + 5 * G_TIME_SPAN_SECOND; while (!current_data) if (!g_cond_wait_until (&data_cond, &data_mutex, end_time)) { // timeout has passed. g_mutex_unlock (&data_mutex); return NULL; } // there is data for us data = current_data; current_data = NULL; g_mutex_unlock (&data_mutex); return data; }lNotice that the end time is calculated once, before entering the loop and reused. This is the motivation behind the use of absolute time on this API -- if a relative time of 5 seconds were passed directly to the call and a spurious wakeup occurred, the program would have to start over waiting again (which would lead to a total wait time of more than 5 seconds).rs tuvcond: a r wcond: an initialised r xcond: an uninitialized r ycond: a r zcond: a r mutex: a ^ that is currently locked {cond: a r mutex: a ^ that is currently locked endTime#: the monotonic time to wait until Returns:  Y on a signal,  X on a timeout |} rstuvwxyz{ rstuvwxyz{rs tuvwxyz{|}"7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^' Adds the application with name and execA to the list of applications that have registered a bookmark for uri into bookmark.Every bookmark inside a ~ must have at least an application registered. Each application must provide a name, a command line useful for launching the bookmark, the number of times the bookmark has been registered by the application and the last time the application registered this bookmark.If name is  _;, the name of the application will be the same returned by G_; if exec is  _L, the command line will be a composition of the program name as returned by G`E and the "%u" modifier, which will be expanded to the bookmark's URI.This function will automatically take care of updating the registrations count and timestamping in case an application with the same name' had already registered a bookmark for uri inside bookmark.If no bookmark for uri is found, one is created. Adds group1 to the list of groups to which the bookmark for uri belongs to.If no bookmark for uri is found then it is created. Frees a ~. Gets the time the bookmark for uri was added to bookmark9In the event the URI cannot be found, -1 is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. &Gets the registration informations of appName for the bookmark for uri. See / for more informations about the returned data.The string returned in appExec must be freed.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND.. In the event that no application with name appName has registered a bookmark for uri,  X! is returned and error is set to (G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTEREDF. In the event that unquoting the command line fails, an error of the  G_SHELL_ERROR domain is set and  X is returned. NRetrieves the names of the applications that have registered the bookmark for uri.&In the event the URI cannot be found,  _ is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. .Retrieves the description of the bookmark for uri.&In the event the URI cannot be found,  _ is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. 6Retrieves the list of group names of the bookmark for uri.&In the event the URI cannot be found,  _ is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND.The returned array is  _ terminated, so length may optionally be  _. "Gets the icon of the bookmark for uri.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. 2Gets whether the private flag of the bookmark for uri is set.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND7. In the event that the private flag cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_INVALID_VALUE. 3Retrieves the MIME type of the resource pointed by uri.&In the event the URI cannot be found,  _ is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND4. In the event that the MIME type cannot be found,  _ is returned and error is set to #G_BOOKMARK_FILE_ERROR_INVALID_VALUE. $Gets the time when the bookmark for uri was last modified.9In the event the URI cannot be found, -1 is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. $Gets the number of bookmarks inside bookmark. &Returns the title of the bookmark for uri.If uri is  _, the title of bookmark is returned.&In the event the URI cannot be found,  _ is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. 7Returns all URIs of the bookmarks in the bookmark file bookmark%. The array of returned URIs will be  _-terminated, so length may optionally be  _. Gets the time the bookmark for uri was last visited.9In the event the URI cannot be found, -1 is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND.  Checks whether the bookmark for uri inside bookmark$ has been registered by application name.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. Checks whether group9 appears in the list of groups to which the bookmark for uri belongs to.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. CLooks whether the desktop bookmark has an item with its URI set to uri. 0Loads a bookmark file from memory into an empty ~2 structure. If the object cannot be created then error is set to a @a. 6This function looks for a desktop bookmark file named file in the paths returned from Gb and Gc, loads the file into bookmark% and returns the file's full path in fullPath+. If the file could not be loaded then an error is set to either a @d or @a. ,Loads a desktop bookmark file into an empty ~1 structure. If the file could not be loaded then error is set to either a @d or @a. (Changes the URI of a bookmark item from oldUri to newUri. Any existing bookmark for newUri will be overwritten. If newUri is  _, then the bookmark is removed.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND. $Removes application registered with nameC from the list of applications that have registered a bookmark for uri inside bookmark.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND-. In the event that no application with name appName has registered a bookmark for uri,  X! is returned and error is set to (G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED. Removes group3 from the list of groups to which the bookmark for uri belongs to.&In the event the URI cannot be found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND%. In the event no group was defined,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_INVALID_VALUE. Removes the bookmark for uri from the bookmark file bookmark. Sets the time the bookmark for uri was added into bookmark.If no bookmark for uri is found then it is created. "Sets the meta-data of application nameE inside the list of applications that have registered a bookmark for uri inside bookmark.)You should rarely use this function; use  and  instead.nameB can be any UTF-8 encoded string used to identify an application. exec can have one of these two modifiers: "%f", which will be expanded as the local file name retrieved from the bookmark's URI; "%u", which will be expanded as the bookmark's URI. The expansion is done automatically when retrieving the stored command line using the  function. count is the number of times the application has registered the bookmark; if is < 0, the current registration count will be increased by one, if is 0, the application with name; will be removed from the list of registered applications. stampW is the Unix time of the last registration; if it is -1, the current time will be used.cIf you try to remove an application by setting its registration count to zero, and no bookmark for uri is found,  X is returned and error is set to #G_BOOKMARK_FILE_ERROR_URI_NOT_FOUND.; similarly, in the event that no application name has registered a bookmark for uri,  X! is returned and error is set to (G_BOOKMARK_FILE_ERROR_APP_NOT_REGISTERED!. Otherwise, if no bookmark for uri is found, one is created. Sets  description( as the description of the bookmark for uri.If uri is  _, the description of bookmark is set.If a bookmark for uri$ cannot be found then it is created. 1Sets a list of group names for the item with URI uri2. Each previously set group name list is removed.If uri0 cannot be found then an item for it is created. #Sets the icon for the bookmark for uri. If href is  _!, unsets the currently set icon. hrefe can either be a full URL for the icon file or the icon name following the Icon Naming specification.If no bookmark for uri is found one is created. *Sets the private flag of the bookmark for uri.If a bookmark for uri$ cannot be found then it is created. Sets mimeType& as the MIME type of the bookmark for uri.If a bookmark for uri$ cannot be found then it is created. $Sets the last time the bookmark for uri was last modified.If no bookmark for uri is found then it is created.nThe "modified" time should only be set when the bookmark's meta-data was actually changed. Every function of ~I that modifies a bookmark also changes the modification time, except for . Sets title" as the title of the bookmark for uri inside the bookmark file bookmark.If uri is  _, the title of bookmark is set.If a bookmark for uri$ cannot be found then it is created. Sets the time the bookmark for uri was last visited.If no bookmark for uri is found then it is created.oThe "visited" time should only be set if the bookmark was launched, either using the command line retrieved by M or by the default application for the bookmark's MIME type, retrieved using C. Changing the "visited" time does not affect the "modified" time. This function outputs bookmark as a string. This function outputs bookmarkE into a file. The write process is guaranteed to be atomic by using Ge internally.3No description available in the introspection data.R~   bookmark: a ~ uri: a valid URI name<: the name of the application registering the bookmark or  _ exec4: command line to be used to launch the bookmark or  _ bookmark: a ~ uri: a valid URI group: the group name to be added bookmark: a ~ bookmark: a ~ uri: a valid URI Returns: a timestamp  (Can throw \]) bookmark: a ~ uri: a valid URI name: an application's name  (Can throw \]) bookmark: a ~ uri: a valid URI Returns: a newly allocated  _$-terminated array of strings. Use Gf to free it.  (Can throw \]) bookmark: a ~ uri: a valid URI Returns: a newly allocated string or  _) if the specified URI cannot be found.  (Can throw \]) bookmark: a ~ uri: a valid URI Returns: a newly allocated  _(-terminated array of group names. Use Gf to free it.  (Can throw \]) bookmark: a ~ uri: a valid URI  (Can throw \]) bookmark: a ~ uri: a valid URI  (Can throw \]) bookmark: a ~ uri: a valid URI Returns: a newly allocated string or  _) if the specified URI cannot be found.  (Can throw \]) bookmark: a ~ uri: a valid URI Returns: a timestamp  (Can throw \]) bookmark: a ~ Returns: the number of bookmarks bookmark: a ~ uri: a valid URI or  _ Returns: a newly allocated string or  _) if the specified URI cannot be found.  (Can throw \]) bookmark: a ~ Returns: a newly allocated  _$-terminated array of strings. Use Gf to free it. bookmark: a ~ uri: a valid URI Returns: a timestamp.  (Can throw \]) bookmark: a ~ uri: a valid URI name: the name of the application  (Can throw \]) bookmark: a ~ uri: a valid URI group : the group name to be searched  (Can throw \]) bookmark: a ~ uri: a valid URI Returns:  Y if uri is inside bookmark,  X otherwise bookmark : an empty ~ struct data%: desktop bookmarks loaded in memory length: the length of data in bytes  (Can throw \]) bookmark: a ~ file2: a relative path to a filename to open and parse fullPathK: return location for a string containing the full path of the file, or  _  (Can throw \]) bookmark : an empty ~ struct filenameE: the path of a filename to load, in the GLib file name encoding  (Can throw \]) bookmark: a ~ oldUri: a valid URI newUri: a valid URI, or  _  (Can throw \]) bookmark: a ~ uri: a valid URI name: the name of the application  (Can throw \]) bookmark: a ~ uri: a valid URI group: the group name to be removed  (Can throw \]) bookmark: a ~ uri: a valid URI  (Can throw \]) bookmark: a ~ uri: a valid URI added,: a timestamp or -1 to use the current time bookmark: a ~ uri: a valid URI name: an application's name exec : an application's command line count8: the number of registrations done for this application stamp9: the time of the last registration for this application  (Can throw \]) bookmark: a ~ uri: a valid URI or  _  description : a string bookmark: a ~ uri: an item's URI groups: an array of group names, or  _ to remove all groups length!: number of group name values in groups bookmark: a ~ uri: a valid URI href+: the URI of the icon for the bookmark, or  _ mimeType-: the MIME type of the icon for the bookmark bookmark: a ~ uri: a valid URI  isPrivate:  Y- if the bookmark should be marked as private bookmark: a ~ uri: a valid URI mimeType: a MIME type bookmark: a ~ uri: a valid URI modified,: a timestamp or -1 to use the current time bookmark: a ~ uri: a valid URI or  _ title: a UTF-8 encoded string bookmark: a ~ uri: a valid URI visited,: a timestamp or -1 to use the current time bookmark: a ~ Returns:8 a newly allocated string holding the contents of the ~  (Can throw \]) bookmark: a ~ filename: path of the output file  (Can throw \]) *~*~Q~   #7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.)Adds the given number of microseconds to time_.  microseconds/ can also be negative to decrease the value of time_.  Converts time_ into an RFC 3339 encoded string, relative to the Coordinated Universal Time (UTC). This is one of the many formats allowed by ISO 8601.ISO 8601 allows a large number of date/time formats, with or without punctuation and optional elements. The format returned by this function is a complete date and time, with optional punctuation included, the UTC time zone represented as "Z", and the tvUsecp part included if and only if it is nonzero, i.e. either "YYYY-MM-DDTHH:MM:SSZ" or "YYYY-MM-DDTHH:MM:SS.fffffZ".=This corresponds to the Internet date/time format defined by  $https://www.ietf.org/rfc/rfc3339.txtRFC 3339H, and to either of the two most-precise formats defined by the W3C Note  +http://www.w3.org/TR/NOTE-datetime-19980827Date and Time Formats3. Both of these documents are profiles of ISO 8601.Use %g or g_strdup_printf()9 if a different variation of ISO 8601 format is required. DConverts a string containing an ISO 8601 encoded date and time to a  and puts it into time_.isoDate must include year, month, day, hours, minutes, and seconds. It can optionally include fractions of a second and a time zone indicator. (In the absence of any time zone indication, the timestamp is assumed to be in local time.)   time_: a   microseconds#: number of microseconds to add to time time_: a  Returns:6 a newly allocated string containing an ISO 8601 date isoDate": an ISO 8601 encoded date string Returns:  Y# if the conversion was successful.      $7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Returns the length of the queue.Actually this function returns the number of data items in the queue minus the number of waiting threads, so a negative value means waiting threads, and a positive value means available entries in the queue. A return value of 0 could mean n entries in the queue and n threads waiting. This can happen due to locking of the queue or due to scheduling. Returns the length of the queue.Actually this function returns the number of data items in the queue minus the number of waiting threads, so a negative value means waiting threads, and a positive value means available entries in the queue. A return value of 0 could mean n entries in the queue and n threads waiting. This can happen due to locking of the queue or due to scheduling./This function must be called while holding the queue's lock. Acquires the queuen's lock. If another thread is already holding the lock, this call will block until the lock becomes available.Call  to drop the lock again.=While holding the lock, you can only call the g_async_queue_* _unlocked() functions on queue . Otherwise, deadlock may occur.Pops data from the queue. If queue= is empty, this function blocks until data becomes available.Pops data from the queue. If queue= is empty, this function blocks until data becomes available./This function must be called while holding the queue's lock. Pushes the data into the queue. data must not be  _.. Pushes the item into the queue. item must not be  _. In contrast to , this function pushes the new item ahead of the items already in the queue, so that it will be the next one to be popped off the queue.. Pushes the item into the queue. item must not be  _. In contrast to , this function pushes the new item ahead of the items already in the queue, so that it will be the next one to be popped off the queue./This function must be called while holding the queue's lock. Pushes the data into the queue. data must not be  _./This function must be called while holding the queue's lock.2Increases the reference count of the asynchronous queue by 1..Remove an item from the queue..Remove an item from the queue./This function must be called while holding the queue's lock.Pops data from the queue&. If the queue is empty, blocks until endTime! or until data becomes available.If no data is received before endTime,  _ is returned.To easily calculate endTime, a combination of Gh and #i can be used.Pops data from the queue&. If the queue is empty, blocks until endTime! or until data becomes available.If no data is received before endTime,  _ is returned.To easily calculate endTime, a combination of Gh and #i can be used./This function must be called while holding the queue's lock.Pops data from the queue$. If the queue is empty, blocks for timeout/ microseconds, or until data becomes available.+If no data is received before the timeout,  _ is returned.Pops data from the queue$. If the queue is empty, blocks for timeout/ microseconds, or until data becomes available.+If no data is received before the timeout,  _ is returned./This function must be called while holding the queue's lock.Tries to pop data from the queue. If no data is available,  _ is returned.Tries to pop data from the queue. If no data is available,  _ is returned./This function must be called while holding the queue's lock.Releases the queue's lock.:Calling this function when you have not acquired the with  leads to undefined behaviour.2Decreases the reference count of the asynchronous queue by 1.&If the reference count went to 0, the queue] will be destroyed and the memory allocated will be freed. So you are not allowed to use the queueb afterwards, as it might have disappeared. You do not need to hold the lock to call this function.2Decreases the reference count of the asynchronous queueL by 1 and releases the lock. This function must be called while holding the queue/'s lock. If the reference count went to 0, the queue: will be destroyed and the memory allocated will be freed.. !"queue: a . Returns: the length of the queue queue: a  Returns: the length of the queue. queue: a  queue: a  Returns: data from the queue queue: a  Returns: data from the queue. queue: a  data: data to push into the queue queue: a  item: data to push into the queue queue: a  item: data to push into the queue queue: a  data: data to push into the queue queue: a  queue: a  item: the data to remove from the queue Returns:  Y if the item was removed queue: a  item: the data to remove from the queue Returns:  Y if the item was removed queue: a  endTime: a #j, determining the final time Returns: data from the queue or  _&, when no data is received before endTime. queue: a  endTime: a #j, determining the final time Returns: data from the queue or  _&, when no data is received before endTime. queue: a  timeout%: the number of microseconds to wait Returns: data from the queue or  _3, when no data is received before the timeout. queue: a  timeout%: the number of microseconds to wait Returns: data from the queue or  _3, when no data is received before the timeout. queue: a  Returns: data from the queue or  _-, when no data is available immediately. queue: a  Returns: data from the queue or  _-, when no data is available immediately. queue: a  queue: a . queue: a  - !"%7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^/Creates a new ; corresponding to the given date and time in the time zone tz.The year must be between 1 and 9999, month between 1 and 12 and dayD between 1 and 28, 29, 30 or 31 depending on the month and the year.hour must be between 0 and 23 and minute must be between 0 and 59.secondsn must be at least 0.0 and must be strictly less than 60.0. It will be rounded down to the nearest microsecond.TIf the given time is not representable in the given time zone (for example, 02:30 on March 14th 2010 in Toronto, due to daylight savings time) then the time will be rounded up to the nearest existing time (in this case, 03:00). If this matters to you then you should verify the return value for containing the same as the numbers you gave.In the case that the given time is ambiguous in the given time zone (for example, 01:30 on November 7th 2010 in Toronto, due to daylight savings time) then the time falling within standard (ie: non-daylight) time is taken.It not considered a programmer error for the values to this function to be out of range, but in the case that they are, the function will return  _./You should release the return value by calling  when you are done with it. Creates a  corresponding to the given #j tv in the local time zone.The time contained in a #jt is always stored in the form of seconds elapsed since 1970-01-01 00:00:00 UTC, regardless of the local time offset.This call can fail (returning  _) if tv5 represents a time outside of the supported range of ./You should release the return value by calling  when you are done with it. Creates a  corresponding to the given #j tv in UTC.The time contained in a #jO is always stored in the form of seconds elapsed since 1970-01-01 00:00:00 UTC.This call can fail (returning  _) if tv5 represents a time outside of the supported range of ./You should release the return value by calling  when you are done with it. Creates a & corresponding to the given Unix time t in the local time zone.xUnix time is the number of seconds that have elapsed since 1970-01-01 00:00:00 UTC, regardless of the local time offset.This call can fail (returning  _) if t5 represents a time outside of the supported range of ./You should release the return value by calling  when you are done with it. Creates a & corresponding to the given Unix time t in UTC.SUnix time is the number of seconds that have elapsed since 1970-01-01 00:00:00 UTC.This call can fail (returning  _) if t5 represents a time outside of the supported range of ./You should release the return value by calling  when you are done with it.Creates a new A corresponding to the given date and time in the local time zone.#This call is equivalent to calling  with the time zone returned by  k. Creates a < corresponding to this exact instant in the given time zone tzX. The time is as accurate as the system allows, to a maximum accuracy of 1 microsecond.This function will always succeed unless the system clock is set to truly insane values (or unless GLib is still being used after the year 9999)./You should release the return value by calling  when you are done with it. Creates a < corresponding to this exact instant in the local time zone.This is equivalent to calling  with the time zone returned by  k. Creates a , corresponding to this exact instant in UTC.This is equivalent to calling  with the time zone returned by  l.Creates a new 1 corresponding to the given date and time in UTC.#This call is equivalent to calling  with the time zone returned by  l.Creates a copy of datetime- and adds the specified timespan to the copy.Creates a copy of datetimeY and adds the specified number of days to the copy. Add negative values to subtract days.Creates a new = adding the specified values to the current date and time in datetime". Add negative values to subtract.Creates a copy of datetimeO and adds the specified number of hours. Add negative values to subtract hours.Creates a copy of datetimeQ adding the specified number of minutes. Add negative values to subtract minutes.Creates a copy of datetime] and adds the specified number of months to the copy. Add negative values to subtract months.Creates a copy of datetimeS and adds the specified number of seconds. Add negative values to subtract seconds.Creates a copy of datetime[ and adds the specified number of weeks to the copy. Add negative values to subtract weeks.Creates a copy of datetime[ and adds the specified number of years to the copy. Add negative values to subtract years.*Calculates the difference in time between end and begin. The  GTimeSpan! that is returned is effectively end - begin1 (ie: positive if the first parameter is larger).<Creates a newly allocated string representing the requested format.CThe format strings understood by this function are a subset of the  strftime() format language as specified by C99. The %D, %U and %W conversions are not supported, nor is the 'E' modifier. The GNU extensions %k, %l, %s and %P are supported, however, as are the '0', '_' and '-' modifiers.In contrast to  strftime(), this function always produces a UTF-8 string, regardless of the current locale. Note that the rendering of many formats is locale-dependent and may not match the  strftime() output exactly..The following format specifiers are supported:(@%a: the abbreviated weekday name according to the current locale9%A: the full weekday name according to the current locale>%b: the abbreviated month name according to the current locale7%B: the full month name according to the current localeE%c: the preferred date and time representation for the current locale>%C: the century number (year/100) as a 2-digit integer (00-99)=%d: the day of the month as a decimal number (range 01 to 31)=%e: the day of the month as a decimal number (range 1 to 31)%F: equivalent to %Y-%m-%d (the ISO 8601 date format)t%g: the last two digits of the ISO 8601 week-based year as a decimal number (00-99). This works well with %V and %u.U%G: the ISO 8601 week-based year as a decimal number. This works well with %V and %u.%h: equivalent to %bG%H: the hour as a decimal number using a 24-hour clock (range 00 to 23)G%I: the hour as a decimal number using a 12-hour clock (range 01 to 12)>%j: the day of the year as a decimal number (range 001 to 366)g%k: the hour (24-hour clock) as a decimal number (range 0 to 23); single digits are preceded by a blankg%l: the hour (12-hour clock) as a decimal number (range 1 to 12); single digits are preceded by a blank2%m: the month as a decimal number (range 01 to 12)3%M: the minute as a decimal number (range 00 to 59)%p: either "AM" or "PM" according to the given time value, or the corresponding strings for the current locale. Noon is treated as "PM" and midnight as "AM".X%P: like %p but lowercase: "am" or "pm" or a corresponding string for the current locale%%r: the time in a.m. or p.m. notation(%R: the time in 24-hour notation (%H:%M)Q%s: the number of seconds since the Epoch, that is, since 1970-01-01 00:00:00 UTC3%S: the second as a decimal number (range 00 to 60)%t: a tab character8%T: the time in 24-hour notation with seconds (%H:%M:%S)v%u: the ISO 8601 standard day of the week as a decimal, range 1 to 7, Monday being 1. This works well with %G and %V.%V: the ISO 8601 standard week number of the current year as a decimal number, range 01 to 53, where week 1 is the first week that has at least 4 days in the new year. See !. This works well with %G and %u.%w: the day of the week as a decimal, range 0 to 6, Sunday being 0. This is not the ISO 8601 standard format -- use %u instead.M%x: the preferred date representation for the current locale without the timeM%X: the preferred time representation for the current locale without the date4%y: the year as a decimal number without the century6%Y: the year as a decimal number including the century/%z: the time zone as an offset from UTC (+hhmm)D%:z: the time zone as an offset from UTC (+hh:mm). This is a gnulib  strftime() extension. Since: 2.38H%::z: the time zone as an offset from UTC (+hh:mm:ss). This is a gnulib  strftime() extension. Since: 2.38p%:::z: the time zone as an offset from UTC, with : to necessary precision (e.g., -04, +05:30). This is a gnulib  strftime() extension. Since: 2.38)%Z: the time zone or name or abbreviation%%: a literal % characterSome conversion specifications can be modified by preceding the conversion specifier by one or more modifier characters. The following modifiers are supported for many of the numeric conversions:IO: Use alternative numeric symbols, if the current locale supports those.Z_: Pad a numeric result with spaces. This overrides the default padding for the specifier.U-: Do not pad a numeric result. This overrides the default padding for the specifier.Y0: Pad a numeric result with zeros. This overrides the default padding for the specifier..Retrieves the day of the month represented by datetime in the gregorian calendar.0Retrieves the ISO 8601 day of the week on which datetime2 falls (1 is Monday, 2 is Tuesday... 7 is Sunday).-Retrieves the day of the year represented by datetime in the Gregorian calendar.-Retrieves the hour of the day represented by datetime5Retrieves the microsecond of the date represented by datetime0Retrieves the minute of the hour represented by datetime/Retrieves the month of the year represented by datetime in the Gregorian calendar.2Retrieves the second of the minute represented by datetimebRetrieves the number of seconds since the start of the last minute, including the fractional part.UDetermines the time zone abbreviation to be used at the time and in the time zone of datetime.For example, in Toronto this is currently "EST" during the winter months and "EDT" during the summer months when daylight savings time is in effect.KDetermines the offset to UTC in effect at the time and in the time zone of datetime.The offset is the number of microseconds that you add to UTC time to arrive at local time for the time zone (ie: negative numbers for time zones west of GMT, positive numbers for east).If datetime5 represents UTC time, then the offset is always zero.FReturns the ISO 8601 week-numbering year in which the week containing datetime falls.#This function, taken together with  and : can be used to determine the full ISO week date on which datetime falls.CThis is usually equal to the normal Gregorian year (as returned by ), except as detailed below:For Thursday, the week-numbering year is always equal to the usual calendar year. For other days, the number is such that every day within a complete week (Monday to Sunday) is contained within the same week-numbering year.For Monday, Tuesday and Wednesday occurring near the end of the year, this may mean that the week-numbering year is one greater than the calendar year (so that these days have the same week-numbering year as the Thursday occurring early in the next year).For Friday, Saturday and Sunday occurring near the start of the year, this may mean that the week-numbering year is one less than the calendar year (so that these days have the same week-numbering year as the Thursday occurring late in the previous year).An equivalent description is that the week-numbering year is equal to the calendar year containing the majority of the days in the current week (Monday to Sunday).kNote that January 1 0001 in the proleptic Gregorian calendar is a Monday, so this function never returns 0.9Returns the ISO 8601 week number for the week containing datetime. The ISO 8601 week number is the same for every day of the week (from Moday through Sunday). That can produce some unusual results (described below).The first week of the year is week 1. This is the week that contains the first Thursday of the year. Equivalently, this is the first week that has more than 4 of its days falling within the calendar year.The value 0 is never returned by this function. Days contained within a year but occurring before the first ISO 8601 week of that year are considered as being contained in the last week of the previous year. Similarly, the final days of a calendar year may be considered as being part of the first ISO 8601 week of the next year if 4 or more days of that week are contained within the new year."Retrieves the year represented by datetime in the Gregorian calendar.8Retrieves the Gregorian day, month, and year of a given .UDetermines if daylight savings time is in effect at the time and in the time zone of datetime.-Atomically increments the reference count of datetime by one.Creates a new . corresponding to the same instant in time as datetime, but in the local time zone.#This call is equivalent to calling  with the time zone returned by  k. Stores the instant in time that datetime represents into tv.The time contained in a #j| is always stored in the form of seconds elapsed since 1970-01-01 00:00:00 UTC, regardless of the time zone associated with datetime.TOn systems where 'long' is 32bit (ie: all 32bit systems and all Windows systems), a #j9 is incapable of storing the entire range of values that D is capable of expressing. On those systems, this function returns  X+ to indicate that the time is out of range.<On systems where 'long' is 64bit, this function never fails. Create a new . corresponding to the same instant in time as datetime, but in the time zone tz.This call can fail in the case that the time goes out of bounds. For example, converting 0001-01-01 00:00:00 UTC to a time zone west of Greenwich will fail (due to the year 0 being out of range)./You should release the return value by calling  when you are done with it.%Gives the Unix time corresponding to datetime&, rounding down to the nearest second.Unix time is the number of seconds that have elapsed since 1970-01-01 00:00:00 UTC, regardless of the time zone associated with datetime.Creates a new . corresponding to the same instant in time as datetime , but in UTC.#This call is equivalent to calling  with the time zone returned by  l.-Atomically decrements the reference count of datetime by one.BWhen the reference count reaches zero, the resources allocated by datetime are freedA comparison function for  GDateTimes that is suitable as a Fm. Both  GDateTimes must be non- _.Checks to see if dt1 and dt2 are equal.aEqual here means that they represent the same moment after converting them to the same time zone.Hashes datetime into a guint, suitable for use within NO.c#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRtz: a  n year!: the year component of the date month": the month component of the date day : the day component of the date hour!: the hour component of the date minute#: the minute component of the date seconds(: the number of seconds past the minute Returns: a new , or  _ tv: a #j Returns: a new , or  _ tv: a #j Returns: a new , or  _ t: the Unix time Returns: a new , or  _ t: the Unix time Returns: a new , or  _ year!: the year component of the date month": the month component of the date day : the day component of the date hour!: the hour component of the date minute#: the minute component of the date seconds(: the number of seconds past the minute Returns: a , or  _ tz: a  n Returns: a new , or  _ Returns: a new , or  _ Returns: a new , or  _ year!: the year component of the date month": the month component of the date day : the day component of the date hour!: the hour component of the date minute#: the minute component of the date seconds(: the number of seconds past the minute Returns: a , or  _ datetime: a  timespan: a  GTimeSpan Returns: the newly created  which should be freed with . datetime: a  days: the number of days Returns: the newly created  which should be freed with . datetime: a  years: the number of years to add months: the number of months to add days: the number of days to add hours: the number of hours to add minutes: the number of minutes to add seconds: the number of seconds to add Returns: the newly created  that should be freed with . datetime: a  hours: the number of hours to add Returns: the newly created  which should be freed with . datetime: a  minutes: the number of minutes to add Returns: the newly created  which should be freed with . datetime: a  months: the number of months Returns: the newly created  which should be freed with . datetime: a  seconds: the number of seconds to add Returns: the newly created  which should be freed with . datetime: a  weeks: the number of weeks Returns: the newly created  which should be freed with . datetime: a  years: the number of years Returns: the newly created  which should be freed with . end: a  begin: a  Returns: the difference between the two ., as a time span expressed in microseconds. datetime: A  format?: a valid UTF-8 string, containing the format for the  Returns:C a newly allocated string formatted to the requested format or  _J in the case that there was an error. The string should be freed with GM. datetime: a  Returns: the day of the month datetime: a  Returns: the day of the week datetime: a  Returns: the day of the year datetime: a  Returns: the hour of the day datetime: a  Returns: the microsecond of the second datetime: a  Returns: the minute of the hour datetime: a  Returns: the month represented by datetime datetime: a  Returns: the second represented by datetime datetime: a  Returns: the number of seconds datetime: a  Returns:J the time zone abbreviation. The returned string is owned by the 1 and it should not be modified or freed datetime: a  Returns:W the number of microseconds that should be added to UTC to get the local time datetime: a  Returns:& the ISO 8601 week-numbering year for datetime datetime: a  Returns: the ISO 8601 week number for datetime. datetime: A  Returns: the year represented by datetime datetime: a . datetime: a  Returns:  Y' if daylight savings time is in effect datetime: a  Returns: the $ with the reference count increased datetime: a  Returns: the newly created  datetime: a  tv: a #j to modify Returns:  Y if successful, else  X datetime: a  tz : the new  n Returns: a new , or  _ datetime: a  Returns: the Unix time corresponding to datetime datetime: a  Returns: the newly created  datetime: a  dt1: first  to compare dt2 : second  to compare Returns: -1, 0 or 1 if dt1* is less than, equal to or greater than dt2. dt1: a  dt2: a  Returns:  Y if dt1 and dt2 are equal datetime: a  Returns: a guint containing the hash 22b#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQR&7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^Adds testCase to suite.Adds  nestedsuite to suite.STsuite: a  testCase: a o suite: a   nestedsuite : another  ST'7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ `Compares two compiled pattern specs and returns whether they will match the same set of strings. #Frees the memory allocated for the . UV  pspec1: a  pspec2 : another  Returns:) Whether the compiled patterns are equal  pspec: a            UV    )7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^"Same as the standard UNIX routine  iconv_close(), but may be implemented via libiconv on UNIX flavors that lack a native implementation. Should be called to clean up the conversion descriptor from g_iconv_open()% when you are done converting things.GLib provides Gp and Gq> which are likely more convenient than the raw iconv wrappers.W converter: a conversion descriptor from g_iconv_open() Returns: -1 on error, 0 on success W*7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.    +7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ !"# !" !" !"#,7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ ' Creates a new $ from data.data is copied. If size is 0, data may be  _.( Creates a new $ from data.After this call, dataD belongs to the bytes and may no longer be modified by the caller. GM will be called on data5 when the bytes is no longer in use. Because of this data% must have been created by a call to Gr, Gs or Gt@ or by one of the many functions that wrap these calls (such as g_new(), Gu, etc). For creating $( with memory from other allocators, see g_bytes_new_with_free_func().data may be  _ if size is 0.) Compares the two $ values.JThis function can be used to sort GBytes instances in lexographical order.* Compares the two $% values being pointed to and returns  Y if they are equal.This function can be passed to g_hash_table_new() as the  keyEqualFunc parameter, when using non- _ $ pointers as keys in a NO.+ Get the byte data in the $#. This data should not be modified.>This function will always return the same pointer for a given $. _ may be returned if size& is 0. This is not guaranteed, as the $$ may represent an empty string with data non- _ and size as 0.  _ will not be returned if size is non-zero., %Get the size of the byte data in the $.<This function will always return the same value for a given $.- 6Creates an integer hash code for the byte data in the $.This function can be passed to g_hash_table_new() as the  keyHashFunc parameter, when using non- _ $ pointers as keys in a NO..  Creates a $" which is a subsection of another $. The offset + length$ may not be longer than the size of bytes.A reference to bytes# will be held by the newly created $) until the byte data is no longer needed./  Increase the reference count on bytes.0 Releases a reference on bytes,. This may result in the bytes being freed.1 2Unreferences the bytes, and returns a new mutable -v containing the same byte data.As an optimization, the byte data is transferred to the array without copying if this was the last reference to bytes and bytes was created with ', ( or Gw(. In all other cases the data is copied.2 JUnreferences the bytes, and returns a pointer the same byte data contents.As an optimization, the byte data is returned without copying if this was the last reference to bytes and bytes was created with ', ( or Gw(. In all other cases the data is copied.$%XYZ[\]^_`abcd&'data,: the data to be used for the bytes Returns: a new $ (data/: the data to be used for the bytes Returns: a new $ )bytes1: a pointer to a $ bytes2: a pointer to a $ to compare with bytes1 Returns:} a negative value if bytes2 is lesser, a positive value if bytes2 is greater, and zero if bytes2 is equal to bytes1 *bytes1: a pointer to a $ bytes2: a pointer to a $ to compare with bytes1 Returns:  Y if the two keys match. +bytes: a $ Returns:* a pointer to the byte data, or  _ ,bytes: a $ Returns: the size -bytes: a pointer to a $ key Returns:( a hash value corresponding to the key. .bytes: a $ offset$: offset which subsection starts at length: length of subsection Returns: a new $ /bytes: a $ Returns: the $ 0bytes: a $ 1bytes: a $ Returns: a new mutable -v containing the same byte data 2bytes: a $ Returns:F a pointer to the same byte data, which should be freed with GM 3$%&'()*+,-./012$%&)*+,-'.(/012$%XYZ[\]^_`abcd&'()*+,-./0123-7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^6 Construct a 4 struct initialized to zero.<"Frees the memory allocated by the 4. If  freeSegment is  Y: it frees the actual byte data. If the reference count of array is greater than one, the 4& wrapper is preserved but the size of array will be set to zero.= Transfers the data from the 4 into a new immutable ,x.The 4( is freed unless the reference count of array is greater than one, the 4& wrapper is preserved but the size of array will be set to zero.This is identical to using ,y and Gz together.>Creates a new 4 with a reference count of 1.? bCreate byte array containing the data. The data will be owned by the array and will be freed with GM#, i.e. it could be allocated using Gu.@-Atomically decrements the reference count of array by one. If the reference count drops to 0, all memory allocated by the array is released. This function is thread-safe and may be called from any thread.45efghij6789:;<array: a 4  freeSegment: if  Y' the actual byte data is freed as well Returns: the element data if  freeSegment is  X, otherwise  _*. The element data should be freed using GM. =array: a 4 Returns: a new immutable ,x7 representing same byte data that was in the array >Returns: the new 4 ?data: byte data for the array Returns: a new 4 @array: A 4 AB 456789:;<=>?@ 4567<=>?@89:;45efghij6789:;<=>?@AB.7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^F4Maps a file into memory. On UNIX, this is using the mmap() function.If writable is  Y, the mapped buffer may be modified, otherwise it is an error to modify the mapped buffer. Modifications to the buffer are not visible to other processes mapping the same file, and are not written back to the file.PNote that modifications of the underlying file might affect the contents of the C. Therefore, mapping should only be used if the file will not be modified, or if all modifications of the file are done atomically (e.g. using Ge).If filenameW is the name of an empty, regular file, the function will successfully return an empty CB. In other cases of size 0 (e.g. device files such as /dev/null), error will be set to the @d value G_FILE_ERROR_INVAL.G 4Maps a file into memory. On UNIX, this is using the mmap() function.If writable is  Y, the mapped buffer may be modified, otherwise it is an error to modify the mapped buffer. Modifications to the buffer are not visible to other processes mapping the same file, and are not written back to the file.PNote that modifications of the underlying file might affect the contents of the C. Therefore, mapping should only be used if the file will not be modified, or if all modifications of the file are done atomically (e.g. using Ge).HThis call existed before C6 had refcounting and is currently exactly the same as M.I"Creates a new ,x' which references the data mapped from filec. The mapped contents of the file must not be modified after creating this bytes object, because a ,x should be immutable.JReturns the contents of a C.?Note that the contents may not be zero-terminated, even if the C is backed by a text file.If the file is empty then  _ is returned.K(Returns the length of the contents of a C.L"Increments the reference count of file; by one. It is safe to call this function from any thread.M"Decrements the reference count of fileB by one. If the reference count drops to 0, unmaps the buffer of file and frees it.1It is safe to call this function from any thread. Since 2.22CDklmnopqrsEFfilenameB: The path of the file to load, in the GLib filename encoding writable): whether the mapping should be writable Returns: a newly allocated C which must be unref'd with M, or  _ if the mapping failed.  (Can throw \]) Gfd*: The file descriptor of the file to load writable): whether the mapping should be writable Returns: a newly allocated C which must be unref'd with M, or  _ if the mapping failed.  (Can throw \]) Hfile: a C Ifile: a C Returns: A newly allocated ,x referencing data from file Jfile: a C Returns: the contents of file, or  _. Kfile: a C Returns: the length of the contents of file. Lfile: a C Returns: the passed in C. Mfile: a C N CDEFGHIJKLM CDEHIJKFGLMCDklmnopqrsEFGHIJKLMN/7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^Q Construct a O struct initialized to zero.Z Adds a string onto the end of a O, expanding it if necessary.[Adds a byte onto the end of a O, expanding it if necessary.\Appends len bytes of val to string . Because len is provided, val: may contain embedded nuls and need not be nul-terminated.aSince this function does not stop at nul bytes, it is the caller's responsibility to ensure that val has at least len addressable bytes.]FConverts a Unicode character into UTF-8, and appends it to the string.^Appends  unescaped to stringT, escaped any characters that are reserved in URIs using URI-style escape sequences._@Converts all uppercase ASCII letters to lowercase ASCII letters.`@Converts all lowercase ASCII letters to uppercase ASCII letters.a&Copies the bytes from a string into a OC, destroying any previous contents. It is rather like the standard strcpy()] function, except that you do not have to worry about having enough space to copy the string.b Converts a O to lowercase.c-Compares two strings for equality, returning  Y! if they are equal. For use with NO.dRemoves len bytes from a O, starting at position pos. The rest of the O! is shifted down to fill the gap.e#Frees the memory allocated for the O. If  freeSegment is  Y, it also frees the character data. If it's  XK, the caller gains ownership of the buffer and must free it after use with GM.f"'Transfers ownership of the contents of string to a newly allocated ,x. The OE structure itself is deallocated, and it is therefore invalid to use string after invoking this function.Note that while Oh ensures that its buffer always has a trailing nul character (not reflected in its "len"), the returned ,xW does not include this extra nul; i.e. it has length exactly equal to the "len" member.gCreates a hash code for str; for use with NO.h"Inserts a copy of a string into a O, expanding it if necessary.iInserts a byte into a O, expanding it if necessary.jInserts len bytes of val into string at pos . Because len is provided, val> may contain embedded nuls and need not be nul-terminated. If pos4 is -1, bytes are inserted at the end of the string.aSince this function does not stop at nul bytes, it is the caller's responsibility to ensure that val has at least len addressable bytes.k]Converts a Unicode character into UTF-8, and insert it into the string at the given position.l9Overwrites part of a string, lengthening it if necessary.meOverwrites part of a string, lengthening it if necessary. This function will work with embedded nuls.n#Adds a string on to the start of a O, expanding it if necessary.o Adds a byte onto the start of a O, expanding it if necessary.p Prepends len bytes of val to string . Because len is provided, val: may contain embedded nuls and need not be nul-terminated.aSince this function does not stop at nul bytes, it is the caller's responsibility to ensure that val has at least len addressable bytes.qGConverts a Unicode character into UTF-8, and prepends it to the string.rSets the length of a O. If the length is less than the current length, the string will be truncated. If the length is greater than the current length, the contents of the newly added area are undefined. (However, as always, string->str[string->len] will be a nul byte.)s3Cuts off the end of the GString, leaving the first len bytes.t Converts a O to uppercase.DOPtuvwxyz{|}~QRSTUVWXYZstring: a O val': the string to append onto the end of string Returns: string [string: a O c%: the byte to append onto the end of string Returns: string \string: a O val: bytes to append len: number of bytes of val to use Returns: string ]string: a O wc: a Unicode character Returns: string ^string: a O  unescaped : a string reservedCharsAllowed=: a string of reserved characters allowed to be used, or  _  allowUtf8: set  Y3 if the escaped string may include UTF8 characters Returns: string _string : a GString Returns: passed-in stringw pointer, with all the uppercase characters converted to lowercase in place, with semantics that exactly match G{. `string : a GString Returns: passed-in stringw pointer, with all the lowercase characters converted to uppercase in place, with semantics that exactly match G|. astring: the destination O/. Its current contents are destroyed. rval: the string to copy into string Returns: string bstring: a O Returns: the O cv: a O v2 : another O Returns:  YC if the strings are the same length and contain the same bytes dstring: a O pos(: the position of the content to remove lenK: the number of bytes to remove, or -1 to remove all following bytes Returns: string estring: a O  freeSegment: if  Y-, the actual character data is freed as well Returns: the character data of string (i.e.  _ if  freeSegment is  Y) fstring: a O Returns: A newly allocated ,x containing contents of string; string itself is freed gstr: a string to hash Returns: hash code for str hstring: a O pos0: the position to insert the copy of the string val: the string to insert Returns: string istring: a O pos": the position to insert the byte c: the byte to insert Returns: string jstring: a O pos: position in string; where insertion should happen, or -1 for at the end val: bytes to insert len: number of bytes of val to insert Returns: string kstring: a O posZ: the position at which to insert character, or -1 to append at the end of the string wc: a Unicode character Returns: string lstring: a O pos-: the position at which to start overwriting val%: the string that will overwrite the string starting at pos Returns: string mstring: a O pos-: the position at which to start overwriting val%: the string that will overwrite the string starting at pos len$: the number of bytes to write from val Returns: string nstring: a O val(: the string to prepend on the start of string Returns: string ostring: a O c*: the byte to prepend on the start of the O Returns: string pstring: a O val: bytes to prepend len: number of bytes in val to prepend Returns: string qstring: a O wc: a Unicode character Returns: string rstring: a O len: the new length Returns: string sstring: a O len: the new size of string Returns: string tstring: a O Returns: string uv&OPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrst&OPQRZ[\]^_`abcdefghijklmnopqrstXYVWUSTCOPtuvwxyz{|}~QRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuv17Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^|Returns a negative number if a comes before b0, 0 if they are equal, and a positive number if a comes after b.The a and b- iterators must point into the same sequence.}Returns the position of iter~Returns whether iter is the begin iteratorReturns whether iter is the end iterator yz{|a: a y b: a y Returns: a negative number if a comes before b4, 0 if they are equal, and a positive number if a comes after b }iter: a y Returns: the position of iter ~iter: a y Returns: whether iter is the begin iterator iter: a y Returns: Whether iter is the end iterator yz{|}~yz{|}~ yz{|}~27Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Frees the memory allocated for seq. If seqY has a data destroy function associated with it, that function is called on all items in seq.Returns the length of seqf. Note that this method is O(h) where `h' is the height of the tree. It is thus more efficient to use # when comparing the length to zero.0Returns  Y% if the sequence contains zero items.BThis function is functionally identical to checking the result of P being equal to zero. However this function is implemented in O(1) running time.Returns the data that iter points to.Moves the item pointed to by src to the position indicated by dest. After calling this function dest. will point to the position immediately after src. It is allowed for src and dest# to point into different sequences. Inserts the (begin, end2) range at the destination pointed to by ptr. The begin and end< iters must point into the same sequence. It is allowed for dest? to point to a different sequence than the one pointed into by begin and end.If dest! is NULL, the range indicated by begin and end" is removed from the sequence. If dest$ iter points to a place within the (begin, end!) range, the range does not move.Removes the item pointed to by iter;. It is an error to pass the end iterator to this function.yIf the sequence has a data destroy function associated with it, this function is called on the data for the removed item.Removes all items in the (begin, end) range.zIf the sequence has a data destroy function associated with it, this function is called on the data for the removed items.,Changes the data for the item pointed to by iter to be datat. If the sequence has a data destroy function associated with it, that function is called on the existing data that iter pointed to.Swaps the items pointed to by a and b. It is allowed for a and b$ to point into difference sequences.seq: a  seq: a  Returns: the length of seq seq: a  Returns:  Y% if the sequence is empty, otherwise  X. iter: a 1} Returns: the data that iter points to src: a 1} pointing to the item to move dest: a 1}9 pointing to the position to which the item is moved dest: a 1} begin: a 1} end: a 1} iter: a 1} begin: a 1} end: a 1} iter: a 1} data: new data for the item a: a 1} b: a 1}   47Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.    87Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^,Returns a new string containing the text in stringToExpand] with references and escape sequences expanded. References refer to the last match done with string against regex" and have the same syntax used by ~.The stringToExpand must be UTF-8 encoded even if  G_REGEX_RAW was passed to .The backreferences are extracted from the string passed to the match function, so you cannot call this function after freeing the string. matchInfo may be  _ in which case stringToExpand must not contain references. For instance "foo\n" does not refer to an actual pattern and '\n' merely will be replaced with \n character, while to expand "\0" (whole match) one needs the result of a match. Use G to find out whether stringToExpand contains references. Retrieves the text matching the matchNumn'th capturing parentheses. 0 is the full text of the match, 1 is the first paren set, 2 the second, and so on.If matchNum is a valid sub pattern but it didn't match anything (e.g. sub pattern 1, matching "b" against "(a)?b") then an empty string is returned.AIf the match was obtained using the DFA algorithm, that is using  or , the retrieved string is not that of a set of parentheses but that of a matched substring. Substrings are matched in reverse order of length, so 0 is the longest match.~The string is fetched from the string passed to the match function, so you cannot call this function after freeing the string.Bundles up pointers to each of the matching substrings from a match and stores them in an array of gchar pointers. The first element in the returned array is the match number 0, i.e. the entire matched text.{If a sub pattern didn't match anything (e.g. sub pattern 1, matching "b" against "(a)?b") then an empty string is inserted.FIf the last match was obtained using the DFA algorithm, that is using  or , the retrieved strings are not that matched by sets of parentheses but that of the matched substring. Substrings are matched in reverse order of length, so the first one is the longest match.The strings are fetched from the string passed to the match function, so you cannot call this function after freeing the string.<Retrieves the text matching the capturing parentheses named name.If name is a valid sub pattern name but it didn't match anything (e.g. sub pattern "X", matching "b" against "(?P<X>a)?b") then an empty string is returned.~The string is fetched from the string passed to the match function, so you cannot call this function after freeing the string.CRetrieves the position in bytes of the capturing parentheses named name.If namey is a valid sub pattern name but it didn't match anything (e.g. sub pattern "X", matching "b" against "(?P<X>a)?b") then startPos and endPos are set to -1 and  Y is returned.'Retrieves the position in bytes of the matchNumn'th capturing parentheses. 0 is the full text of the match, 1 is the first paren set, 2 the second, and so on.If matchNumm is a valid sub pattern but it didn't match anything (e.g. sub pattern 1, matching "b" against "(a)?b") then startPos and endPos are set to -1 and  Y is returned.AIf the match was obtained using the DFA algorithm, that is using  or , the retrieved position is not that of a set of parentheses but that of a matched substring. Substrings are matched in reverse order of length, so 0 is the longest match.If  matchInfo is not  _, calls ; otherwise does nothing.Retrieves the number of matched substrings (including substring 0, that is the whole matched text), so 1 is returned if the pattern has no substrings in it and 0 is returned if the match failed.FIf the last match was obtained using the DFA algorithm, that is using  or v, the retrieved count is not that of the number of capturing parentheses but that of the number of matched substrings.Returns  object used in  matchInfo0. It belongs to Glib and must not be freed. Use ' if you need to keep it after you free  matchInfo object.!Returns the string searched with  matchInfo. This is the string passed to  or ~5 so you may not free it before calling this function.zUsually if the string passed to g_regex_match*() matches as far as it goes, but is too short to match the entire pattern,  X is returned. There are circumstances where it might be helpful to distinguish this case from other cases in which there is no match.Consider, for example, an application where a human is required to type in data for a field with specific formatting requirements. An example might be a date in the form ddmmmyy, defined by the pattern "^\d?\d(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)\d\d$". If the application sees the user s keystrokes one by one, and can check that what has been typed so far is potentially valid, it is able to raise an error as soon as a mistake is made.@GRegex supports the concept of partial matching by means of the G_REGEX_MATCH_PARTIAL_SOFT and G_REGEX_MATCH_PARTIAL_HARD0 flags. When they are used, the return code for  or  is, as usual,  Y for a complete match,  X- otherwise. But, when these functions return  X1, you can check if the match was partial calling .The difference between G_REGEX_MATCH_PARTIAL_SOFT and G_REGEX_MATCH_PARTIAL_HARD2 is that when a partial match is encountered with G_REGEX_MATCH_PARTIAL_SOFTI, matching continues to search for a possible complete match, while with G_REGEX_MATCH_PARTIAL_HARD0 matching stops at the partial match. When both G_REGEX_MATCH_PARTIAL_SOFT and G_REGEX_MATCH_PARTIAL_HARD& are set, the latter takes precedence.lThere were formerly some restrictions on the pattern for partial matching. The restrictions no longer apply.<See pcrepartial(3) for more information on partial matching.7Returns whether the previous match operation succeeded.KScans for the next match using the same parameters of the previous call to  or  that returned  matchInfo.qThe match is done on the string passed to the match function, so you cannot free it before calling this function.Increases reference count of  matchInfo by 1.Decreases reference count of  matchInfol by 1. When reference count drops to zero, it frees all the memory associated with the match_info structure.# matchInfo: a  or  _ stringToExpand: the string to expand Returns: the expanded string, or  _ if an error occurred  (Can throw \])  matchInfo:  structure matchNum: number of the sub expression Returns: The matched substring, or  _@ if an error occurred. You have to free the string yourself  matchInfo: a  structure Returns: a  _C-terminated array of gchar * pointers. It must be freed using Gf#. If the previous match failed  _ is returned  matchInfo:  structure name: name of the subexpression Returns: The matched substring, or  _@ if an error occurred. You have to free the string yourself  matchInfo:  structure name: name of the subexpression Returns:  Y if the position was fetched,  X3 otherwise. If the position cannot be fetched, startPos and endPos are left unchanged.  matchInfo:  structure matchNum: number of the sub expression Returns:  Y if the position was fetched,  X1 otherwise. If the position cannot be fetched, startPos and endPos are left unchanged  matchInfo: a , or  _  matchInfo: a  structure Returns:: Number of matched substrings, or -1 if an error occurred  matchInfo: a  Returns:  object used in  matchInfo  matchInfo: a  Returns: the string searched with  matchInfo  matchInfo: a  structure Returns:  Y if the match was partial,  X otherwise  matchInfo: a  structure Returns:  Y. if the previous match operation succeeded,  X otherwise  matchInfo: a  structure  (Can throw \])  matchInfo: a  Returns:  matchInfo  matchInfo: a  ":7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.   7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^5  !"#$%&'()*+,-./23456789:>7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^3No description available in the introspection data."A test to perform on a file using G.5Flags to modify the format of the string returned by G.Flags used internally in the = implementation.OA bitwise combination representing a condition to watch for on an event source.Specifies properties of a ;*. Some of the flags can only be read with ;, but not changed with ;."Flags which influence the parsing.+Flags specifying the level of log messages.NIt is possible to change how GLib treats messages of the various levels using g_log_set_handler() and G.A mixed enumerated type and flags field. You must specify one type (string, strdup, boolean, tristate). Additionally, you may optionally bitwise OR the type with the flag .RIt is likely that this enum will be extended in the future to support other types..Flags that affect the behaviour of the parser.&Flags which modify individual options.&Flags specifying compile-time options.$Flags specifying match-time options.Flags passed to G, G and G.Flags to pass to G to control input and output.Note that in contrast with G/, the default is to not show stdout and stderr.STest traps are guards around forked tests. These flags determine what traps to set.RSpecifies which nodes are visited during several of the tree functions, including g_node_traverse() and  g_node_find().3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.3No description available in the introspection data.Catch-all for unknown values Y_ if the file is a regular file (not a directory). Note that this test will also return  Y; if the tested file is a symlink to a regular file. Y if the file is a symlink. Y if the file is a directory. Y if the file is executable. YA if the file exists. It may or may not be a regular file.Catch-all for unknown valuesbehave the same as Gqinclude the exact number of bytes as part of the returned string. For example, "45.6 kB (45,612 bytes)". use IEC (base 1024) units with "KiB"-style suffixes. IEC units should only be used for reporting things with a strong "power of 2" basis, like RAM sizes or RAID stripe sizes. Network and storage sizes should be reported in the normal SI units.Catch-all for unknown values&set if the hook has not been destroyed&set if the hook is currently being run<A mask covering all bits reserved for hook flags; see ECatch-all for unknown valuesThere is data to read.'Data can be written (without blocking).There is urgent data to read.Error condition.WHung up (the connection has been broken, usually for pipes and sockets).1Invalid request. The file descriptor is not open.Catch-all for unknown values%turns on append mode, corresponds to O_APPEND, (see the documentation of the UNIX open() syscall)2turns on nonblocking mode, corresponds to  O_NONBLOCK/O_NDELAY$ (see the documentation of the UNIX open() syscall)Oindicates that the io channel is readable. This flag cannot be changed.Oindicates that the io channel is writable. This flag cannot be changed.a misspelled version of gIOFLAGISWRITABLE that existed before the spelling was fixed in GLib 2.30. It is kept here for compatibility reasons. Deprecated since 2.30=indicates that the io channel is seekable, i.e. that ;8 can be used on it. This flag cannot be changed.,the mask that specifies all the valid flags.5the mask of the flags that are returned from ;<the mask of the flags that the user can modify with ;Catch-all for unknown valuesNo flags, default behaviour Use this flag if you plan to write the (possibly modified) contents of the key file back to a file; otherwise all comments will be lost when the key file is written back. Use this flag if you plan to write the (possibly modified) contents of the key file back to a file; otherwise only the translations for the current language will be written back. Catch-all for unknown values  internal flag  internal flaglog level for errors, see  g_error();. This level is also used for messages produced by  g_assert().5log level for critical warning messages, see  g_critical();. This level is also used for messages produced by g_return_if_fail() and g_return_val_if_fail().log level for warnings, see  g_warning()log level for messages, see  g_message()*log level for informational messages, see g_info()"log level for debug messages, see  g_debug()a mask including all log levelsCatch-all for unknown values;used to terminate the list of attributes to collectcollect the string pointer directly from the attribute_values[] array. Expects a parameter of type (const char **). If V is specified and the attribute isn't present then the pointer will be set to  _as with 8, but expects a parameter of type (char **) and Gu?s the returned pointer. The pointer must be freed with GMcexpects a parameter of type (gboolean *) and parses the attribute value as a boolean. Sets  X if the attribute isn't present. Valid boolean values consist of (case-insensitive) "false", "f", "no", "n", "0" and "true", "t", "yes", "y", "1"as with g, but in the case of a missing attribute a value is set that compares equal to neither  X nor  Y- G_MARKUP_COLLECT_OPTIONAL is impliedcan be bitwise ORed with the other fields. If present, allows the attribute not to appear. A default value is set depending on what value type is usedCatch-all for unknown valuesflag you should not useUWhen this flag is set, CDATA marked sections are not passed literally to the  passthroughZ function of the parser. Instead, the content of the section (without the  <![CDATA[ and ]]>) is passed to the text+ function. This flag was added in GLib 2.12Normally errors caught by GMarkup itself have line/column information prefixed to them to let the caller know the location of the error. When this flag is set the location information is also prefixed to errors generated by the  implementation functions Ignore (don't report) qualified attributes and tags, along with their contents. A qualified attribute or tag is one that contains ':' in its name (ie: is in another namespace). Since: 2.40.!Catch-all for unknown values"No flags. Since: 2.42.#The option doesn't appear in --help output.$6The option appears in the main section of the --help* output, even if it is defined in a group.%For options of the @L kind, this flag indicates that the sense of the option is reversed.&For options of the @` kind, this flag indicates that the callback does not take any argument (like a @ option). Since 2.8'For options of the @ kind, this flag indicates that the argument should be passed to the callback in the GLib filename encoding rather than UTF-8. Since 2.8(For options of the @v kind, this flag indicates that the argument supply is optional. If no argument is given then data of GOptionParseFunc' will be set to NULL. Since 2.8)dThis flag turns off the automatic conflict resolution which prefixes long option names with  groupname- if there is a conflict. This option should only be used in situations where aliasing is necessary to model some legacy commandline interface. It is not safe to use this option, unless all option groups are under your direct control. Since 2.8.*Catch-all for unknown values+Letters in the pattern match both upper- and lowercase letters. This option can be changed within a pattern by a "(?i)" option setting.,pBy default, GRegex treats the strings as consisting of a single line of characters (even if it actually contains newlines). The "start of line" metacharacter ("^") matches only at the start of the string, while the "end of line" metacharacter ("$") matches only at the end of the string, or before a terminating newline (unless G_REGEX_DOLLAR_ENDONLY is set). When G_REGEX_MULTILINE is set, the "start of line" and "end of line" constructs match immediately following or immediately before any newline in the string, respectively, as well as at the very start and end. This can be changed within a pattern by a "(?m)" option setting.-A dot metacharater (".") in the pattern matches all characters, including newlines. Without it, newlines are excluded. This option can be changed within a pattern by a ("?s") option setting..Whitespace data characters in the pattern are totally ignored except when escaped or inside a character class. Whitespace does not include the VT character (code 11). In addition, characters between an unescaped "#" outside a character class and the next newline character, inclusive, are also ignored. This can be changed within a pattern by a "(?x)" option setting./!The pattern is forced to be "anchored", that is, it is constrained to match only at the first matching point in the string that is being searched. This effect can also be achieved by appropriate constructs in the pattern itself such as the "^" metacharater.0A dollar metacharacter ("$") in the pattern matches only at the end of the string. Without this option, a dollar also matches immediately before the final character if it is a newline (but not before any other newlines). This option is ignored if G_REGEX_MULTILINE is set.1Inverts the "greediness" of the quantifiers so that they are not greedy by default, but become greedy if followed by "?". It can also be set by a "(?U)" option setting within the pattern.2tUsually strings must be valid UTF-8 strings, using this flag they are considered as a raw sequence of bytes.3 Disables the use of numbered capturing parentheses in the pattern. Any opening parenthesis that is not followed by "?" behaves as if it were followed by "?:" but named parentheses can still be used for capturing (and they acquire numbers in the usual way).4Optimize the regular expression. If the pattern will be used many times, then it may be worth the effort to optimize it to improve the speed of matches.5[Limits an unanchored pattern to match before (or at) the first newline. Since: 2.346Names used to identify capturing subpatterns need not be unique. This can be helpful for certain types of pattern when it is known that only one instance of the named subpattern can ever be matched.7Usually any newline character or character sequence is recognized. If this option is set, the only recognized newline character is '\r'.8Usually any newline character or character sequence is recognized. If this option is set, the only recognized newline character is '\n'.9Usually any newline character or character sequence is recognized. If this option is set, the only recognized newline character sequence is '\r\n'.:Usually any newline character or character sequence is recognized. If this option is set, the only recognized newline character sequences are '\r', '\n', and '\r\n'. Since: 2.34;Usually any newline character or character sequence is recognised. If this option is set, then "\R" only recognizes the newline characters '\r', '\n' and '\r\n'. Since: 2.34<`Changes behaviour so that it is compatible with JavaScript rather than PCRE. Since: 2.34=Catch-all for unknown values>!The pattern is forced to be "anchored", that is, it is constrained to match only at the first matching point in the string that is being searched. This effect can also be achieved by appropriate constructs in the pattern itself such as the "^" metacharater.?Specifies that first character of the string is not the beginning of a line, so the circumflex metacharacter should not match before it. Setting this without G_REGEX_MULTILINE (at compile time) causes circumflex never to match. This option affects only the behaviour of the circumflex metacharacter, it does not affect "\A".@Specifies that the end of the subject string is not the end of a line, so the dollar metacharacter should not match it nor (except in multiline mode) a newline immediately before it. Setting this without G_REGEX_MULTILINE (at compile time) causes dollar never to match. This option affects only the behaviour of the dollar metacharacter, it does not affect "\Z" or "\z".AAn empty string is not considered to be a valid match if this option is set. If there are alternatives in the pattern, they are tried. If all the alternatives match the empty string, the entire match fails. For example, if the pattern "a?b?" is applied to a string not beginning with "a" or "b", it matches the empty string at the start of the string. With this flag set, this match is not valid, so GRegex searches further into the string for occurrences of "a" or "b".B^Turns on the partial matching feature, for more documentation on partial matching see 8.CAOverrides the newline definition set when creating a new 0, setting the '\r' character as line terminator.DAOverrides the newline definition set when creating a new 0, setting the '\n' character as line terminator.EAOverrides the newline definition set when creating a new <, setting the '\r\n' characters sequence as line terminator.FAOverrides the newline definition set when creating a new , any Unicode newline sequence is recognised as a newline. These are '\r', '\n' and '\rn', and the single characters U+000B LINE TABULATION, U+000C FORM FEED (FF), U+0085 NEXT LINE (NEL), U+2028 LINE SEPARATOR and U+2029 PARAGRAPH SEPARATOR.GAOverrides the newline definition set when creating a new ^; any '\r', '\n', or '\r\n' character sequence is recognized as a newline. Since: 2.34HJOverrides the newline definition for "\R" set when creating a new i; only '\r', '\n', or '\r\n' character sequences are recognized as a newline by "\R". Since: 2.34IJOverrides the newline definition for "\R" set when creating a new =; any Unicode newline character or character sequence are recognized as a newline by "\R". These are '\r', '\n' and '\rn', and the single characters U+000B LINE TABULATION, U+000C FORM FEED (FF), U+0085 NEXT LINE (NEL), U+2028 LINE SEPARATOR and U+2029 PARAGRAPH SEPARATOR. Since: 2.34J An alias for G_REGEX_MATCH_PARTIAL . Since: 2.34KATurns on the partial matching feature. In contrast to to G_REGEX_MATCH_PARTIAL_SOFT, this stops matching as soon as a partial match is found, without continuing to search for a possible complete match. See 8" for more information. Since: 2.34LLike G_REGEX_MATCH_NOTEMPTY, but only applied to the start of the matched string. For anchored patterns this can only happen for pattern containing "\K". Since: 2.34MCatch-all for unknown valuesNno flags, default behaviourOthe parent's open file descriptors will be inherited by the child; otherwise all descriptors except stdin, stdout and stderr will be closed before calling exec() in the child.PAthe child will not be automatically reaped; you must use g_child_watch_add() yourself (or call  waitpid() or handle SIGCHLD. yourself), or the child will become a zombie.Qargv[0]K need not be an absolute path, it will be looked for in the user's PATH.R}the child's standard output will be discarded, instead of going to the same location as the parent's standard output.S-the child's standard error will be discarded.Trthe child will inherit the parent's standard input (by default, the child's standard input is attached to  /dev/null).Uthe first element of argv is the file to execute, while the remaining elements are the actual argument vector to pass to the file. Normally G uses argv[0]3 as the file to execute, and passes all of argv to the child.Vif argv[0]> is not an abolute path, it will be looked for in the PATH7 from the passed child environment. Since: 2.34Wcreate all pipes with the  O_CLOEXEC flag set. Since: 2.40XCatch-all for unknown valuesYIf this flag is given, the child process will inherit the parent's stdin. Otherwise, the child's stdin is redirected to  /dev/null.ZIf this flag is given, the child process will inherit the parent's stdout. Otherwise, the child's stdout will not be visible, but it will be captured to allow later tests with g_test_trap_assert_stdout().[If this flag is given, the child process will inherit the parent's stderr. Otherwise, the child's stderr will not be visible, but it will be captured to allow later tests with g_test_trap_assert_stderr().\Catch-all for unknown values]-Redirect stdout of the test child to  /dev/null so it cannot be observed on the console during test runs. The actual output is still captured though to allow later tests with g_test_trap_assert_stdout().^-Redirect stderr of the test child to  /dev/null so it cannot be observed on the console during test runs. The actual output is still captured though to allow later tests with g_test_trap_assert_stderr()._If this flag is given, stdin of the child process is shared with stdin of its parent process. It is redirected to  /dev/null otherwise.`Catch-all for unknown valuesaonly leaf nodes should be visited. This name has been introduced in 2.6, for older version use e.bonly non-leaf nodes should be visited. This name has been introduced in 2.6, for older version use f.call nodes should be visited.da mask of all traverse flags.e identical to a.f identical to b.gCatch-all for unknown values      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefgabcdefg]^_`YZ[\NOPQRSTUVWX>?@ABCDEFGHIJKLM+,-./0123456789:;<="#$%&'()* !     F         ! "#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLM NOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~77Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a  struct initialized to zero.*Gets the position of the first child of a  which contains the given data.Gets the position of a  with respect to its siblings. child must be a child of node9. The first child is numbered 0, the second 1, and so on.Gets the depth of a .If node is  _m the depth is 0. The root node has a depth of 1. For the children of the root node the depth is 2. And so on.Removes root> and its children from the tree, freeing any memory allocated.Returns  Y if node is an ancestor of  descendant(. This is true if node is the parent of  descendant#, or if node is the grandparent of  descendant etc.2Gets the maximum height of all branches beneath a (. This is the maximum distance from the  to all leaf nodes.If root is  _, 0 is returned. If root$ has no children, 1 is returned. If root( has children, 2 is returned. And so on.!Gets the number of children of a .#Gets the number of nodes in a tree.(Reverses the order of the children of a 5. (It doesn't change the order of the grandchildren.) Unlinks a . from a tree, resulting in two separate trees.)node: a  data: the data to find Returns: the index of the child of node which contains data!, or -1 if the data is not found node: a  child : a child of node Returns: the position of child with respect to its siblings node: a  Returns: the depth of the  root*: the root of the tree/subtree to destroy node: a   descendant: a  Returns:  Y if node is an ancestor of  descendant root: a  Returns:( the maximum height of the tree beneath root node: a  Returns: the number of children of node root: a  flags8: which types of children are to be counted, one of >, > and > Returns:! the number of nodes in the tree node: a . node: the 1 to unlink, which becomes the root of a new tree (?7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^.Creates a new empty  object. Use , ,  or  to read an existing key file."Returns the value associated with key under  groupName as a boolean.If key cannot be found then  X is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND). Likewise, if the value associated with key) cannot be interpreted as a boolean then  X is returned and error is set to G_KEY_FILE_ERROR_INVALID_VALUE.#Returns the values associated with key under  groupName as booleans.If key cannot be found then  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND*. Likewise, if the values associated with key( cannot be interpreted as booleans then  _ is returned and error is set to G_KEY_FILE_ERROR_INVALID_VALUE.Retrieves a comment above key from  groupName. If key is  _ then comment will be read from above  groupName . If both key and  groupName are  _, then comment5 will be read from above the first group in the file.?Note that the returned string includes the '#' comment markers. "Returns the value associated with key under  groupName as a double. If  groupName is  _, the start_group is used.If key* cannot be found then 0.0 is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND). Likewise, if the value associated with key< cannot be interpreted as a double then 0.0 is returned and error is set to G_KEY_FILE_ERROR_INVALID_VALUE. #Returns the values associated with key under  groupName as doubles.If key cannot be found then  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND*. Likewise, if the values associated with key' cannot be interpreted as doubles then  _ is returned and error is set to G_KEY_FILE_ERROR_INVALID_VALUE./Returns all groups in the key file loaded with keyFile'. The array of returned groups will be  _-terminated, so length may optionally be  _."Returns the value associated with key under  groupName0 as a signed 64-bit integer. This is similar to 2 but can return 64-bit results without truncation."Returns the value associated with key under  groupName as an integer.If key( cannot be found then 0 is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND). Likewise, if the value associated with key< cannot be interpreted as an integer then 0 is returned and error is set to G_KEY_FILE_ERROR_INVALID_VALUE.#Returns the values associated with key under  groupName as integers.If key cannot be found then  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND*. Likewise, if the values associated with key( cannot be interpreted as integers then  _ is returned and error is set to G_KEY_FILE_ERROR_INVALID_VALUE.$Returns all keys for the group name  groupName&. The array of returned keys will be  _-terminated, so length may optionally be  _. In the event that the  groupName cannot be found,  _ is returned and error is set to  G_KEY_FILE_ERROR_GROUP_NOT_FOUND."Returns the value associated with key under  groupName translated in the given locale if available. If locale is  _$ then the current locale is assumed.If key cannot be found then  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND. If the value associated with keyg cannot be interpreted or no suitable translation can be found then the untranslated value is returned.#Returns the values associated with key under  groupName translated in the given locale if available. If locale is  _$ then the current locale is assumed.If key cannot be found then  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND . If the values associated with key cannot be interpreted or no suitable translations can be found then the untranslated values are returned. The returned array is  _-terminated, so length may optionally be  _.0Returns the name of the start group of the file.)Returns the string value associated with key under  groupName . Unlike 1, this function handles escape sequences like \s.&In the event the key cannot be found,  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND. In the event that the  groupName cannot be found,  _ is returned and error is set to  G_KEY_FILE_ERROR_GROUP_NOT_FOUND.#Returns the values associated with key under  groupName.&In the event the key cannot be found,  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND. In the event that the  groupName cannot be found,  _ is returned and error is set to  G_KEY_FILE_ERROR_GROUP_NOT_FOUND."Returns the value associated with key under  groupName3 as an unsigned 64-bit integer. This is similar to : but can return large positive results without truncation.&Returns the raw value associated with key under  groupName. Use ' to retrieve an unescaped UTF-8 string.&In the event the key cannot be found,  _ is returned and error is set to G_KEY_FILE_ERROR_KEY_NOT_FOUND. In the event that the  groupName cannot be found,  _ is returned and error is set to  G_KEY_FILE_ERROR_GROUP_NOT_FOUND.)Looks whether the key file has the group  groupName.2"Loads a key file from the data in bytes into an empty 1 structure. If the object cannot be created then error is set to a @.+Loads a key file from memory into an empty 1 structure. If the object cannot be created then error is set to a @.)This function looks for a key file named file in the paths returned from Gb and Gc, loads the file into keyFile% and returns the file's full path in fullPath+. If the file could not be loaded then an error is set to either a @d or @.)This function looks for a key file named file in the paths specified in  searchDirs, loads the file into keyFile% and returns the file's full path in fullPath+. If the file could not be loaded then an error is set to either a @d or @.Loads a key file into an empty 1 structure. If the file could not be loaded then error is set to either a @d or @.Removes a comment above key from  groupName. If key is  _ then comment will be removed above  groupName . If both key and  groupName are  _, then comment3 will be removed above the first group in the file.Removes the specified group,  groupName, from the key file.Removes key in  groupName from the key file.(Writes the contents of keyFile to filename using Ge.3This function can fail for any of the reasons that Ge may fail.$Associates a new boolean value with key under  groupName. If key$ cannot be found then it is created.)Associates a list of boolean values with key under  groupName. If key( cannot be found then it is created. If  groupName is  _, the start_group is used.Places a comment above key from  groupName.If key is  _ then comment will be written above  groupName . If both key and  groupName are  _, then comment3 will be written above the first group in the file.FNote that this function prepends a '#' comment marker to each line of comment. #Associates a new double value with key under  groupName. If key$ cannot be found then it is created. (Associates a list of double values with key under  groupName. If key$ cannot be found then it is created.$Associates a new integer value with key under  groupName. If key$ cannot be found then it is created.$Associates a new integer value with key under  groupName. If key$ cannot be found then it is created.)Associates a list of integer values with key under  groupName. If key$ cannot be found then it is created.Sets the character which is used to separate values in lists. Typically ';' or ',' are used as separators. The default list separator is ';'.Associates a string value for key and locale under  groupName. If the translation for key$ cannot be found then it is created.'Associates a list of string values for key and locale under  groupName. If the translation for key$ cannot be found then it is created.#Associates a new string value with key under  groupName. If key( cannot be found then it is created. If  groupName, cannot be found then it is created. Unlike H, this function handles characters that need escaping, such as newlines.'Associates a list of string values for key under  groupName. If key( cannot be found then it is created. If  groupName$ cannot be found then it is created.$Associates a new integer value with key under  groupName. If key$ cannot be found then it is created.Associates a new value with key under  groupName.If key( cannot be found then it is created. If  groupName cannot be found then it is created. To set an UTF-8 string which may contain characters that need escaping (such as newlines or spaces), use . This function outputs keyFile as a string.FNote that this function never reports an error, so it is safe to pass  _ as error.  !Decreases the reference count of keyFile\ by 1. If the reference count reaches zero, frees the key file and all its allocated memory. 3No description available in the introspection data.aReturns: an empty . keyFile: a   groupName: a group name key: a key  (Can throw \]) keyFile: a   groupName: a group name key: a key Returns:B the values associated with the key as a list of booleans, or  _k if the key was not found or could not be parsed. The returned list of booleans should be freed with GM when no longer needed.  (Can throw \]) keyFile: a   groupName: a group name, or  _ key: a key Returns:% a comment that should be freed with GM  (Can throw \]) keyFile: a   groupName: a group name key: a key Returns:l the value associated with the key as a double, or 0.0 if the key was not found or could not be parsed.  (Can throw \]) keyFile: a   groupName: a group name key: a key Returns:B the values associated with the key as a list of doubles, or  _l if the key was not found or could not be parsed. The returned list of doubles should be freed with GM when no longer needed.  (Can throw \]) keyFile: a  Returns: a newly-allocated  _$-terminated array of strings. Use Gf to free it. keyFile: a non- _   groupName: a non- _ group name key: a non- _ key Returns:u the value associated with the key as a signed 64-bit integer, or 0 if the key was not found or could not be parsed.  (Can throw \]) keyFile: a   groupName: a group name key: a key Returns:l the value associated with the key as an integer, or 0 if the key was not found or could not be parsed.  (Can throw \]) keyFile: a   groupName: a group name key: a key Returns:C the values associated with the key as a list of integers, or  _m if the key was not found or could not be parsed. The returned list of integers should be freed with GM when no longer needed.  (Can throw \]) keyFile: a   groupName: a group name Returns: a newly-allocated  _&-terminated array of strings. Use Gf to free it.  (Can throw \]) keyFile: a   groupName: a group name key: a key locale: a locale identifier or  _ Returns: a newly allocated string or  _) if the specified key cannot be found.  (Can throw \]) keyFile: a   groupName: a group name key: a key locale: a locale identifier or  _ Returns: a newly allocated  _-terminated string array or  _A if the key isn't found. The string array should be freed with Gf.  (Can throw \]) keyFile: a  Returns:" The start group of the key file. keyFile: a   groupName: a group name key: a key Returns: a newly allocated string or  _) if the specified key cannot be found.  (Can throw \]) keyFile: a   groupName: a group name key: a key Returns: a  _-terminated string array or  _G if the specified key cannot be found. The array should be freed with Gf.  (Can throw \]) keyFile: a non- _   groupName: a non- _ group name key: a non- _ key Returns:x the value associated with the key as an unsigned 64-bit integer, or 0 if the key was not found or could not be parsed.  (Can throw \]) keyFile: a   groupName: a group name key: a key Returns: a newly allocated string or  _( if the specified key cannot be found.  (Can throw \]) keyFile: a   groupName: a group name Returns:  Y if  groupName is a part of keyFile,  X otherwise. keyFile : an empty  struct bytes: a ,x flags : flags from >  (Can throw \]) keyFile : an empty  struct data: key file loaded in memory length: the length of data3 in bytes (or (gsize)-1 if data is nul-terminated) flags : flags from >  (Can throw \]) keyFile : an empty  struct file2: a relative path to a filename to open and parse flags : flags from >  (Can throw \]) keyFile : an empty  struct file2: a relative path to a filename to open and parse  searchDirs:  _+-terminated array of directories to search flags : flags from >  (Can throw \]) keyFile : an empty  struct file@: the path of a filename to load, in the GLib filename encoding flags : flags from >  (Can throw \]) keyFile: a   groupName: a group name, or  _ key: a key  (Can throw \]) keyFile: a   groupName: a group name  (Can throw \]) keyFile: a   groupName: a group name key: a key name to remove  (Can throw \]) keyFile: a  filename#: the name of the file to write to  (Can throw \]) keyFile: a   groupName: a group name key: a key value:  Y or  X keyFile: a   groupName: a group name key: a key list: an array of boolean values keyFile: a   groupName: a group name, or  _ key: a key comment : a comment  (Can throw \]) keyFile: a   groupName: a group name key: a key value: an double value keyFile: a   groupName: a group name key: a key list: an array of double values keyFile: a   groupName: a group name key: a key value: an integer value keyFile: a   groupName: a group name key: a key value: an integer value keyFile: a   groupName: a group name key: a key list: an array of integer values keyFile: a   separator: the separator keyFile: a   groupName: a group name key: a key locale: a locale identifier string : a string keyFile: a   groupName: a group name key: a key locale: a locale identifier list: a  _*-terminated array of locale string values length: the length of list keyFile: a   groupName: a group name key: a key string : a string keyFile: a   groupName: a group name key: a key list: an array of string values length: number of string values in list keyFile: a   groupName: a group name key: a key value: an integer value keyFile: a   groupName: a group name key: a key value : a string  keyFile: a  Returns:8 a newly allocated string holding the contents of the   (Can throw \])  keyFile: a    1   1   `    7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^WCompiles the regular expression to an internal form, and does the initial setup of the  structure.;Returns the number of capturing subpatterns in the pattern.!Returns the compile options that regex was created with.sDepending on the version of PCRE that is used, this may or may not include flags set by option expressions such as (?i)4 found at the top-level within the compiled pattern."AChecks whether the pattern contains explicit CR or LF references.Returns the match options that regex was created with.vReturns the number of the highest back reference in the pattern, or 0 if the pattern does not contain back references.&Gets the number of characters in the longest lookbehind assertion in the pattern. This information is useful when doing multi-segment matching using the partial matching facilities.(Gets the pattern string associated with regex&, i.e. a copy of the string passed to .0Retrieves the number of the subexpression named name./Scans for a match in string for the pattern in regex. The  matchOptions8 are combined with the match options specified when the regexE structure was created, letting you have more flexibility in reusing  structures.A 8? structure, used to get information on the match, is stored in  matchInfo if not  _. Note that if  matchInfo is not  _1 then it is created even if the function returns  XJ, i.e. you must free it regardless if regular expression actually matched.QTo retrieve all the non-overlapping matches of the pattern in string you can use 8.C code  static void print_uppercase_words (const gchar *string) { // Print all uppercase-only words. GRegex *regex; GMatchInfo *match_info; regex = g_regex_new ("[A-Z]+", 0, 0, NULL); g_regex_match (regex, string, 0, &match_info); while (g_match_info_matches (match_info)) { gchar *word = g_match_info_fetch (match_info, 0); g_print ("Found: %s\n", word); g_free (word); g_match_info_next (match_info, NULL); } g_match_info_free (match_info); g_regex_unref (regex); }string is not copied and is used in 8 internally. If you use any 8 method (except 8) after freeing or modifying string! then the behaviour is undefined.Using the standard algorithm for regular expression matching only the longest match in the string is retrieved. This function uses a different algorithm so it can retrieve all the possible matches. For more documentation see .A 8? structure, used to get information on the match, is stored in  matchInfo if not  _. Note that if  matchInfo is not  _1 then it is created even if the function returns  XJ, i.e. you must free it regardless if regular expression actually matched.string is not copied and is used in 8 internally. If you use any 8 method (except 8) after freeing or modifying string! then the behaviour is undefined.Using the standard algorithm for regular expression matching only the longest match in the string is retrieved, it is not possible to obtain all the available matches. For instance matching "<a> <b> <c>" against the pattern "<.*>" you get "<a> <b> <c>".:This function uses a different algorithm (called DFA, i.e. deterministic finite automaton), so it can retrieve all the possible matches, all starting at the same point in the string. For instance matching "<a> <b> <c>" against the pattern "<.*>;" you would obtain three matches: "<a> <b> <c>", "<a> <b>" and "<a>".1The number of matched strings is retrieved using 8N. To obtain the matched strings and their position you can use, respectively, 8 and 8u. Note that the strings are returned in reverse order of length; that is, the longest matching string is given first.Note that the DFA algorithm is slower than the standard one and it is not able to capture substrings, so backreferences do not work.Setting  startPosition? differs from just passing over a shortened string and setting G_REGEX_MATCH_NOTBOLZ in the case of a pattern that begins with any kind of lookbehind assertion, such as "\b".A 8? structure, used to get information on the match, is stored in  matchInfo if not  _. Note that if  matchInfo is not  _1 then it is created even if the function returns  XJ, i.e. you must free it regardless if regular expression actually matched.string is not copied and is used in 8 internally. If you use any 8 method (except 8) after freeing or modifying string! then the behaviour is undefined./Scans for a match in string for the pattern in regex. The  matchOptions8 are combined with the match options specified when the regexE structure was created, letting you have more flexibility in reusing  structures.Setting  startPosition? differs from just passing over a shortened string and setting G_REGEX_MATCH_NOTBOLZ in the case of a pattern that begins with any kind of lookbehind assertion, such as "\b".A 8? structure, used to get information on the match, is stored in  matchInfo if not  _. Note that if  matchInfo is not  _1 then it is created even if the function returns  XJ, i.e. you must free it regardless if regular expression actually matched.string is not copied and is used in 8 internally. If you use any 8 method (except 8) after freeing or modifying string! then the behaviour is undefined.QTo retrieve all the non-overlapping matches of the pattern in string you can use 8.C code  static void print_uppercase_words (const gchar *string) { // Print all uppercase-only words. GRegex *regex; GMatchInfo *match_info; GError *error = NULL; regex = g_regex_new ("[A-Z]+", 0, 0, NULL); g_regex_match_full (regex, string, -1, 0, 0, &match_info, &error); while (g_match_info_matches (match_info)) { gchar *word = g_match_info_fetch (match_info, 0); g_print ("Found: %s\n", word); g_free (word); g_match_info_next (match_info, &error); } g_match_info_free (match_info); g_regex_unref (regex); if (error != NULL) { g_printerr ("Error while matching: %s\n", error->message); g_error_free (error); } }Increases reference count of regex by 1.+Replaces all occurrences of the pattern in regex with the replacement text. Backreferences of the form '\number' or '\g<number>' in the replacement text are interpolated by the number-th captured subexpression of the match, '\g<name>' refers to the captured subexpression with the given name. '\0' refers to the complete match, but '\0' followed by a number is the octal representation of a character. To include a literal '\' in the replacement, write '\'.CThere are also escapes that changes the case of the following text:,\l: Convert to lower case the next character,\u: Convert to upper case the next character!\L: Convert to lower case till \E!\U: Convert to upper case till \E\E: End case modification-If you do not need to use backreferences use .The  replacement& string must be UTF-8 encoded even if  G_REGEX_RAW was passed to :. If you want to use not UTF-8 encoded stings you can use .Setting  startPosition? differs from just passing over a shortened string and setting G_REGEX_MATCH_NOTBOLZ in the case of a pattern that begins with any kind of lookbehind assertion, such as "\b".+Replaces all occurrences of the pattern in regex with the replacement text.  replacement6 is replaced literally, to include backreferences use .Setting  startPosition? differs from just passing over a shortened string and setting G_REGEX_MATCH_NOTBOLZ in the case of a pattern that begins with any kind of lookbehind assertion, such as "\b". Breaks the string on the pattern, and returns an array of the tokens. If the pattern contains capturing parentheses, then the text for each of the substrings will also be returned. If the pattern does not match anywhere in the string, then the whole string is returned as the first token.As a special case, the result of splitting the empty string "" is an empty vector, not a vector containing a single string. The reason for this special case is that being able to represent a empty vector is typically more useful than consistent handling of empty elements. If you do need to represent empty elements, you'll need to check for the empty string before calling this function..A pattern that can match empty strings splits string into separate characters wherever it matches the empty string between characters. For example splitting "ab c" using as a separator "\s*", you will get "a", "b" and "c". Breaks the string on the pattern, and returns an array of the tokens. If the pattern contains capturing parentheses, then the text for each of the substrings will also be returned. If the pattern does not match anywhere in the string, then the whole string is returned as the first token.As a special case, the result of splitting the empty string "" is an empty vector, not a vector containing a single string. The reason for this special case is that being able to represent a empty vector is typically more useful than consistent handling of empty elements. If you do need to represent empty elements, you'll need to check for the empty string before calling this function..A pattern that can match empty strings splits string into separate characters wherever it matches the empty string between characters. For example splitting "ab c" using as a separator "\s*", you will get "a", "b" and "c".Setting  startPosition? differs from just passing over a shortened string and setting G_REGEX_MATCH_NOTBOLZ in the case of a pattern that begins with any kind of lookbehind assertion, such as "\b". Decreases reference count of regexg by 1. When reference count drops to zero, it frees all the memory associated with the regex structure.!Checks whether  replacement$ is a valid replacement string (see 2), i.e. that all escape sequences in it are valid.If  hasReferences is not  _ then  replacement is checked for pattern references. For instance, replacement text 'foo\n' does not contain references and may be evaluated without information about actual match, but '\0\1' (whole match followed by first subpattern) requires valid 8 object."3No description available in the introspection data.#Escapes the nul characters in stringL to "\x00". It can be used to compile a regex with embedded nul characters.For completeness, lengthb can be -1 for a nul-terminated string. In this case the output string will be of course equal to string.$?Escapes the special characters used for regular expressions in stringn, for instance "a.b*c" becomes "a\.b\*c". This function is useful to dynamically generate regular expressions.stringp can contain nul characters that are replaced with "\0", in this case remember to specify the correct length of string in length.%Scans for a match in string for pattern.This function is equivalent to 5 but it does not require to compile the pattern with x, avoiding some lines of code when you need just to do a match without extracting substrings, capture counts, and so on.-If this function is to be called on the same patternF more than once, it's more efficient to compile the pattern once with  and then use .& Breaks the string on the pattern, and returns an array of the tokens. If the pattern contains capturing parentheses, then the text for each of the substrings will also be returned. If the pattern does not match anywhere in the string, then the whole string is returned as the first token.This function is equivalent to 5 but it does not require to compile the pattern with x, avoiding some lines of code when you need just to do a split without extracting substrings, capture counts, and so on.-If this function is to be called on the same patternF more than once, it's more efficient to compile the pattern once with  and then use .As a special case, the result of splitting the empty string "" is an empty vector, not a vector containing a single string. The reason for this special case is that being able to represent a empty vector is typically more useful than consistent handling of empty elements. If you do need to represent empty elements, you'll need to check for the empty string before calling this function..A pattern that can match empty strings splits string into separate characters wherever it matches the empty string between characters. For example splitting "ab c" using as a separator "\s*", you will get "a", "b" and "c".7 pattern: the regular expression compileOptions3: compile options for the regular expression, or 0  matchOptions1: match options for the regular expression, or 0 Returns: a  structure or  _ if an error occured. Call   when you are done with it  (Can throw \]) regex: a  Returns:% the number of capturing subpatterns regex: a  Returns: flags from > regex: a  structure Returns:  Y6 if the pattern contains explicit CR or LF references regex: a  Returns: flags from > regex: a  Returns:* the number of the highest back reference regex: a  structure Returns:? the number of characters in the longest lookbehind assertion. regex: a  structure Returns: the pattern of regex regex:  structure name: name of the subexpression Returns:* The number of the subexpression or -1 if name does not exists regex: a  structure from  string!: the string to scan for matches  matchOptions: match options Returns:  Y is the string matched,  X otherwise regex: a  structure from  string!: the string to scan for matches  matchOptions: match options Returns:  Y is the string matched,  X otherwise regex: a  structure from  string!: the string to scan for matches  startPosition2: starting index of the string to match, in bytes  matchOptions: match options  (Can throw \]) regex: a  structure from  string!: the string to scan for matches  startPosition2: starting index of the string to match, in bytes  matchOptions: match options  (Can throw \]) regex: a  Returns: regex regex: a  structure string(: the string to perform matches against  startPosition2: starting index of the string to match, in bytes  replacement": text to replace each match with  matchOptions: options for the match Returns:6 a newly allocated string containing the replacements  (Can throw \]) regex: a  structure string(: the string to perform matches against  startPosition2: starting index of the string to match, in bytes  replacement": text to replace each match with  matchOptions: options for the match Returns:6 a newly allocated string containing the replacements  (Can throw \]) regex: a  structure string': the string to split with the pattern  matchOptions: match time option flags Returns: a  _*-terminated gchar ** array. Free it using Gf regex: a  structure string': the string to split with the pattern  startPosition2: starting index of the string to match, in bytes  matchOptions: match time option flags  maxTokens(: the maximum number of tokens to split string@ into. If this is less than 1, the string is split completely Returns: a  _*-terminated gchar ** array. Free it using Gf  (Can throw \])  regex: a  ! replacement: the replacement string  (Can throw \]) "#string: the string to escape length: the length of string Returns:" a newly-allocated escaped string $string: the string to escape Returns:" a newly-allocated escaped string %pattern: the regular expression string!: the string to scan for matches compileOptions3: compile options for the regular expression, or 0  matchOptions: match options, or 0 Returns:  Y if the string matched,  X otherwise &pattern: the regular expression string!: the string to scan for matches compileOptions3: compile options for the regular expression, or 0  matchOptions: match options, or 0 Returns: a  _,-terminated array of strings. Free it using Gf '  !"#$%& !"#$%& 6  !"#$%&'@7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^H(.Error codes returned by bookmark file parsing.)$The hashing algorithm to be used by A) when performing the digest of some data.Note that the )T enumeration may be extended at a later date to include new hashing algorithm types.*:Error codes returned by character set conversion routines.+pThis enumeration isn't used in the API, but may be useful if you need to mark a number as a day, month, or year.,-Enumeration representing a month; values are G_DATE_JANUARY, G_DATE_FEBRUARY, etc. G_DATE_BAD_MONTH is the invalid value.-,Enumeration representing a day of the week;  G_DATE_MONDAY, G_DATE_TUESDAY, etc. G_DATE_BAD_WEEKDAY is an invalid weekday..!The possible errors, used in the vError field of , when the token is a _./Values corresponding to errno5 codes returned from file operations on UNIX. Unlike errnoA codes, GFileError values are available on all systems, even Windows. The exact meaning of each code depends on what sort of file operation you were performing; the UNIX documentation gives more details. The following error code descriptions come from the GNU C Library manual, and are under the copyright of that manual.It's not very portable to make detailed assumptions about exactly which errors will be returned from a given operation. Some errors don't occur on some systems, etc., sometimes there are subtle differences in when a system will report a given error, etc.0Error codes returned by ; operations.11* is only used by the deprecated functions ;, ;, and ;.2Stati returned by most of the H functions.3)Error codes returned by key file parsing.42Return values from GLogWriterFuncs to indicate whether the given log entry was successfully handled by the writer, or whether there was an error in handling it (and hence a fallback writer should be used).If a F' ignores a log entry, it should return .5'Error codes returned by markup parsing.6$Defines how a Unicode string is transformed in a canonical form, standardizing such issues as whether a character with an accent is represented as a base character and combining accent or as a single precomposed character. Unicode strings should generally be normalized before comparing them.7LThe possible statuses of a one-time initialization function controlled by a C struct.8The 8 enum values determine which type of extra argument the options expect to find. If an option expects an extra argument, it can be specified in several ways; with a short option: -x arg, with a long option:  --name arg# or combined in a single argument:  --name=arg.9'Error codes returned by option parsing.:6Error codes returned by regular expressions functions.;2An enumeration specifying the base position for a ; operation.<(Error codes returned by shell functions.=3No description available in the introspection data.>+Error codes returned by spawning processes.?&<The type of file to return the filename for, when used with g_test_build_filename().These two options correspond rather directly to the 'dist' and 'built' terminology that automake uses and are explicitly used to distinguish between the 'srcdir' and 'builddir' being separate. All files in your project should either be dist (in the  DIST_EXTRA or dist_schema_DATAJ sense, in which case they will always be in the srcdir) or built (in the  BUILT_SOURCES; sense, in which case they will always be in the builddir).Note: as a general rule of automake, files that are generated only as part of the build-from-git process (but then are distributed with the tarball) always go in srcdir (even if doing a srcdir != builddir build from git) and are considered as distributed files.@3No description available in the introspection data.A,Possible errors of thread related functions.B'Disambiguates a given time in two ways.AFirst, specifies if the given time is in universal or local time.Second, if the time is in local time, specifies if it is local standard time or local daylight time. This is important for the case where the same local time occurs twice (during daylight savings time transitions, for example).C/The possible types of token returned from each 3 call.D,Specifies the type of traveral performed by g_tree_traverse(), g_node_traverse() and  g_node_find(),. The different orders are illustrated here:$In order: A, B, C, D, E, F, G, H, I Ehttp://developer.gnome.org/glib/stable/Sorted_binary_tree_inorder.svg%Pre order: F, B, A, D, C, E, G, I, H Fhttp://developer.gnome.org/glib/stable/Sorted_binary_tree_preorder.svg&Post order: A, C, E, D, B, H, I, G, F Ghttp://developer.gnome.org/glib/stable/Sorted_binary_tree_postorder.svg'Level order: F, B, G, A, D, I, C, E, H Uhttp://developer.gnome.org/glib/stable/Sorted_binary_tree_breadth-first_traversal.svgE2These are the possible line break classifications.Since new unicode versions may add new types here, applications should be ready to handle unknown values. They may be regarded as .sSee <ulink url="http://www.unicode.org/unicode/reports/tr14/">http://www.unicode.org/unicode/reports/tr14/</ulink>.FThe F enumeration identifies different writing systems. The values correspond to the names as defined in the Unicode standard. The enumeration has been added in GLib 2.14, and is interchangeable with  PangoScript.Note that new types may be added in the future. Applications should be ready to handle unknown values. See <ulink url="http://www.unicode.org/reports/tr24/">Unicode Standard Annex 24: Script names</ulink>.GThese are the possible character classifications from the Unicode specification. See <ulink url="http://www.unicode.org/reports/tr44/General_Category_Values&">Unicode Character Database</unlink>.HoThese are logical ids for special directories which are defined depending on the platform used. You should use G8 to retrieve the full path associated to the logical id.The Hx enumeration can be extended at later date. Not every platform has a directory for every logical id in this enumeration.I)The range of possible top-level types of  ` instances.J6Error codes returned by parsing text-format GVariants.KURI was ill-formedLa requested field was not foundM;a requested application did not register a bookmarkNa requested URI was not foundOdocument was ill formedP8the text being parsed was in an unknown encodingQan error occurred while writingRrequested file was not foundSCatch-all for unknown valuesTUse the MD5 hashing algorithmUUse the SHA-1 hashing algorithmV!Use the SHA-256 hashing algorithmW/Use the SHA-512 hashing algorithm (Since: 2.36)XCatch-all for unknown valuesYIConversion between the requested character sets is not supported.Z*Invalid byte sequence in conversion input.["Conversion failed for some reason.\+Partial character sequence at end of input.]URI is invalid.^!Pathname is not an absolute path._ No memory available. Since: 2.40`Catch-all for unknown valuesaa dayba monthca yeardCatch-all for unknown valuese invalid valuefJanuarygFebruaryhMarchiApriljMaykJunelJulymAugustn SeptemberoOctoberpNovemberqDecemberrCatch-all for unknown valuess invalid valuetMondayuTuesdayv WednesdaywThursdayxFridayySaturdayzSunday{Catch-all for unknown values| unknown error}unexpected end of file~unterminated string constantunterminated commentnon-digit character in a numberdigit beyond radix in a number!non-decimal floating point numbermalformed floating point numberCatch-all for unknown valuesOperation not permitted; only the owner of the file (or other resource) or processes with special privileges can perform the operation.kFile is a directory; you cannot open a directory for writing, or create or remove hard links to it.UPermission denied; the file permissions do not allow the attempted operation.Filename too long.No such file or directory. This is a "file doesn't exist" error for ordinary files that are referenced in contexts where they are expected to already exist.QA file that isn't a directory was specified when a directory is required.3No such device or address. The system tried to use the device represented by a file you specified, and it couldn't find the device. This can mean that the device file was installed incorrectly, or that the physical device is missing or not correctly attached to the computer.YThe underlying file system of the specified file does not support memory mapping.hThe directory containing the new link can't be modified because it's on a read-only file system.Text file busy.You passed in a pointer to bad memory. (GLib won't reliably return this, don't pass in pointers to bad memory.)Too many levels of symbolic links were encountered in looking up a file name. This often indicates a cycle of symbolic links.[No space left on device; write operation on a file failed because the disk is full.iNo memory available. The system cannot allocate more virtual memory because its capacity is full.The current process has too many files open and can't open any more. Duplicate descriptors do count toward this limit.GThere are too many distinct file openings in the entire system.Bad file descriptor; for example, I/O on a descriptor that has been closed or reading from a descriptor open only for writing (or vice versa).Invalid argument. This is used to indicate various kinds of problems with passing the wrong argument to a library function.dBroken pipe; there is no process reading from the other end of a pipe. Every library function that returns this error code also generates a 'SIGPIPE' signal; this signal terminates the program if not handled or blocked. Thus, your program will never actually see this code unless it has handled or blocked 'SIGPIPE'.UResource temporarily unavailable; the call might work if you try again later.Interrupted function call; an asynchronous signal occurred and prevented completion of the call. When this happens, you should try the call again.Input/output error; usually used for physical read or write errors. i.e. the disk or other physical device hardware is returning errors.Operation not permitted; only the owner of the file (or other resource) or processes with special privileges can perform the operation.^Function not implemented; this indicates that the system is missing some functionality.Does not correspond to a UNIX error code; this is the standard "failed for unspecified reason" error code present in all F error code enumerations. Returned if no specific code applies.Catch-all for unknown valuesFile too large.Invalid argument. IO error.File is a directory.No space left on device.No such device or address.%Value too large for defined datatype. Broken pipe.Some other error.Catch-all for unknown valuesno erroran EAGAIN error occurredan EINVAL error occurredanother error occurredCatch-all for unknown valuesAn error occurred.Success. End of file.!Resource temporarily unavailable.Catch-all for unknown values8the text being parsed was in an unknown encodingdocument was ill-formedthe file was not founda requested key was not founda requested group was not founda value could not be parsedCatch-all for unknown values%Log writer has handled the log entry.*Log writer could not handle the log entry.Catch-all for unknown values%text being parsed was not valid UTF-8.document contained nothing, or only whitespacedocument was ill-formederror should be set by ( functions; element wasn't knownerror should be set by * functions; attribute wasn't knownerror should be set by ' functions; content was invaliderror should be set by 4 functions; a required attribute was missingCatch-all for unknown valuesvstandardize differences that do not affect the text content, such as the above-mentioned accent representationanother name for like I, but with composed forms rather than a maximally decomposed formanother name for beyond  also standardize the "compatibility" characters in Unicode, such as SUPERSCRIPT THREE to the standard forms (in this case DIGIT THREE). Formatting information may be lost but for most text operations such characters should be considered the sameanother name for like I, but with composed forms rather than a maximally decomposed formanother name for Catch-all for unknown values%the function has not been called yet.+the function call is currently in progress.the function has been called.Catch-all for unknown values3No extra argument. This is useful for simple flags.#The option takes a string argument.%The option takes an integer argument.0The option provides a callback (of type F) to parse the extra argument.(The option takes a filename as argument.oThe option takes a string argument, multiple uses of the option are collected into an array of strings.tThe option takes a filename as argument, multiple uses of the option are collected into an array of strings.The option takes a double argument. The argument can be formatted either for the user's locale or for the "C" locale. Since 2.120The option takes a 64-bit integer. Like j but for larger numbers. The number can be in decimal base, or in hexadecimal (when prefixed with 0x, for example,  0xffffffff ). Since 2.12Catch-all for unknown valuesAn option was not known to the parser. This error will only be reported, if the parser hasn't been instructed to ignore unknown options, see 6.A value couldn't be parsed.A F callback failed.Catch-all for unknown values-Compilation of the regular expression failed..Optimization of the regular expression failed.CReplacement failed due to an ill-formed replacement string.The match process failed.CInternal error of the regular expression engine. Since 2.16!"\" at end of pattern. Since 2.16""\c" at end of pattern. Since 2.166Unrecognized character follows "\". Since 2.16;Numbers out of order in "{}" quantifier. Since 2.165Number too big in "{}" quantifier. Since 2.16?Missing terminating "]" for character class. Since 2.16>Invalid escape sequence in character class. Since 2.169Range out of order in character class. Since 2.16Nothing to repeat. Since 2.16EUnrecognized character after "(?", "(?<" or "(?P". Since 2.16IPOSIX named classes are supported only within a class. Since 2.16FMissing terminating ")" or ")" without opening "(". Since 2.168Reference to non-existent subpattern. Since 2.169Missing terminating ")" after comment. Since 2.160Regular expression too large. Since 2.16 Failed to get memory. Since 2.16<Lookbehind assertion is not fixed length. Since 2.168Malformed number or name after "(?(". Since 2.16EConditional group contains more than two branches. Since 2.162Assertion expected after "(?(". Since 2.16,Unknown POSIX class name. Since 2.16>POSIX collating elements are not supported. Since 2.16FCharacter value in "\x{...}" sequence is too large. Since 2.16%Invalid condition "(?(0)". Since 2.16:\C not allowed in lookbehind assertion. Since 2.16:Recursive call could loop indefinitely. Since 2.169Missing terminator in subpattern name. Since 2.16<Two named subpatterns have the same name. Since 2.163Malformed "\P" or "\p" sequence. Since 2.16<Unknown property name after "\P" or "\p". Since 2.16GSubpattern name is too long (maximum 32 characters). Since 2.16?Too many named subpatterns (maximum 10,000). Since 2.166Octal value is greater than "\377". Since 2.16@"DEFINE" group contains more than one branch. Since 2.16kRepeating a "DEFINE" group is not allowed. This error is never raised. Since: 2.16 Deprecated: 2.340Inconsistent newline options. Since 2.16 w"\g" is not followed by a braced, angle-bracketed, or quoted name or number, or by a plain number. Since: 2.16 0relative reference must not be zero. Since: 2.34 Qthe backtracing control verb used does not allow an argument. Since: 2.34 5unknown backtracing control verb. Since: 2.34 1number is too big in escape sequence. Since: 2.34$Missing subpattern name. Since: 2.34Missing digit. Since 2.34WIn JavaScript compatibility mode, "[" is an invalid data character. Since: 2.34Wdifferent names for subpatterns of the same number are not allowed. Since: 2.34Fthe backtracing control verb requires an argument. Since: 2.34@"\c" must be followed by an ASCII character. Since: 2.34V"\k" is not followed by a braced, angle-bracketed, or quoted name. Since: 2.34-"\N" is not supported in a class. Since: 2.34(too many forward references. Since: 2.34[the name is too long in "(*MARK)", "(*PRUNE)", "(*SKIP)", or "(*THEN)". Since: 2.34Hthe character value in the \u sequence is too large. Since: 2.34Catch-all for unknown values!the current position in the file.the start of the file.the end of the file.Catch-all for unknown values(Mismatched or otherwise mangled quoting.String to be parsed was empty. Some other error.!Catch-all for unknown values"3No description available in the introspection data.#3No description available in the introspection data.$3No description available in the introspection data.%3No description available in the introspection data.&3No description available in the introspection data.'3No description available in the introspection data.(Catch-all for unknown values)"Fork failed due to lack of memory.*Read or select on pipes failed.+%Changing to working directory failed.,execv() returned EACCES-execv() returned EPERM.execv() returned E2BIG/deprecated alias for .0execv() returned ENOEXEC1execv() returned  ENAMETOOLONG2execv() returned ENOENT3execv() returned ENOMEM4execv() returned ENOTDIR5execv() returned ELOOP6execv() returned ETXTBUSY7execv() returned EIO8execv() returned ENFILE9execv() returned EMFILE:execv() returned EINVAL;execv() returned EISDIR<execv() returned ELIBBAD= Some other fatal failure, error->message should explain.>Catch-all for unknown values?4a file that was included in the distribution tarball@.a file that was built on the compiling machineACatch-all for unknown valuesB3No description available in the introspection data.C3No description available in the introspection data.D3No description available in the introspection data.E3No description available in the introspection data.F3No description available in the introspection data.G3No description available in the introspection data.H3No description available in the introspection data.I3No description available in the introspection data.J3No description available in the introspection data.K3No description available in the introspection data.L3No description available in the introspection data.M3No description available in the introspection data.NCatch-all for unknown valuesOba thread couldn't be created due to resource shortage. Try again later.PCatch-all for unknown valuesQ"the time is in local standard timeR"the time is in local daylight timeSthe time is in UTCTCatch-all for unknown valuesUthe end of the fileVa '(' characterWa ')' characterXa '{' characterYa '}' characterZa '[' character[a ']' character\a '=' character]a ',' character^ not a token_an error occurred` a characteraa binary integerban octal integerc an integerd a hex integerea floating point numberfa stringga symbolh an identifieria null identifierjone line commentkmulti line commentlCatch-all for unknown valuesmvists a node's left child first, then the node itself, then its right child. This is the one to use if you want the output sorted according to the compare function.n!visits a node, then its children.o1visits the node's children, then the node itself.pQis not implemented for [balanced binary trees][glib-Balanced-Binary-Trees]. For [n-ary trees][glib-N-ary-Trees], it vists the root node first, then its children, then its grandchildren, and so on. Note that this is less efficient than the other orders.qCatch-all for unknown valuesrMandatory Break (BK)sCarriage Return (CR)tLine Feed (LF)u,Attached Characters and Combining Marks (CM)vSurrogates (SG)wZero Width Space (ZW)xInseparable (IN)yNon-breaking ("Glue") (GL)z!Contingent Break Opportunity (CB){ Space (SP)|Break Opportunity After (BA)}Break Opportunity Before (BB)~'Break Opportunity Before and After (B2) Hyphen (HY)Nonstarter (NS)Opening Punctuation (OP)Closing Punctuation (CL)Ambiguous Quotation (QU)Exclamation/Interrogation (EX)Ideographic (ID) Numeric (NU)Infix Separator (Numeric) (IS)!Symbols Allowing Break After (SY).Ordinary Alphabetic and Symbol Characters (AL)Prefix (Numeric) (PR)Postfix (Numeric) (PO)1Complex Content Dependent (South East Asian) (SA)*Ambiguous (Alphabetic or Ideographic) (AI) Unknown (XX)Next Line (NL)Word Joiner (WJ)Hangul L Jamo (JL)Hangul V Jamo (JV)Hangul T Jamo (JT)Hangul LV Syllable (H2)Hangul LVT Syllable (H3)$Closing Parenthesis (CP). Since 2.28.Conditional Japanese Starter (CJ). Since: 2.32Hebrew Letter (HL). Since: 2.32$Regional Indicator (RI). Since: 2.36Catch-all for unknown valuesa value never returned from G.a character used by multiple different scriptspa mark glyph that takes its script from the base glyph to which it is attachedArabicArmenianBengaliBopomofoCherokeeCopticCyrillicDeseret DevanagariEthiopicGeorgianGothicGreekGujaratiGurmukhiHanHangulHebrewHiraganaKannadaKatakanaKhmerLaoLatin Malayalam MongolianMyanmarOgham Old ItalicOriyaRunicSinhalaSyriacTamilTeluguThaanaThaiTibetanCanadian AboriginalYiTagalogHanunooBuhidTagbanwaBrailleCypriotLimbuOsmanyaShavianLinear BTai LeUgaritic New Tai LueBuginese GlagoliticTifinagh Syloti Nagri Old Persian Kharoshthian unassigned code pointBalinese Cuneiform PhoenicianPhags-paN'KoKayah Li. Since 2.16.3Lepcha. Since 2.16.3Rejang. Since 2.16.3Sundanese. Since 2.16.3Saurashtra. Since 2.16.3Cham. Since 2.16.3Ol Chiki. Since 2.16.3Vai. Since 2.16.3Carian. Since 2.16.3Lycian. Since 2.16.3Lydian. Since 2.16.3Avestan. Since 2.26Bamum. Since 2.26 Egyptian Hieroglpyhs. Since 2.26Imperial Aramaic. Since 2.26!Inscriptional Pahlavi. Since 2.26"Inscriptional Parthian. Since 2.26Javanese. Since 2.26Kaithi. Since 2.26Lisu. Since 2.26Meetei Mayek. Since 2.26Old South Arabian. Since 2.26Old Turkic. Since 2.28Samaritan. Since 2.26Tai Tham. Since 2.26Tai Viet. Since 2.26Batak. Since 2.28Brahmi. Since 2.28Mandaic. Since 2.28Chakma. Since: 2.32Meroitic Cursive. Since: 2.32!Meroitic Hieroglyphs. Since: 2.32Miao. Since: 2.32Sharada. Since: 2.32Sora Sompeng. Since: 2.32Takri. Since: 2.32Bassa. Since: 2.42Caucasian Albanian. Since: 2.42Duployan. Since: 2.42Elbasan. Since: 2.42Grantha. Since: 2.42Kjohki. Since: 2.42 Khudawadi, Sindhi. Since: 2.42 Linear A. Since: 2.42 Mahajani. Since: 2.42 Manichaean. Since: 2.42 Mende Kikakui. Since: 2.42Modi. Since: 2.42Mro. Since: 2.42Nabataean. Since: 2.42Old North Arabian. Since: 2.42Old Permic. Since: 2.42Pahawh Hmong. Since: 2.42Palmyrene. Since: 2.42Pau Cin Hau. Since: 2.42Psalter Pahlavi. Since: 2.42Siddham. Since: 2.42Tirhuta. Since: 2.42Warang Citi. Since: 2.42Ahom. Since: 2.48"Anatolian Hieroglyphs. Since: 2.48Hatran. Since: 2.48Multani. Since: 2.48Old Hungarian. Since: 2.48Signwriting. Since: 2.48 Catch-all for unknown values!&General category "Other, Control" (Cc)"%General category "Other, Format" (Cf)#+General category "Other, Not Assigned" (Cn)$*General category "Other, Private Use" (Co)%(General category "Other, Surrogate" (Cs)&)General category "Letter, Lowercase" (Ll)'(General category "Letter, Modifier" (Lm)(%General category "Letter, Other" (Lo)))General category "Letter, Titlecase" (Lt)*)General category "Letter, Uppercase" (Lu)+%General category "Mark, Spacing" (Mc),'General category "Mark, Enclosing" (Me)-(General category "Mark, Nonspacing" (Mn).-General category "Number, Decimal Digit" (Nd)/&General category "Number, Letter" (Nl)0%General category "Number, Other" (No)1.General category "Punctuation, Connector" (Pc)2)General category "Punctuation, Dash" (Pd)3*General category "Punctuation, Close" (Pe)40General category "Punctuation, Final quote" (Pf)52General category "Punctuation, Initial quote" (Pi)6*General category "Punctuation, Other" (Po)7)General category "Punctuation, Open" (Ps)8(General category "Symbol, Currency" (Sc)9(General category "Symbol, Modifier" (Sk):$General category "Symbol, Math" (Sm);%General category "Symbol, Other" (So)<'General category "Separator, Line" (Zl)=,General category "Separator, Paragraph" (Zp)>(General category "Separator, Space" (Zs)?Catch-all for unknown values@the user's Desktop directoryAthe user's Documents directoryBthe user's Downloads directoryCthe user's Music directoryDthe user's Pictures directoryEthe user's shared directoryFthe user's Templates directoryGthe user's Movies directoryHthe number of enum valuesICatch-all for unknown valuesJThe  ` is a boolean.KThe  ` is a byte.LThe  ` is a signed 16 bit integer.MThe  ` is an unsigned 16 bit integer.NThe  ` is a signed 32 bit integer.OThe  ` is an unsigned 32 bit integer.PThe  ` is a signed 64 bit integer.QThe  ` is an unsigned 64 bit integer.RThe  ` is a file handle index.SThe  `I is a double precision floating point value.TThe  ` is a normal string.UThe  `A is a D-Bus object path string.VThe  ` is a D-Bus signature string.WThe  ` is a variant.XThe  ` is a maybe-typed value.YThe  ` is an array.ZThe  ` is a tuple.[The  ` is a dictionary entry.\Catch-all for unknown values]generic error (unused)^ a non-basic S* was given where a basic type was expected_cannot infer the S`an indefinite S- was given where a definite type was expecteda!extra data after parsing finishedb-invalid character in number or unicode escapec not a valid  ` format stringdnot a valid object pathenot a valid type signaturef not a valid  ` type stringg.could not find a common type for array entriesh5the numerical value is out of range of the given typei0the numerical value is out of range for any typej-cannot parse as variant of the specified typek#an unexpected token was encounteredl"an unknown keyword was encounteredmunterminated string constantnno value givenoCatch-all for unknown values()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~`(KLMNOPQRS)TUVWX*YZ[\]^_`+abcd,efghijklmnopqr-stuvwxyz{.|}~/0123456789:     ;< !="#$%&'(>)*+,-./0123456789:;<=>??@A@BCDEFGHIJKLMNAOPBQRSTCUVWXYZ[\]^_`abcdefghijklDmnopqErstuvwxyz{|}~F      G!"#$%&'()*+,-./0123456789:;<=>?H@ABCDEFGHIIJKLMNOPQRSTUVWXYZ[\J]^_`abcdefghijklmnopqrstuvwxyz{|}~`pqrstuvwxyz{|}~J]^_`abcdefghijklmnoIJKLMNOPQRSTUVWXYZ[\H@ABCDEFGHIG!"#$%&'()*+,-./0123456789:;<=>?F      Erstuvwxyz{|}~DmnopqCUVWXYZ[\]^_`abcdefghijklBQRSTAOP@BCDEFGHIJKLMN??@A>)*+,-./0123456789:;<=>="#$%&'(< !;:     9876543210/.|}~-stuvwxyz{,efghijklmnopqr+abcd*YZ[\]^_`)TUVWX(KLMNOPQRS( KLMNOPQRS)TUVWX*YZ[\]^_`+abcd,efghijklmnopqr- stuvwxyz{. |}~/0 123456 78 9::     ;< !="#$%&'(>)*+,-./0123456789:;<=>??@A@ BCDEFGHIJKLMNAOPBQRSTCUVWXYZ[\]^_`abcdefghijklDmnopqE)rstuvwxyz{|}~F      G!"#$%&'()*+,-./0123456789:;<=>?H @ABCDEFGHIIJKLMNOPQRSTUVWXYZ[\J]^_`abcdefghijklmnopqrstuvwxyz{|}~;7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^#  Construct a  struct initialized to zero." Open a file filename as a  using mode moded. This channel will be closed when the last reference to it is dropped, so there is no need to call $s (though doing so will not cause problems, as long as no attempt is made to access the channel after it is closed).#Creates a new Y given a file descriptor. On UNIX systems this works for plain files, pipes, and sockets. The returned  has a reference count of 1.The default encoding for  is UTF-8. If your application is reading output from a command using via pipe, you may need to set the encoding to the encoding of the current locale (see G ) with the 9 function.JIf you want to read raw binary data without interpretation, then call the 9 function with  _ for the encoding argument.This function is available in GLib on Windows, too, but you should avoid using it on Windows. The domain of file descriptors and sockets overlap. There is no way for GLib to know which one you mean in case the argument you pass to this function happens to be both a valid file descriptor and socket. If that happens a warning is issued, and GLib assumes that it is the file descriptor you mean.$Close an IO channel. Any pending data to be written will be flushed, ignoring errors. The channel will not be freed until the last reference is dropped using >.%,Flushes the write buffer for the GIOChannel.&This function returns a >b depending on whether there is data to be read/space to write data in the internal buffers in the . Only the flags > and > may be set.'Gets the buffer size.(Returns whether channel is buffered.)9Returns whether the file/socket/whatever associated with channel will be closed when channelI receives its final unref and is destroyed. The default value of this is  Y7 for channels created by g_io_channel_new_file (), and  X for all other channels.*kGets the encoding for the input/output of the channel. The internal encoding is always UTF-8. The encoding  _( makes the channel safe for binary data.+Gets the current flags for a $, including read-only flags such as >.The values of the flags > and > are cached for internal use by the channel when it is created. If they should change at some later point (e.g. partial shutdown of a socket with the UNIX  shutdown()- function), the user should immediately call +. to update the internal values of these flags.,This returns the string that E uses to determine where in the file a line break occurs. A value of  _ indicates autodetection.-Initializes a  struct.>This is called by each of the above functions when creating a b, and so is not often needed by the application programmer (unless you are creating a new type of )..Reads data from a ./Replacement for . with the new API.0=Reads a line, including the terminating character(s), from a  into a newly-allocated string.  strReturn0 will contain allocated memory if the return is @.1+Reads all the remaining data from the file.2Reads a Unicode character from channel3. This function cannot be called on a channel with  _ encoding.3$Increments the reference count of a .4!Sets the current position in the +, similar to the standard library function fseek().5Replacement for 4 with the new API.6Sets the buffer size.7AThe buffering state can only be set if the channel's encoding is  _7. For any other encoding, the channel must be buffered.A buffered channel can only be set unbuffered if the channel's internal buffers have been flushed. Newly created channels or channels which have returned @ not require such a flush. For write-only channels, a call to g_io_channel_flush () is sufficient. For all other channels, the buffers may be flushed by a call to g_io_channel_seek_position (). This includes the possibility of seeking with seek type @ and an offset of zero. Note that this means that socket-based channels cannot be set unbuffered once they have had data read from them.On unbuffered channels, it is safe to mix read and write calls from the new and old APIs, if this is necessary for maintaining old code.-The default state of the channel is buffered.8Setting this flag to  Y: for a channel you have already closed can cause problems.9Sets the encoding for the input/output of the channel. The internal encoding is always UTF-8. The default encoding for the external file is UTF-8. The encoding  _! is safe to use with binary data.HThe encoding can only be set if one of the following conditions is true:KThe channel was just created, and has not been written to or read from yet.The channel is write-only.OThe channel is a file, and the file pointer was just repositioned by a call to 5*. (This flushes all the internal buffers.)The current encoding is  _ or UTF-8.6One of the (new API) read functions has just returned @ (or, in the case of 1, @).One of the functions / or 2 has returned @ or @%. This may be useful in the case of @(. Returning one of these statuses from 0, g_io_channel_read_line_string(), or 16 does not guarantee that the encoding can be changed.CChannels which do not meet one of the above conditions cannot call 5 with an offset of @+, and, if they are "seekable", cannot call @/ after calling one of the API "read" functions.:Sets the (writeable) flags in channel to (flags & >).;This sets the string that 9 uses to determine where in the file a line break occurs.<GClose an IO channel. Any pending data to be written will be flushed if flush is  YJ. The channel will not be freed until the last reference is dropped using >.=#Returns the file descriptor of the .FOn Windows this function returns the file descriptor or socket of the .>$Decrements the reference count of a .?Writes data to a .@Replacement for ? with the new API./On seekable channels with encodings other than  _ or UTF-8, generic mixing of reading and writing is not allowed. A call to g_io_channel_write_chars () may only be made on a channel from which data has been read in the cases described in the documentation for g_io_channel_set_encoding ().AWrites a Unicode character to channel3. This function cannot be called on a channel with  _ encoding.B Converts an errno error number to a @.C3No description available in the introspection data.K      !"#$%& !"filename): A string containing the name of a file modeS: One of "r", "w", "a", "r+", "w+", "a+". These have the same meaning as in fopen() Returns: A  on success,  _ on failure.  (Can throw \]) #fd: a file descriptor. Returns: a new . $channel: A  %channel: a  Returns:' the status of the operation: One of G_IO_STATUS_NORMAL, G_IO_STATUS_AGAIN, or G_IO_STATUS_ERROR.  (Can throw \]) &channel: A  Returns: A > 'channel: a  Returns: the size of the buffer. (channel: a  Returns:  Y if the channel is buffered. )channel: a . Returns:g Whether the channel will be closed on the final unref of the GIOChannel data structure. *channel: a  Returns:Y A string containing the encoding, this string is owned by GLib and must not be freed. +channel: a  Returns:( the flags which are set on the channel ,channel: a  length9: a location to return the length of the line terminator Returns:S The line termination string. This value is owned by GLib and must not be freed. -channel: a  .channel: a  bufS: a buffer to read the data into (which should be at least count bytes long) count': the number of bytes to read from the   bytesRead,: returns the number of bytes actually read Returns: @" if the operation was successful. /channel: a  buf": a buffer to read data into Returns: the status of the operation.  (Can throw \]) 0channel: a  Returns: the status of the operation.  (Can throw \]) 1channel: a  Returns: @- on success. This function never returns @.  (Can throw \]) 2channel: a  Returns: a @  (Can throw \]) 3channel: a  Returns: the channel that was passed in (since 2.6) 4channel: a  offsetL: an offset, in bytes, which is added to the position specified by type type): the position in the file, which can be @ (the current position), @ (the start of the file), or @ (the end of the file) Returns: @" if the operation was successful. 5channel: a  offset5: The offset in bytes from the position specified by type type: a @ . The type @ is only allowed in those cases where a call to g_io_channel_set_encoding () is allowed. See the documentation for g_io_channel_set_encoding () for details. Returns: the status of the operation.  (Can throw \]) 6channel: a  size<: the size of the buffer, or 0 to let GLib pick a good size 7channel: a  buffered4: whether to set the channel buffered or unbuffered 8channel: a  doClose: Whether to close the channel on the final unref of the GIOChannel data structure. The default value of this is  YB for channels created by g_io_channel_new_file (), and  X for all other channels. 9channel: a  encoding: the encoding type Returns: @& if the encoding was successfully set  (Can throw \]) :channel: a  flags%: the flags to set on the IO channel Returns: the status of the operation.  (Can throw \]) ;channel: a  lineTerm#: The line termination string. Use  _ for autodetect. Autodetection breaks on "\n", "\r\n", "\r", "\0", and the Unicode paragraph separator. Autodetection should not be used for anything other than file-based channels. length: The length of the termination string. If -1 is passed, the string is assumed to be nul-terminated. This option allows termination strings with embedded nuls. <channel: a  flush: if  Y, flush pending Returns: the status of the operation.  (Can throw \]) =channel: a , created with #. Returns: the file descriptor of the . >channel: a  ?channel: a  buf*: the buffer containing the data to write count: the number of bytes to write  bytesWritten': the number of bytes actually written Returns: @" if the operation was successful. @channel: a  buf: a buffer to write data from count\: the size of the buffer. If -1, the buffer is taken to be a nul-terminated string. Returns: the status of the operation.  (Can throw \]) Achannel: a  thechar: a character Returns: a @  (Can throw \]) Ben: an errno error number, e.g. EINVAL Returns: a @ error number, e.g. @. CDE& !"#$%&'()*+,-./0123456789:;<=>?@ABC& !$BC%&'()*+,-"./0123456789:;<=#>?@AJ      !"#$%& !"#$%&'()*+,-./0123456789:;<=>?@ABCDEA7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ICreates a new F, using the checksum algorithm  checksumType . If the  checksumType is not known,  _ is returned. A Fq can be used to compute the checksum, or digest, of an arbitrary binary blob, using different hashing algorithms.A F( works by feeding a binary blob through NK until there is data to be checked; the digest can then be extracted using L=, which will return the checksum as a hexadecimal string; or g_checksum_get_digest()7, which will return a vector of raw bytes. Once either L or g_checksum_get_digest() have been called on a F?, the checksum will be closed and it won't be possible to call N on it anymore.J Copies a F. If checksum has been closed, by calling L or g_checksum_get_digest()-, the copied checksum will be closed as well.KFrees the memory allocated for checksum.L)Gets the digest as an hexadecimal string.'Once this function has been called the F can no longer be updated with N..The hexadecimal characters will be lower case.MResets the state of the checksum back to its initial state.NFeeds data into an existing F+. The checksum must still be open, that is L or g_checksum_get_digest() must not have been called on checksum.O,Gets the length in bytes of digests of type  checksumTypeFG'()*+,-.HI checksumType: the desired type of checksum Returns: the newly created F, or  _. Use K% to free the memory allocated by it. Jchecksum: the F to copy Returns: the copy of the passed F. Use K when finished using it. Kchecksum: a F Lchecksum: a F Returns: the hexadecimal representation of the checksum. The returned string is owned by the checksum and should not be modified or freed. Mchecksum: the F to reset Nchecksum: a F data&: buffer used to compute the checksum O checksumType: a @ Returns: the checksum length, or -1 if  checksumType is not supported. P FGHIJKLMNO FGHJKLIMONFG'()*+,-.HIJKLMNOPB7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^1S Construct a Q struct initialized to zero.a Allocates a QV and initializes it to a sane state. The new date will be cleared (as if you'd called hO) but invalid (it won't represent an existing day). Free the return value with k.bLike a, but also sets the value of the date. Assuming the day-month-year triplet you pass in represents an existing day, the returned date will be valid.cLike a, but also sets the value of the date. Assuming the Julian day number you pass in is valid (greater than 0, less than an unreasonably large number), the returned date will be valid.djIncrements a date some number of days. To move forward by weeks, add weeks*7 days. The date must be valid.eIncrements a date by some number of months. If the day of the month is greater than 28, this routine may change the day of the month (because the destination month may not have the current day in it). The date must be valid.fIncrements a date by some number of years. If the date is February 29, and the destination year is not a leap year, the date will be changed to February 28. The date must be valid.gIf date is prior to minDate, sets date equal to minDate. If date falls after maxDate, sets date equal to maxDate . Otherwise, date is unchanged. Either of minDate and maxDate may be  _ . All non- _ dates must be valid.hInitializes one or more Q structs to a sane but invalid state. The cleared dates will not represent an existing date, but will not contain garbage. Useful to init a date declared on the stack. Validity can be tested with .iqsort()?-style comparison function for dates. Both dates must be valid.j2Computes the number of days between two dates. If date2 is prior to date1;, the returned value is negative. Both dates must be valid.kFrees a Q returned from a.l5Returns the day of the month. The date must be valid.m^Returns the day of the year, where Jan 1 is the first day of the year. The date must be valid.nPReturns the week of the year, where weeks are interpreted according to ISO 8601.o1Returns the Julian day or "serial number" of the Q. The Julian day is simply the number of days since January 1, Year 1; i.e., January 1, Year 1 is Julian day 1; January 2, Year 1 is Julian day 2, etc. The date must be valid.pReturns the week of the year, where weeks are understood to start on Monday. If the date is before the first Monday of the year, return 0. The date must be valid.q6Returns the month of the year. The date must be valid.rReturns the week of the year during which this date falls, if weeks are understood to begin on Sunday. The date must be valid. Can return 0 if the day is before the first Sunday of the year.s"Returns the day of the week for a Q. The date must be valid.tReturns the year of a Q. The date must be valid.uReturns  Y@ if the date is on the first of a month. The date must be valid.vReturns  YB if the date is the last day of the month. The date must be valid.w Checks if date1 is less than or equal to date2., and swap the values if this is not the case.x Sets the day of the month for a QO. If the resulting day-month-year triplet is invalid, the date will be invalid.ySets the value of a Qg from a day, month, and year. The day-month-year triplet must be valid; if you aren't sure it is, call G to check before you set it.zSets the value of a Q from a Julian day number.{!Sets the month of the year for a QP. If the resulting day-month-year triplet is invalid, the date will be invalid.|Parses a user-inputted string str, and try to figure out what date it represents, taking the [current locale][setlocale] into account. If the string is successfully parsed, the date will be valid after the call. Otherwise, it will be invalid. You should check using & to see whether the parsing succeeded.This function is not appropriate for file formats and the like; it isn't very precise, and its exact behavior varies with the locale. It's intended to be a heuristic routine that guesses what the user means by a given string (and it does work pretty well in that capacity).} Sets the value of a date from a GTimeN value. The time to date conversion is done using the user's current timezone.~ Sets the value of a date to the date corresponding to a time specified as a time_t. The time to date conversion is done using the user's current timezone.?To set the value of a date to the current day, you could write:C code ' g_date_set_time_t (date, time (NULL));  Sets the value of a date from a #j value. Note that the tvUsec member is ignored, because Q, can't make use of the additional precision.FThe time to date conversion is done using the user's current timezone.Sets the year for a QO. If the resulting day-month-year triplet is invalid, the date will be invalid.tMoves a date some number of days into the past. To move by weeks, just move by weeks*7 days. The date must be valid.Moves a date some number of months into the past. If the current day of the month doesn't exist in the destination month, the day of the month may change. The date must be valid.Moves a date some number of years into the past. If the current day doesn't exist in the destination year (i.e. it's February 29 and you move to a non-leap-year) then the day is changed to February 29. The date must be valid.8Fills in the date-related bits of a struct tm using the dateK value. Initializes the non-date parts with something sane but meaningless.Returns  Y if the Qe represents an existing day. The date must not contain garbage; it should have been initialized with h& if it wasn't allocated by one of the a variants.FReturns the number of days in a month, taking leap years into account.tReturns the number of weeks in the year, where weeks are taken to start on Monday. Will be 52 or 53. The date must be valid. (Years always have 52 7-day periods, plus 1 or 2 extra days depending on whether it's a leap year. This function is basically telling you how many Mondays are in the year, i.e. there are 53 Mondays if one of the extra days happens to be a Monday.)tReturns the number of weeks in the year, where weeks are taken to start on Sunday. Will be 52 or 53. The date must be valid. (Years always have 52 7-day periods, plus 1 or 2 extra days depending on whether it's a leap year. This function is basically telling you how many Sundays are in the year, i.e. there are 53 Sundays if one of the extra days happens to be a Sunday.)Returns  Y if the year is a leap year.For the purposes of this function, leap year is every year divisible by 4 unless that year is divisible by 100. If it is divisible by 100 it would be a leap year only if that year is also divisible by 400.Generates a printed representation of the date, in a [locale][setlocale]-specific way. Works just like the platform's C library  strftime()z function, but only accepts date-related formats; time-related formats give undefined results. Date must be valid. Unlike  strftime()\ (which uses the locale encoding), works on a UTF-8 format string and stores a UTF-8 result.This function does not provide any conversion specifiers in addition to those implemented by the platform's C library. For example, don't expect that using G' would make the %F provided by the C99  strftime(): work on Windows where the C library only complies to C89.Returns  YV if the day of the month is valid (a day is valid if it's between 1 and 31 inclusive).Returns  YP if the day-month-year triplet forms a valid, existing day in the range of days QP understands (Year 1 or later, no more than a few thousand years in the future).Returns  Yt if the Julian day is valid. Anything greater than zero is basically a valid Julian, though there is a 32-bit limit.Returns  Y% if the month value is valid. The 12 @. enumeration values are the only valid months.Returns  Y$ if the weekday is valid. The seven @0 enumeration values are the only valid weekdays.Returns  Y` if the year is valid. Any year greater than 0 is valid, though there is a 16-bit limit to what Q will understand.sQR/0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_STUVWXYZ[\]^_`aReturns: a newly-allocated Q bday: day of the month month: month of the year year: year Returns: a newly-allocated Q initialized with day, month, and year c julianDay: days since January 1, Year 1 Returns: a newly-allocated Q initialized with  julianDay ddate: a Q to increment nDays*: number of days to move the date forward edate: a Q to increment nMonths#: number of months to move forward fdate: a Q to increment nYears": number of years to move forward gdate: a Q to clamp minDate: minimum accepted value for date maxDate: maximum accepted value for date hdate(: pointer to one or more dates to clear nDates: number of dates to clear ilhs: first date to compare rhs: second date to compare Returns: 0 for equal, less than zero if lhs is less than rhs, greater than zero if lhs is greater than rhs jdate1: the first date date2: the second date Returns: the number of days between date1 and date2 kdate: a Q to free ldate: a Q& to extract the day of the month from Returns: day of the month mdate: a Q to extract day of year from Returns: day of the year ndate : a valid Q Returns:# ISO 8601 week number of the year. odate: a Q to extract the Julian day from Returns: Julian day pdate: a Q Returns: week of the year qdate: a Q to get the month from Returns: month of the year as a @ rdate: a Q Returns: week number sdate: a Q Returns: day of the week as a @. tdate: a Q Returns: year in which the date falls udate: a Q to check Returns:  Y' if the date is the first of the month vdate: a Q to check Returns:  Y* if the date is the last day of the month wdate1: the first date date2: the second date xdate: a Q day : day to set ydate: a Q day: day month: month y: year zdate: a Q  julianDate3: Julian day number (days since January 1, Year 1) {date: a Q month: month to set |date: a Q to fill in str: string to parse }date: a Q. time_: GTime value to set. ~date: a Q timet: time_t value to set date: a Q timeval: #j value to set date: a Q year: year to set date: a Q to decrement nDays: number of days to move date: a Q to decrement nMonths: number of months to move date: a Q to decrement nYears: number of years to move date: a Q to set the struct tm from tm: struct tm to fill date: a Q to check Returns: Whether the date is valid month: month year: year Returns: number of days in month during the year year : a year Returns: number of Mondays in the year year: year to count weeks in Returns: the number of weeks in year year: year to check Returns:  Y if the year is a leap year s: destination buffer slen: buffer size format: format string date: valid Q Returns:K number of characters written to the buffer, or 0 the buffer was too small day: day to check Returns:  Y if the day is valid day: day month: month year: year Returns:  Y if the date is a valid one  julianDate: Julian day to check Returns:  Y if the Julian day is valid month: month Returns:  Y if the month is valid weekday : weekday Returns:  Y if the weekday is valid year: year Returns:  Y if the year is valid @QRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~@QRSTdefghijklmnopqrstuvabcwxyz{|}~[\YZWXUV]^_`rQR/0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_STUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~C7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.TFunction to be called when starting a critical initialization section. The argument location must point to a static 0-initialized variable that will be set to a value other than 0 at the end of the initialization section. In combination with G and the unique address  valueLocation, it can be ensured that an initialization section will be executed only once during a program's life time, and that concurrent threads are blocked until initialization completed. To be used in constructs like this:C code  static gsize initialization_value = 0; if (g_once_init_enter (&initialization_value)) { gsize setup_value = 42; // initialization code here g_once_init_leave (&initialization_value, setup_value); } // use initialization_value hereCounterpart to G. Expects a location of a static 0-initialized initialization variable, and an initialization value other than 0. Sets the variable to the initialization value, and releases concurrent threads blocking in G! on this initialization variable.`alocation>: location of a static initializable variable containing 0 Returns:  Y6 if the initialization section should be entered,  X and blocks otherwise location>: location of a static initializable variable containing 0 result: new non-0 value for * valueLocation   `a7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a F struct initialized to zero.FGFGFGFGD7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Construct a  struct initialized to zero.TInternal function for gtester to free test log messages, no ABI guarantees provided.bb 7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Creates a  corresponding to  identifier. identifiere can either be an RFC3339/ISO 8601 time offset or something that would pass as a valid value for the TZ! environment variable (including  _). In Windows,  identifierh can also be the unlocalized name of a time zone for standard time, for example "Pacific Standard Time".Valid RFC3339 time offsets are "Z" (for UTC) or "hh:mm"#. ISO 8601 additionally specifies "hhmm" and "hh"a. Offsets are time values to be added to Coordinated Universal Time (UTC) to get the local time. In UNIX, the TZ environment variable typically corresponds to the name of a file in the zoneinfo database, or string in "std offset [dst [offset],start[/time],end[/time]]" (POSIX) format. There are no spaces in the specification. The name of standard and daylight savings time zone must be three or more alphabetic characters. Offsets are time values to be added to local time to get Coordinated Universal Time (UTC) and should be "[]hh[[:]mm[:ss]]". Dates are either "Jn"@ (Julian day with n between 1 and 365, leap years not counted), "n"5 (zero-based Julian day with n between 0 and 365) or "Mm.w.d" (day d (0 <= d <= 6) of week w (1 <= w <= 5) of month m (1 <= m <= 12), day 0 is a Sunday). Times are in local wall clock time, the default is 02:00:00.kIn Windows, the "tzn[+| ]hh[:mm[:ss]][dzn]" format is used, but also accepts POSIX format. The Windows format uses US rules for all time zones; daylight savings time is 60 minutes behind the standard time with date and time of change taken from Pacific Standard Time. Offsets are time values to be added to the local time to get Coordinated Universal Time (UTC).+ calls this function with the value of the TZK environment variable. This function itself is independent of the value of TZ , but if  identifier is  _ then /etc/localtimec will be consulted to discover the correct time zone on UNIX and the registry will be consulted or GetTimeZoneInformation()4 will be used to get the local time zone on Windows.:If intervals are not available, only time zone rules from TZ environment variable or other means, then they will be computed from year 1900 to 2037. If the maximum year for the rules is available and it is greater than 2037, then it will followed instead.See  .http://tools.ietf.org/html/rfc3339#section-5.6 RFC3339 5.6= for a precise definition of valid RFC3339 time offsets (the  time-offsetG expansion) and ISO 8601 for the full list of valid time offsets. See  ;http://www.gnu.org/s/libc/manual/html_node/TZ-Variable.htmlThe GNU C Library manual2 for an explanation of the possible values of the TZ environment variable. See  Khttp://msdn.microsoft.com/en-us/library/ms912391%28v=winembedded.11%29.aspx Microsoft Time Zone Index Values' for the list of time zones on Windows./You should release the return value by calling  when you are done with it. Creates a  corresponding to local time. The local time zone may change between invocations to this function; for example, if the system administrator changes it.This is equivalent to calling  with the value of the TZ4 environment variable (including the possibility of  _)./You should release the return value by calling  when you are done with it. Creates a  corresponding to UTC.This is equivalent to calling * with a value like "Z", "UTC", "+00", etc./You should release the return value by calling  when you are done with it.Finds an interval within tz that corresponds to the given time_, possibly adjusting time_5 if required to fit into an interval. The meaning of time_ depends on type.This function is similar to Z, with the difference that it always succeeds (by making the adjustments described below).In any of the cases where G succeeds then this function returns the same value, without modifying time_.#This function may, however, modify time_F in order to deal with non-existent times. If the non-existent local time_W of 02:30 were requested on March 14th 2010 in Toronto then this function would adjust time_B to be 03:00 and return the interval containing the adjusted time.Finds an the interval within tz that corresponds to the given time_. The meaning of time_ depends on type.If type is @[ then this function will always succeed (since universal time is monotonic and continuous). Otherwise time_4 is treated as local time. The distinction between @ and @. is ignored except in the case that the given time_ is ambiguous. In Toronto, for example, 01:30 on November 7th 2010 occurred twice (once inside of daylight savings time and the next, an hour later, outside of daylight savings time). In this case, the different value of type5 would result in a different interval being returned.It is still possible for this function to fail. In Toronto, for example, 02:00 on March 14th 2010 does not exist (due to the leap forward to begin daylight savings time). -1 is returned in that case.EDetermines the time zone abbreviation to be used during a particular interval of time in the time zone tz.For example, in Toronto this is currently "EST" during the winter months and "EDT" during the summer months when daylight savings time is in effect.;Determines the offset to UTC in effect during a particular interval of time in the time zone tz.YThe offset is the number of seconds that you add to UTC time to arrive at local time for tzN (ie: negative numbers for time zones west of GMT, positive numbers for east).EDetermines if daylight savings time is in effect during a particular interval of time in the time zone tz.!Increases the reference count on tz.!Decreases the reference count on tz.cdefghijklm identifier: a timezone identifier Returns: the requested timezone Returns: the local timezone Returns: the universal timezone tz: a  type: the @ of time_ time_9: a pointer to a number of seconds since January 1, 1970 Returns: the interval containing time_ , never -1 tz: a  type: the @ of time_ time_,: a number of seconds since January 1, 1970 Returns: the interval containing time_, or -1 in case of failure tz: a  interval": an interval within the timezone Returns:. the time zone abbreviation, which belongs to tz tz: a  interval": an interval within the timezone Returns:U the number of seconds that should be added to UTC to get the local time in tz tz: a  interval": an interval within the timezone Returns:  Y' if daylight savings time is in effect tz: a  Returns: a new reference to tz. tz: a    cdefghijklmE7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None$*,9:;<=DRT^b3No description available in the introspection data.+A good size for a buffer to be passed into Gn. It is guaranteed to be enough for all output of that function on systems with 64bit IEEE-compatible doubles.*The typical usage would be something like:C code n char buf[G_ASCII_DTOSTR_BUF_SIZE]; fprintf (out, "value=%s\n", g_ascii_dtostr (buf, sizeof (buf), value));7Specifies one of the possible types of byte order. See  G_BYTE_ORDER.cThe set of uppercase ASCII alphabet characters. Used for specifying valid identifier characters in .LThe set of ASCII digits. Used for specifying valid identifier characters in .cThe set of lowercase ASCII alphabet characters. Used for specifying valid identifier characters in .6A bitmask that restricts the possible flags passed to GN. Passing a flags value where flags & ~G_DATALIST_FLAGS_MASK != 0 is an error.Represents an invalid GDateDay.(Represents an invalid Julian day number.Represents an invalid year.VThe directory separator character. This is '/' on UNIX machines and '\' under Windows.XThe directory separator as a string. This is "/" on UNIX machines and "\" under Windows.The base of natural logarithms.]This is the platform dependent conversion specifier for scanning and printing values of type gint16. It is a string literal, but doesn't include the percent-sign, such that you can add precision and length modifiers between percent-sign and conversion specifier.C code t gint16 in; gint32 out; sscanf ("42", "%" G_GINT16_FORMAT, &in) out = in * 1000; g_print ("%" G_GINT32_FORMAT, out);jThe platform dependent length modifier for conversion specifiers for scanning and printing values of type gint16 or guint16. It is a string literal, but doesn't include the percent-sign, such that you can add precision and length modifiers between percent-sign and conversion specifier and append a conversion specifier.$The following example prints "0x7b";C code A gint16 value = 123; g_print ("%#" G_GINT16_MODIFIER "x", value);]This is the platform dependent conversion specifier for scanning and printing values of type gint32 . See also .jThe platform dependent length modifier for conversion specifiers for scanning and printing values of type gint32 or guint32#. It is a string literal. See also .]This is the platform dependent conversion specifier for scanning and printing values of type gint64 . See also .|Some platforms do not support scanning and printing 64-bit integers, even though the types are supported. On such platforms  is not defined. Note that scanf()* may not support 64-bit integers, even if - is defined. Due to its weak error handling, scanf()7 is not recommended for parsing anyway; consider using G instead.jThe platform dependent length modifier for conversion specifiers for scanning and printing values of type gint64 or guint64. It is a string literal.oSome platforms do not support printing 64-bit integers, even though the types are supported. On such platforms  is not defined.]This is the platform dependent conversion specifier for scanning and printing values of type gintptr.jThe platform dependent length modifier for conversion specifiers for scanning and printing values of type gintptr or guintptr. It is a string literal./Expands to "" on all modern compilers, and to FUNCTION" on gcc version 2.x. Don't use it..Expands to "" on all modern compilers, and to PRETTY_FUNCTION" on gcc version 2.x. Don't use it.]This is the platform dependent conversion specifier for scanning and printing values of type gsize . See also .jThe platform dependent length modifier for conversion specifiers for scanning and printing values of type gsize. It is a string literal.]This is the platform dependent conversion specifier for scanning and printing values of type gssize . See also .jThe platform dependent length modifier for conversion specifiers for scanning and printing values of type gssize. It is a string literal.]This is the platform dependent conversion specifier for scanning and printing values of type guint16 . See also ]This is the platform dependent conversion specifier for scanning and printing values of type guint32 . See also .]This is the platform dependent conversion specifier for scanning and printing values of type guint64 . See also .|Some platforms do not support scanning and printing 64-bit integers, even though the types are supported. On such platforms  is not defined. Note that scanf()* may not support 64-bit integers, even if - is defined. Due to its weak error handling, scanf()7 is not recommended for parsing anyway; consider using G instead.]This is the platform dependent conversion specifier for scanning and printing values of type guintptr.3No description available in the introspection data.3No description available in the introspection data.;Defined to 1 if gcc-style visibility handling is supported.3No description available in the introspection data.3No description available in the introspection data.LThe position of the first bit which is not reserved for internal use be the = implementation, i.e. 1 << G_HOOK_FLAG_USER_SHIFTB is the first bit which can be used for application-defined flags.BThe bias by which exponents in double-precision floats are offset.BThe bias by which exponents in single-precision floats are offset.FThe name of the main group of a desktop entry file, as defined in the  3http://freedesktop.org/Standards/desktop-entry-specDesktop Entry SpecificationR. Consult the specification for more details about the meanings of the keys below.& A key under H, whose value is a string list giving the available application actions. A key under n, whose value is a list of strings giving the categories in which the desktop entry should be shown in a menu. A key under M, whose value is a localized string giving the tooltip for the desktop entry.& A key under O, whose value is a boolean set to true if the application is D-Bus activatable. A key under l, whose value is a string giving the command line to execute. It is only valid for desktop entries with the  Application type. A key under Q, whose value is a localized string giving the generic name of the desktop entry. A key under Z, whose value is a boolean stating whether the desktop entry has been deleted by the user. A key under f, whose value is a localized string giving the name of the icon to be displayed for the desktop entry. A key under Y, whose value is a list of strings giving the MIME types supported by this desktop entry. A key under R, whose value is a localized string giving the specific name of the desktop entry. A key under j, whose value is a list of strings identifying the environments that should not display the desktop entry. A key under V, whose value is a boolean stating whether the desktop entry should be shown in menus. A key under f, whose value is a list of strings identifying the environments that should display the desktop entry.  A key under , whose value is a string containing the working directory to run the program in. It is only valid for desktop entries with the  Application type.  A key under H, whose value is a boolean stating whether the application supports the  >http://www.freedesktop.org/Standards/startup-notification-spec+Startup Notification Protocol Specification.  A key under , whose value is string identifying the WM class or name hint of a window that the application will create, which can be used to emulate Startup Notification with older applications.  A key under , whose value is a boolean stating whether the program should be run in a terminal window. It is only valid for desktop entries with the  Application type.  A key under , whose value is a string giving the file name of a binary on disk used to determine if the program is actually installed. It is only valid for desktop entries with the  Application type. A key under H, whose value is a string giving the type of the desktop entry. Usually , , or . A key under b, whose value is a string giving the URL to access. It is only valid for desktop entries with the Link type. A key under p, whose value is a string giving the version of the Desktop Entry Specification used for the desktop entry file.The value of the 4, key for desktop entries representing applications.The value of the 3, key for desktop entries representing directories.The value of the :, key for desktop entries representing links to documents.7Specifies one of the possible types of byte order. See  G_BYTE_ORDER.The natural logarithm of 10.The natural logarithm of 2.KMultiplying the base 2 exponent by this number yields the base 10 exponent.Defines the log domain.8For applications, this is typically left as the default  _ (or "") domain. Libraries should define this so that any messages which they log can be differentiated from messages from other libraries and application code. But be careful not to define it in any public header files.UFor example, GTK+ uses this in its Makefile.am: > >AM_CPPFLAGS = -DG_LOG_DOMAIN="Gtk"5GLib log levels that are considered fatal by default.lThis is not used if structured logging is enabled; see [Using Structured Logging][using-structured-logging].qLog levels below 1<<G_LOG_LEVEL_USER_SHIFT are used by GLib. Higher bits can be used for user-defined log levels.-The major version number of the GLib library.Like glib_major_version}, but from the headers used at application compile time, rather than from the library linked against at application run time.)The maximum value which can be held in a gint16.)The maximum value which can be held in a gint32.)The maximum value which can be held in a gint64.)The maximum value which can be held in a gint8. )The maximum value which can be held in a guint16.!)The maximum value which can be held in a guint32.")The maximum value which can be held in a guint64.#)The maximum value which can be held in a guint8.$-The micro version number of the GLib library.Like gtk_micro_version}, but from the headers used at application compile time, rather than from the library linked against at application run time.%)The minimum value which can be held in a gint16.&)The minimum value which can be held in a gint32.')The minimum value which can be held in a gint64.()The minimum value which can be held in a gint8.)-The minor version number of the GLib library.Like gtk_minor_version}, but from the headers used at application compile time, rather than from the library linked against at application run time.*3No description available in the introspection data.+If a long option in the main group has this name, it is not treated as a regular option. Instead it collects all non-option arguments which would otherwise be left in argv. The option must be of type @, @ or @.Using + instead of simply scanning argv} for leftover arguments has the advantage that GOption takes care of necessary encoding conversions for strings or filenames.,JSpecifies one of the possible types of byte order (currently unused). See  G_BYTE_ORDER.-BThe value of pi (ratio of circle's circumference to its diameter)..2'A format specifier that can be used in printf()&-style format strings when printing a GPid./Pi divided by 2.0Pi divided by 4.1'A format specifier that can be used in printf()(-style format strings when printing the fd member of a 4.2,Use this for default priority event sources.AIn GLib this priority is used when adding timeout functions with g_timeout_add()<. In GDK this priority is used for events from the X server.3-Use this for default priority idle functions.>In GLib this priority is used when adding idle functions with  g_idle_add().4)Use this for high priority event sources.#It is not used within GLib or GTK+.5*Use this for high priority idle functions. GTK+ uses 5# + 10 for resizing operations, and 5 + 20 for redrawing operations. (This is done to ensure that any pending resizes are processed before any pending redraws, so that widgets are not redrawn twice unnecessarily.)60Use this for very low priority background tasks.#It is not used within GLib or GTK+.7XThe search path separator character. This is ':' on UNIX machines and ';' under Windows.8ZThe search path separator as a string. This is ":" on UNIX machines and ";" under Windows.93No description available in the introspection data.:3No description available in the introspection data.;3No description available in the introspection data.<3No description available in the introspection data.= (Use this macro as the return value of a F to leave the 0 in the main loop.> (Use this macro as the return value of a F to remove the 0 from the main loop.?The square root of two.@!The standard delimiters, used in G.A3No description available in the introspection data.B3No description available in the introspection data.C3No description available in the introspection data.D3No description available in the introspection data.E3No description available in the introspection data.F3No description available in the introspection data.G$Evaluates to a time span of one day.H%Evaluates to a time span of one hour.I,Evaluates to a time span of one millisecond.J'Evaluates to a time span of one minute.K'Evaluates to a time span of one second.L oThe maximum length (in codepoints) of a compatibility or canonical decomposition of a single Unicode character."This is as defined by Unicode 6.1.MIGeneric delimiters characters as defined in RFC 3986. Includes ":/?#[]@".NQSubcomponent delimiter characters as defined in RFC 3986. Includes "!$&'()*+,;=".O^Number of microseconds in one second (1 million). This macro is provided for code readability.P3No description available in the introspection data.Q A macro that should be defined by the user prior to including the glib.h header. The definition should be one of the predefined GLib version macros: GLIB_VERSION_2_26, GLIB_VERSION_2_28,...kThis macro defines the earliest version of GLib that the package is required to be able to compile against.If the compiler is configured to warn about the use of deprecated functions, then using functions that were deprecated in version Q\ or earlier will cause warnings (but using functions deprecated in later releases will not).R3No description available in the introspection data.      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQR      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRRQPONMLKJIHGFEDCBA@?>=<;:9876543210/.-,+*)('&%$#"!            !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRF7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^OSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~nopqrstuvwxyz{ | } ~                               ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ;fd": the fd that triggered the event  condition : the IO conditions reported on fd userData: user data passed to g_unix_fd_add() Returns:  X! if the source should be removed < = > ? @ Akey : a key of a  node value%: the value corresponding to the key data: user data passed to g_tree_traverse() Returns:  Y to stop the traversal B C D Estr: the untranslated string data=: user data specified when installing the function, e.g. in 5 Returns:r a translation of the string for the current locale. The returned string is owned by GLib and must not be freed. F G H Idata: data passed to the thread Returns: the return value of the thread J K L M logDomain : the log domain of the message logLevelI: the log level of the message (including the fatal and recursion flags) message: the message to process userData: user data, set in g_test_log_set_fatal_handler() Returns:  Y if the program should abort,  X otherwise N O P Q R S T U V Wfixture: the test fixture userData.: the data provided when registering the test X Y Z [ \ ]userData.: the data provided when registering the test ^ _ ` a b cuserData%: user data to pass to the function. d e f g h i j k l m n o p q r s t uuserDatac: data passed to the function, set when the source was created with one of the above functions Returns:  X" if the source should be removed. E and E0 are more memorable names for the return value. v w x y z { | } ~  a: a 1} b: a 1} data : user data Returns:6 zero if the iterators are equal, a negative value if a comes before b, and a positive value if b comes before a. scanner: a 3 message: the message error:  Y& if the message signals an error,  X if it signals a warning.  matchInfo: the 8! generated by the match. Use 8 and 8 if you need the  or the matched string. result: a / containing the new string userData: user data passed to g_regex_replace_eval() Returns:  X& to continue the replacement process,  Y to stop it string: the message to output ufds: an array of 4 elements nfsd: the number of elements in ufds timeout_u: the maximum time to wait for an event of the file descriptors. A negative value indicates an infinite timeout. Returns: the number of 4P elements which have events or errors reported, or -1 if an error occurred. context : The active 6 group*: The group to which the function belongs data: User data added to the 51 containing the option when it was created with 5  (Can throw \]) context : The active 6 group*: The group to which the function belongs data: User data added to the 51 containing the option when it was created with 5  (Can throw \])  optionName: The name of the option being parsed. This will be either a single dash followed by a single letter (for a short name) or two dashes followed by a long option name. value: The value to be parsed. data: User data added to the 51 containing the option when it was created with 5  (Can throw \]) node: a 7. data: user data passed to g_node_traverse(). Returns:  Y to stop the traversal. node: a 7. data: user data passed to g_node_children_foreach().  (Can throw \])  (Can throw \])  (Can throw \])  (Can throw \]) logLevel: log level of the message fields: fields forming the message userData: user data passed to G Returns: @/ if the log entry was handled successfully; @ otherwise  logDomain : the log domain of the message logLevelM: the log level of the message (including the fatal and recursion flags) message: the message to process userData: user data, set in g_log_set_handler()  (Can throw \])  (Can throw \])  (Can throw \])  (Can throw \])  (Can throw \]) source: the ; event source  condition): the condition which has been satisfied data: user data set in g_io_add_watch() or G Returns: the function should return  X0 if the event source should be removed hook: a =  marshalData : user data   data: the data field of the =% is passed to the hook function here    hook: a = data: user data passed to g_hook_find_func() Returns:  Y if the required = has been found  hookList: a < hook: the hook in hookList that gets finalized  newHook: the = being inserted sibling: the = to compare with newHook Returns: a value <= 0 if newHook should be before sibling    hook: a =  marshalData : user data Returns:  X if hook should be destroyed    data: the data field of the =% is passed to the hook function here Returns:  X if the = should be destroyed    key: a key Returns:) the hash value corresponding to the key    key: a key value$: the value associated with the key userData: user data passed to G Returns:  Y6 if the key/value pair should be removed from the NO ! " # $ %key: a key value%: the value corresponding to the key userData: user data passed to g_hash_table_foreach() & ' ( ) * +data: the element's data userData: user data passed to g_list_foreach() or g_slist_foreach() , - . / 0 1data: a data pointer 2 3 4 5a : a value b: a value to compare with Returns:  Y if a = b;  X otherwise 6 7 8 9data: the data to duplicate userData": user data that was specified in g_datalist_id_dup_data() Returns: a duplicate of data : ; < = > ?data: the data element. @ A B CkeyId: the GQuark% id to identifying the data element. data: the data element. userData: user data passed to g_dataset_foreach(). D E F G H Isrc/: A pointer to the data which should be copied data: Additional data Returns: A pointer to the copy J K L Ma : a value b: a value to compare with Returns: negative value if a < b ; zero if a = b; positive value if a > b N O P Qa : a value b: a value to compare with userData : user data Returns: negative value if a < b ; zero if a = b; positive value if a > b R S T U V Wpid&: the process id of the child process statusX: Status information about the child process, encoded in a platform-specific manner userData: user data passed to g_child_watch_add() X Y Z [ \ STUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                           ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ UTS Z W [ X Y \XWV T Q U R S VZY M O N P\[ I K J L_^] F C G D E Ha` ? A @ Bdcb < 9 = : ; >fe 5 7 6 8hg 1 3 2 4kji . + / , - 0nml ( % ) & ' *qpo "  # ! $sr    ut    wv    yx     {z  }|    ~                                                         !  "  #  $  %  &   '  { } ( | ~ x u y ) v w z q s * r t m o + n p i k , j l f c g - d e h ` ] a . ^ _ b Z W [ / X Y \ S U 0 T V P M Q 1 N O R I K 2 J L E G 3 F H A C 4 B D > ; ? 5 < = @ 7 9 6 8 :OSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~nopqrstuvwxyz{ | } ~                               ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \G7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ ]3No description available in the introspection data. ^Validates UTF-8 encoded text. str is the text to validate; if str is nul-terminated, then maxLen can be -1, otherwise maxLen/ should be the number of bytes to validate. If end is non- _, then the end of the valid range will be stored there (i.e. the start of the first invalid character if some bytes were invalid, or the end of the text being validated otherwise). Note that  ^ returns  X if maxLen is positive and any of the maxLen bytes are nul.Returns  Y if all of str was valid. Many GLib and GTK+ routines require valid UTF-8 as input; so data read from a file or the network should be checked with  ^$ before doing anything else with it. _MCopies a substring out of a UTF-8 encoded string. The substring will contain endPos - startPos characters. ` Converts all Unicode characters in the string that have a case to uppercase. The exact manner that this is done depends on the current locale, and may result in the number of characters in the string increasing. (For instance, the German ess-zet will be changed to SS.) aReverses a UTF-8 string. str( must be valid UTF-8 encoded text. (Use  ^C on all text before trying to use UTF-8 utility functions with it.)$This function is intended for programmatic uses of reversed strings. It pays no attention to decomposed characters, combining marks, byte order marks, directional indicators (LRM, LRO, etc) and similar characters which might need special handling when reversing a string for display purposes.Note that unlike  K, this function returns newly-allocated memory, which should be freed with  y when no longer needed. buFind the rightmost occurrence of the given Unicode character in a UTF-8 encoded string, while limiting the search to len bytes. If len is -1, allow unbounded search. cLike the standard C  strncpy()[ function, but copies a given number of characters instead of a given number of bytes. The src/ string must be valid UTF-8 encoded text. (Use  ^C on all text before trying to use UTF-8 utility functions with it.) deComputes the length of the string in characters, not including the terminating nul character. If the maxY'th byte falls in the middle of a character, the last (partial) character is not counted. eConverts all Unicode characters in the string that have a case to lowercase. The exact manner that this is done depends on the current locale, and may result in the number of characters in the string changing. fuFinds the leftmost occurrence of the given Unicode character in a UTF-8 encoded string, while limiting the search to len bytes. If len is -1, allow unbounded search. g8Finds the previous UTF-8 character in the string before p.p does not have to be at the beginning of a UTF-8 character. No check is made to see if the character found is actually valid other than it starts with an appropriate byte. If p: might be the first character of the string, you must use  m instead. hRConverts from a pointer to position within a string to a integer character offset.!Since 2.10, this function allows pos to be before str-, and returns a negative offset in this case. iWConverts from an integer character offset to a pointer to a position within the string.4Since 2.10, this function allows to pass a negative offset_ to step backwards. It is usually worth stepping backwards from the end instead of forwards if offseth is in the last fourth of the string, since moving forward is about 3 times faster than moving backward.?Note that this function doesn't abort when reaching the end of str$. Therefore you should be sure that offset@ is within string boundaries before calling that function. Call  d when unsure. This limitation exists as this function is called frequently during text rendering and therefore has to be as fast as possible. jConverts a string into canonical form, standardizing such issues as whether a character with an accent is represented as a base character and combining accent or as a single precomposed character. The string has to be valid UTF-8, otherwise  _( is returned. You should generally call  j& before comparing two Unicode strings.The normalization mode @w only standardizes differences that do not affect the text content, such as the above-mentioned accent representation. @ also standardizes the "compatibility" characters in Unicode, such as SUPERSCRIPT THREE to the standard forms (in this case DIGIT THREE). Formatting information may be lost but for most text operations such characters should be considered the same.@ and @ are like @ and @, but returned a result with composed forms rather than a maximally decomposed form. This is often useful if you intend to convert the string to a legacy encoding or pass it to a system with less capable Unicode handling. kConvert a sequence of bytes encoded as UTF-8 to a Unicode character. This function checks for incomplete characters, for invalid characters such as characters that are out of the range of Unicode, and for overlong encodings of valid characters. lEConverts a sequence of bytes encoded as UTF-8 to a Unicode character.If p does not point to a valid UTF-8 encoded character, results are undefined. If you are not sure that the bytes are complete valid Unicode characters, you should use  k instead. mGiven a position p with a UTF-8 encoded string strA, find the start of the previous UTF-8 character starting before p . Returns  _' if no UTF-8 characters are present in str before p.p does not have to be at the beginning of a UTF-8 character. No check is made to see if the character found is actually valid other than it starts with an appropriate byte. n@Finds the start of the next UTF-8 character in the string after p.p does not have to be at the beginning of a UTF-8 character. No check is made to see if the character found is actually valid other than it starts with an appropriate byte. ozConverts a string into a collation key that can be compared with other collation keys produced by the same function using strcmp().In order to sort filenames correctly, this function treats the dot '.' as a special case. Most dictionary orderings seem to consider it insignificant, thus producing the ordering "event.c" "eventgenerator.c" "event.h" instead of "event.c" "event.h" "eventgenerator.c". Also, we would like to treat numbers intelligently so that "file1" "file10" "file5" is sorted as "file1" "file5" "file10".CNote that this function depends on the [current locale][setlocale]. pzConverts a string into a collation key that can be compared with other collation keys produced by the same function using strcmp().@The results of comparing the collation keys of two strings with strcmp()A will always be the same as comparing the two original keys with  q.CNote that this function depends on the [current locale][setlocale]. qCompares two strings for ordering using the linguistically correct rules for the [current locale][setlocale]. When sorting a large number of strings, it will be significantly faster to obtain collation keys with  p and compare the keys with strcmp()6 when sorting instead of sorting the original strings. rConverts a string into a form that is independent of case. The result will not correspond to any particular case, but can be compared for equality or ordered with the results of calling  r on other strings.Note that calling  r followed by  q is only an approximation to the correct linguistic case insensitive ordering, though it is a fairly good one. Getting this exactly right would require a more sophisticated collation function that takes case sensitivity into account. GLib does not currently provide such a function. s?Pauses the current thread for the given number of microseconds.@There are 1 million microseconds per second (represented by the E macro).  su may have limited precision, depending on hardware and operating system; don't rely on the exact length of the sleep. t!Unescapes a whole escaped string.If any of the characters in illegalCharacters: or the character zero appears as an escaped character in  escapedString then that is an error and  _ will be returned. This is useful it you want to avoid for instance having a slash being expanded in an escaped path element, which might confuse pathname handling. u)Unescapes a segment of an escaped string.If any of the characters in illegalCharacters: or the character zero appears as an escaped character in  escapedString then that is an error and  _ will be returned. This is useful it you want to avoid for instance having a slash being expanded in an escaped path element, which might confuse pathname handling. vGets the scheme portion of a URI string. RFC 3986 decodes the scheme as: > >URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ]6Common schemes include "file", "http", "svn+ssh", etc. wSplits an URI list conforming to the text/uri-list mime type defined in RFC 2483 into individual URIs, discarding any comments. The URIs are not validated. x"Escapes a string for use in a URI.Normally all characters that are not "unreserved" (i.e. ASCII alphanumerical characters plus dash, dot, underscore and tilde) are escaped. But if you specify characters in reservedCharsAllowed they are not escaped. This is useful for the "reserved" characters in the URI specification, since those are allowed unescaped in some portions of a URI. y5Removes an environment variable from the environment.Note that on some systems, when variables are overwritten, the memory used for the previous variables and its value isn't reclaimed.You should be mindful of the fact that environment variable handling in UNIX is not thread-safe, and your program may crash if one thread calls  y! while another thread is calling getenv()). (And note that many functions, such as  gettext(), call getenv() internally.) This function is only safe to use at the very start of your program, before creating any other threads (or creating objects that create worker threads of their own).GIf you need to set up the environment for a child process, you can use  s/ to get an environment array, modify that with   and  ', and then pass that array directly to  execvpe(),  , or the like. zA wrapper for the POSIX unlink() function. The unlink() function deletes a name from the filesystem. If this was the last link to the file and no processes have it opened, the diskspace occupied by the file is freed.1See your C library manual for more details about unlink(){. Note that on Windows, it is in general not possible to delete files that are open to some process, or mapped into memory. { Create a 0: that will be dispatched upon delivery of the UNIX signal signum&. In GLib versions before 2.36, only SIGHUP, SIGINT, SIGTERM" can be monitored. In GLib 2.36, SIGUSR1 and SIGUSR2 were added.Note that unlike the UNIX default, all sources which have created a watch will be dispatched, regardless of which underlying thread invoked  {.<For example, an effective use of this function is to handle SIGTERM cleanly; flushing any outstanding files, and then calling g_main_loop_quit (). It is not safe to do any of this a regular UNIX signal handler; your handler may be invoked while malloc() or another library function is running, causing reentrancy if you attempt to use it from the handler. None of the GLib/GObject API is safe against this kind of reentrancy.MThe interaction of this source when combined with native UNIX functions like  sigprocmask() is not defined.5The source will not initially be associated with any W and must be added to one with 0 before it will be executed. |A convenience function for  { , which attaches to the default W". You can remove the watch using G. }JControl the non-blocking state of the given file descriptor, according to nonblock. On most systems this uses  O_NONBLOCK!, but on some older ones may use O_NDELAY. ~Similar to the UNIX pipe()1 call, but on modern systems like Linux uses the pipe2()n system call, which atomically creates a pipe with the configured flags. The only supported flag currently is  FD_CLOEXEC'. If for example you want to configure  O_NONBLOCK*, that must still be done separately with fcntl().This function does not take  O_CLOEXEC , it takes  FD_CLOEXEC as if for fcntl()%; these are different on Linux/glibc. $ Creates a 0= to watch for a particular IO condition on a file descriptor.>The source will never close the fd -- you must do it yourself. $DSets a function to be called when the IO condition, as specified by  condition becomes true for fd.This is the same as g_unix_fd_add()N, except that it allows you to specify a non-default priority and a provide a F for userData. 3No description available in the introspection data.  Looks up the ISO 15924 code for script. ISO 15924 assigns four-letter codes to scripts. For example, the code for Arabic is 'Arab'. The four letter codes are encoded as a guint32 by this function in a big-endian fashion. That is, the code returned for Arabic is 0x41726162 (0x41 is ASCII code for 'A', 0x72 is ASCII code for 'r', etc).See  *http://unicode.org/iso15924/codelists.html0Codes for the representation of names of scripts for details.  Looks up the Unicode script for iso15924. ISO 15924 assigns four-letter codes to scripts. For example, the code for Arabic is 'Arab'. This function accepts four letter codes encoded as a guint32 in a big-endian fashion. That is, the code expected for Arabic is 0x41726162 (0x41 is ASCII code for 'A', 0x72 is ASCII code for 'r', etc).See  *http://unicode.org/iso15924/codelists.html0Codes for the representation of names of scripts for details. Computes the canonical ordering of a string in-place. This rearranges decomposed characters in the string according to their combining classes. See the Unicode manual for more information. <Computes the canonical decomposition of a Unicode character. CDetermines the numeric value of a character as a hexidecimal digit. Checks whether ch? is a valid Unicode character. Some possible integer values of ch` will not be valid. 0 is considered a valid character, though it's normally a string terminator. 'Classifies a Unicode character by type. "Converts a character to uppercase. &Converts a character to the titlecase. #Converts a character to lower case. ^Determines if a given character typically takes zero width when rendered. The return value is  Y for all non-spacing and enclosing marks (e.g., combining accents), format characters, zero-width space, but not U+00AD SOFT HYPHEN..A typical use of this function is with one of   or   to determine the number of cells a string occupies when displayed on a grid display (terminals). However, note that not all terminals support zero-width rendering of zero-width marks. 1Determines if a character is a hexidecimal digit.  Determines if a character is typically rendered in a double-width cell under legacy East Asian locales. If a character is wide according to  f, then it is also reported wide with this function, but the converse is not necessarily true. See the  $http://www.unicode.org/reports/tr11/Unicode Standard Annex #11 for details.If a character passes the  } test then it will also pass this test, but not the other way around. Note that some characters may pass both this test and  . GDetermines if a character is typically rendered in a double-width cell. 'Determines if a character is uppercase. [Determines if a character is titlecase. Some characters in Unicode which are composites, such as the DZ digraph have three case variants instead of just two. The titlecase form is used at the beginning of a word where only the first letter is capitalized. The titlecase form of the DZ digraph is U+01F2 LATIN CAPITAL LETTTER D WITH SMALL LETTER Z. Determines whether a character is a space, tab, or line separator (newline, carriage return, etc.). Given some UTF-8 text, obtain a character value with  l.(Note: don't use this to do word breaking; you have to use Pango or equivalent to get word breaking right, the algorithm is fairly complex.) pDetermines whether a character is punctuation or a symbol. Given some UTF-8 text, obtain a character value with  l. 4Determines whether a character is printable. Unlike   , returns  YB for spaces. Given some UTF-8 text, obtain a character value with  l. Determines whether a character is a mark (non-spacing mark, combining mark, or enclosing mark in Unicode speak). Given some UTF-8 text, obtain a character value with  l.Note: in most cases where isalpha characters are allowed, ismark characters should be allowed to as they are essential for writing most European languages as well as many non-Latin scripts. kDetermines whether a character is a lowercase letter. Given some UTF-8 text, obtain a character value with  l. EDetermines whether a character is printable and not a space (returns  X9 for control characters, format characters, and spaces).   is similar, but returns  YB for spaces. Given some UTF-8 text, obtain a character value with  l. Determines whether a character is numeric (i.e. a digit). This covers ASCII 0-9 and also digits in other languages/scripts. Given some UTF-8 text, obtain a character value with  l. DDetermines if a given character is assigned in the Unicode standard. lDetermines whether a character is a control character. Given some UTF-8 text, obtain a character value with  l. sDetermines whether a character is alphabetic (i.e. a letter). Given some UTF-8 text, obtain a character value with  l. eDetermines whether a character is alphanumeric. Given some UTF-8 text, obtain a character value with  l.  Looks up the @] for a particular character (as defined by Unicode Standard Annex #24). No check is made for ch\ being a valid Unicode character; if you pass in invalid character, the result is undefined.This function is equivalent to pango_script_for_unichar()! and the two are interchangeable. In Unicode, some characters are "mirrored". This means that their images are mirrored horizontally in text that is laid out from right to left. For instance, "(" would become its mirror image, ")", in right-to-left text.If ch has the Unicode mirrored property and there is another unicode character that typically has a glyph that is the mirror image of ch 's glyph and  mirroredCh= is set, it puts that character in the address pointed to by  mirroredCh+. Otherwise the original character is put. ?Determines the numeric value of a character as a decimal digit. VPerforms a single decomposition step of the Unicode canonical decomposition algorithm.This function does not include compatibility decompositions. It does, however, include algorithmic Hangul Jamo decomposition, as well as 'singleton' decompositions which replace a character by a single other character. In the case of singletons *b will be set to zero.If ch is not decomposable, *a is set to ch and *b is set to zero.QNote that the way Unicode decomposition pairs are defined, it is guaranteed that b" would not decompose further, but aD may itself decompose. To get the full canonical decomposition for ch6, one would need to recursively call this function on a . Or use g_unichar_fully_decompose().See  http://unicode.org/reports/tr15/UAX#15 for details. RPerforms a single composition step of the Unicode canonical composition algorithm.aThis function includes algorithmic Hangul Jamo composition, but it is not exactly the inverse of  $. No composition can have either of a or b equal to zero. To be precise, this function composes if and only if there exists a Primary Composite P which is canonically equivalent to the sequence <a,bE>. See the Unicode Standard for the definition of Primary Composite.If a and b! do not compose a new character, ch is set to zero.See  http://unicode.org/reports/tr15/UAX#15 for details. @Determines the canonical combining class of a Unicode character. Determines the break type of c. cS should be a Unicode character (to derive a character from UTF-8 encoded text, use  l). The break type is used to find word and line breaks ("text boundaries"), Pango implements the Unicode boundary resolution algorithms and normally you would use a function such as  pango_break(). instead of caring about break types yourself. This function is similar to  , allocating (nBlocks *  nBlockBytesM) bytes, but care is taken to detect possible overflow during multiplication. Attempts to realloc mem to a new size, nBytes, and returns  _ on failure. Contrast with  &, which aborts the program on failure.If mem is  _, behaves the same as  . This function is similar to  , allocating (nBlocks *  nBlockBytesM) bytes, but care is taken to detect possible overflow during multiplication. This function is similar to  , allocating (nBlocks *  nBlockBytesM) bytes, but care is taken to detect possible overflow during multiplication. Attempts to allocate nBytes", initialized to 0's, and returns  _ on failure. Contrast with  :&, which aborts the program on failure. Attempts to allocate nBytes, and returns  _ on failure. Contrast with  ;&, which aborts the program on failure. Creates a new timeout source.5The source will not initially be associated with any W and must be added to one with 0 before it will be executed.NThe scheduling granularity/accuracy of this timeout source will be in seconds.HThe interval given in terms of monotonic time, not wall clock time. See  m. Creates a new timeout source.5The source will not initially be associated with any W and must be added to one with 0 before it will be executed.LThe interval given is in terms of monotonic time, not wall clock time. See  m. 8Sets a function to be called at regular intervals, with priority5. The function is called repeatedly until it returns  Xb, at which point the timeout is automatically destroyed and the function will not be called again.Unlike g_timeout_add() , this function operates at whole second granularity. The initial starting point of the timer is determined by the implementation and the implementation is expected to group multiple timers together so that they fire all at the same time. To allow this grouping, the interval to the first timer is rounded and can deviate up to one second from the specified interval. Subsequent timer iterations will generally run at the specified interval.Note that timeout functions may be delayed, due to the processing of other event sources. Thus they should not be relied on for precise timing. After each call to the timeout function, the time of the next timeout is recalculated based on the current time and the given intervalSee [memory management of sources][mainloop-memory-management] for details on how to handle the return value and memory management of data.8If you want timing more precise than whole seconds, use g_timeout_add() instead.The grouping of timers to fire at the same time results in a more power and CPU efficient behavior so if your timer is in multiples of seconds and you don't require the first timer exactly one second from now, the use of g_timeout_add_seconds() is preferred over g_timeout_add().1This internally creates a main loop source using  0 and attaches it to the main loop context using 0>. You can do these steps manually if you need greater control.LThe interval given is in terms of monotonic time, not wall clock time. See  m. Sets a function to be called at regular intervals, with the given priority. The function is called repeatedly until it returns  Xh, at which point the timeout is automatically destroyed and the function will not be called again. The notifys function is called when the timeout is destroyed. The first call to the function will be at the end of the first interval.KNote that timeout functions may be delayed, due to the processing of other event sources. Thus they should not be relied on for precise timing. After each call to the timeout function, the time of the next timeout is recalculated based on the current time and the given interval (it does not try to 'catch up' time lost in delays).See [memory management of sources][mainloop-memory-management] for details on how to handle the return value and memory management of data.1This internally creates a main loop source using   and attaches it to the global W using 0, so the callback will be invoked in whichever thread is running that main context. You can do these steps manually if you need greater control or to use a custom main context.HThe interval given in terms of monotonic time, not wall clock time. See  m. &&Respawns the test program to run only testPath^ in a subprocess. This can be used for a test case that might not return, or that might abort.If testPath is  _; then the same test is re-run in a subprocess. You can use  9 to determine whether the test is in a subprocess or not.testPath7 can also be the name of the parent test, followed by " /subprocess/A" and then a name for the specific subtest (or just ending with " /subprocessz" if the test only has one child test); tests with names of this form will automatically be skipped in the parent process.If  usecTimeout\ is non-0, the test subprocess is aborted and considered failing if its run time exceeds it.3The subprocess behavior can be configured with the > flags.You can use methods such as g_test_trap_assert_passed(), g_test_trap_assert_failed(), and g_test_trap_assert_stderr()8 to check the results of the subprocess. (But note that g_test_trap_assert_stdout() and g_test_trap_assert_stderr() cannot be used if  testFlagsC specifies that the child should inherit the parent stdout/stderr.)If your main ()= needs to behave differently in the subprocess, you can call   (after calling  g_test_init())) to see whether you are in a subprocess.)The following example tests that calling my_object_new(1000000)" will abort with an error message.C code  static void test_create_large_object (void) { if (g_test_subprocess ()) { my_object_new (1000000); return; } // Reruns this same test in a subprocess g_test_trap_subprocess (NULL, 0, 0); g_test_trap_assert_failed (); g_test_trap_assert_stderr ("*ERROR*too large*"); } int main (int argc, char **argv) { g_test_init (&argc, &argv, NULL); g_test_add_func ("/myobject/create_large_object", test_create_large_object); return g_test_run (); } Check the result of the last   call. Check the result of the last   call. _Fork the current test program to execute a test case that might not return or that might abort.If  usecTimeout] is non-0, the forked test case is aborted and considered failing if its run time exceeds it.0The forking behavior can be configured with the > flags.In the following example, the test code forks, the forked child process produces some sample output and exits successfully. The forking parent process then asserts successful child program termination and validates child program outputs.C code  static void test_fork_patterns (void) { if (g_test_trap_fork (0, G_TEST_TRAP_SILENCE_STDOUT | G_TEST_TRAP_SILENCE_STDERR)) { g_print ("some stdout text: somagic17\n"); g_printerr ("some stderr text: semagic43\n"); exit (0); // successful test run } g_test_trap_assert_passed (); g_test_trap_assert_stdout ("*somagic17*"); g_test_trap_assert_stderr ("*semagic43*"); } 3No description available in the introspection data. Start a timing test. Call  U when the task is supposed to be done. Call this function again to restart the timer. Report the last result of  . 4Get the time since the last start of the timer with  . &Returns  Y (after  g_test_init()7 has been called) if the test program is running under  . &"Indicates that a test was skipped.Calling this function will not stop the test from running, you need to return from the test function yourself. So you can produce additional diagnostic messages or even continue running the test.=If not called from inside a test, this function does nothing. &Changes the behaviour of g_assert_cmpstr(), g_assert_cmpint(), g_assert_cmpuint(), g_assert_cmphex(), g_assert_cmpfloat(), g_assert_true(), g_assert_false(), g_assert_null(), g_assert_no_error(), g_assert_error(), !g_test_assert_expected_messages()Y and the various g_test_trap_assert_*() macros to not abort to program, but instead call  2 and continue. (This also changes the behavior of  W so that it will not cause the test program to abort after completing the failed test.)Note that the g_assert_not_reached() and  g_assert() are not affected by this.'This function can only be called after  g_test_init(). Execute the tests within suite and all nested  GTestSuitesP. The test suites to be executed are filtered according to test path arguments ( -p testpath) as parsed by  g_test_init() . See the  G documentation for more information on the order that tests are run in.  or  & may only be called once in a program. DRuns all tests under the toplevel suite which can be retrieved with g_test_get_root() . Similar to  J, the test cases to be run are filtered according to test path arguments ( -p testpath) as parsed by  g_test_init().   or  & may only be called once in a program.In general, the tests and sub-suites within each suite are run in the order in which they are defined. However, note that prior to GLib 2.36, there was a bug in the  g_test_add_* functions which caused them to create multiple suites with the same name, meaning that if you created tests "/foo/simple", "/bar/simple", and "/foo/using-bar" in that order, they would get run in that order (since  = would run the first "/foo" suite, then the "/bar" suite, then the second "/foo" suite). As of 2.36, this bug is fixed, and adding the tests in that order would result in a running order of "/foo/simple", "/foo/using-bar", "/bar/simple". If this new ordering is sub-optimal (because it puts more-complicated tests before simpler ones, making it harder to figure out exactly what has failed), you can fix it by changing the test paths to group tests by suite in a way that will result in the desired running order. Eg, "/simple/foo", "/simple/bar", "/complex/foo-using-bar".However, you should never make the actual result of a test depend on the order that tests are run in. If you need to ensure that some particular code runs before or after a given test case, use  g_test_add()6, which lets you specify setup and teardown functions.If all tests are skipped, this function will return 0 if producing TAP output, or 77 (treated as "skip test" by Automake) otherwise. GGet a reproducible random integer number out of a specified range, see  ) for details on test case random numbers. )Get a reproducible random integer number.The random numbers generated by the g_test_rand_*() family of functions change with every new test program start, unless the --seed option is given when starting test programs.For individual test cases however, the random number generator is reseeded, to avoid dependencies between tests and to make --seed effective for all test cases. PGet a reproducible random floating pointer number out of a specified range, see  ) for details on test case random numbers. 5Get a reproducible random floating point number, see  ) for details on test case random numbers. &Enqueue a pointer to be released with  y? during the next teardown phase. This is equivalent to calling   with a destroy callback of  y. !This function enqueus a callback  destroyFunc to be executed during the next test case teardown phase. This is most useful to auto destruct allocted test resources at the end of a test run. Resources are released in reverse queue order, that means enqueueing callback A before callback B will cause B() to be called before A() during teardown. 3No description available in the introspection data. &Indicates that a test failed because of some incomplete functionality. This function can be called multiple times from the same test.Calling this function will not stop the test from running, you need to return from the test function yourself. So you can produce additional diagnostic messages or even continue running the test.=If not called from inside a test, this function does nothing. &RGets the pathname of the directory containing test files of the type specified by fileType.rThis is approximately the same as calling g_test_build_filename("."), but you don't need to free the return value. &FReturns whether a test has already failed. This will be the case when  ,   or  7 have been called, but also if an assertion has failed.gThis can be useful to return early from a test if continuing after a failed assertion might be harmful.aThe return value of this function is only meaningful if it is called from inside a test function. Indicates that a test failed. This function can be called multiple times from the same test. You can use this function if your test failed in a recoverable way.YDo not use this function if the failure of a test could cause other tests to malfunction.Calling this function will not stop the test from running, you need to return from the test function yourself. So you can produce additional diagnostic messages or even continue running the test.=If not called from inside a test, this function does nothing. "(Indicates that a message with the given  logDomain and logLevel, with text matching patternr, is expected to be logged. When this message is logged, it will not be printed, and the test case will not abort.4This API may only be used with the old logging API (g_log() without G_LOG_USE_STRUCTUREDn defined). It will not work with the structured logging API. See [Testing for Messages][testing-for-messages].Use !g_test_assert_expected_messages()O to assert that all previously-expected messages have been seen and suppressed.You can call this multiple times in a row, if multiple messages are expected as a result of a single call. (The messages must appear in the same order as the calls to  .) For example:C code V // g_main_context_push_thread_default() should fail if the // context is already owned by another thread. g_test_expect_message (G_LOG_DOMAIN, G_LOG_LEVEL_CRITICAL, "assertion*acquired_context*failed"); g_main_context_push_thread_default (bad_context); g_test_assert_expected_messages ();&Note that you cannot use this to test  g_error() messages, since  g_error()D intentionally never returns even if the program doesn't abort; use   in this case.If messages at >. are emitted, but not explicitly expected via   then they will be ignored. %Specify the base URI for bug reports.:The base URI is used to construct bug report messages for g_test_message() when   is called. Calling this function outside of a test case sets the default base URI for all test cases. Calling it from within a test case changes the base URI for the scope of the test case only. Bug URIs are constructed by appending a bug specific URI portion to  uriPattern1, or by replacing the special string '%s' within  uriPattern if that is present. This function adds a message to test reports that associates a bug URI with a test case. Bug URIs are constructed from a base URI set with   and  bugUriSnippet. 3No description available in the introspection data. #Create a new test case, similar to g_test_create_case(). However the test is assumed to use no fixture, and test suites are automatically created on the fly and added to the root fixture, based on the slash-separated portions of testpath.If testpath includes the component "subprocess" anywhere in it, the test will be skipped by default, and only run if explicitly required via the -p command-line option or  . #Create a new test case, similar to g_test_create_case(). However the test is assumed to use no fixture, and test suites are automatically created on the fly and added to the root fixture, based on the slash-separated portions of testpath. The testData. argument will be passed as first argument to testFunc.If testpath includes the component "subprocess" anywhere in it, the test will be skipped by default, and only run if explicitly required via the -p command-line option or  .  Returns the length of the given  _-terminated string array strArray. 3No description available in the introspection data. , Checks if strv contains str. strv must not be  _.  Converts a string to upper case. Converts a string to a gdouble value. It calls the standard strtod()x function to handle the conversion, but if the string is not completely converted it attempts the conversion again with  , and returns the best match.sThis function should seldom be used. The normal situation when reading numbers not for human consumption is to use  . Only when you know that you must expect both locale formatted and C formatted numbers should you use this. Make sure that you don't pass strings such as comma separated lists of values, since the commas may be interpreted as a decimal point in some locales, causing unexpected results. Searches the string haystack( for the first occurrence of the string needle', limiting the length of the search to  haystackLen. wReturns a string describing the given signal, e.g. "Segmentation fault". You should use this function in preference to  strsignal()Y, because it returns a string in UTF-8 encoding, and since not all platforms support the  strsignal() function. Searches the string haystack' for the last occurrence of the string needle', limiting the length of the search to  haystackLen. Searches the string haystack' for the last occurrence of the string needle. 4Reverses all of the bytes in a string. For example, g_strreverse ("abcdef") will result in "fedcba". Note that  V doesn't work on UTF-8 strings containing multibyte characters. For that purpose, use  a. Creates a new string length bytes long filled with fillChar<. The returned string should be freed when no longer needed. Duplicates the first n7 bytes of a string, returning a newly-allocated buffer n8 + 1 bytes long which will always be nul-terminated. If str is less than n/ bytes long the buffer is padded with nuls. If str is  _ it returns  _;. The returned value should be freed when no longer needed.@To copy a number of characters from a UTF-8 encoded string, use  c instead. DA case-insensitive string comparison, corresponding to the standard  strncasecmp(): function on platforms which support it. It is similar to  # except it only compares the first n characters of the strings. Portability wrapper that calls  strlcpy()( on systems which have it, and emulates  strlcpy() otherwise. Copies src to dest; dest% is guaranteed to be nul-terminated; src must be nul-terminated; destSize5 is the buffer size, not the number of bytes to copy.At most destSize> - 1 characters will be copied. Always nul-terminates (unless destSize7 is 0). This function does not allocate memory. Unlike  strncpy(), this function doesn't pad destZ (so it's often faster). It returns the size of the attempted result, strlen (src), so if retval >= destSize, truncation occurred.Caveat:  strlcpy() is supposedly more secure than strcpy() or  strncpy(),, but if you really want to avoid screwups,   is an even better idea. Portability wrapper that calls  strlcat()M on systems which have it, and emulates it otherwise. Appends nul-terminated src string to dest#, guaranteeing nul-termination for dest. The total size of dest won't exceed destSize.At most destSize' - 1 characters will be copied. Unlike  strncat(), destSize} is the full size of dest, not the space left over. This function does not allocate memory. It always nul-terminates (unless destSize- == 0 or there were no nul characters in the destSize# characters of dest to start with).8Caveat: this is supposedly a more secure alternative to strcat() or  strncat(), but for real security  g_strconcat() is harder to mess up. NJoins a number of strings together to form one long string, with the optional  separatorI inserted between each of them. The returned string should be freed with  y.If strArray< has no items, the return value will be an empty string. If strArray contains a single item,  separator) will not appear in the resulting string. An auxiliary function for  gettext() support (see Q_()). Creates a new /, with enough space for dflSizey bytes. This is useful if you are going to add a lot of text to the string and don't want it to be reallocated too often. Creates a new / with len bytes of the init' buffer. Because a length is provided, init@ need not be nul-terminated, and can contain embedded nul bytes.aSince this function does not stop at nul bytes, it is the caller's responsibility to ensure that init has at least len addressable bytes. Creates a new /$, initialized with the given string. Frees a  _A-terminated array of strings, as well as each string it contains.If strArray is  _, this function simply returns. ]Escapes the special characters '\b', '\f', '\n', '\r', '\t', '\v', '\' and '"' in the string source by inserting a '\' before them. Additionally all characters in the range 0x01-0x1F (everything below SPACE) and in the range 0x7F-0xFF (all non-ASCII chars) are replaced with a '\' followed by their octal representation. Characters supplied in  exceptions are not escaped.  does the reverse conversion. WReturns a string corresponding to the given error code, e.g. "no such process". Unlike  strerror(), this always returns a string in UTF-8 encoding, and the pointer is guaranteed to remain valid for the lifetime of the process.GNote that the string may be translated according to the current locale. The value of errno& will not be changed by this function. Duplicates a string. If str is  _ it returns  _+. The returned string should be freed with  y when no longer needed.  Converts a string to lower case. %Converts any delimiter characters in string to  newDelimiter. Any characters in string which are found in  delimiters are changed to the  newDelimiter character. Modifies string in place, and returns stringA itself, not a copy. The return value is to allow nesting such asC code 0 g_ascii_strup (g_strdelimit (str, "abc", '?')) ?Replaces all escaped characters with their one byte equivalent.-This function does the reverse conversion of  .  Compares str1 and str2 like strcmp() . Handles  _% gracefully by sorting it before non- _ strings. Comparing two  _ pointers returns 0. WRemoves leading whitespace from a string, by moving the rest of the characters forward.EThis function doesn't allocate or reallocate any memory; it modifies stringH in place. Therefore, it cannot be used on statically allocated strings.The pointer to string/ is returned to allow the nesting of functions. Also see   and  g_strstrip(). *Removes trailing whitespace from a string.EThis function doesn't allocate or reallocate any memory; it modifies stringH in place. Therefore, it cannot be used on statically allocated strings.The pointer to string/ is returned to allow the nesting of functions. Also see   and  g_strstrip(). DA case-insensitive string comparison, corresponding to the standard  strcasecmp()( function on platforms which support it. For each character in string, if the character is not in  validChars, replaces the character with  substitutor . Modifies string in place, and return stringA itself, not a copy. The return value is to allow nesting such asC code . g_ascii_strup (g_strcanon (str, "abc", '?')) ( Tokenises string$ and performs folding on each token.A token is a non-empty sequence of alphanumeric characters in the source string, separated by non-alphanumeric characters. An "alphanumeric" character for this purpose is one that matches   or  .=Each token is then (Unicode) normalised and case-folded. If asciiAlternates is non- _d and some of the returned tokens contain non-ASCII characters, ASCII alternatives will be generated.dThe number of ASCII alternatives that are generated and the method for doing so is unspecified, but translitLocale^ (if specified) may improve the transliteration if the language of the source string is known. (Transliterate str to plain ASCII.For best results, str' should be in composed normalised form.This function performs a reasonably good set of character replacements. The particular set of replacements that is done may change by version or even by runtime environment.If the source language of strS is known, it can used to improve the accuracy of the translation by passing it as  fromLocaleY. It should be a valid POSIX locale string (of the form "language[_territory][.codeset][modifier]").If  fromLocale is  _! then the current locale is used.If you want to do translation for no specific locale, and you want it to be done independently of the currently locale, specify "C" for  fromLocale. (!Checks if a search conducted for  searchTerm should match  potentialHit.This function calls   on both  searchTerm and  potentialHit(. ASCII alternates are never taken for  searchTerm but will be taken for  potentialHit according to the value of acceptAlternates.'A hit occurs when each folded token in  searchTerm$ is a prefix of a folded token from  potentialHit.SDepending on how you're performing the search, it will typically be faster to call  [ on each string in your corpus and build an index on the returned folded tokens, then call  8 on the search term and perform lookups into that index.IAs some examples, searching for "fred" would match the potential hit "Smith, Fred" and also "Frdric". Searching for "Frd" would match "Frdric" but not "Frederic" (due to the one-directional nature of accent matching). Searching "fo" would match "Foo" and "Bar Foo Baz", but not "SFO" (because no word as "fo" as a prefix). (kDetermines if a string is pure ASCII. A string is pure ASCII if it contains no bytes with the high bit set. "Converts a string to a hash value.This function implements the widely used "djb" hash apparently posted by Daniel Bernstein to comp.lang.c some time ago. The 32 bit unsigned hash value starts at 5381 and for each byte 'c' in the string, is updated: hash = hash * 33 + c3. This function uses the signed value of each byte.It can be passed to g_hash_table_new() as the hashFunc parameter, when using non- _ strings as keys in a NO.Note that this function may not be a perfect fit for all use cases. For example, it produces some hash collisions with strings as short as 2. Looks whether the string str ends with suffix. Looks whether the string str begins with prefix. ;Compares two strings for byte-by-byte equality and returns  Y( if they are equal. It can be passed to g_hash_table_new() as the  keyEqualFunc parameter, when using non- _ strings as keys in a NO.gNote that this function is primarily meant as a hash table comparison function. For a general-purpose,  _&-safe string comparison function, see  . Copies a nul-terminated string into the dest buffer, include the trailing nul, and return a pointer to the trailing nul byte. This is useful for concatenating multiple strings together without having to repeatedly scan for the end. vExecutes a child synchronously (waits for the child to exit before returning). All output from the child is stored in standardOutput and  standardError, if those parameters are non- _. Note that you must set the > and > flags when passing  _ for standardOutput and  standardError.If  exitStatus is non- _[, the platform-specific exit status of the child is stored there; see the documentation of  D for how to use and interpret this. Note that it is invalid to pass > in flags.+If an error occurs, no data is returned in standardOutput,  standardError, or  exitStatus.This function calls  { internally; see that function for full details on the other parameters and details on how these functions work on Windows. 3No description available in the introspection data. 3No description available in the introspection data. A simple version of  ` with little-used parameters removed, taking a command line instead of an argument vector. See   for full details.  commandLine will be parsed by   . Unlike  , the > flag is enabled. Note that >3 can have security implications, so consider using  9 directly if appropriate. Possible errors are those from   and those from  .If  exitStatus is non- _[, the platform-specific exit status of the child is stored there; see the documentation of  # for how to use and interpret this.,On Windows, please note the implications of   parsing  commandLine. Parsing is done according to Unix shell rules, not Windows command interpreter rules. Space is a separator, and backslashes are special. Thus you cannot simply pass a  commandLine containing canonical Windows paths, like "c:\program files\app\app.exe", as the backslashes will be eaten, and the space will act as a separator. You need to enclose such paths with single quotes, like "'c:\program files\app\app.exe' 'e:\folder\argument.txt'". A simple version of  ! that parses a command line with   and passes it to  0. Runs a command line in the background. Unlike  , the >1 flag is enabled, other flags are not. Note that >3 can have security implications, so consider using  9 directly if appropriate. Possible errors are those from   and  .*The same concerns on Windows apply as for  . (On some platforms, notably Windows, the GPidN type represents a resource which must be closed to prevent resource leaking.  q is provided for this purpose. It should be used on all platforms, even though it doesn't do anything under UNIX. "Set error if  exitStatus^ indicates the child exited abnormally (e.g. with a nonzero exit code, or via a fatal signal).The   and g_child_watch_add() family of APIs return an exit status for subprocesses encoded in a platform-specific way. On Unix, this is guaranteed to be in the same format  waitpid()> returns, and on Windows it is guaranteed to be the result of GetExitCodeProcess().FPrior to the introduction of this function in GLib 2.34, interpreting  exitStatusp required use of platform-specific APIs, which is problematic for software using GLib as a cross-platform layer.zAdditionally, many programs simply want to determine whether or not the child exited successfully, and either propagate a v or print a message to standard error. In that common case, this function can be used. Note that the error message in error? will contain human-readable information about the exit status.The domain and code of error have special semantics in the case where the process has an "exit code", as opposed to being killed by a signal. On Unix, this happens if  WIFEXITED() would be true of  exitStatus$. On Windows, it is always the case.LThe special semantics are that the actual exit code will be the code set in error, and the domain will be G_SPAWN_EXIT_ERROR@. This allows you to differentiate between different exit codes.ZIf the process was terminated by some means other than an exit status, the domain will be  G_SPAWN_ERROR, and the code will be @.oThis function just offers convenience; you can of course also check the available platform via a macro such as  G_OS_UNIX , and use  WIFEXITED() and  WEXITSTATUS() on  exitStatus directly. Do not attempt to scan or parse the error message string; it may be translated and/or change in future versions of GLib. Executes a child program asynchronously (your program will not block waiting for the child to exit). The child program is specified by the only argument that must be provided, argv. argv should be a  _e-terminated array of strings, to be passed as the argument vector for the child. The first string in argvn is of course the name of the program to execute. By default, the name of the program must be a full path. If flags contains the > flag, the PATH? environment variable is used to search for the executable. If flags contains the > flag, the PATH variable from envp3 is used to search for the executable. If both the > and > flags are set, the PATH variable from envp0 takes precedence over the environment variable.+If the program name is not a full path and >O flag is not used, then the program will be run from the current directory (or workingDirectoryw, if specified); this might be unexpected or even dangerous in some cases when the current directory is world-writable.On Windows, note that all the string or string vector arguments to this function and the other g_spawn*() functions are in UTF-8, the GLib file name encoding. Unicode characters that are not part of the system codepage passed in these arguments will be correctly available in the spawned program only if it uses wide character API to retrieve its command line. For C programs built with Microsoft's tools it is enough to make the program have a wmain() instead of main(). wmain()3 has a wide character argument vector as parameter.*At least currently, mingw doesn't support wmain()E, so if you use mingw to develop the spawned program, it should call g_win32_get_command_line() to get arguments in UTF-8.4On Windows the low-level child process creation API CreateProcess()o doesn't use argument vectors, but a command line. The C runtime library's spawn*() family of functions (which   eventually calls) paste the argument vector elements together into a command line, and the C runtime startup code does a corresponding reconstruction of an argument vector from the command line, to be passed to main()Q. Complications arise when you have argument vector elements that contain spaces of double quotes. The spawn*() functions don't do any quoting or escaping, but on the other hand the startup code does do unquoting and unescaping in order to enable receiving arguments with embedded spaces or double quotes. To work around this asymmetry,  d will do quoting and escaping on argument vector elements that need it before calling the C runtime spawn() function. The returned childPid on Windows is a handle to the child process, not its identifier. Process handles and process identifiers are different concepts on Windows.envp is a  _=-terminated array of strings, where each string has the form  KEY=VALUE/. This will become the child's environment. If envp is  _., the child inherits its parent's environment.flagsX should be the bitwise OR of any flags you want to affect the function's behaviour. The > means that the child will not automatically be reaped; you must use a child watch to be notified about the death of the child process. Eventually you must call   on the childPid, in order to free resources which may be associated with the child process. (On Unix, using a child watch is equivalent to calling  waitpid() or handling the SIGCHLD& signal manually. On Windows, calling   is equivalent to calling  CloseHandle()# on the process handle returned in childPid). See g_child_watch_add().> means that the parent's open file descriptors will be inherited by the child; otherwise all descriptors except stdin/stdout/stderr will be closed before calling exec() in the child. > means that argv?[0] need not be an absolute path, it will be looked for in the PATH environment variable. >B means need not be an absolute path, it will be looked for in the PATH variable from envp . If both > and > are used, the value from envp( takes precedence over the environment. > means that the child's standard output will be discarded, instead of going to the same location as the parent's standard output. If you use this flag, standardOutput must be  _. > means that the child's standard error will be discarded, instead of going to the same location as the parent's standard error. If you use this flag,  standardError must be  _. > means that the child will inherit the parent's standard input (by default, the child's standard input is attached to /dev/null). If you use this flag,  standardInput must be  _. >! means that the first element of argvs is the file to execute, while the remaining elements are the actual argument vector to pass to the file. Normally   uses argv.[0] as the file to execute, and passes all of argv to the child. childSetup and userData are a function and user data. On POSIX platforms, the function is called in the child after GLib has performed all the setup it plans to perform (including creating pipes, closing file descriptors, etc.) but before calling exec() . That is,  childSetup is called just before calling exec()c in the child. Obviously actions taken in this function will only affect the child, not the parent.!On Windows, there is no separate fork() and exec()L functionality. Child processes are created and run with a single API call, CreateProcess(). There is no sensible thing  childSetup> could be used for on Windows so it is ignored and not called.If non- _, childPidx will on Unix be filled with the child's process ID. You can use the process ID to send signals to the child, or to use g_child_watch_add() (or  waitpid()) if you specified the > flag. On Windows, childPidM will be filled with a handle to the child process only if you specified the > flag. You can then access the child process using the Win32 API, for example wait for its termination with the WaitFor*() functions, or examine its exit code with GetExitCodeProcess()#. You should close the handle with  CloseHandle() or   when you no longer need it.If non- _, the  standardInput, standardOutput,  standardError locations will be filled with file descriptors for writing to the child's standard input or reading from its standard output or standard error. The caller of  [ must close these file descriptors when they are no longer in use. If these parameters are  _*, the corresponding pipe won't be created.If  standardInputE is NULL, the child's standard input is attached to /dev/null unless > is set.If  standardErrore is NULL, the child's standard error goes to the same location as the parent's standard error unless > is set.If standardOutputg is NULL, the child's standard output goes to the same location as the parent's standard output unless > is set.error can be  _ to ignore errors, or non- _< to report errors. If an error is set, the function returns  XX. Errors are reported even if they occur in the child (for example if the executable in argv![0] is not found). Typically the message[ field of returned errors should be displayed to users. Possible errors are those from the  G_SPAWN_ERROR domain.If an error occurs, childPid,  standardInput, standardOutput, and  standardError& will not be filled with valid values.If childPid is not  _V and an error does not occur then the returned process reference must be closed using  .If you are writing a GTK+ application, and the program you are spawning is a graphical application, too, then you may want to use  gdk_spawn_on_screen_with_pipes()R instead to ensure that the spawned program opens its windows on the right screen. See  8 for a full description; this function simply calls the   without any pipes.You should call  I on the returned child process reference when you don't need it any more.If you are writing a GTK+ application, and the program you are spawning is a graphical application, too, then you may want to use gdk_spawn_on_screen()R instead to ensure that the spawned program opens its windows on the right screen.Note that the returned childPid on Windows is a handle to the child process and not its identifier. Process handles and process identifiers are different concepts on Windows. TGets the smallest prime number from a built-in array of primes which is larger than num>. This is used within GLib to calculate the optimum size of a NO.}The built-in array of primes ranges from 11 to 13845163 such that each prime is approximately 1.5-2 times the previous prime. 3No description available in the introspection data. 3No description available in the introspection data. 3No description available in the introspection data.  7Frees a linked list of memory blocks of structure type type.5The memory blocks must be equal-sized, allocated via   or   and linked together by a next pointer (similar to ). The offset of the nextq field in each block is passed as third argument. Note that the exact release behaviour can be changed with the [G_DEBUG=gc-friendly+][G_DEBUG] environment variable, also see [G_SLICE)][G_SLICE] for related debugging options.If memChain is  _, this function does nothing.  Frees a block of memory.(The memory must have been allocated via   or   and the  blockSizeq has to match the size specified upon allocation. Note that the exact release behaviour can be changed with the [G_DEBUG=gc-friendly+][G_DEBUG] environment variable, also see [G_SLICE)][G_SLICE] for related debugging options.If memBlock is  _, this function does nothing. @Allocates a block of memory from the slice allocator and copies  blockSize bytes into it from memBlock.memBlock must be non- _ if  blockSize is non-zero.   Allocates a block of memory via  x and initializes the returned memory to 0. Note that the underlying slice allocation mechanism can be changed with the [G_SLICE=always-malloc ][G_SLICE] environment variable.  Allocates a block of memory from the slice allocator. The block adress handed out can be expected to be aligned to at least 1 * sizeof (void*), though in general slices are 2 * sizeof (void*) bytes aligned, if a malloc() fallback implementation is used instead, the alignment may be reduced in a libc dependent fashion. Note that the underlying slice allocation mechanism can be changed with the [G_SLICE=always-malloc ][G_SLICE] environment variable. Unquotes a string as the shell (/bin/sh) would. Only handles quotes; if a string contains file globs, arithmetic operators, variables, backticks, redirections, or other special-to-the-shell features, the result will be different from the result a real shell would produce (the variables, backticks, etc. will be passed through literally instead of being expanded). This function is guaranteed to succeed if applied to the result of  . If it fails, it returns  _ and sets the error. The  quotedString3 need not actually contain quoted or escaped text;   simply goes through the string and unquotes/unescapes anything that the shell would. Both single and double quotes are handled, as are escapes including escaped newlines. The return value must be freed with  y. Possible errors are in the  G_SHELL_ERROR domain.WShell quoting rules are a bit strange. Single quotes preserve the literal string exactly. escape sequences are not allowed; not even \' - if you want a ' in the quoted text, you have to do something like 'foo'\''bar'. Double quotes allow $, `, ", \, and newline to be escaped with backslash. Otherwise double quotes preserve things literally. UQuotes a string so that the shell (/bin/sh) will interpret the quoted string to mean unquotedString. If you pass a filename to the shell, for example, you should first quote it with this function. The return value must be freed with  yL. The quoting style used is undefined (single or double quotes may be used). Parses a command line into an argument vector, in much the same way the shell would, but without many of the expansions the shell would perform (variable expansion, globs, operators, filename expansion, etc. are not supported). The results are defined to be the same as those you would get from a UNIX98 /bin/sh, as long as the input contains none of the unsupported shell expansions. If the input does contain such expansions, they are passed through literally. Possible errors are those from the  G_SHELL_ERROR' domain. Free the returned vector with  . 3No description available in the introspection data. Sets an environment variable. On UNIX, both the variable's name and value can be arbitrary byte strings, except that the variable's name cannot contain '='. On Windows, they should be in UTF-8.Note that on some systems, when variables are overwritten, the memory used for the previous variables and its value isn't reclaimed.You should be mindful of the fact that environment variable handling in UNIX is not thread-safe, and your program may crash if one thread calls  ! while another thread is calling getenv()). (And note that many functions, such as  gettext(), call getenv() internally.) This function is only safe to use at the very start of your program, before creating any other threads (or creating objects that create worker threads of their own).GIf you need to set up the environment for a child process, you can use  s/ to get an environment array, modify that with   and  ', and then pass that array directly to  execvpe(),  , or the like. PSets the name of the program. This name should not be localized, in contrast to  .JNote that for thread-safety reasons this function can only be called once. Does nothing if err is  _; if err is non- _, then *err must be  _. A new  is created and assigned to *err . Unlike  g_set_error(), message is not a printf()+-style format string. Use this function if message? contains text you don't have control over, that could include printf() escape sequences. Sets a human-readable name for the application. This name should be localized if possible, and is intended for display to the user. Contrast with  #, which sets a non-localized name.  ! will be called automatically by  gtk_init(), but   will not.KNote that for thread safety reasons, this function can only be called once.The application name will be used in contexts such as error messages, or when displaying an application's name in the task list. A wrapper for the POSIX rmdir() function. The rmdir()2 function deletes a directory from the filesystem.5See your C library manual for more details about how rmdir() works on your system. Resets the cache used for  `k, so that the latest on-disk version is used. Call this only if you just changed the data on disk yourself.`Due to threadsafety issues this may cause leaking of strings that were previously returned from  `m that can't be freed. We ensure to only leak the data for the directories that actually changed value though. This function is similar to  , allocating (nBlocks *  nBlockBytesM) bytes, but care is taken to detect possible overflow during multiplication. %Reallocates the memory pointed to by mem, so that it now has space for nBytesW bytes of memory. It returns the new address of the memory, which may have been moved. mem may be  _5, in which case it's considered to have zero-length. nBytes may be 0, in which case  _ will be returned and mem will be freed unless it is  _. dSets the seed for the global random number generator, which is used by the g_random_* functions, to seed. Returns a random gint32% equally distributed over the range [begin..end-1]. Return a random guint320 equally distributed over the range [0..2^32-1]. Returns a random gdouble% equally distributed over the range [begin..end). Returns a random gdouble+ equally distributed over the range [0..1).  Gets the GQuark5 associated with the given string, or 0 if string is  _ or it has no associated GQuark.FIf you want the GQuark to be created if it doesn't already exist, use   or  . *Gets the string associated with the given GQuark.  Gets the GQuarkS identifying the given string. If the string does not currently have an associated GQuark, a new GQuark( is created, using a copy of the string.  Gets the GQuark\ identifying the given (static) string. If the string does not currently have an associated GQuark, a new GQuark( is created, linked to the given string.(Note that this function is identical to   except that if a new GQuark is created the string itself is used rather than a copy. This saves memory, but can only be used if the string will continue to exist until the program terminates. It can be used with statically allocated strings in the main program, but not with statically allocated memory in dynamically loaded modules, if you expect to ever unload the module again (e.g. do not use this function in GTK+ theme engines). If dest is  _, free src; otherwise, moves src into *dest. The error variable dest points to must be  _.src must be non- _. Note that srcg is no longer valid after this call. If you want to keep using the same GError*, you need to set it to  _# after calling this function on it. Polls fds, as with the poll()8 system call, but portably. (On systems that don't have poll(), it is emulated using select().) This is used internally by W, but it can be called directly if you need to block until a file descriptor is ready, but don't want to run the full main loop.Each element of fds is a 42 describing a single file descriptor to poll. The fd. field indicates the file descriptor, and the events8 field indicates the events to poll for. On return, the revents> fields will be filled with the events that actually occurred.*On POSIX systems, the file descriptors in fdso can be any sort of file descriptor, but the situation is much more complicated on Windows. If you need to use  V in code that has to run on Windows, the easiest solution is to construct all of your GPollFDs with  g_io_channel_win32_make_pollfd(). \This is equivalent to g_bit_unlock, but working on pointers (or other pointer-sized values).PFor portability reasons, you may only lock on the bottom 32 bits of the pointer. ]This is equivalent to g_bit_trylock, but working on pointers (or other pointer-sized values).PFor portability reasons, you may only lock on the bottom 32 bits of the pointer. ZThis is equivalent to g_bit_lock, but working on pointers (or other pointer-sized values).PFor portability reasons, you may only lock on the bottom 32 bits of the pointer. !zMatches a string against a compiled pattern. If the string is to be matched against more than one pattern, consider using  #- instead while supplying the reversed string. "Matches a string against a pattern given as a string. If this function is to be called in a loop, it's more efficient to compile the pattern once with g_pattern_spec_new() and call  ! repeatedly. #Matches a string against a compiled pattern. Passing the correct length of the string given is mandatory. The reversed string can be omitted by passing  _`, this is more efficient if the reversed version of the string to be matched is not at hand, as  #I will only construct it if the compiled pattern requires reverse matches.6Note that, if the user code will (possibly) match a string against a multitude of patterns containing wildcards, chances are high that some patterns will require a reversed string. In this case, it's more efficient to provide the reversed string to avoid multiple constructions thereof in the various calls to  #.WNote also that the reverse of a UTF-8 encoded string can in general not be obtained by  [. This works only if the string does not contain any multibyte characters. GLib offers the  a+ function to reverse UTF-8 encoded strings. $Returns a pointer into fileNameQ after the root component, i.e. after the "/" in UNIX or "C:\" under Windows. If fileName$ is not an absolute path it returns  _. %Returns  Y if the given fileNameQ is an absolute file name. Note that this is a somewhat vague concept on Windows.On POSIX systems, an absolute file name is well-defined. It always starts from the single root directory. For example "/usr/local".On Windows, the concepts of current drive and drive-specific current directory introduce vagueness. This function interprets as an absolute file name one that either begins with a directory separator such as "\Users\tml" or begins with the root on a drive, for example "C:\Windows". The first case also includes UNC paths such as "\myserver\docs\foo". In all cases, either slashes or backslashes are accepted.Note that a file name relative to the current drive root does not truly specify a file uniquely over time and across processes, as the current drive is a per-process value and can be changed.File names relative the current directory on some specific drive, such as "D:foo/bar", are not interpreted as absolute by this function, but they obviously are not relative to the normal current directory as returned by getcwd() or  uY either. Such paths should be avoided, or need to be handled using Windows-specific code. &-Gets the directory components of a file name.xIf the file name has no directory components "." is returned. The returned string should be freed when no longer needed. '(Gets the last component of the filename.If fileNameQ ends with a directory separator it gets the component before the last slash. If fileNameu consists only of directory separators (and on Windows, possibly a drive letter), a single separator is returned. If fileName is empty, it gets ".". (4Parses a string containing debugging options into a guint containing bit flags. This is used within GDK and GTK+ to parse the debug options passed on the command line or through environment variables.If stringO is equal to "all", all flags are set. Any flags specified along with "all" in stringq are inverted; thus, "all,foo,bar" or "foo,bar,all" sets all flags except those corresponding to "foo" and "bar".If string/ is equal to "help", all the available keys in keys# are printed out to standard error. )3No description available in the introspection data. *VInvokes gdb, which attaches to the current process and shows a stack trace. Called by  +b when the "[S]tack trace" option is selected. You can get the current process's program name with  k , assuming that you have called  gtk_init() or  gdk_init().@This function may cause different actions on non-UNIX platforms. +Prompts the user with /[E]xit, [H]alt, show [S]tack trace or [P]roceed. This function is intended to be used for debugging use only. The following example shows how it can be used together with the g_log() functions.C code 6 #include <glib.h> static void log_handler (const gchar *log_domain, GLogLevelFlags log_level, const gchar *message, gpointer user_data) { g_log_default_handler (log_domain, log_level, message, user_data); g_on_error_query (MY_PROGRAM_NAME); } int main (int argc, char *argv[]) { g_log_set_handler (MY_LOG_DOMAIN, G_LOG_LEVEL_WARNING | G_LOG_LEVEL_ERROR | G_LOG_LEVEL_CRITICAL, log_handler, NULL); ...LIf "[E]xit" is selected, the application terminates with a call to _exit(0). If "[S]tack" trace is selected,  *| is called. This invokes gdb, which attaches to the current process and shows a stack trace. The prompt is then shown again.1If "[P]roceed" is selected, the function returns.@This function may cause different actions on non-UNIX platforms. ,-Set the pointer at the specified location to  _. - Opens a temporary file. See the  mkstemp()) documentation on most UNIX-like systems.;The parameter is a string that should follow the rules for  mkstemp(). templates, i.e. contain the string "XXXXXX".  - is slightly more flexible than  mkstemp()` in that the sequence does not have to occur at the very end of the template and you can pass a mode and additional flags. The X string will be modified to form the name of a file that didn't exist. The string should be in the GLib file name encoding. Most importantly, on Windows it should be in UTF-8. . Opens a temporary file. See the  mkstemp()) documentation on most UNIX-like systems.;The parameter is a string that should follow the rules for  mkstemp(). templates, i.e. contain the string "XXXXXX".  . is slightly more flexible than  mkstemp() in that the sequence does not have to occur at the very end of the template. The X string will be modified to form the name of a file that didn't exist. The string should be in the GLib file name encoding. Most importantly, on Windows it should be in UTF-8. /'Creates a temporary directory. See the  mkdtemp()) documentation on most UNIX-like systems.;The parameter is a string that should follow the rules for  mkdtemp(). templates, i.e. contain the string "XXXXXX".  0 is slightly more flexible than  mkdtemp()` in that the sequence does not have to occur at the very end of the template and you can pass a mode. The X string will be modified to form the name of a directory that didn't exist. The string should be in the GLib file name encoding. Most importantly, on Windows it should be in UTF-8. 0'Creates a temporary directory. See the  mkdtemp()) documentation on most UNIX-like systems.;The parameter is a string that should follow the rules for  mkdtemp(). templates, i.e. contain the string "XXXXXX".  0 is slightly more flexible than  mkdtemp()` in that the sequence does not have to occur at the very end of the template and you can pass a mode and additional flags. The X string will be modified to form the name of a directory that didn't exist. The string should be in the GLib file name encoding. Most importantly, on Windows it should be in UTF-8. 1fCreate a directory if it doesn't already exist. Create intermediate parent directories as needed, too. 2 Allocates byteSize bytes of memory, and copies byteSize bytes into it from mem. If mem is  _ it returns  _. 3This function used to let you override the memory allocation function. However, its use was incompatible with the use of global constructors in GLib and GIO, because those use the GLib allocators before main is reached. Therefore this function is now deprecated and is just a stub. 4GLib used to support some tools for memory profiling, but this no longer works. There are many other useful tools for memory profiling these days which can be used instead. 5%Checks whether the allocator used by  ;6 is the system's malloc implementation. If it returns  Y memory allocated with malloc()9 can be used interchangeable with memory allocated using  ;j. This function is useful for avoiding an extra copy of allocated memory returned by a non-GLib-based API. 6Escapes text so that the markup parser will parse it verbatim. Less than, greater than, ampersand, etc. are replaced with the corresponding entities. This function would typically be used when writing out a file to be parsed with the markup parser.Note that this function doesn't protect whitespace and line endings from being processed according to the XML rules for normalization of line endings and attribute values.PNote also that this function will produce character references in the range of &x1; ... &x1f; for all control sequences except for tabstop, newline and carriage return. The character references in this range are not valid XML 1.0, but they are valid XML 1.1 and will be accepted by the GMarkup parser. 73No description available in the introspection data. 8This function is similar to  ;, allocating (nBlocks *  nBlockBytesM) bytes, but care is taken to detect possible overflow during multiplication. 9This function is similar to  :, allocating (nBlocks *  nBlockBytesM) bytes, but care is taken to detect possible overflow during multiplication. : Allocates nBytes) bytes of memory, initialized to 0's. If nBytes is 0 it returns  _. ; Allocates nBytes bytes of memory. If nBytes is 0 it returns  _. <+Returns the depth of the stack of calls to  on any Wu in the current thread. That is, when called from the toplevel, it gives 0. When called from within a callback from  (or  P, etc.) it returns 1. When called from within a callback to a recursive call to , it returns 2. And so forth.rThis function is useful in a situation like the following: Imagine an extremely simple "garbage collected" system.C code  static GList *free_list; gpointer allocate_memory (gsize size) { gpointer result = g_malloc (size); free_list = g_list_prepend (free_list, result); return result; } void free_allocated_memory (void) { GList *l; for (l = free_list; l; l = l->next); g_free (l->data); g_list_free (free_list); free_list = NULL; } [...] while (TRUE); { g_main_context_iteration (NULL, TRUE); free_allocated_memory(); }This works from an application, however, if you want to do the same thing from a library, it gets more difficult, since you no longer control the main loop. You might think you can simply use an idle function to make the call to free_allocated_memory()w, but that doesn't work, since the idle function could be called from a recursive callback. This can be fixed by using  <C code l gpointer allocate_memory (gsize size) { FreeListBlock *block = g_new (FreeListBlock, 1); block->mem = g_malloc (size); block->depth = g_main_depth (); free_list = g_list_prepend (free_list, block); return block->mem; } void free_allocated_memory (void) { GList *l; int depth = g_main_depth (); for (l = free_list; l; ); { GList *next = l->next; FreeListBlock *block = l->data; if (block->depth > depth) { g_free (block->mem); g_free (block); free_list = g_list_delete_link (free_list, l); } l = next; } }There is a temptation to use  < to solve problems with reentrancy. For instance, while waiting for data to be received from the network in response to a menu item, the menu item might be selected again. It might seem that one could make the menu item's callback return immediately and do nothing if  <: returns a value greater than 1. However, this should be avoided since the user then sees selecting the menu item do nothing. Furthermore, you'll find yourself adding these checks all over your code, since there are doubtless many, many things that the user could do. Instead, you can use the following techniques: Use gtk_widget_set_sensitive()l or modal dialogs to prevent the user from interacting with elements while the main loop is recursing.Avoid main loop recursion in situations where you can't handle arbitrary callbacks. Instead, structure your code so that you simply return to the main loop and then get called again when there is more work to do. = 4Returns the currently firing source for this thread. >2Check whether the given outputFds file descriptor supports ANSI color escape sequences. If so, they can safely be used when formatting log messages. ?27Format a structured log message and print it to either stdout or stderr, depending on its log level. >  and > messages are sent to stdout#; all other log levels are sent to stderrj. Only fields which are understood by this function are included in the formatted string which is printed.[If the output stream supports ANSI color escape sequences, they will be used in the output.MA trailing new-line character is added to the log message when it is printed.This is suitable for use as a F. @2Format a structured log message and send it to the systemd journal as a set of key value pairs. All fields are sent to the journal, but if a field has length zero (indicating program-specific data) then only its key will be sent.This is suitable for use as a F.jIf GLib has been compiled without systemd support, this function is still defined, but will always return @. A2Check whether the given outputFd_ file descriptor is a connection to the systemd journal, or something else (like a log file or stdout or stderr). B2Format a structured log message as a string suitable for outputting to the terminal (or elsewhere). This will include the values of all fields it knows how to interpret, which includes MESSAGE and  GLIB_DOMAIN (see the documentation for g_log_structured()2). It does not include values from unknown fields.The returned string does **not** have a trailing new-line character. It is encoded in the character set of the current locale, which is not necessarily UTF-8. C2Format a structured log message and output it to the default log destination for the platform. On Linux, this is typically the systemd journal, falling back to stdout or stderrI if running from the terminal or if output is being redirected to a file.Support for other platform-specific logging mechanisms may be added in future. Distributors of GLib may modify this function to impose their own (documented) platform-specific log writing policies.This is suitable for use as a F:, and is the default writer used if no other is set using G.As with  JS, this function drops debug and informational messages unless their log domain (or all#) is listed in the space-separated G_MESSAGES_DEBUG environment variable. D2@Log a message with structured data, accepting the data within a  `R. This version is especially useful for use in other languages, via introspection.The only mandatory item in the fieldsK dictionary is the "MESSAGE" which must contain the text shown to the user.The values in the fields- dictionary are likely to be of type String (G_VARIANT_TYPE_STRING). Array of bytes (G_VARIANT_TYPE_BYTESTRING) is also supported. In this case the message is handled as binary and will be forwarded to the log writer as such. The size of the array should not be higher than  G_MAXSSIZE?. Otherwise it will be truncated to this size. For other types P 1 will be used to convert the value into a string.<For more details on its usage and about the parameters, see g_log_structured(). E2vLog a message with structured data. The message will be passed through to the log writer set by the application using G1. If the message is fatal (i.e. its log level is > ;), the program will be aborted at the end of this function.See g_log_structured() for more documentation.This assumes that logLevel is already present in fields (typically as the PRIORITY field). F.Like g_log_sets_handler()%, but takes a destroy notify for the userData.nThis has no effect if structured logging is enabled; see [Using Structured Logging][using-structured-logging]. G9Sets the log levels which are fatal in the given domain. >  is always fatal.5This has no effect on structured log messages (using g_log_structured() or  Eu). To change the fatal behaviour for specific log messages, programs must install a custom log writer function using G;. See [Using Structured Logging][using-structured-logging]. HSets the message levels which are always fatal, in any log domain. When a message with any of these levels is logged the program terminates. You can only set the levels defined by GLib to be fatal. >  is always fatal.FYou can also make some message levels fatal at runtime by setting the G_DEBUG environment variable (see  8http://developer.gnome.org/glib/stable/glib-running.htmlRunning GLib Applications).~Libraries should not call this function, as it affects all messages logged by a process, including those from other libraries.Structured log messages (using g_log_structured() and  E) are fatal only if the default log writer is used; otherwise it is up to the writer function to determine which log messages are fatal. See [Using Structured Logging][using-structured-logging]. IRemoves the log handler.nThis has no effect if structured logging is enabled; see [Using Structured Logging][using-structured-logging]. J(The default log handler set up by GLib; g_log_set_default_handler() allows to install an alternate default log handler. This is used if no log handler has been set for the particular log domain and log level combination. It outputs the message to stderr or stdout and if the log level is fatal it calls abort()r. It automatically prints a new-line character after the message, so one does not need to be manually included in message.XThe behavior of this log handler can be influenced by a number of environment variables:G_MESSAGES_PREFIXEDw: A :-separated list of log levels for which messages should be prefixed by the program name and PID of the aplication.G_MESSAGES_DEBUG: A space-separated list of log domains for which debug and informational messages are printed. By default these messages are not printed.stderr is used for levels > , > , > and >. stdout is used for the rest.nThis has no effect if structured logging is enabled; see [Using Structured Logging][using-structured-logging]. KConverts a string which is in the encoding used for strings by the C runtime (usually the same as that used by the operating system) in the [current locale][setlocale] into a UTF-8 string. LConverts a string from UTF-8 to the encoding used for strings by the C runtime (usually the same as that used by the operating system) in the [current locale][setlocale]. On Windows this means the system codepage. M7Gets the names of all variables set in the environment.TPrograms that want to be portable to Windows should typically use this function and  _ instead of using the environ array from the C library directly. On Windows, the strings in the environ array are in system codepage encoding, while in most of the typical use cases for environment variables in GLib-using programs you want the UTF-8 encoding that this function and  _ provide. N Creates a 0 that's dispatched when  condition is met for the given channel. For example, if condition is G_IO_INH, the source will be dispatched when there's data available for reading.g_io_add_watch() is a simpler interface to this same functionality, for the case where you want to add the source to the default main loop context at the default priority.On Windows, polling a 0 created to watch a channel for a socket puts the socket in non-blocking mode. This is a side-effect of the implementation and unavoidable. O Adds the ;< into the default main loop context with the given priority.1This internally creates a main loop source using  N/ and attaches it to the main loop context with 0>. You can do these steps manually if you need greater control. P 'Returns a canonical representation for string\. Interned strings can be compared for equality by comparing the pointers, instead of using strcmp(). Q 'Returns a canonical representation for string\. Interned strings can be compared for equality by comparing the pointers, instead of using strcmp().  Q% does not copy the string, therefore string must not be freed or modified. RConverts a pointer to a gint& to a hash value. It can be passed to g_hash_table_new() as the hashFunc parameter, when using non- _) pointers to integer values as keys in a NO.,Note that this function acts on pointers to gint , not on gint5 directly: if your hash table's keys are of the form GINT_TO_POINTER (n), use   instead. SCompares the two gint% values being pointed to and returns  Y( if they are equal. It can be passed to g_hash_table_new() as the  keyEqualFunc parameter, when using non- _# pointers to integers as keys in a NO.,Note that this function acts on pointers to gint , not on gint5 directly: if your hash table's keys are of the form GINT_TO_POINTER (n), use   instead. TConverts a pointer to a gint64 to a hash value.It can be passed to g_hash_table_new() as the hashFunc parameter, when using non- _0 pointers to 64-bit integer values as keys in a NO. UCompares the two gint64% values being pointed to and returns  Y( if they are equal. It can be passed to g_hash_table_new() as the  keyEqualFunc parameter, when using non- _* pointers to 64-bit integers as keys in a NO. VCreates a new idle source.5The source will not initially be associated with any W and must be added to one with 0P before it will be executed. Note that the default priority for idle sources is E@, as compared to other sources which have a default priority of E. W.Removes the idle function with the given data. XlAdds a function to be called whenever there are no higher priority events pending. If the function returns  XY it is automatically removed from the list of event sources and will not be called again.See [memory management of sources][mainloop-memory-management] for details on how to handle the return value and memory management of data.1This internally creates a main loop source using  V and attaches it to the global W using 0, so the callback will be invoked in whichever thread is running that main context. You can do these steps manually if you need greater control or to use a custom main context. Y"Same as the standard UNIX routine iconv()X, but may be implemented via libiconv on UNIX flavors that lack a native implementation.GLib provides   and  K> which are likely more convenient than the raw iconv wrappers. Z Converts hostname to its canonical presentation form; a UTF-8 string in Unicode normalization form C, containing no uppercase letters, no forbidden characters, and no ASCII-encoded segments, and not ending with a trailing dot. Of course if hostnamec is not an internationalized hostname, then the canonical presentation form will be entirely ASCII. [ Converts hostnamev to its canonical ASCII form; an ASCII-only string containing no uppercase letters and not ending with a trailing dot. \ Tests if hostname. contains Unicode characters. If this returns  Y', you need to encode the hostname with  [+ before using it in non-IDN-aware contexts.fNote that a hostname might contain a mix of encoded and unencoded segments, and so it is possible for  \ and  ^ to both return  Y for a name. ] Tests if hostnameD is the string form of an IPv4 or IPv6 address. (Eg, "192.168.0.1".) ^ Tests if hostnamej contains segments with an ASCII-compatible encoding of an Internationalized Domain Name. If this returns  Y&, you should decode the hostname with  Z" before displaying it to the user.fNote that a hostname might contain a mix of encoded and unencoded segments, and so it is possible for  \ and  ^ to both return  Y for a name. _-Returns the value of an environment variable.On UNIX, the name and value are byte strings which might or might not be in some consistent character set and encoding. On Windows, they are in UTF-8. On Windows, in case the environment variable's value contains references to other environment variables, they are expanded. `BReturns the full path of a special directory using its logical id.gOn UNIX this is done using the XDG special user directories. For compatibility with existing practise, @ falls back to  $HOME/Desktop8 when XDG special user directories have not been set up.Depending on the platform, the user might be able to change the path of the special directory without requiring the session to restart; GLib will not reflect any change once the special directories are loaded. aKReturns a directory that is unique to the current user on the local system.KOn UNIX platforms this is determined using the mechanisms described in the  1http://www.freedesktop.org/Standards/basedir-spec XDG Base Directory Specification). This is the directory specified in the XDG_RUNTIME_DIRY environment variable. In the case that this variable is not set, we return the value of  e!, after verifying that it exists.On Windows this is the folder to use for local (as opposed to roaming) application data. See documentation for CSIDL_LOCAL_APPDATA. Note that on Windows it thus is the same as what  d returns. b Gets the user name of the current user. The encoding of the returned string is system-defined. On UNIX, it might be the preferred file name encoding, or something else, and there is no guarantee that it is even consistent on a machine. On Windows, it is always UTF-8. ctReturns a base directory in which to access application data such as icons that is customized for a particular user.KOn UNIX platforms this is determined using the mechanisms described in the  1http://www.freedesktop.org/Standards/basedir-spec XDG Base Directory Specification/. In this case the directory retrieved will be  XDG_DATA_HOME.On Windows this is the folder to use for local (as opposed to roaming) application data. See documentation for CSIDL_LOCAL_APPDATA. Note that on Windows it thus is the same as what  d returns. dReturns a base directory in which to store user-specific application configuration information such as user preferences and settings.KOn UNIX platforms this is determined using the mechanisms described in the  1http://www.freedesktop.org/Standards/basedir-spec XDG Base Directory Specification/. In this case the directory retrieved will be XDG_CONFIG_HOME.On Windows this is the folder to use for local (as opposed to roaming) application data. See documentation for CSIDL_LOCAL_APPDATA. Note that on Windows it thus is the same as what  c returns. ebReturns a base directory in which to store non-essential, cached data specific to particular user.KOn UNIX platforms this is determined using the mechanisms described in the  1http://www.freedesktop.org/Standards/basedir-spec XDG Base Directory Specification>. In this case the directory retrieved will be XDG_CACHE_HOME.On Windows is the directory that serves as a common repository for temporary Internet files. A typical path is C:\Documents and Settings\username\Local Settings\Temporary Internet Files. See documentation for CSIDL_INTERNET_CACHE. f.Gets the directory to use for temporary files. On UNIX, this is taken from the TMPDIR3 environment variable. If the variable is not set, P_tmpdirg is used, as defined by the system C library. Failing that, a hard-coded default of "/tmp" is returned.On Windows, the TEMPq environment variable is used, with the root directory of the Windows installation (eg: "C:\") used as a default.qThe encoding of the returned string is system-defined. On Windows, it is always UTF-8. The return value is never  _ or the empty string. g\Returns an ordered list of base directories in which to access system-wide application data.KOn UNIX platforms this is determined using the mechanisms described in the  1http://www.freedesktop.org/Standards/basedir-spec XDG Base Directory SpecificationF In this case the list of directories retrieved will be XDG_DATA_DIRS.!On Windows the first elements in the list are the Application Data and Documents folders for All Users. (These can be determined only on Windows 2000 or later and are not present in the list on other Windows versions.) See documentation for CSIDL_COMMON_APPDATA and CSIDL_COMMON_DOCUMENTS.Then follows the "share" subfolder in the installation folder for the package containing the DLL that calls this function, if it can be determined.Finally the list contains the "share" subfolder in the installation folder for GLib, and in the installation folder for the package the application's .exe file belongs to.The installation folders above are determined by looking up the folder where the module (DLL or EXE) in question is located. If the folder's name is "bin", its parent is used, otherwise the folder itself.[Note that on Windows the returned list can vary depending on where this function is called. heReturns an ordered list of base directories in which to access system-wide configuration information.KOn UNIX platforms this is determined using the mechanisms described in the  1http://www.freedesktop.org/Standards/basedir-spec XDG Base Directory Specification9. In this case the list of directories retrieved will be XDG_CONFIG_DIRS.On Windows is the directory that contains application data for all users. A typical path is C:\Documents and Settings\All Users\Application Data. This folder is used for application data that is not user specific. For example, an application can store a spell-check dictionary, a database of clip art, or a log file in the CSIDL_COMMON_APPDATA folder. This information will not roam and is available to anyone using the computer. i#Queries the system wall-clock time.(This call is functionally equivalent to  tK except that the return value is often more convenient than dealing with a #j.[You should only use this call if you are actually interested in the real wall-clock time.  m1 is probably more useful for measuring intervals. jPGets the real name of the user. This usually comes from the user's entry in the passwd file. The encoding of the returned string is system-defined. (On Windows, it is, however, always UTF-8.) If the real user name cannot be determined, the string "Unknown" is returned. kPGets the name of the program. This name should not be localized, in contrast to  x.8If you are using GDK or GTK+ the program name is set in  gdk_init(), which is called by  gtk_init()<. The program name is found by taking the last component of argv[0]. l$Determine the approximate number of threads that the system will schedule simultaneously for this process. This is intended to be used as a parameter to g_thread_pool_new()' for CPU bound tasks and similar cases. m"Queries the system monotonic time.The monotonic clock will always increase and doesn't suffer discontinuities when the user (or NTP) changes the system time. It may or may not continue to tick during times where the machine is suspended.{We try to use the clock that corresponds as closely as possible to the passage of time as measured by system calls such as poll(). but it may not always be possible to do this. n&Returns a list of derived variants of locale, which can be used to e.g. construct locale-dependent filenames or search paths. The returned list is sorted from most desirable to least desirable. This function handles territory, charset and extra locale modifiers.For example, if locale5 is "fr_BE", then the returned list is "fr_BE", "fr".=If you need the list of variants for the current locale, use  o. oComputes a list of applicable locale names, which can be used to e.g. construct locale-dependent filenames or search paths. The returned list is sorted from most desirable to least desirable and always contains the default locale "C".VFor example, if LANGUAGE=de:en_US, then the returned list is "de", "en_US", "en", "C".1This function consults the environment variables LANGUAGE, LC_ALL,  LC_MESSAGES and LANG3 to find the list of locales specified by the user. pReturn a name for the machine.UThe returned name is not necessarily a fully-qualified domain name, or even present in DNS or some other name service at all. It need not even be unique on your local network or site, but usually it is. Callers should not rely on the return value having any specific properties like uniqueness for security purposes. Even if the name of the machine is changed while an application is running, the return value from this function does not change. The returned string is owned by GLib and should not be modified or freed. If no name can be determined, a default fixed string "localhost" is returned. q'Gets the current user's home directory.DAs with most UNIX tools, this function will return the value of the HOMEZ environment variable if it is set to an existing absolute path name, falling back to the passwd# file in the case that it is unset.If the path given in HOMEQ is non-absolute, does not exist, or is not a directory, the result is undefined.3Before version 2.36 this function would ignore the HOME1 environment variable, taking the value from the passwd database instead. This was changed to increase the compatibility of GLib with other programs (and the XDG basedir specification) and to increase testability of programs based on GLib (by making it easier to run them from test frameworks).If your program has a strong requirement for either the new or the old behaviour (and if you don't wish to increase your GLib dependency to ensure that the new behaviour is in effect) then you should either directly check the HOMEP environment variable yourself or unset it before calling any functions in GLib. r]Determines the preferred character sets used for filenames. The first character set from the charsets is the filename encoding, the subsequent character sets are used when trying to generate a displayable representation of a filename, see  .SOn Unix, the character sets are determined by consulting the environment variables G_FILENAME_ENCODING and G_BROKEN_FILENAMESs. On Windows, the character set used in the GLib API is always UTF-8 and said environment variables have no effect.G_FILENAME_ENCODING may be set to a comma-separated list of character set names. The special token "@locale" is taken to mean the character set for the [current locale][setlocale]. If G_FILENAME_ENCODING is not set, but G_BROKEN_FILENAMES is, the character set of the current locale is taken as the filename encoding. If neither environment variable is set, UTF-8 is taken as the filename encoding, but the character set of the current locale is also put in the list of encodings. The returned charsets& belong to GLib and must not be freed.=Note that on Unix, regardless of the locale character set or G_FILENAME_ENCODINGd value, the actual file names present on a system might be in any random encoding or just gibberish. s?Gets the list of environment variables for the current process. The list is  _B terminated and each item in the list is of the form 'NAME=VALUE'.VThis is equivalent to direct access to the 'environ' global variable, except portable.BThe return value is freshly allocated and it should be freed with   when it is no longer needed. tEquivalent to the UNIX gettimeofday() function, but portable. You may find  i to be more convenient. uGets the current directory.The returned string should be freed when no longer needed. The encoding of the returned string is system defined. On Windows, it is always UTF-8.Since GLib 2.40, this function will return the value of the "PWD" environment variable if it is set and it happens to be the same as the current directory. This can make a difference in the case that the current directory is the target of a symbolic link. v.Gets the character set for the current locale. wrObtains the character set for the [current locale][setlocale]; you might use this character set as an argument to  T, to convert from the current locale's encoding to some other encoding. (Frequently  K and  L are nice shortcuts, though.),On Windows the character set returned by this function is the so-called system default ANSI code-page. That is the character set used by the "narrow" versions of C library and Win32 functions that handle file names. It might be different from the character set used by the C library's current locale.The return value is  YO if the locale's encoding is UTF-8, in that case you can perhaps avoid calling  .The string returned in charset+ is not allocated, and should not be freed. x:Gets a human-readable name for the application, as set by  e. This name should be localized if possible, and is intended for display to the user. Contrast with  k&, which gets a non-localized name. If  , has not been called, returns the result of  k (which may be  _ if   has also not been called). yFrees the memory pointed to by mem.If mem is  _1 it simply returns, so there is no need to check mem against  _ before calling this function. zFormats a size.This function is similar to  |2 but allows for flags that modify the output. See >. {Formats a size (for example the size of a file) into a human readable string. Sizes are rounded to the nearest size prefix (KB, MB, GB) and are displayed rounded to the nearest tenth. E.g. the file size 3292528 bytes will be converted into the string "3.1 MB".8The prefix units base is 1024 (i.e. 1 KB is 1024 bytes).!This string should be freed with  y when not needed any longer. |Formats a size (for example the size of a file) into a human readable string. Sizes are rounded to the nearest size prefix (kB, MB, GB) and are displayed rounded to the nearest tenth. E.g. the file size 3292528 bytes will be converted into the string "3.2 MB".8The prefix units base is 1000 (i.e. 1 kB is 1000 bytes).!This string should be freed with  y when not needed any longer.See  z8 for more options about how the size might be formatted. }#Locates the first executable named program* in the user's path, in the same way that execvp()N would locate it. Returns an allocated string with the absolute path name, or  _- if the program is not found in the path. If program0 is already an absolute path, returns a copy of program if program exists and is executable, and  _ otherwise.On Windows, if programn does not have a file type suffix, tries with the suffixes .exe, .cmd, .bat and .com, and the suffixes in the PATHEXT environment variable.5On Windows, it looks for the file in the same way as CreateProcess() would. This means first in the directory where the executing program was loaded from, then in the current directory, then in the Windows 32-bit system directory, then in the Windows directory, and finally in the directories in the PATHr environment variable. If the program is found, the return value contains the full name including the type suffix. ~Converts a string which is in the encoding used by GLib for filenames into a UTF-8 string. Note that on Windows GLib uses UTF-8 for filenames; on other platforms, this function indirectly depends on the [current locale][setlocale]. zConverts an absolute filename to an escaped ASCII-encoded URI, with the path component following Section 3.3. of RFC 2396. Converts a string from UTF-8 to the encoding GLib uses for filenames. Note that on Windows GLib uses UTF-8 for filenames; on other platforms, this function indirectly depends on the [current locale][setlocale]. ]Converts an escaped ASCII-encoded URI to a local filename in the encoding used for filenames. Converts a filename into a valid UTF-8 string. The conversion is not necessarily reversible, so you should keep the original around and use the return value of this function only for display purposes. Unlike  ~%, the result is guaranteed to be non- _D even if the filename actually isn't in the GLib file name encoding.-If GLib cannot make sense of the encoding of filename, as a last resort it replaces unknown characters with U+FFFD, the Unicode replacement character. You can search the result for the UTF-8 encoding of this character (which is "\357\277\275" in octal notation) to find out if filename was in an invalid encoding.:If you know the whole pathname of the file you should use  <, since that allows location-based translation of filenames. Returns the display basename for the particular filename, guaranteed to be valid UTF-8. The display name might not be identical to the filename, for instance there might be problems converting it to UTF-8, and some files can be translated in the display.-If GLib cannot make sense of the encoding of filename, as a last resort it replaces unknown characters with U+FFFD, the Unicode replacement character. You can search the result for the UTF-8 encoding of this character (which is "\357\277\275" in octal notation) to find out if filename was in an invalid encoding.tYou must pass the whole absolute pathname to this functions so that translation of well known locations can be done. This function is preferred over  6 if you know the whole path, as it allows translation. Returns  Y% if any of the tests in the bitfield test are  Y. For example, )(G_FILE_TEST_EXISTS | G_FILE_TEST_IS_DIR) will return  Yc if the file exists; the check whether it's a directory doesn't matter since the existence test is  Yd. With the current set of available tests, there's no point passing in more than one test at a time. Apart from >K all tests follow symbolic links, so for a symbolic link to a regular file   will return  Y for both > and >.(Note, that for a dangling symbolic link   will return  Y for > and  X for all other flags.You should never use   to test whether it is safe to perform an operation, because there is always the possibility of the condition changing before you actually perform the operation. For example, you might think you could use >} to know whether it is safe to write to a file without being tricked into writing into a different location. It doesn't work!C code  // DON'T DO THIS if (!g_file_test (filename, G_FILE_TEST_IS_SYMLINK)) { fd = g_open (filename, O_WRONLY); // write to fd }Another thing to note is that > and > are implemented using the access() system call. This usually doesn't matter, but if your program is setuid or setgid it means that these tests will give you the answer for the real user ID and group ID, rather than the effective user ID and group ID.2On Windows, there are no symlinks, so testing for > will always return  X. Testing for > will just check that the file exists and its name indicates that it is executable, checking for well-known extensions and those listed in the PATHEXT environment variable. Writes all of contents to a file named filename-, with good error checking. If a file called filename' already exists it will be overwritten.~This write is atomic in the sense that it is first written to a temporary file which is then renamed to the final name. Notes: On UNIX, if filename already exists hard links to filenamey will break. Also since the file is recreated, existing permissions, access control lists, metadata etc. may be lost. If filenameK is a symbolic link, the link itself will be replaced, not the linked file.On Windows renaming a file will not remove an existing file with the new name, so on Windows there is a race condition between the existing file being removed and the temporary file being renamed.On Windows there is no way to remove a file that is open to some process, or mapped into memory. Thus, this function will fail if filename already exists and is open.'If the call was successful, it returns  Y-. If the call was not successful, it returns  X and sets error. The error domain is  G_FILE_ERROR(. Possible error codes are those in the @d enumeration.\Note that the name for the temporary file is constructed by appending up to 7 characters to filename. (Reads the contents of the symbolic link filename like the POSIX  readlink()K function. The returned string is in the encoding used for filenames. Use  ~ to convert it to UTF-8. XOpens a file for writing in the preferred directory for temporary files (as returned by  f).tmplt should be a string in the GLib file name encoding containing a sequence of six 'X' characters, as the parameter to  .. However, unlike these functions, the template should only be a basename, no directory components are allowed. If template is  _, a default template is used.Note that in contrast to  . (and  mkstemp()) tmpl? is not modified, and might thus be a read-only literal string.Upon success, and if nameUsed is non- _&, the actual name used is returned in nameUsed#. This string should be freed with  yQ when not needed any longer. The returned name is in the GLib file name encoding. EReads an entire file into allocated memory, with good error checking.'If the call was successful, it returns  Y and sets contents to the file contents and lengthC to the length of the file contents in bytes. The string stored in contents8 will be nul-terminated, so for text files you can pass  _ for the length6 argument. If the call was not successful, it returns  X and sets error. The error domain is  G_FILE_ERROR(. Possible error codes are those in the @d! enumeration. In the error case, contents is set to  _ and length is set to zero. 3No description available in the introspection data. Gets a @d! constant based on the passed-in errNo. For example, if you pass in EEXIST this function returns G_FILE_ERROR_EXIST . Unlike errno* values, you can portably assume that all @d values will exist. Normally a @d value goes into a C returned from a function that manipulates files. So you would use   when constructing a .  !Removes the environment variable variable from the provided environment envp.  Sets the environment variable variable in the provided list envp to value.  .Returns the value of the environment variable variable in the provided list envp. This function is a variant of   which supports a disambiguating message context. GNU gettext uses the '\004' character to separate the message context and message id in  msgctxtid. This uses  5 internally. See that functions for differences with  dgettext() proper.This function differs from C_()c in that it is not a macro and thus you may use non-string-literals as context and msgid arguments. This function is a variant of   which supports a disambiguating message context. GNU gettext uses the '\004' character to separate the message context and message id in  msgctxtid. If 0 is passed as  msgidoffsetq, this function will fall back to trying to use the deprecated convention of using "|" as a separation character. This uses  5 internally. See that functions for differences with  dgettext() proper.IApplications should normally not use this function directly, but use the C_()% macro for translations with context. Converts a pointer to a gdouble& to a hash value. It can be passed to g_hash_table_new() as the hashFunc parameter, It can be passed to g_hash_table_new() as the hashFunc parameter, when using non- _" pointers to doubles as keys in a NO. Compares the two gdouble% values being pointed to and returns  Y( if they are equal. It can be passed to g_hash_table_new() as the  keyEqualFunc parameter, when using non- _" pointers to doubles as keys in a NO. This function is a wrapper of  dngettext()H which does not translate the message if the default domain as set with  textdomain(), has no translations for the current locale.See  & for details of how this differs from  dngettext() proper. 9Converts a gpointer to a hash value. It can be passed to g_hash_table_new() as the hashFuncN parameter, when using opaque pointers compared by pointer value as keys in a NO.^This hash function is also appropriate for keys that are integers stored in pointers, such as GINT_TO_POINTER (n).  Compares two gpointer arguments and returns  Y( if they are equal. It can be passed to g_hash_table_new() as the  keyEqualFuncN parameter, when using opaque pointers compared by pointer value as keys in a NO.bThis equality function is also appropriate for keys that are integers stored in pointers, such as GINT_TO_POINTER (n). This function is a wrapper of  dgettext()H which does not translate the message if the default domain as set with  textdomain(), has no translations for the current locale.*The advantage of using this function over  dgettext()4 proper is that libraries using this function (like GTK+) will not use translations if the application using the library does not have translations for the current locale. This results in a consistent English-only interface instead of one having partial translations. For this feature to work, the call to  textdomain() and  setlocale() should precede any  * invocations. For GTK+, it means calling  textdomain()! before gtk_init or its variants.iThis function disables translations if and only if upon its first call all the following conditions hold:domain is not  _ textdomain()- has been called to set a default text domainUthere is no translations available for the default text domain and the current localeLcurrent locale is not "C" or any English locales (those starting with "en_")Note that this behavior may not be desired for example if an application has its untranslated messages in a language other than English. In those cases the application should call  textdomain() after initializing GTK+.IApplications should normally not use this function directly, but use the _() macro for translations. This is a variant of  B that allows specifying a locale category instead of always using  LC_MESSAGES. See  D for more information about how this functions differs from calling  dcgettext() directly. 0Sets the data element associated with the given GQuark id, and also the function to call when the data element is destroyed. Any previous data with the same key is removed, and its destroy function is called. FRemoves an element, without calling its destroy notification function. )Gets the data element corresponding to a GQuark. lDestroys the dataset, freeing all memory allocated, and calling any destroy functions set for data elements. +Turns off flag values for a data list. See   Turns on flag values for a data list. This function is used to keep a small number of boolean flags in an object with a data list without using any additional space. It is not generally useful except in circumstances where space is very tight. (It is used in the base GObject type, for example.) Resets the datalist to  _<. It does not free any memory or call any destroy functions. )Sets the data corresponding to the given GQuark id, and the function to be called when the element is removed from the datalist. Any previous data with the same key is removed, and its destroy function is called. ",Compares the member that is associated with keyId in datalist to oldval$, and if they are the same, replace oldval with newval.NThis is like a typical atomic compare-and-exchange operation, for a member of datalist.DIf the previous value was replaced then ownership of the old value (oldvalX) is passed to the caller, including the registred destroy notify for it (passed out in  oldDestroyV). Its up to the caller to free this as he wishes, which may or may not include using  oldDestroyJ as sometimes replacement should not destroy the object in the normal way. FRemoves an element, without calling its destroy notification function. ,Retrieves the data element corresponding to keyId. <Gets flags values packed in together with the datalist. See  . FGets a data element, using its string identifier. This is slower than   because it compares strings. sFrees all the data elements of the datalist. The data elements' destroy functions are called if they have been set. 4Converts a string from one character set to another.Note that you should use  Y2 for streaming conversions. Despite the fact that byesRead can return information about partial characters, the g_convert_... functions are not generally suitable for streaming. If the underlying converter maintains internal state, then this won't be preserved across successive calls to  ,   or  . (An example of this is the GNU C converter for CP1255 which does not emit a base character until it knows that the next character is not a mark that could combine with the base character.) Converts a string from one character set to another, possibly including fallback sequences for characters not representable in the output. Note that it is not guaranteed that the specification for the fallback sequences in fallbackE will be honored. Some systems may do an approximate conversion from  fromCodeset to  toCodeset in their iconv()N functions, in which case GLib will simply return that approximate conversion.Note that you should use  Y2 for streaming conversions. Despite the fact that byesRead can return information about partial characters, the g_convert_... functions are not generally suitable for streaming. If the underlying converter maintains internal state, then this won't be preserved across successive calls to  ,   or  . (An example of this is the GNU C converter for CP1255 which does not emit a base character until it knows that the next character is not a mark that could combine with the base character.) 3No description available in the introspection data. 4Converts a string from one character set to another.Note that you should use  Y2 for streaming conversions. Despite the fact that byesRead can return information about partial characters, the g_convert_... functions are not generally suitable for streaming. If the underlying converter maintains internal state, then this won't be preserved across successive calls to  ,   or  . (An example of this is the GNU C converter for CP1255 which does not emit a base character until it knows that the next character is not a mark that could combine with the base character.)mUsing extensions such as "//TRANSLIT" may not work (or may not work well) on many platforms. Consider using   instead. Computes the HMAC for a string.6The hexadecimal string returned will be in lower case. Computes the HMAC for a binary data of length$. This is a convenience wrapper for  g_hmac_new(),  and .6The hexadecimal string returned will be in lower case. 2Computes the HMAC for a binary data$. This is a convenience wrapper for  g_hmac_new(),  and .6The hexadecimal string returned will be in lower case. "Computes the checksum of a string.6The hexadecimal string returned will be in lower case. #Computes the checksum for a binary data of length$. This is a convenience wrapper for A, A and A.6The hexadecimal string returned will be in lower case. "#Computes the checksum for a binary data$. This is a convenience wrapper for A, A and A.6The hexadecimal string returned will be in lower case. $This wraps the close() call; in case of error, errno; will be preserved, but the error will also be stored as a  in error.Besides using , there is another major reason to prefer this function over the call provided by the system; on Unix, it will attempt to correctly handle EINTR(, which has platform-specific semantics. If err or *err is  _!, does nothing. Otherwise, calls  on *err and sets *err to  _. !Creates a new child_watch source.5The source will not initially be associated with any W and must be added to one with 0 before it will be executed.CNote that child watch sources can only be used in conjunction with  g_spawn... when the > flag is used.Note that on platforms where GPid must be explicitly closed (see  ) pidW must not be closed while the source is still active. Typically, you will want to call  ) in the callback function for the source.Note further that using   is not compatible with calling waitpid? with a nonpositive first argument in the application. Calling  waitpid()* for individual pids will still work fine.#Similarly, on POSIX platforms, the pid passed to this function must be greater than 0 (i.e. this function must wait for a specific child, and cannot wait for one of many children by using a nonpositive argument). 9Sets a function to be called when the child indicated by pid exits, at the priority priority.If you obtain pid from   or   you will need to pass G_SPAWN_DO_NOT_REAP_CHILD> as flag to the spawn function for the child watching to work.(In many programs, you will want to call  K in the callback to determine whether or not the child exited successfully.#Also, note that on platforms where GPid must be explicitly closed (see  ) pidT must not be closed while the source is still active. Typically, you should invoke  ) in the callback function for the source.4GLib supports only a single callback per process id.1This internally creates a main loop source using  0 and attaches it to the main loop context using 0>. You can do these steps manually if you need greater control. tChecks that the GLib library in use is compatible with the given version. Generally you would pass in the constants E, E , E! as the three arguments to this function; that produces a check that the library in use is compatible with the version of GLib the application or module was compiled against.kCompatibility is defined by two things: first the version of the running library is newer than the version  requiredMajor.required_minor. requiredMicroH. Second the running library must be binary compatible with the version  requiredMajor.required_minor. requiredMicro (same major version.) A wrapper for the POSIX chdir()H function. The function changes the current directory of the process to path.1See your C library manual for more details about chdir(). Behaves exactly like g_build_path()y, but takes the path elements as a string array, instead of varargs. This function is mainly meant for language bindings. Behaves exactly like g_build_filename()y, but takes the path elements as a string array, instead of varargs. This function is mainly meant for language bindings. Clears the indicated lockBit in address-. If another thread is currently blocked in  + on this same bit then it will be woken up.This function accesses address$ atomically. All other accesses to address< must be atomic in order for this function to work reliably. Sets the indicated lockBit in address , returning  Y4 if successful. If the bit is already set, returns  X immediately.RAttempting to lock on two different bits within the same integer is not supported.+The value of the bit that is set is (1u << bit). If bit6 is not between 0 and 31 then the result is undefined.This function accesses address$ atomically. All other accesses to address< must be atomic in order for this function to work reliably. %Gets the number of bits used to hold number , e.g. if number is 4, 3 bits are needed. *Find the position of the first bit set in mask%, searching from (but not including) nthBitC downwards. Bits are numbered from 0 (least significant) to sizeof(gulongI) * 8 - 1 (31 or 63, usually). To start searching from the last bit, set nthBit to -1 or GLIB_SIZEOF_LONG * 8. *Find the position of the first bit set in mask%, searching from (but not including) nthBitA upwards. Bits are numbered from 0 (least significant) to sizeof(gulongH) * 8 - 1 (31 or 63, usually). To start searching from the 0th bit, set nthBit to -1. Sets the indicated lockBit in address9. If the bit is already set, this call will block until   unsets the corresponding bit.yAttempting to lock on two different bits within the same integer is not supported and will very probably cause deadlocks.+The value of the bit that is set is (1u << bit). If bit6 is not between 0 and 31 then the result is undefined.This function accesses address$ atomically. All other accesses to address< must be atomic in order for this function to work reliably. yGets the name of the file without any leading directory components. It returns a pointer into the given file name string.  MEncode a sequence of binary data into its Base-64 stringified representation. YDecode a sequence of Base-64 encoded text into binary data by overwriting the input data.  Decode a sequence of Base-64 encoded text into binary data. Note that the returned binary data is not necessarily zero-terminated, so it should not be used as a character string. 1Performs an atomic bitwise 'xor' of the value of atomic and val, storing the result back in atomic.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic ^= val; return tmp; }.>This call acts as a full compiler and hardware memory barrier. Sets the value of atomic to newval.NThis call acts as a full compiler and hardware memory barrier (after the set). 0Performs an atomic bitwise 'or' of the value of atomic and val, storing the result back in atomic.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic |= val; return tmp; }.>This call acts as a full compiler and hardware memory barrier. Gets the current value of atomic.OThis call acts as a full compiler and hardware memory barrier (before the get).  Compares atomic to oldval and, if equal, sets it to newval. If atomic was not equal to oldval then no change occurs.-This compare and exchange is done atomically.0Think of this operation as an atomic version of P{ if (*atomic == oldval) { *atomic = newval; return TRUE; } else return FALSE; }.>This call acts as a full compiler and hardware memory barrier. 1Performs an atomic bitwise 'and' of the value of atomic and val, storing the result back in atomic.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic &= val; return tmp; }.>This call acts as a full compiler and hardware memory barrier. Atomically adds val to the value of atomic.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic += val; return tmp; }.>This call acts as a full compiler and hardware memory barrier. 1Performs an atomic bitwise 'xor' of the value of atomic and val, storing the result back in atomic.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic ^= val; return tmp; }.>This call acts as a full compiler and hardware memory barrier. Sets the value of atomic to newval.NThis call acts as a full compiler and hardware memory barrier (after the set). 0Performs an atomic bitwise 'or' of the value of atomic and val, storing the result back in atomic.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic |= val; return tmp; }.>This call acts as a full compiler and hardware memory barrier. Increments the value of atomic by 1.0Think of this operation as an atomic version of { *atomic += 1; }.>This call acts as a full compiler and hardware memory barrier. Gets the current value of atomic.OThis call acts as a full compiler and hardware memory barrier (before the get). This function existed before   returned the prior value of the integer (which it now does). It is retained only for compatibility reasons. Don't use this function in new code. Decrements the value of atomic by 1.0Think of this operation as an atomic version of ({ *atomic -= 1; return (*atomic == 0); }.>This call acts as a full compiler and hardware memory barrier.  Compares atomic to oldval and, if equal, sets it to newval. If atomic was not equal to oldval then no change occurs.-This compare and exchange is done atomically.0Think of this operation as an atomic version of P{ if (*atomic == oldval) { *atomic = newval; return TRUE; } else return FALSE; }.>This call acts as a full compiler and hardware memory barrier. 1Performs an atomic bitwise 'and' of the value of atomic and val, storing the result back in atomic.>This call acts as a full compiler and hardware memory barrier.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic &= val; return tmp; }. Atomically adds val to the value of atomic.0Think of this operation as an atomic version of .{ tmp = *atomic; *atomic += val; return tmp; }.>This call acts as a full compiler and hardware memory barrier.?Before version 2.30, this function did not return a value (but   did, and had the same meaning). @Specifies a function to be called at normal program termination.Since GLib 2.8.2, on Windows  = actually is a preprocessor macro that maps to a call to the atexit()H function in the C library. This means that in case the code that calls  , i.e. atexit(), is in a DLL, the function will be called when the DLL is detached from the program. This typically makes more sense than that the function is called when the GLib DLL is detached, which happened earlier when   was a function in the GLib DLL.The behaviour of atexit()Z in the context of dynamically loaded modules is not formally specified and varies wildly.On POSIX systems, calling   (or atexit()z) in a dynamically loaded module which is unloaded before the program terminates might well cause a crash at program exit.Some POSIX systems implement atexit() like Windows, and have each dynamically loaded module maintain an own atexit chain that is called when the module is unloaded.On other POSIX systems, before a dynamically loaded module is unloaded, the registered atexit functions (if any) residing in that module are called, regardless where the code that registered them resided. This is presumably the most robust approach.JAs can be seen from the above, for portability it's best to avoid calling   (or atexit()-) except in the main executable of a program. 3No description available in the introspection data. 3No description available in the introspection data. 3No description available in the introspection data. 3No description available in the introspection data. QDetermines the numeric value of a character as a hexidecimal digit. Differs from  \ because it takes a char, so there's no worry about sign extension if characters are signed. (Convert a character to ASCII upper case.Unlike the standard C library  toupper()* function, this only recognizes standard ASCII letters and ignores the locale, returning all non-ASCII characters unchanged, even if they are upper case letters in a particular character set. Also unlike the standard library function, this takes and returns a char, not an int, so don't call it on EOF' but no need to worry about casting to guchar2 before passing a possibly non-ASCII character in. (Convert a character to ASCII lower case.Unlike the standard C library  tolower()* function, this only recognizes standard ASCII letters and ignores the locale, returning all non-ASCII characters unchanged, even if they are lower case letters in a particular character set. Also unlike the standard library function, this takes and returns a char, not an int, so don't call it on EOF' but no need to worry about casting to guchar2 before passing a possibly non-ASCII character in. BConverts all lower case ASCII letters to upper case ASCII letters. Converts a string to a guint640 value. This function behaves like the standard  strtoull() function does in the C locale. It does this without actually changing the current locale, since that would not be thread-safe.This function is typically used when reading configuration files or other non-user input that should be locale independent. To handle input from the user you should normally use the locale-sensitive system  strtoull() function.+If the correct value would cause overflow, E" is returned, and ERANGE is stored in errno@. If the base is outside the valid range, zero is returned, and EINVAL is stored in errno8. If the string conversion fails, zero is returned, and endptr returns nptr (if endptr is non- _).  Converts a string to a gint640 value. This function behaves like the standard  strtoll() function does in the C locale. It does this without actually changing the current locale, since that would not be thread-safe.This function is typically used when reading configuration files or other non-user input that should be locale independent. To handle input from the user you should normally use the locale-sensitive system  strtoll() function.+If the correct value would cause overflow, E# or E$ is returned, and ERANGE is stored in errno@. If the base is outside the valid range, zero is returned, and EINVAL is stored in errno8. If the string conversion fails, zero is returned, and endptr returns nptr (if endptr is non- _). Converts a string to a gdouble value.(This function behaves like the standard strtod() function does in the C locale. It does this without actually changing the current locale, since that would not be thread-safe. A limitation of the implementation is that this function will still accept localized versions of infinities and NANs.This function is typically used when reading configuration files or other non-user input that should be locale independent. To handle input from the user you should normally use the locale-sensitive system strtod() function.To convert from a gdouble. to a string in a locale-insensitive way, use  .9If the correct value would cause overflow, plus or minus HUGE_VAL7 is returned (according to the sign of the value), and ERANGE is stored in errnoC. If the correct value would cause underflow, zero is returned and ERANGE is stored in errno.This function resets errno before calling strtod()8 so that you can reliably detect overflow and underflow. Compare s1 and s2K, ignoring the case of ASCII characters and any characters after the first n in each string.Unlike the BSD  strcasecmp() function, this only recognizes standard ASCII letters and ignores the locale, treating all non-ASCII characters as if they are not letters.The same warning as in   applies: Use this function only on strings known to be in encodings where bytes corresponding to ASCII letters always represent themselves. BConverts all upper case ASCII letters to lower case ASCII letters. ;Compare two strings, ignoring the case of ASCII characters.Unlike the BSD  strcasecmp() function, this only recognizes standard ASCII letters and ignores the locale, treating all non-ASCII bytes as if they are not letters.This function should be used only on strings that are known to be in encodings where the bytes corresponding to ASCII letters always represent themselves. This includes UTF-8 and the ISO-8859-* charsets, but not for instance double-byte encodings like the Windows Codepage 932, where the trailing bytes of double-byte characters include all ASCII letters. If you compare two CP932 strings using this function, you will get false matches.Both s1 and s2 must be non- _.  Converts a gdoubleQ to a string, using the '.' as decimal point. To format the number you pass in a printf()X-style format string. Allowed conversion specifiers are 'e', 'E', 'f', 'F', 'g' and 'G'.7The returned buffer is guaranteed to be nul-terminated.CIf you just want to want to serialize the value into a string, use  .  Converts a gdouble- to a string, using the '.' as decimal point.OThis function generates enough precision that converting the string back using   gives the same machine-number (on machines with IEEE compatible 64bit doubles). It is guaranteed that the size of the resulting string will never be larger than gASCIIDTOSTRBUFSIZEG bytes, including the terminating nul character, which is always added. MDetermines the numeric value of a character as a decimal digit. Differs from  \ because it takes a char, so there's no worry about sign extension if characters are signed. A wrapper for the POSIX access() function. This function is used to test a pathname for one or several of read, write or execute permissions, or just existence.kOn Windows, the file protection mechanism is not at all POSIX-like, and the underlying function in the C library only checks the FAT-style READONLY attribute, and does not look at the ACL of a file at all. This function is this in practise almost useless on Windows. Software that needs to handle file permissions on Windows more exactly should use the Win32 API.1See your C library manual for more details about access().      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789: ] ^str: a pointer to character data Returns:  Y if the text was valid UTF-8 _str: a UTF-8 encoded string startPos: a character offset within str endPos": another character offset within str Returns:B a newly allocated copy of the requested substring. Free with  y when no longer needed. `str: a UTF-8 encoded string len : length of str, in bytes, or -1 if str is nul-terminated. Returns:J a newly allocated string, with all characters converted to uppercase. astr: a UTF-8 encoded string len: the maximum length of str to use, in bytes. If len- < 0, then the string is nul-terminated. Returns:2 a newly-allocated string which is the reverse of str bp(: a nul-terminated UTF-8 encoded string len: the maximum length of p c: a Unicode character Returns:  _ if the string does not contain the character, otherwise, a pointer to the start of the rightmost occurrence of the character in the string. cdest&: buffer to fill with characters from src src: UTF-8 encoded string n: character count Returns: dest dp1: pointer to the start of a UTF-8 encoded string max-: the maximum number of bytes to examine. If maxQ is less than 0, then the string is assumed to be nul-terminated. If max is 0, p' will not be examined and may be  _. If max is greater than 0, up to max bytes are examined Returns:( the length of the string in characters estr: a UTF-8 encoded string len : length of str, in bytes, or -1 if str is nul-terminated. Returns:J a newly allocated string, with all characters converted to lowercase. fp(: a nul-terminated UTF-8 encoded string len: the maximum length of p c: a Unicode character Returns:  _ if the string does not contain the character, otherwise, a pointer to the start of the leftmost occurrence of the character in the string. gp8: a pointer to a position within a UTF-8 encoded string Returns:" a pointer to the found character hstr: a UTF-8 encoded string pos!: a pointer to a position within str Returns: the resulting character offset istr: a UTF-8 encoded string offset: a character offset within str Returns: the resulting pointer jstr: a UTF-8 encoded string. len : length of str, in bytes, or -1 if str is nul-terminated. mode(: the type of normalization to perform. Returns:< a newly allocated string, that is the normalized form of str, or  _ if str is not valid UTF-8. kp2: a pointer to Unicode character encoded as UTF-8 maxLenG: the maximum number of bytes to read, or -1, for no maximum or if p is nul-terminated Returns: the resulting character. If pg points to a partial sequence at the end of a string that could begin a valid character (or if maxLen3 is zero), returns (gunichar)-2; otherwise, if pV does not point to a valid UTF-8 encoded Unicode character, returns (gunichar)-1. lp2: a pointer to Unicode character encoded as UTF-8 Returns: the resulting character mstr5: pointer to the beginning of a UTF-8 encoded string p": pointer to some position within str Returns:% a pointer to the found character or  _. np8: a pointer to a position within a UTF-8 encoded string end@: a pointer to the byte following the end of the string, or  _/ to indicate that the string is nul-terminated Returns:% a pointer to the found character or  _ ostr: a UTF-8 encoded string. len : length of str, in bytes, or -1 if str is nul-terminated. Returns:> a newly allocated string. This string should be freed with  y when you are done with it. pstr: a UTF-8 encoded string. len : length of str, in bytes, or -1 if str is nul-terminated. Returns:> a newly allocated string. This string should be freed with  y when you are done with it. qstr1: a UTF-8 encoded string str2: a UTF-8 encoded string Returns: < 0 if str1 compares before str2$, 0 if they compare equal, > 0 if str1 compares after str2. rstr: a UTF-8 encoded string len : length of str, in bytes, or -1 if str is nul-terminated. Returns:@ a newly allocated string, that is a case independent form of str. s microseconds": number of microseconds to pause t escapedString%: an escaped string to be unescaped. illegalCharacters<: a string of illegal characters not to be allowed, or  _. Returns: an unescaped version of  escapedString=. The returned string should be freed when no longer needed. u escapedString: A string, may be  _ escapedStringEnd: Pointer to end of  escapedString , may be  _ illegalCharactersE: An optional string of illegal characters not to be allowed, may be  _ Returns: an unescaped version of  escapedString or  _\ on error. The returned string should be freed when no longer needed. As a special case if  _ is given for  escapedString, this function will return  _. vuri: a valid URI. Returns:' The "Scheme" component of the URI, or  _F on error. The returned string should be freed when no longer needed. wuriList: an URI list Returns: a newly allocated  _\-terminated list of strings holding the individual URIs. The array should be freed with  . x unescaped: the unescaped input string. reservedCharsAllowedG: a string of reserved characters that are allowed to be used, or  _.  allowUtf8:  Y- if the result can include UTF-8 characters. Returns: an escaped version of  unescaped=. The returned string should be freed when no longer needed. yvariable;: the environment variable to remove, must not contain '=' zfilenameC: a pathname in the GLib file name encoding (UTF-8 on Windows) Returns:D 0 if the name was successfully deleted, -1 if an error occurred {signum: A signal number Returns: A newly created 0 |priority\: the priority of the signal source. Typically this will be in the range between E and E%. signum: Signal number handler : Callback Returns:- An ID (greater than 0) for the event source }fd: A file descriptor nonblock: If  Y(, set the descriptor to be non-blocking  (Can throw \]) ~fds: Array of two integers flags,: Bitfield of file descriptor flags, as for fcntl()  (Can throw \]) fd: a file descriptor  condition : IO conditions to watch for on fd Returns: the newly created 0 priority: the priority of the source fd: a file descriptor  condition : IO conditions to watch for on fd function: a F& Returns:- the ID (greater than 0) of the event source script: a Unicode script Returns: the ISO 15924 code for script&, encoded as an integer, of zero if script is @'9 or ISO 15924 code 'Zzzz' (script code for UNKNOWN) if script is not understood. iso15924: a Unicode script Returns: the Unicode script for iso15924 , or of @' if iso15924 is zero and @( if iso15924 is unknown. string: a UCS-4 encoded string. len: the maximum length of string to use. ch: a Unicode character.  resultLen4: location to store the length of the return value. Returns:3 a newly allocated string of Unicode characters.  resultLen/ is set to the resulting length of the string. c: a Unicode character Returns: If c is a hex digit (according to  %), its numeric value. Otherwise, -1. ch: a Unicode character Returns:  Y if ch is a valid Unicode character c: a Unicode character Returns: the type of the character. c: a Unicode character Returns: the result of converting c to uppercase. If c[ is not an lowercase or titlecase character, or has no upper case equivalent c is returned unchanged. c: a Unicode character Returns: the result of converting c to titlecase. If c; is not an uppercase or lowercase character, c is returned unchanged. c: a Unicode character. Returns: the result of converting c! to lower case. If c[ is not an upperlower or titlecase character, or has no lowercase equivalent c is returned unchanged. c: a Unicode character Returns:  Y! if the character has zero width c: a Unicode character. Returns:  Y) if the character is a hexadecimal digit c: a Unicode character Returns:  Y7 if the character is wide in legacy East Asian locales c: a Unicode character Returns:  Y if the character is wide c: a Unicode character Returns:  Y if c is an uppercase character c: a Unicode character Returns:  Y if the character is titlecase c: a Unicode character Returns:  Y if c is a space character c: a Unicode character Returns:  Y if c& is a punctuation or symbol character c: a Unicode character Returns:  Y if c is printable c: a Unicode character Returns:  Y if c is a mark character c: a Unicode character Returns:  Y if c is a lowercase letter c: a Unicode character Returns:  Y if c" is printable unless it's a space c: a Unicode character Returns:  Y if c is a digit c: a Unicode character Returns:  Y( if the character has an assigned value c: a Unicode character Returns:  Y if c is a control character c: a Unicode character Returns:  Y if c is an alphabetic character c: a Unicode character Returns:  Y if c is an alphanumeric character ch: a Unicode character Returns: the @ for the character. ch: a Unicode character  mirroredCh+: location to store the mirrored character Returns:  Y if ch has a mirrored character,  X otherwise c: a Unicode character Returns: If c" is a decimal digit (according to  %), its numeric value. Otherwise, -1. ch: a Unicode character a-: return location for the first component of ch b.: return location for the second component of ch Returns:  Y& if the character could be decomposed a: a Unicode character b: a Unicode character ch-: return location for the composed character Returns:  Y% if the characters could be composed uc: a Unicode character Returns:& the combining class of the character c: a Unicode character Returns: the break type of c mem": previously-allocated memory, or  _. nBlocks#: the number of blocks to allocate  nBlockBytes": the size of each block in bytes Returns: the allocated memory, or  _. mem": previously-allocated memory, or  _. nBytes: number of bytes to allocate. Returns: the allocated memory, or  _. nBlocks#: the number of blocks to allocate  nBlockBytes": the size of each block in bytes Returns: the allocated memory, or  _. nBlocks#: the number of blocks to allocate  nBlockBytes": the size of each block in bytes Returns: the allocated memory, or  _ nBytes: number of bytes to allocate Returns: the allocated memory, or  _ nBytes: number of bytes to allocate. Returns: the allocated memory, or  _. interval": the timeout interval in seconds Returns:" the newly-created timeout source interval(: the timeout interval in milliseconds. Returns:" the newly-created timeout source priority]: the priority of the timeout source. Typically this will be in the range between E and E%. interval5: the time between calls to the function, in seconds function: function to call Returns:. the ID (greater than 0) of the event source. priority]: the priority of the timeout source. Typically this will be in the range between E and E%. interval^: the time between calls to the function, in milliseconds (1/1000ths of a second) function: function to call Returns:. the ID (greater than 0) of the event source. testPath: Test to run in a subprocess  usecTimeout4: Timeout for the subprocess test in micro seconds.  testFlags(: Flags to modify subprocess behaviour. Returns:  Y: if the last test subprocess got killed due to a timeout. Returns:  Y6 if the last test subprocess terminated successfully.  usecTimeout0: Timeout for the forked test in micro seconds.  testTrapFlags%: Flags to modify forking behaviour. Returns:  Y for the forked child and  X# for the executing parent process. Returns: the last result of  , as a double Returns:9 the time since the last start of the timer, as a double Returns:  Y& if the test program is running under  . msg: explanation suite: a &) Returns: 0 on success Returns:c 0 on success, 1 on failure (assuming it returns at all), 0 or 77 if all tests were skipped with   begin.: the minimum value returned by this function end9: the smallest value not to be returned by this function Returns: a number with begin <= number < end. Returns:: a random number from the seeded random number generator.  rangeStart.: the minimum value returned by this function rangeEnd2: the minimum value not returned by this function Returns: a number with  rangeStart <= number < rangeEnd. Returns:: a random number from the seeded random number generator.  gfreePointer: the pointer to be stored.  destroyFunc': Destroy callback for teardown phase.  destroyData: Destroy callback data. msg: explanation fileType+: the type of file (built vs. distributed) Returns:* the path of the directory, owned by GLib Returns:  Y if the test has failed  logDomain : the log domain of the message logLevel: the log level of the message pattern;: a glob-style [pattern][glib-Glob-style-pattern-matching]  uriPattern : the base pattern for bug URIs  bugUriSnippet(: Bug specific bug tracker URI portion. testpath0: /-separated test case path name for the test. testFunc-: The test function to invoke for this test. testpath0: /-separated test case path name for the test. testData,: Test data argument for the test function. testFunc-: The test function to invoke for this test. strArray: a  _-terminated array of strings Returns: length of strArray. strv: a  _-terminated array of strings str : a string Returns:  Y if str is an element of strv, according to  . string: the string to convert Returns: the string nptr,: the string to convert to a numeric value. Returns: the gdouble value. haystack : a string  haystackLen: the maximum length of haystack). Note that -1 is a valid length, if haystackI is nul-terminated, meaning it will search through the whole string. needle: the string to search for Returns:* a pointer to the found occurrence, or  _ if not found. signum: the signal number. See the signal documentation Returns:m a UTF-8 string describing the signal. If the signal is unknown, it returns "unknown signal (<signum>)". haystack: a nul-terminated string  haystackLen: the maximum length of haystack needle*: the nul-terminated string to search for Returns:* a pointer to the found occurrence, or  _ if not found. haystack: a nul-terminated string needle*: the nul-terminated string to search for Returns:* a pointer to the found occurrence, or  _ if not found. string: the string to reverse Returns: the same pointer passed in as string length: the length of the new string fillChar#: the byte to fill the string with Returns:% a newly-allocated string filled the fillChar str: the string to duplicate n+: the maximum number of bytes to copy from str Returns:/ a newly-allocated buffer containing the first n bytes of str, nul-terminated s1 : a string s2: a string to compare with s1 n.: the maximum number of characters to compare Returns:- 0 if the strings match, a negative value if s1 < s2, or a positive value if s1 > s2. dest: destination buffer src: source buffer destSize : length of dest in bytes Returns: length of src destC: destination buffer, already containing one nul-terminated string src: source buffer destSize : length of dest; buffer in bytes (not length of existing string inside dest) Returns: size of attempted result, which is MIN (dest_size, strlen (original dest)) + strlen (src), so if retval >= dest_size, truncation occurred.  separator9: a string to insert between each of the strings, or  _ strArray: a  _%-terminated array of strings to join Returns:R a newly-allocated string containing all of the strings joined together, with  separator between them msgid : a string msgval: another string Returns: msgval , unless msgval is identical to msgid and contains a '|' character, in which case a pointer to the substring of msgid after the first '|' character is returned. dflSizeA: the default size of the space allocated to hold the string Returns: the new / init!: initial contents of the string len : length of init to use Returns: a new / init/: the initial text to copy into the string, or  _ to start with an empty string Returns: the new / strArray: a  _%-terminated array of strings to free source: a string to escape  exceptions*: a string of characters not to escape in source Returns: a newly-allocated copy of source1 with certain characters escaped. See above. errnum.: the system error number. See the standard C errno documentation Returns: a UTF-8 string describing the error code. If the error code is unknown, it returns a string like "unknown error (<code>)". str: the string to duplicate Returns: a newly-allocated copy of str string: the string to convert. Returns: the string string: the string to convert  delimiters5: a string containing the current delimiters, or  _+ to use the standard delimiters defined in E*  newDelimiter: the new delimiter character Returns: string source: a string to compress Returns: a newly-allocated copy of source+ with all escaped character compressed str1: a C string or  _ str2: another C string or  _ Returns:: an integer less than, equal to, or greater than zero, if str1 is <, == or > than str2. string1: a string to remove the leading whitespace from Returns: string string2: a string to remove the trailing whitespace from Returns: string s1 : a string s2: a string to compare with s1 Returns:- 0 if the strings match, a negative value if s1 < s2, or a positive value if s1 > s2. string": a nul-terminated array of bytes  validChars: bytes permitted in string  substitutor-: replacement character for disallowed bytes Returns: string string : a string translitLocale8: the language code (like 'de' or 'en_GB') from which string originates Returns: the folded tokens str: a string, in UTF-8  fromLocale: the source locale, if known Returns: a string in plain ASCII  searchTerm : the search term from the user  potentialHit: the text that may be a hit acceptAlternates:  Y to accept ASCII alternates Returns:  Y if  potentialHit is a hit str : a string Returns:  Y if str is ASCII v: a string key Returns:' a hash value corresponding to the key str: a nul-terminated string suffix(: the nul-terminated suffix to look for Returns:  Y if str end with suffix,  X otherwise. str: a nul-terminated string prefix(: the nul-terminated prefix to look for Returns:  Y if str begins with prefix,  X otherwise. v1: a key v2: a key to compare with v1 Returns:  Y if the two keys match dest: destination buffer. src: source string. Returns:! a pointer to trailing nul byte. workingDirectory(: child's current working directory, or  _ to inherit parent's argv: child's argument vector envp: child's environment, or  _ to inherit parent's flags : flags from >+  childSetup+: function to run in the child just before exec()  (Can throw \])  commandLine: a command line  (Can throw \])  commandLine: a command line  (Can throw \]) pid!: The process reference to close  exitStatus : An exit code as returned from    (Can throw \]) workingDirectory(: child's current working directory, or  _5 to inherit parent's, in the GLib file name encoding argv:: child's argument vector, in the GLib file name encoding envp: child's environment, or  _5 to inherit parent's, in the GLib file name encoding flags : flags from >+  childSetup+: function to run in the child just before exec()  (Can throw \]) workingDirectory(: child's current working directory, or  _ to inherit parent's argv: child's argument vector envp: child's environment, or  _ to inherit parent's flags : flags from >+  childSetup+: function to run in the child just before exec()  (Can throw \]) num: a guint Returns:T the smallest prime number from a built-in array of primes which is larger than num   blockSize: the size of the blocks memChain,: a pointer to the first block of the chain  nextOffset: the offset of the next field in the blocks  blockSize: the size of the block memBlock!: a pointer to the block to free  blockSize": the number of bytes to allocate memBlock: the memory to copy Returns:8 a pointer to the allocated memory block, which will be  _ if and only if memSize is 0  blockSize": the number of bytes to allocate Returns:1 a pointer to the allocated block, which will be  _ if and only if memSize is 0  blockSize": the number of bytes to allocate Returns:8 a pointer to the allocated memory block, which will be  _ if and only if memSize is 0  quotedString: shell-quoted string Returns: an unquoted string  (Can throw \]) unquotedString: a literal string Returns: quoted string  commandLine: command line to parse  (Can throw \]) variable9: the environment variable to set, must not contain '='. value(: the value for to set the variable to.  overwrite7: whether to change the variable if it already exists. Returns:  X. if the environment variable couldn't be set. prgname: the name of the program. domain: error domain code : error code message: error message applicationName$: localized name of the application filenameC: a pathname in the GLib file name encoding (UTF-8 on Windows) Returns:I 0 if the directory was successfully removed, -1 if an error occurred  mem: the memory to reallocate nBlocks#: the number of blocks to allocate  nBlockBytes": the size of each block in bytes Returns:) the new address of the allocated memory mem: the memory to reallocate nBytes": new size of the memory in bytes Returns:) the new address of the allocated memory seed=: a value to reinitialize the global random number generator begin%: lower closed bound of the interval end#: upper open bound of the interval Returns: a random number Returns: a random number begin%: lower closed bound of the interval end#: upper open bound of the interval Returns: a random number Returns: a random number string : a string Returns: the GQuark% associated with the string, or 0 if string is  _ or there is no GQuark associated with it quark: a GQuark. Returns: the string associated with the GQuark string : a string Returns: the GQuark! identifying the string, or 0 if string is  _ string : a string Returns: the GQuark! identifying the string, or 0 if string is  _ src): error to move into the return location fds: file descriptors to poll nfds$: the number of file descriptors in fds timeoutA: amount of time to wait, in milliseconds, or -1 to wait forever Returns: the number of entries in fds whose reventsh fields were filled in, or 0 if the operation timed out, or -1 on error or if the call was interrupted. address: a pointer to a gpointer -sized value lockBit: a bit value between 0 and 31 address: a pointer to a gpointer -sized value lockBit: a bit value between 0 and 31 Returns:  Y if the lock was acquired address: a pointer to a gpointer -sized value lockBit: a bit value between 0 and 31 !pspec: a ', string$: the UTF-8 encoded string to match Returns:  Y if string matches pspec "pattern: the UTF-8 encoded pattern string$: the UTF-8 encoded string to match Returns:  Y if string matches pspec #pspec: a ',  stringLength: the length of string (in bytes, i.e. strlen() , not  d) string$: the UTF-8 encoded string to match stringReversed: the reverse of string or  _ Returns:  Y if string matches pspec $fileName: a file name Returns: a pointer into fileName after the root component %fileName: a file name Returns:  Y if fileName is absolute &fileName: the name of the file Returns:& the directory components of the file 'fileName: the name of the file Returns:K a newly allocated string containing the last component of the filename (stringE: a list of debug options separated by colons, spaces, or commas, or  _. keys: pointer to an array of *-- which associate strings with bit flags. Returns: the combined set of bit flags. ) *prgNameE: the program name, needed by gdb for the "[S]tack trace" option +prgNameI: the program name, needed by gdb for the "[S]tack trace" option. If prgName is  _,  kE is called to get the program name (which will work correctly if  gdk_init() or  gtk_init() has been called) ,nullifyLocation%: the memory address of the pointer. -tmpl: template filename flags: flags to pass to an open()L call in addition to O_EXCL and O_CREAT, which are passed automatically mode0: permissions to create the temporary file with Returns: A file handle (as from open()\) to the file opened for reading and writing. The file handle should be closed with close(),. In case of errors, -1 is returned and errno will be set. .tmpl: template filename Returns: A file handle (as from open()) to the file opened for reading and writing. The file is opened in binary mode on platforms where there is a difference. The file handle should be closed with close(),. In case of errors, -1 is returned and errno will be set. /tmpl: template directory name mode5: permissions to create the temporary directory with Returns: A pointer to tmplM, which has been modified to hold the directory name. In case of errors,  _ is returned, and errno will be set. 0tmpl: template directory name Returns: A pointer to tmplN, which has been modified to hold the directory name. In case of errors,  _ is returned and errno will be set. 1pathname,: a pathname in the GLib file name encoding mode3: permissions to use for newly created directories Returns:r 0 if the directory already exists, or was successfully created. Returns -1 if an error occurred, with errno set. 2mem: the memory to copy. byteSize: the number of bytes to copy. Returns:9 a pointer to the newly-allocated copy of the memory, or  _ if mem is  _. 3vtable': table of memory allocation routines. 4 5Returns: if  Y, malloc() and  ; can be mixed. 6text: some valid UTF-8 text length : length of text/ in bytes, or -1 if the text is nul-terminated Returns:0 a newly allocated string with the escaped text 7 8nBlocks#: the number of blocks to allocate  nBlockBytes": the size of each block in bytes Returns:# a pointer to the allocated memory 9nBlocks#: the number of blocks to allocate  nBlockBytes": the size of each block in bytes Returns:# a pointer to the allocated memory :nBytes": the number of bytes to allocate Returns:# a pointer to the allocated memory ;nBytes": the number of bytes to allocate Returns:# a pointer to the allocated memory <Returns:5 The main loop recursion level in the current thread =Returns: The currently firing source or  _. >outputFd": output file descriptor to check Returns:  Y& if ANSI color escapes are supported,  X otherwise ?logLevel: log level, either from >., or a user-defined level fields@: key value pairs of structured data forming the log message userData: user data passed to G Returns: @ on success, @ otherwise @logLevel: log level, either from >., or a user-defined level fields@: key value pairs of structured data forming the log message userData: user data passed to G Returns: @ on success, @ otherwise AoutputFd": output file descriptor to check Returns:  Y if outputFd points to the journal,  X otherwise BlogLevel: log level, either from >., or a user-defined level fields@: key value pairs of structured data forming the log message useColor:  YD to use ANSI color escape sequences when formatting the message,  X to not Returns:\ string containing the formatted log message, in the character set of the current locale ClogLevel: log level, either from >., or a user-defined level fields@: key value pairs of structured data forming the log message userData: user data passed to G Returns: @ on success, @ otherwise D logDomain: log domain, usually E/ logLevel: log level, either from >., or a user-defined level fields: a dictionary ( ` of the type G_VARIANT_TYPE_VARDICT2) containing the key-value pairs of message data. ElogLevel: log level, either from >., or a user-defined level fieldsB: key value pairs of structured data to add to the log message F logDomain: the log domain, or  _+ for the default "" application domain  logLevels: the log levels to apply the log handler for. To handle fatal and recursive messages as well, combine the log levels with the G_LOG_FLAG_FATAL and G_LOG_FLAG_RECURSION bit flags. logFunc: the log handler function Returns: the id of the new handler G logDomain: the log domain  fatalMask: the new fatal mask Returns:' the old fatal mask for the log domain H fatalMaskP: the mask containing bits set for each level of error which is to be fatal Returns: the old fatal mask I logDomain: the log domain  handlerId3: the id of the handler, which was returned in g_log_set_handler() J logDomain$: the log domain of the message, or  _' for the default "" application domain logLevel: the level of the message message: the message  unusedData: data passed from g_log() which is unused K opsysstringm: a string in the encoding of the current locale. On Windows this means the system codepage. len: the length of the string, or -1 if the string is nul-terminated (Note that some encodings may allow nul bytes to occur inside strings. In that case, using -1 for the len parameter is unsafe) Returns:L A newly-allocated buffer containing the converted string, or  _% on an error, and error will be set.  (Can throw \]) L utf8string: a UTF-8 encoded string len: the length of the string, or -1 if the string is nul-terminated (Note that some encodings may allow nul bytes to occur inside strings. In that case, using -1 for the len parameter is unsafe) Returns:L A newly-allocated buffer containing the converted string, or  _% on an error, and error will be set.  (Can throw \]) MReturns: a  _9-terminated list of strings which must be freed with  . Nchannel: a ; to watch  condition: conditions to watch for Returns: a new 0 Ochannel: a ; priority: the priority of the ; source  condition: the condition to watch for func7: the function to call when the condition is satisfied Returns: the event source id Pstring : a string Returns:+ a canonical representation for the string Qstring: a static string Returns:+ a canonical representation for the string Rv: a pointer to a gint key Returns:( a hash value corresponding to the key. Sv1: a pointer to a gint key v2: a pointer to a gint key to compare with v1 Returns:  Y if the two keys match. Tv: a pointer to a gint64 key Returns:( a hash value corresponding to the key. Uv1: a pointer to a gint64 key v2: a pointer to a gint64 key to compare with v1 Returns:  Y if the two keys match. VReturns: the newly-created idle source Wdata+: the data for the idle source's callback. Returns:  Y* if an idle source was found and removed. XpriorityZ: the priority of the idle source. Typically this will be in the range between E and E0. function: function to call Returns:. the ID (greater than 0) of the event source. Y converter: conversion descriptor from g_iconv_open() inbuf: bytes to convert  inbytesLeft1: inout parameter, bytes remaining to convert in inbuf outbuf: converted output bytes  outbytesLeft.: inout parameter, bytes available to fill in outbuf Returns:5 count of non-reversible conversions, or -1 on error Zhostname": a valid UTF-8 or ASCII hostname Returns:+ a UTF-8 hostname, which must be freed, or  _ if hostname is in some way invalid. [hostname": a valid UTF-8 or ASCII hostname Returns:, an ASCII hostname, which must be freed, or  _ if hostname is in some way invalid. \hostname : a hostname Returns:  Y if hostname# contains any non-ASCII characters ]hostname,: a hostname (or IP address in string form) Returns:  Y if hostname is an IP address ^hostname : a hostname Returns:  Y if hostname& contains any ASCII-encoded segments. _variable": the environment variable to get Returns:+ the value of the environment variable, or  _n if the environment variable is not found. The returned string may be overwritten by the next call to  _,   or  y. ` directory&: the logical id of special directory Returns:3 the path to the specified special directory, or  _n if the logical id was not found. The returned string is owned by GLib and should not be modified or freed. aReturns:@ a string owned by GLib that must not be modified or freed. bReturns:$ the user name of the current user. cReturns:J a string owned by GLib that must not be modified or freed. dReturns:J a string owned by GLib that must not be modified or freed. eReturns:J a string owned by GLib that must not be modified or freed. fReturns:+ the directory to use for temporary files. gReturns: a  _S-terminated array of strings owned by GLib that must not be modified or freed. hReturns: a  _S-terminated array of strings owned by GLib that must not be modified or freed. iReturns:7 the number of microseconds since January 1, 1970 UTC. jReturns: the user's real name. kReturns:e the name of the program. The returned string belongs to GLib and must not be modified or freed. lReturns:6 Number of schedulable threads, always greater than 0 mReturns:% the monotonic time, in microseconds nlocale: a locale identifier Returns:\ a newly allocated array of newly allocated strings with the locale variants. Free with  . oReturns: a  _R-terminated array of strings owned by GLib that must not be modified or freed. pReturns: the host name of the machine. qReturns:# the current user's home directory rcharsets: return location for the  _#-terminated list of encoding names Returns:  Y$ if the filename encoding is UTF-8. sReturns:' the list of environment variables tresult: #j+ structure in which to store current time. uReturns: the current directory vReturns:g a newly allocated string containing the name of the character set. This string must be freed with  y. wReturns:  Y" if the returned charset is UTF-8 xReturns:- human-readable application name. may return  _ ymem: the memory to free zsize: a size in bytes flags: > to modify the output Returns:N a newly-allocated formatted string containing a human readable file size {size: a size in bytes Returns:N a newly-allocated formatted string containing a human readable file size |size: a size in bytes Returns:N a newly-allocated formatted string containing a human readable file size }program0: a program name in the GLib file name encoding Returns:9 a newly-allocated string with the absolute path, or  _ ~ opsysstring): a string in the encoding for filenames len: the length of the string, or -1 if the string is nul-terminated (Note that some encodings may allow nul bytes to occur inside strings. In that case, using -1 for the len parameter is unsafe) Returns: The converted string, or  _ on an error.  (Can throw \]) filename: an absolute filename specified in the GLib file name encoding, which is the on-disk file name bytes on Unix, and UTF-8 on Windows hostname: A UTF-8 encoded hostname, or  _ for none. Returns:F a newly-allocated string holding the resulting URI, or  _ on an error.  (Can throw \])  utf8string: a UTF-8 encoded string. lenS: the length of the string, or -1 if the string is nul-terminated. Returns:) The converted string, or  _ on an error.  (Can throw \]) uri;: a uri describing a filename (escaped, encoded in ASCII). Returns:K a newly-allocated string holding the resulting filename, or  _ on an error.  (Can throw \]) filename:: a pathname hopefully in the GLib file name encoding Returns:R a newly allocated string containing a rendition of the filename in valid UTF-8 filename:: an absolute pathname in the GLib file name encoding Returns:b a newly allocated string containing a rendition of the basename of the filename in valid UTF-8 filename8: a filename to test in the GLib file name encoding test: bitfield of >1 flags Returns: whether a test was  Y filename: name of a file to write contents& to, in the GLib file name encoding contents: string to write to the file  (Can throw \]) filename: the symbolic link Returns:I A newly-allocated string with the contents of the symbolic link, or  _ if an error occurred.  (Can throw \]) tmpl$: Template for file name, as in  ., basename only, or  _ for a default template Returns: A file handle (as from open()) to the file opened for reading and writing. The file is opened in binary mode on platforms where there is a difference. The file handle should be closed with close()(. In case of errors, -1 is returned and error will be set.  (Can throw \]) filenameG: name of a file to read contents from, in the GLib file name encoding  (Can throw \]) errNo: an "errno" value Returns: @d corresponding to the given errno envp2: an environment list that can be freed using   (e.g., as returned from  s ), or  _ for an empty environment list variable;: the environment variable to remove, must not contain '=' Returns:1 the updated environment list. Free it using  . envp2: an environment list that can be freed using   (e.g., as returned from  s), or  _# for an empty environment list variable8: the environment variable to set, must not contain '=' value': the value for to set the variable to  overwrite6: whether to change the variable if it already exists Returns:1 the updated environment list. Free it using  . envp0: an environment list (eg, as returned from  s), or  _# for an empty environment list variable": the environment variable to get Returns:+ the value of the environment variable, or  _/ if the environment variable is not set in envp&. The returned string is owned by envp, and will be freed if variable is set or unset again. domain$: the translation domain to use, or  _ to use the domain set with  textdomain() context: the message context msgid: the message Returns: The translated string domain$: the translation domain to use, or  _ to use the domain set with  textdomain()  msgctxtidM: a combined message context and message id, separated by a \004 character  msgidoffset": the offset of the message id in msgctxid Returns: The translated string v: a pointer to a gdouble key Returns:( a hash value corresponding to the key. v1: a pointer to a gdouble key v2: a pointer to a gdouble key to compare with v1 Returns:  Y if the two keys match. domain$: the translation domain to use, or  _ to use the domain set with  textdomain() msgid: message to translate  msgidPlural: plural form of the message n/: the quantity for which translation is needed Returns: The translated string v: a gpointer key Returns:( a hash value corresponding to the key. v1: a key v2: a key to compare with v1 Returns:  Y if the two keys match. domain$: the translation domain to use, or  _ to use the domain set with  textdomain() msgid: message to translate Returns: The translated string domain$: the translation domain to use, or  _ to use the domain set with  textdomain() msgid: message to translate category: a locale category Returns:5 the translated string for the given locale category datasetLocation(: the location identifying the dataset. keyId: the GQuark" id to identify the data element. data: the data element.  destroyFunc: the function to call when the data element is removed. This function will be called with the data element and can be used to free any memory allocated for it. datasetLocation(: the location identifying the dataset. keyId: the GQuark" ID identifying the data element. Returns: the data previously stored at keyId, or  _ if none. datasetLocation(: the location identifying the dataset. keyId: the GQuark" id to identify the data element. Returns:' the data element corresponding to the GQuark, or  _ if it is not found. datasetLocation(: the location identifying the dataset. datalist,: pointer to the location that holds a list flagsE: the flags to turn off. The values of the flags are restricted by E2C (currently 3: giving two possible boolean flags). A value for flags1 that doesn't fit within the mask is an error. datalist,: pointer to the location that holds a list flagsD: the flags to turn on. The values of the flags are restricted by E2C (currently 3; giving two possible boolean flags). A value for flags1 that doesn't fit within the mask is an error. datalist(: a pointer to a pointer to a datalist. datalist: a datalist. keyId: the GQuark to identify the data element. data: the data element or  _8 to remove any previous element corresponding to keyId.  destroyFunc: the function to call when the data element is removed. This function will be called with the data element and can be used to free any memory allocated for it. If data is  _, then  destroyFunc must also be  _. datalist: location of a datalist keyId: the GQuark identifying a data element oldval#: the old value to compare against newval#: the new value to replace it with destroy#: destroy notify for the new value  oldDestroy(: destroy notify for the existing value Returns:  Y if the existing value for keyId was replaced by newval,  X otherwise. datalist: a datalist. keyId: the GQuark identifying a data element. Returns: the data previously stored at keyId, or  _ if none. datalist: a datalist. keyId: the GQuark identifying a data element. Returns: the data element, or  _ if it is not found. datalist,: pointer to the location that holds a list Returns: the flags of the datalist datalist: a datalist. key): the string identifying a data element. Returns: the data element, or  _ if it is not found. datalist: a datalist. str: the string to convert len: the length of the string in bytes, or -1 if the string is nul-terminated (Note that some encodings may allow nul bytes to occur inside strings. In that case, using -1 for the len parameter is unsafe)  converter: conversion descriptor from g_iconv_open()  bytesReadq: location to store the number of bytes in the input string that were successfully converted, or  __. Even if the conversion was successful, this may be less than lenh if there were partial characters at the end of the input. If the error  G_CONVERT_ERROR_ILLEGAL_SEQUENCEt occurs, the value stored will the byte offset after the last valid input sequence.  bytesWritteng: the number of bytes stored in the output buffer (not including the terminating nul). Returns: If the conversion was successful, a newly allocated nul-terminated string, which must be freed with  y . Otherwise  _ and error will be set.  (Can throw \]) str: the string to convert len: the length of the string in bytes, or -1 if the string is nul-terminated (Note that some encodings may allow nul bytes to occur inside strings. In that case, using -1 for the len parameter is unsafe)  toCodeset.: name of character set into which to convert str  fromCodeset: character set of str. fallback: UTF-8 string to use in place of character not present in the target encoding. (The string must be representable in the target encoding). If  _w, characters not in the target encoding will be represented as Unicode escapes \uxxxx or \Uxxxxyyyy.  bytesReadp: location to store the number of bytes in the input string that were successfully converted, or  _]. Even if the conversion was successful, this may be less than lenJ if there were partial characters at the end of the input.  bytesWrittenf: the number of bytes stored in the output buffer (not including the terminating nul). Returns: If the conversion was successful, a newly allocated nul-terminated string, which must be freed with  y . Otherwise  _ and error will be set.  (Can throw \]) str: the string to convert len: the length of the string in bytes, or -1 if the string is nul-terminated (Note that some encodings may allow nul bytes to occur inside strings. In that case, using -1 for the len parameter is unsafe)  toCodeset.: name of character set into which to convert str  fromCodeset: character set of str. Returns: If the conversion was successful, a newly allocated nul-terminated string, which must be freed with  y . Otherwise  _ and error will be set.  (Can throw \])  digestType: a @ to use for the HMAC key: the key to use in the HMAC str%: the string to compute the HMAC for lengthB: the length of the string, or -1 if the string is nul-terminated Returns:P the HMAC as a hexadecimal string. The returned string should be freed with  y when done using it.  digestType: a @ to use for the HMAC key: the key to use in the HMAC data%: binary blob to compute the HMAC of Returns:d the HMAC of the binary data as a string in hexadecimal. The returned string should be freed with  y when done using it.  digestType: a @ to use for the HMAC key: the key to use in the HMAC data%: binary blob to compute the HMAC of Returns:d the HMAC of the binary data as a string in hexadecimal. The returned string should be freed with  y when done using it.  checksumType: a @ str(: the string to compute the checksum of lengthD: the length of the string, or -1 if the string is null-terminated. Returns:R the checksum as a hexadecimal string. The returned string should be freed with  y when done using it.  checksumType: a @ data': binary blob to compute the digest of Returns:f the digest of the binary data as a string in hexadecimal. The returned string should be freed with  y when done using it.  checksumType: a @ data': binary blob to compute the digest of Returns:f the digest of the binary data as a string in hexadecimal. The returned string should be freed with  y when done using it. fd: A file descriptor  (Can throw \])  (Can throw \]) pid: process to watch. On POSIX the positive pid of a child process. On Windows a handle for a process (which doesn't have to be a child). Returns:& the newly-created child watch source priorityZ: the priority of the idle source. Typically this will be in the range between E and E0. pid: process to watch. On POSIX the positive pid of a child process. On Windows a handle for a process (which doesn't have to be a child). function: function to call Returns:. the ID (greater than 0) of the event source.  requiredMajor: the required major version  requiredMinor: the required minor version  requiredMicro: the required micro version Returns:  _ if the GLib library is compatible with the given version, or a string describing the version mismatch. The returned string is owned by GLib and must not be modified or freed. pathC: a pathname in the GLib file name encoding (UTF-8 on Windows) Returns:( 0 on success, -1 if an error occurred.  separator7: a string used to separator the elements of the path. args:  _?-terminated array of strings containing the path elements. Returns:6 a newly-allocated string that must be freed with  y. args:  _?-terminated array of strings containing the path elements. Returns:6 a newly-allocated string that must be freed with  y. address: a pointer to an integer lockBit: a bit value between 0 and 31 address: a pointer to an integer lockBit: a bit value between 0 and 31 Returns:  Y if the lock was acquired number: a guint Returns:! the number of bits used to hold number mask: a gulong containing flags nthBit0: the index of the bit to start the search from Returns:4 the index of the first bit set which is lower than nthBit$, or -1 if no lower bits are set mask: a gulong containing flags nthBit0: the index of the bit to start the search from Returns:5 the index of the first bit set which is higher than nthBit%, or -1 if no higher bits are set address: a pointer to an integer lockBit: a bit value between 0 and 31 fileName: the name of the file Returns:C the name of the file without any leading directory components data: the binary data to encode Returns:V a newly allocated, zero-terminated Base-64 encoded string representing data7. The returned string must be freed with  y. text;: zero-terminated string with base64 text to decode Returns: The binary data that text? responds. This pointer is the same as the input text. text4: zero-terminated string with base64 text to decode Returns:U newly allocated buffer containing the binary data that textB represents. The returned buffer must be freed with  y. atomic: a pointer to a gpointer -sized value val: the value to 'xor' Returns: the value of atomic before the operation, unsigned atomic: a pointer to a gpointer -sized value newval: a new value to store atomic: a pointer to a gpointer -sized value val: the value to 'or' Returns: the value of atomic before the operation, unsigned atomic: a pointer to a gpointer -sized value Returns: the value of the pointer atomic: a pointer to a gpointer -sized value oldval: the value to compare with newval*: the value to conditionally replace with Returns:  Y if the exchange took place atomic: a pointer to a gpointer -sized value val: the value to 'and' Returns: the value of atomic before the operation, unsigned atomic: a pointer to a gpointer -sized value val: the value to add Returns: the value of atomic before the add, signed atomic: a pointer to a gint or guint val: the value to 'xor' Returns: the value of atomic before the operation, unsigned atomic: a pointer to a gint or guint newval: a new value to store atomic: a pointer to a gint or guint val: the value to 'or' Returns: the value of atomic before the operation, unsigned atomic: a pointer to a gint or guint atomic: a pointer to a gint or guint Returns: the value of the integer atomic: a pointer to a gint val: the value to add Returns: the value of atomic before the add, signed atomic: a pointer to a gint or guint Returns:  Y if the resultant value is zero atomic: a pointer to a gint or guint oldval: the value to compare with newval*: the value to conditionally replace with Returns:  Y if the exchange took place atomic: a pointer to a gint or guint val: the value to 'and' Returns: the value of atomic before the operation, unsigned atomic: a pointer to a gint or guint val: the value to add Returns: the value of atomic before the add, signed func6: the function to call on normal program termination. c: an ASCII character. Returns: If c is a hex digit (according to g_ascii_isxdigit())), its numeric value. Otherwise, -1. c: any character Returns: the result of converting c to upper case. If c' is not an ASCII lower case letter, c is returned unchanged. c: any character Returns: the result of converting c to lower case. If c( is not an ASCII upper case letter, c is returned unchanged. str : a string len : length of str in bytes, or -1 if str is nul-terminated Returns:E a newly allocated string, with all the lower case characters in str@ converted to upper case, with semantics that exactly match  (. (Note that this is unlike the old  ', which modified the string in place.) nptr,: the string to convert to a numeric value. base,: to be used for the conversion, 2..36 or 0 Returns: the guint64 value or zero on error. nptr,: the string to convert to a numeric value. base,: to be used for the conversion, 2..36 or 0 Returns: the gint64 value or zero on error. nptr,: the string to convert to a numeric value. Returns: the gdouble value. s1: string to compare with s2 s2: string to compare with s1 n": number of characters to compare Returns:- 0 if the strings match, a negative value if s1 < s2, or a positive value if s1 > s2. str : a string len : length of str in bytes, or -1 if str is nul-terminated Returns:E a newly-allocated string, with all the upper case characters in str@ converted to lower case, with semantics that exactly match  (. (Note that this is unlike the old  ', which modified the string in place.) s1: string to compare with s2 s2: string to compare with s1 Returns:- 0 if the strings match, a negative value if s1 < s2, or a positive value if s1 > s2. buffer,: A buffer to place the resulting string in bufLen: The length of the buffer. format: The printf()B-style format to use for the code to use for converting. d: The gdouble to convert Returns:6 The pointer to the buffer with the converted string. buffer,: A buffer to place the resulting string in bufLen: The length of the buffer. d: The gdouble to convert Returns:6 The pointer to the buffer with the converted string. c: an ASCII character Returns: If c" is a decimal digit (according to g_ascii_isdigit()(), its numeric value. Otherwise, -1. filenameC: a pathname in the GLib file name encoding (UTF-8 on Windows) mode: as in access() Returns: zero if the pathname refers to an existing file system object that has all the tested permissions, or -1 otherwise or on error.  ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~    ~ } | { z y x w v u t s r q p o n m l k j i h g f e d c b a ` _ ^ ] \ [ Z Y X W V U T S R Q P O N M L K J I H G F E D C B A @ ? > = < ; : 9 8 7 6 5 4 3 2 1 0 / . - , + * ) ( ' & % $ # " !                            ~ } | { z y x w v u t s r q p o n m l k j i h g f e d c b a ` _ ^ ]      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789: ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~  =7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a  struct initialized to zero. Compares the ids of two Q elements, returning a negative value if the second id is greater than the first.  Destroys a , given its ID.  Removes one  from a <", marking it inactive and calling G3 on it.  Calls the <  finalizeHook? function if it exists, and frees the memory allocated for the .  Inserts a  into a <, before a given .  Prepends a  on the start of a <. $Decrements the reference count of a ). If the reference count falls to 0, the  is removed from the < and G4 is called to free it.);<=>?@A newHook: a  sibling: a  to compare with newHook Returns: a value <= 0 if the id of sibling is >= the id of newHook hookList: a < hookId : a hook ID Returns:  Y if the  was found in the < and destroyed hookList: a < hook: the  to remove hookList: a < hook: the  to free hookList: a < sibling: the  to insert the new  before hook: the  to insert hookList: a < hook: the  to add to the start of hookList hookList: a < hook: the  to unref         (;<=>?@A    <7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a  struct initialized to zero. Removes all the = elements from a . Initializes a !. This must be called before the  is used. Calls all of the = functions in a . Calls all of the = functions in a . Any function which returns  X is removed from the .BCDE             hookList: a  hookList: a  hookSize": the size of each element in the , typically sizeof (GHook). hookList: a   mayRecurse:  Y^ if functions which are already running (e.g. in another thread) can be called. If set to  X, these are skipped hookList: a   mayRecurse:  Y^ if functions which are already running (e.g. in another thread) can be called. If set to  X, these are skipped                                  BCDE                  97Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Creates a new parse context. A parse context is used to parse marked-up documents. You can feed any number of documents into a context, as long as no errors occur; once an error occurs, the parse context can't continue to parse text (you have to free it and create a new parse context). Signals to the 8 that all data has been fed into the parse context with  ".fThis function reports an error if the document isn't complete, for example if elements are still open. Frees a .5This function can't be called from inside one of the * functions or while a subparser is pushed. 1Retrieves the name of the currently open element.If called from the start_element or end_element handlers this will give the element_name as passed to those functions. For the parent elements, see *g_markup_parse_context_get_element_stack(). !&Returns the user_data associated with context.7This will either be the user_data that was provided to   or to the most recent call of  $. "Feed some data to the .The data need not be valid UTF-8; an error will be signaled if it's invalid. The data need not be an entire document; you can feed a document into the parser incrementally, via multiple calls to this function. Typically, as you receive data from a network connection or file, you feed each received chunk of data into this function, aborting the process if an error occurs. Once an error is reported, no further data may be fed to the ; all errors are fatal. #<Completes the process of a temporary sub-parser redirection.NThis function exists to collect the user_data allocated by a matching call to  $g. It must be called in the end_element handler corresponding to the start_element handler during which  $L was called. You must not call this function from the error callback -- the userData3 is provided directly to the callback in that case.This function is not intended to be directly called by users interested in invoking subparsers. Instead, it is intended to be used by the subparsers themselves to implement a higher-level interface. $2Temporarily redirects markup data to a sub-parser.EThis function may only be called from the start_element handler of a 2. It must be matched with a corresponding call to  #a in the matching end_element handler (except in the case that the parser aborts due to an error).`All tags, text and other data between the matching tags is redirected to the subparser given by parser. userData+ is used as the user_data for that parser. userData is also passed to the error callback in the event that an error occurs. This includes errors that occur in subparsers of the subparser.The end tag matching the start tag for which this call was made is handled by the previous parser (which is given its own user_data) which is why  #/ is provided to allow "one last access" to the userData6 provided to this function. In the case of error, the userDataM provided here is passed directly to the error callback of the subparser and  #* should not be called. In either case, if userDataF was allocated then it ought to be freed from both of these locations.This function is not intended to be directly called by users interested in invoking subparsers. Instead, it is intended to be used by the subparsers themselves to implement a higher-level interface.nAs an example, see the following implementation of a simple parser that counts the number of tags encountered.C code " typedef struct { gint tag_count; } CounterData; static void counter_start_element (GMarkupParseContext *context, const gchar *element_name, const gchar **attribute_names, const gchar **attribute_values, gpointer user_data, GError **error) { CounterData *data = user_data; data->tag_count++; } static void counter_error (GMarkupParseContext *context, GError *error, gpointer user_data) { CounterData *data = user_data; g_slice_free (CounterData, data); } static GMarkupParser counter_subparser = { counter_start_element, NULL, NULL, NULL, counter_error };dIn order to allow this parser to be easily used as a subparser, the following interface is provided:C code  void start_counting (GMarkupParseContext *context) { CounterData *data = g_slice_new (CounterData); data->tag_count = 0; g_markup_parse_context_push (context, &counter_subparser, data); } gint end_counting (GMarkupParseContext *context) { CounterData *data = g_markup_parse_context_pop (context); int result; result = data->tag_count; g_slice_free (CounterData, data); return result; },The subparser would then be used as follows:C code r static void start_element (context, element_name, ...) { if (strcmp (element_name, "count-these") == 0) start_counting (context); // else, handle other tags... } static void end_element (context, element_name, ...) { if (strcmp (element_name, "count-these") == 0) g_print ("Counted %d tags\n", end_counting (context)); // else, handle other tags... } %$!Increases the reference count of context. &$!Decreases the reference count of context4. When its reference count drops to 0, it is freed.FGHIJKLMNOP  parser: a  flags: one or more >5 userData: user data to pass to  functions userDataDnotifyH: user data destroy notifier called when the parse context is freed Returns: a new  context: a   (Can throw \]) context: a  context: a  Returns:, the name of the currently open element, or  _ !context: a  Returns:h the provided user_data. The returned data belongs to the markup context and will be freed when   is called. "context: a  text: chunk of text to parse textLen : length of text in bytes  (Can throw \]) #context: a  Returns: the user data passed to  $ $context: a  parser: a  userData: user data to pass to  functions %context: a  Returns: the same context &context: a  '      ! " # $ % &     !  " # $ % &FGHIJKLMNOP     ! " # $ % & '67Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ )Adds a 5 to the context, so that parsing with contextT will recognize the options in the group. Note that this will take ownership of the group and thus the group should not be freed. *PA convenience function which creates a main group if it doesn't exist, adds the entries' to it and sets the translation domain. +=Frees context and all the groups which have been added to it.CPlease note that parsed arguments need to be freed separately (see 6). , Returns the description. See  5. -`Returns a formatted, translated help text for the given context. To obtain the text produced by --help, call /g_option_context_get_help (context, TRUE, NULL)!. To obtain the text produced by  --help-all, call 0g_option_context_get_help (context, FALSE, NULL)4. To obtain the help text for an option group, call 1g_option_context_get_help (context, FALSE, group). .Returns whether automatic --help generation is turned on for context. See  6. /8Returns whether unknown options are ignored or not. See  7. 0'Returns a pointer to the main group of context. 1,-Returns whether strict POSIX code is enabled.See  9 for more information. 2 Returns the summary. See  :. 3PParses the command line arguments, recognizing options which have been added to context1. A side-effect of calling this function is that G7 will be called.RIf the parsing is successful, any parsed arguments are removed from the array and argc and argv9 are updated accordingly. A '--' option is stripped from argv} unless there are unparsed options before and after it, or some of the options after it start with '-'. In case of an error, argc and argv are left unmodified. If automatic --help support is enabled (see  6 ), and the argvn array contains one of the recognized help options, this function will produce help output to stdout and call exit (0).Note that function depends on the [current locale][setlocale] for automatic character set conversion of string and filename arguments. 4("Parses the command line arguments.This function is similar to  3 except that it respects the normal memory rules when dealing with a strv instead of assuming that the passed-in array is the argv of the main function.TIn particular, strings that are removed from the arguments list will be freed using GM.MOn Windows, the strings are expected to be in UTF-8. This is in contrast to  3R which expects them to be in the system codepage, which is how they are passed as argv to main(). See g_win32_get_command_line() for a solution.1This function is useful if you are trying to use  with  GApplication. 5 !Adds a string to be displayed in --helpT output after the list of options. This text often includes a bug reporting address.)Note that the summary is translated (see  ;). 6,Enables or disables automatic generation of --help output. By default,  3 recognizes --help, -h, -?,  --help-all and --help-groupname' and creates suitable output to stdout. 7\Sets whether to ignore unknown options or not. If an argument is ignored, it is left in the argv" array after parsing. By default,  3! treats unknown options as error.This setting does not affect non-option arguments (i.e. arguments which don't start with a dash). But note that GOption cannot reliably determine whether a non-option belongs to a preceding unknown option. 8Sets a 5 as main group of the context&. This has the same effect as calling  )d, the only difference is that the options in the main group are treated differently when generating --help output. 9,Sets strict POSIX mode."By default, this mode is disabled.In strict POSIX mode, the first non-argument parameter encountered (eg: filename) terminates argument processing. Remaining arguments are treated as non-options and are not attempted to be parsed.If strict POSIX mode is disabled then parsing is done in the GNU way where option arguments can be freely mixed with non-options.As an example, consider "ls foo -l". With GNU style parsing, this will list "foo" in long mode. In strict POSIX style, this will list the files named "foo" and "-l".It may be useful to force strict POSIX mode when creating "verb style" command line tools. For example, the "gsettings" command line tool supports the global option "--schemadir" as well as many subcommands ("get", "set", etc.) which each have their own set of arguments. Using strict POSIX mode will allow parsing the global options up to the verb name while leaving the remaining options to be parsed by the relevant subcommand (which can be determined by examining the verb name, which should be present in argv[1] after parsing). : !Adds a string to be displayed in --help] output before the list of options. This is typically a summary of the program functionality.)Note that the summary is translated (see  ; and  <). ; TSets the function which is used to translate the contexts user-visible strings, for --help output. If func is  _, strings are not translated.]Note that option groups have their own translation functions, this function only affects the parameterString (see g_option_context_new()), the summary (see  :) and the description (see  5).If you are using  gettext()3, you only need to set the translation domain, see  <. < A convenience function to use  gettext()& for translating user-visible strings.,QRSTUVWXYZ[\]^_`abcd ( )context: a  group: the group to add *context: a  entries: a  _-terminated array of  GOptionEntrys translationDomain5: a translation domain to use for translating the --help output for the options in entries with  gettext(), or  _ +context: a  ,context: a  Returns: the description -context: a  mainHelp: if  Y, only include the main group group: the 5 to create help for, or  _ Returns:3 A newly allocated string containing the help text .context: a  Returns:  Y, if automatic help generation is turned on. /context: a  Returns:  Y! if unknown options are ignored. 0context: a  Returns: the main group of context, or  _ if context8 doesn't have a main group. Note that group belongs to context& and should not be modified or freed. 1context: a GoptionContext Returns:  Y if strict POSIX is enabled,  X otherwise. 2context: a  Returns: the summary 3context: a  argv3: a pointer to the array of command line arguments  (Can throw \]) 4context: a   argumentsQ: a pointer to the command line arguments (which must be in UTF-8 on Windows)  (Can throw \]) 5context: a   description: a string to be shown in --help( output after the list of options, or  _ 6context: a   helpEnabled:  Y to enable --help,  X to disable it 7context: a   ignoreUnknown:  Y to ignore unknown options,  X5 to produce an error when unknown options are met 8context: a  group!: the group to set as main group 9context: a GoptionContext  strictPosix: the new value :context: a  summary: a string to be shown in --help( output before the list of options, or  _ ;context: a  func: the F8, or  _ <context: a  domain: the domain to use = ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; <+QRSTUVWXYZ[\]^_`abcd ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < =57Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ ?Creates a new . @Adds the options specified in entries to group. AFrees a @. Note that you must not free groups which have been added to a 6. B,"Increments the reference count of group by one. CGSets the function which is used to translate user-visible strings, for --help, output. Different groups can use different GTranslateFuncs. If func is  _, strings are not translated.If you are using  gettext()3, you only need to set the translation domain, see  D. DA convenience function to use  gettext()& for translating user-visible strings. E,"Decrements the reference count of group0 by one. If the reference count drops to 0, the group0 will be freed. and all memory allocated by the group is released.efghijkl > ?namec: the name for the option group, this is used to provide help for the options in this group with --help-name  description0: a description for this group to be shown in --help`. This string is translated using the translation domain or translation function of the group helpDescription: a description for the --help-namei option. This string is translated using the translation domain or translation function of the group userDatag: user data that will be passed to the pre- and post-parse hooks, the error hook and to callbacks of @ options, or  _ destroy): a function that will be called to free userData, or  _ Returns:9 a newly created option group. It should be added to a 6 or freed with  E. @group: a  entries: a  _-terminated array of  GOptionEntrys Agroup: a  Bgroup: a  Returns: a  GoptionGroup Cgroup: a  func: the F8, or  _ Dgroup: a  domain: the domain to use Egroup: a  F  > ? @ A B C D E  > @ A ? B C D Eefghijkl > ? @ A B C D E F37Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ G Construct a  struct initialized to zero. jnReturns the current line in the input stream (counting from 1). This is the line of the last token parsed via  o. kvReturns the current position in the current line (counting from 0). This is the position of the last token parsed via  o. l0Gets the current token type. This is simply the token field in the  structure. mFrees all memory used by the . nReturns  Y? if the scanner has reached the end of the file or text buffer. o Parses the next token just like  sL and also removes it from the input stream. The token data is placed in the token, value, line, and position fields of the  structure. pPrepares to scan a file. qPrepares to scan a text buffer. rnLooks up a symbol in the current scope and return its value. If the symbol is not bound in the current scope,  _ is returned. sbParses the next token, without removing it from the input stream. The token data is placed in the  nextToken,  nextValue, nextLine, and  nextPosition fields of the  structure.WNote that, while the token is not removed from the input stream (i.e. the next call to  of will return the same token), it will not be reevaluated. This can lead to surprising results when changing scope or the scanner configuration after peeking the next token. Getting the next token after switching the scope or configuration will return whatever was peeked before, regardless of any symbols that may have been added or removed in the new scope. t!Adds a symbol to the given scope. u\Looks up a symbol in a scope and return its value. If the symbol is not bound in the scope,  _ is returned. vRemoves a symbol from a scope. wSets the current scope. xRewinds the filedescriptor to the current buffer position and blows the file read ahead buffer. This is useful for third party uses of the scanners filedescriptor, which hooks onto the current scanning position. yOutputs a message through the scanner's msg_handler, resulting from an unexpected token in the input stream. Note that you should not call  s followed by  y! without an intermediate call to  o, as  y_ evaluates the scanner's current token (not the peeked token) to construct part of the message.Gmnopqrstuvwxyz{| G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i jscanner: a  Returns: the current line kscanner: a  Returns:" the current position on the line lscanner: a  Returns: the current token type mscanner: a  nscanner: a  Returns:  YC if the scanner has reached the end of the file or text buffer oscanner: a  Returns: the type of the token pscanner: a  inputFd: a file descriptor qscanner: a  text: the text buffer to scan textLen : the length of the text buffer rscanner: a  symbol: the symbol to look up Returns: the value of symbol in the current scope, or  _ if symbol# is not bound in the current scope sscanner: a  Returns: the type of the token tscanner: a  scopeId: the scope id symbol: the symbol to add value: the value of the symbol uscanner: a  scopeId: the scope id symbol: the symbol to look up Returns: the value of symbol in the given scope, or  _ if symbol" is not bound in the given scope. vscanner: a  scopeId: the scope id symbol: the symbol to remove wscanner: a  scopeId: the new scope id Returns: the old scope id xscanner: a  yscanner: a   expectedToken: the expected token identifierSpecH: a string describing how the scanner's user refers to identifiers ( _0 defaults to "identifier"). This is used if  expectedToken is @9 or @:.  symbolSpecD: a string describing how the scanner's user refers to symbols ( _, defaults to "symbol"). This is used if  expectedToken is @;% or any token value greater than  G_TOKEN_LAST.  symbolNameJ: the name of the symbol, if the scanner's current token is a symbol. messageE: a message string to output at the end of the warning/error, or  _. isError: if  Y it is output as an error. If  X it is output as a warning. z {5 G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y5 G H j k l m n o p q r s t u v w x y X V W R P Q \ ] L M i g h c d e f ` a b N O ^ _ U S T Y Z K I J [Fmnopqrstuvwxyz{| G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z {07Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^" | Construct a w struct initialized to zero. ~Creates a new wL structure. The size is specified to allow creating structures derived from wC that contain additional data. The size passed in must be at least sizeof (GSource).5The source will not initially be associated with any W and must be added to one with   before it will be executed. Adds  childSource to source as a "polled" source; when source is added to a W,  childSource: will be automatically added with the same priority, when  childSource is triggered, it will cause sourceA to dispatch (in addition to calling its own callback), and when source is destroyed, it will destroy  childSource as well. (source] will also still be dispatched if its own prepare/check functions indicate that it is ready.)If you don't need  childSource: to do anything on its own when it triggers, you can call g_source_set_dummy_callback(): on it to set a callback that does nothing (except return  Y if appropriate).source will hold a reference on  childSource while  childSource is attached to it.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create. lAdds a file descriptor to the set of file descriptors polled for this source. This is usually combined with  ~S to add an event source. The event source's check function will typically test the revents field in the 4 struct and return  Y if events need to be processed.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create.Using this API forces the linear scanning of event sources on each main loop iteration. Newly-written event sources should try to use   instead of this API. $ Monitors fd for the IO events in events.aThe tag returned by this function can be used to remove or modify the monitoring of the fd using   or  .gIt is not necessary to remove the fd before destroying the source; it will be cleaned up automatically.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create.@As the name suggests, this function is not available on Windows. Adds a w to a contextG so that it will be executed within that context. Remove it by calling  . Removes a source from its W, if any, and mark it as destroyed. The source cannot be subsequently added to another context. It is safe to call this on sources which have already been removed from their context. AChecks whether a source is allowed to be called recursively. see  .  Gets the W% with which the source is associated.IYou can call this on a source that has been destroyed, provided that the WD it was attached to still exists (in which case it will return that WP). In particular, you can always call this function on the source returned from G<.. But calling this function on a source whose W has been destroyed is an error. This function ignores source and is otherwise the same as Gh. Returns the numeric ID for a particular source. The ID of a source is a positive integer which is unique within a particular main loop context. The reverse mapping from ID to source is done by =. NGets a name for the source, used in debugging and profiling. The name may be NULL if it has never been set with  . Gets the priority of a source. Gets the "ready time" of source , as set by  .pAny time before the current monotonic time (including 0) is an indication that the source will fire immediately. hGets the time to be used when checking this source. The advantage of calling this function over calling G> directly is that when checking multiple sources, GLib can cache a single value instead of having to repeatedly get the system monotonic time.oThe time here is the system monotonic time, if available, or some other reasonable alternative otherwise. See G>.  Returns whether source has been destroyed.This is important when you operate upon your objects from within idle handlers, but may have freed the object before the dispatch of your idle handler.C code  static gboolean idle_callback (gpointer data) { SomeWidget *self = data; GDK_THREADS_ENTER (); // do stuff with self self->idle_id = 0; GDK_THREADS_LEAVE (); return G_SOURCE_REMOVE; } static void some_widget_do_stuff_later (SomeWidget *self) { self->idle_id = g_idle_add (idle_callback, self); } static void some_widget_finalize (GObject *object) { SomeWidget *self = SOME_WIDGET (object); if (self->idle_id) g_source_remove (self->idle_id); G_OBJECT_CLASS (parent_class)->finalize (object); }This will fail in a multi-threaded application if the widget is destroyed before the idle handler fires due to the use after free in the callback. A solution, to this particular problem, is to check to if the source has already been destroy within the callback.C code  static gboolean idle_callback (gpointer data) { SomeWidget *self = data; GDK_THREADS_ENTER (); if (!g_source_is_destroyed (g_main_current_source ())) { // do stuff with self } GDK_THREADS_LEAVE (); return FALSE; } $9Updates the event mask to watch for the fd identified by tag.tag is the tag returned from  .LIf you want to remove a fd, don't set its event mask to zero. Instead, call  .;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create.@As the name suggests, this function is not available on Windows. $8Queries the events reported for the fd corresponding to tag on source during the last poll.wThe return value of this function is only defined when the function is called from the check or dispatch functions for source.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create.@As the name suggests, this function is not available on Windows. 1Increases the reference count on a source by one.  Detaches  childSource from source and destroys it.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create. RRemoves a file descriptor from the set of file descriptors polled for this source.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create. $*Reverses the effect of a previous call to  .You only need to call this if you want to remove an fd from being watched while keeping the same source around. In the normal case you will just want to destroy the source.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create.@As the name suggests, this function is not available on Windows. qSets the callback function for a source. The callback for a source is called from the source's dispatch function.The exact type of func< depends on the type of source; ie. you should not count on func being called with data as its first parameter.qSee [memory management of sources][mainloop-memory-management] for details on how to handle memory management of data.kTypically, you won't use this function. Instead use functions specific to the type of source you are using. zSets the callback function storing the data as a refcounted callback "object". This is used internally. Note that calling  ' assumes an initial reference count on  callbackData , and thus  callbackFuncs1->unref will eventually be called once more than  callbackFuncs->ref. 4Sets whether a source can be called recursively. If  canRecurse is  Y, then while the source is being dispatched then this source will be processed normally. Otherwise, all processing of this source is blocked until the dispatch function returns.  dSets the source functions (can be used to override default implementations) of an unattached source. RSets a name for the source, used in debugging and profiling. The name defaults to NULL.The source name should describe in a human-readable way what the source does. For example, "X11 event queue" or "GTK+ repaint idle handler" or whatever it is.It is permitted to call this function multiple times, but is not recommended due to the potential performance impact. For example, one could change the name in the "check" function of a ?; to include details like the event type in the source name.OUse caution if changing the name while another thread may be accessing it with  ; that function does not copy the value, and changing the value will free it while the other thread may be attempting to use it. Sets the priority of a source. While the main loop is being run, a source will be dispatched if it is ready to be dispatched and no sources at a higher (numerically smaller) priority are ready to be dispatched.A child source always has the same priority as its parent. It is not permitted to change the priority of a source once it has been added as a child of another source. $Sets a w to be dispatched when the given monotonic time is reached (or passed). If the monotonic time is in the past (as it always will be if  readyTime6 is 0) then the source will be dispatched immediately.If  readyTimeM is -1 then the source is never woken up on the basis of the passage of time.tDispatching the source does not reset the ready time. You should do so yourself, from the source dispatch function.5Note that if you have a pair of sources where the ready time of one suggests that it will be delivered first but the priority for the other suggests that it would be delivered first, and the ready time for both sources is reached during the same main context iteration then the order of dispatch is undefined.;This API is only intended to be used by implementations of w. Do not call this API on a w that you did not create. Decreases the reference count of a source by one. If the resulting reference count is zero the source and associated memory will be destroyed. CRemoves the source with the given id from the default main context. The id of a w is given by  ', or will be returned by the functions  ,  g_idle_add(), G@, g_timeout_add(), GA, g_child_watch_add(), GB, g_io_add_watch(), and G. See also  . You must use  1 for sources added to a non-default main context.DIt is a programmer error to attempt to remove a non-existent source.More specifically: source IDs can be reissued after a source has been destroyed and therefore it is never valid to use this function with a source ID which may have already been removed. An example is when scheduling an idle to run in another thread with  g_idle_add(): the idle may already have run and been removed by the time this function is called on its (now invalid) source ID. This source ID may have been reissued, leading to the operation being performed against the wrong source. Removes a source from the default main loop context given the source functions and user data. If multiple sources exist with the same source functions and user data, only one will be destroyed. Removes a source from the default main loop context given the user data for the callback. If multiple sources exist with the same user data, only one will be destroyed. 'Sets the name of a source using its ID.KThis is a convenience utility to set source names from the return value of  g_idle_add(), g_timeout_add(), etc.MIt is a programmer error to attempt to set the name of a non-existent source.More specifically: source IDs can be reissued after a source has been destroyed and therefore it is never valid to use this function with a source ID which may have already been removed. An example is when scheduling an idle to run in another thread with  g_idle_add(): the idle may already have run and been removed by the time this function is called on its (now invalid) source ID. This source ID may have been reissued, leading to the operation being performed against the wrong source.Iwx}~ | } ~ sourceFuncsU: structure containing functions that implement the sources behavior.  structSize: size of the w structure to create. Returns: the newly-created w. source: a w  childSource : a second w that source should "poll" source: a w fd: a 4F structure holding information about a file descriptor to watch. source: a w fd: the fd to monitor events: an event mask Returns: an opaque tag source: a w context: a W (if  _$, the default context will be used) Returns:5 the ID (greater than 0) for the source within the W. source: a w source: a w Returns: whether recursion is allowed. source: a w Returns: the W7 with which the source is associated, or  _B if the context has not yet been added to a source. source: a w timeval: #j+ structure in which to store current time. source: a w Returns:( the ID (greater than 0) for the source source: a w Returns: the name of the source source: a w Returns: the priority of the source source: a w Returns:* the monotonic ready time, -1 for "never" source: a w Returns:$ the monotonic time in microseconds source: a w Returns:  Y" if the source has been destroyed source: a w tag: the tag from    newEvents: the new event mask to watch source: a w tag: the tag from   Returns:# the conditions reported on the fd source: a w Returns: source source: a w  childSource: a w previously passed to  . source: a w fd: a 4 structure previously passed to  . source: a w tag: the tag from   source : the source func: a callback function source : the source  callbackData$: pointer to callback data "object"  callbackFuncs#: functions for reference counting  callbackData4 and getting the callback and data source: a w  canRecurse/: whether recursion is allowed for this source source: a w funcs : the new ? source: a w name: debug name for the source source: a w priority: the new priority. source: a w  readyTimei: the monotonic time at which the source will be ready, 0 for "immediately", -1 for "never" source: a w tag": the ID of the source to remove. Returns:6 For historical reasons, this function always returns  Y funcs: The  sourceFuncs passed to  ~ userData!: the user data for the callback Returns:  Y$ if a source was found and removed. userData": the user_data for the callback. Returns:  Y$ if a source was found and removed. tag: a w ID name: debug name for the source %wx | } ~  %wx | }  ~ Hwx}~ | } ~  (7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a  struct initialized to zero.    H7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a   struct initialized to zero.     7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ Creates a new J structure. nTries to become the owner of the specified context. If some other thread is the owner of the context, returns  Xu immediately. Ownership is properly recursive: the owner can require ownership again and will release ownership when   is called as many times as  .7You must be the owner of a context before you can call  ,  ,  ,  . Adds a file descriptor to the set of file descriptors polled for this context. This will very seldom be used directly. Instead a typical event source will use 0C instead. 4Passes the results of polling back to the main loop.5You must have successfully acquired the context with  # before you may call this function. Dispatches all pending sources.5You must have successfully acquired the context with  # before you may call this function. Finds a source with the given source functions and user data. If multiple sources exist with the same source function and user data, the first one found will be returned. Finds a 0 given a pair of context and ID.DIt is a programmer error to attempt to lookup a non-existent source.More specifically: source IDs can be reissued after a source has been destroyed and therefore it is never valid to use this function with a source ID which may have already been removed. An example is when scheduling an idle to run in another thread with  g_idle_add(): the idle may already have run and been removed by the time this function is called on its (now invalid) source ID. This source ID may have been reissued, leading to the operation being performed against the wrong source. Finds a source with the given user data for the callback. If multiple sources exist with the same user data, the first one found will be returned. &Invokes a function in such a way that context# is owned during the invocation of function.This function is the same as g_main_context_invoke()5 except that it lets you specify the priority incase function= ends up being scheduled as an idle and also lets you give a F for data.notifyh should not assume that it is called from any particular thread or with any particular context acquired.  GDetermines whether this thread holds the (recursive) ownership of this Jc. This is useful to know before waiting on another thread that may be blocking to get ownership of context. Runs a single iteration for the given main loop. This involves checking to see if any event sources are ready to be processed, then if no events sources are ready and mayBlock is  Y{, waiting for a source to become ready, then dispatching the highest priority events sources that are ready. Otherwise, if mayBlock is  X sources are not waited to become ready, only those highest priority events sources will be dispatched (if any), that are ready at this given moment without further waiting.Note that even when mayBlock is  Y, it is still possible for   to return  XZ, since the wait may be interrupted for other reasons than an event source becoming ready. @Checks if any sources have pending events for the given context. Pops contextV off the thread-default context stack (verifying that it was on the top of the stack). Prepares to poll sources within a main loop. The resulting information for polling is determined by calling g_main_context_query ().5You must have successfully acquired the context with  # before you may call this function.  Acquires context and sets it as the thread-default context for the current thread. This will cause certain asynchronous operations (such as most [gio][gio]-based I/O) which are started in this thread to run under context and deliver their results to its main loop, rather than running under the global default context in the main thread. Note that calling this function changes the context returned by GD, not the one returned by GE;, so it does not affect the context used by functions like  g_idle_add().XNormally you would call this function shortly after creating a new thread, passing it a J which will be run by a F in that thread, to set a new default context for all async operations in that thread. In this case you may not need to ever call  , assuming you want the new J9 to be the default for the whole lifecycle of the thread.If you don't have control over how the new thread was created (e.g. in the new thread isn't newly created, or if the thread life cycle is managed by a JVF), it is always suggested to wrap the logic that needs to use the new J inside a   /  U pair, otherwise threads that are re-used will end up never explicitly releasing the J reference they hold.In some cases you may want to schedule a single operation in a non-default context, or temporarily use a non-default context in the main thread. In that case, you can wrap the call to the asynchronous operation inside a   /   pair, but it is up to you to ensure that no other asynchronous operations accidentally get started while the non-default context is active.Beware that libraries that predate this function may not correctly handle being used from a thread with a thread-default context. Eg, see !g_file_supports_thread_contexts(). 8Determines information necessary to poll this main loop.5You must have successfully acquired the context with  # before you may call this function. #Increases the reference count on a J object by one. HReleases ownership of a context previously acquired by this thread with  W. If the context was acquired multiple times, the ownership will be released only when  , is called as many times as it was acquired. _Removes file descriptor from the set of file descriptors to be polled for a particular context. #Decreases the reference count on a JW object by one. If the result is zero, free the context and free all associated memory. <Tries to become the owner of the specified context, as with  6. But if another thread is the owner, atomically drop mutex and wait on cond. until that owner releases ownership or until cond8 is signaled, then try again (once) to become the owner. If context is currently blocking in  v waiting for a source to become ready, cause it to stop blocking and return. Otherwise, cause the next invocation of   to return without blocking..This API is useful for low-level control over JE; for example, integrating it with main loop implementations such as F.Another related use for this function is when implementing a main loop with a termination condition, computed from multiple threads:C code  #define NUM_TASKS 10 static volatile gint tasks_remaining = NUM_TASKS; ... while (g_atomic_int_get (&tasks_remaining) != 0) g_main_context_iteration (NULL, TRUE);Then in a thread:C code f perform_work(); if (g_atomic_int_dec_and_test (&tasks_remaining)) g_main_context_wakeup (NULL); Returns the global default main context. This is the main context used for main loop functions when a main loop is not explicitly specified, and corresponds to the "main" main loop. See also GD. Gets the thread-default J for this thread. Asynchronous operations that want to be able to be run in contexts other than the default one should call this method or GG to get a J to add their GSources to. (Note that even in single-threaded programs applications may sometimes want to temporarily push a non-default context, so it is not safe to assume that this will always return  _+ if you are running in the default thread.)4If you need to hold a reference on the context, use GG instead.  Gets the thread-default J for this thread, as with GD', but also adds a reference to it with  . In addition, unlike GDU, if the thread-default context is the global default context, this will return that J0 (with a ref added to it) rather than returning  _.7JK Returns: the new J context: a J Returns:  YC if the operation succeeded, and this thread is now the owner of context. context: a J (or  _ for the default context) fd: a 4F structure holding information about a file descriptor to watch. priority_: the priority for this file descriptor which should be the same as the priority used for 0W to ensure that the file descriptor is polled whenever the results may be needed. context: a J  maxPriority5: the maximum numerical priority of sources to check fds : array of !'GI.GLib.Structs.PollFD.PollFD'\',s that was passed to the last call to   Returns:  Y- if some sources are ready to be dispatched. context: a J context: a J (if  _%, the default context will be used). funcs: the  sourceFuncs passed to 0H. userData#: the user data from the callback. Returns:) the source, if one was found, otherwise  _ context: a J (if  _$, the default context will be used) sourceId : the source ID, as returned by 0I. Returns: the 0 context: a J userData": the user_data for the callback. Returns:) the source, if one was found, otherwise  _ context: a J, or  _ priority: the priority at which to run function function: function to call context: a J Returns:  Y if current thread is owner of context. context: a J (if  _$, the default context will be used) mayBlock: whether the call may block. Returns:  Y if events were dispatched. context: a J (if  _$, the default context will be used) Returns:  Y if events are pending. context: a J object, or  _ context: a J priorityR: location to store priority of highest priority source already ready. Returns:  YJ if some source is ready to be dispatched prior to polling. context: a J, or  _ for the global default context context: a J  maxPriority#: maximum priority source to check fds: location to store 4! records that need to be polled. Returns:* the number of records actually stored in fds, or, if more than nFdsL records need to be stored, the number of records that need to be stored. context: a J Returns: the context that was passed in (since 2.6) context: a J context: a J fd: a 4" descriptor previously added with   context: a J context: a J cond: a condition variable mutex: a mutex, currently held Returns:  YC if the operation succeeded, and this thread is now the owner of context. context: a J Returns:" the global default main context. Returns: the thread-default J, or  _> if the thread-default context is the global default context. Returns: the thread-default J. Unref with   when you are done with it. JK JK 6JK 7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a H struct initialized to zero.HI  HI HI HI  I7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^  Construct a   struct initialized to zero. Removes all the elements in queueU. If queue elements contain dynamically-allocated memory, they should be freed first. #Frees the memory allocated for the  . Only call this function if queue was created with  g_queue_new()U. If queue elements contain dynamically-allocated memory, they should be freed first.NIf queue elements contain dynamically-allocated memory, you should either use   or free them manually first.  9Convenience method, which frees all the memory used by a  C, and calls the specified destroy function on every element's data. Returns the number of items in queue. -Returns the position of the first element in queue which contains data. A statically-allocated  h must be initialized with this function before it can be used. Alternatively you can initialize it with  G_QUEUE_INIT8. It is not necessary to initialize queues created with  g_queue_new(). Returns  Y if the queue is empty. 'Returns the first element of the queue.  Returns the n'th element of queue. &Returns the last element of the queue. <Removes the first element of the queue and returns its data.  Removes the n'th element of queue and returns its data. ;Removes the last element of the queue and returns its data. ,Adds a new element at the head of the queue. Inserts a new element into queue at the given position. ,Adds a new element at the tail of the queue. Removes the first element in queue that contains data. &Remove all elements whose data equals data from queue. !#Reverses the order of the items in queue.4        queue: a   queue: a   queue: a pointer to a   freeFunc8: the function to be called to free each element's data queue: a   Returns: the number of items in queue queue: a   data: the data to find Returns:& the position of the first element in queue which contains data, or -1 if no element in queue contains data queue: an uninitialized   queue: a  . Returns:  Y if the queue is empty queue: a   Returns:0 the data of the first element in the queue, or  _ if the queue is empty queue: a   n: the position of the element Returns: the data for the n'th element of queue , or  _ if n is off the end of queue queue: a   Returns:/ the data of the last element in the queue, or  _ if the queue is empty queue: a   Returns:0 the data of the first element in the queue, or  _ if the queue is empty queue: a   n: the position of the element Returns: the element's data, or  _ if n is off the end of queue queue: a   Returns:/ the data of the last element in the queue, or  _ if the queue is empty queue: a  . data : the data for the new element. queue: a   data: the data for the new element n-: the position to insert the new element. If n> is negative or larger than the number of elements in the queue4, the element is added to the end of the queue. queue: a   data: the data for the new element queue: a   data: the data to remove Returns:  Y if data was found and removed from queue queue: a   data: the data to remove Returns:% the number of elements removed from queue !queue: a   " #                         !                      !    3                         ! " #7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ $ Construct a  struct initialized to zero. $ % & ' ( ) * + , - $ % & ' ( ) * + $ % ( & ' + ) *  $ % & ' ( ) * + , -7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ . Construct a  struct initialized to zero. . / 0 1 2 3 4 5 6 7 8 9 : . / 0 1 2 3 4 5 6 7 8 . / 5 3 4 8 6 7 2 0 1 . / 0 1 2 3 4 5 6 7 8 9 :J7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^ = Construct a  ; struct initialized to zero. G"Frees all resources allocated for pool.If  immediate is  Y, no new task is processed for pool . Otherwise pool is not freed before the last task is processed. Note however, that no thread of this pool is interrupted while processing a task. Instead at least all still running threads can finish their tasks before the pool is freed.If wait_ is  YO, the functions does not return before all tasks to be processed (dependent on  immediatec, whether all or only the currently running) are ready. Otherwise the function returns immediately.After calling this function pool must not be used anymore. H*Returns the maximal number of threads for pool. I3Returns the number of threads currently running in pool. J.aMoves the item to the front of the queue of unprocessed items, so that it will be processed next. KInserts data* into the list of tasks to be executed by pool.When the number of currently running threads is lower than the maximal allowed number of threads, a new thread is started (or reused) with the properties given to g_thread_pool_new() . Otherwise, dataY stays in the queue until a thread in this pool finishes its previous task and processes data.error can be  _ to ignore errors, or non- __ to report errors. An error can only occur when a new thread couldn't be created. In that case data/ is simply appended to the queue of work to do.CBefore version 2.32, this function did not return a success status. L/Sets the maximal allowed number of threads for poolJ. A value of -1 means that the maximal number of threads is unlimited. If poolY is an exclusive thread pool, setting the maximal number of threads to -1 is not allowed.Setting  maxThreads" to 0 means stopping all work for pool!. It is effectively frozen until  maxThreads" is set to a non-zero value again.+A thread is never terminated while calling func, as supplied by g_thread_pool_new()]. Instead the maximal number of threads only has effect for the allocation of new threads in  KQ. A new thread is allocated, whenever the number of currently running threads in pool$ is smaller than the maximal number.error can be  _ to ignore errors, or non- _Q to report errors. An error can only occur when a new thread couldn't be created.CBefore version 2.32, this function did not return a success status. M1Returns the number of tasks still unprocessed in pool. N &This function will return the maximum intervalO that a thread will wait in the thread pool for new tasks before being stopped.\If this function returns 0, threads waiting in the thread pool for new work are not stopped. O5Returns the maximal allowed number of unused threads. P/Returns the number of currently unused threads. Q #This function will set the maximum interval{ that a thread waiting in the pool for new tasks can be idle for before being stopped. This function is similar to calling GJA on a regular timeout, except this is done on a per thread basis. By setting interval( to 0, idle threads will not be stopped.(The default value is 15000 (15 seconds). R-Sets the maximal number of unused threads to  maxThreads. If  maxThreads< is -1, no limit is imposed on the number of unused threads.The default value is 2. SStops all currently unused threads. This does not change the maximal number of unused threads. This function can be used to regularly stop all unused threads e.g. from g_timeout_add().( ; < = > ? @ A B C D E F Gpool: a  ;  immediate : should pool shut down immediately? wait_9: should the function wait for all tasks to be finished? Hpool: a  ; Returns: the maximal number of threads Ipool: a  ; Returns:) the number of threads currently running Jpool: a  ; data": an unprocessed item in the pool Returns:  Y! if the item was found and moved Kpool: a  ; data: a new task for pool  (Can throw \]) Lpool: a  ;  maxThreads&: a new maximal number of threads for pool, or -1 for unlimited  (Can throw \]) Mpool: a  ; Returns:! the number of unprocessed tasks NReturns: the maximum interval\ (milliseconds) to wait for new tasks in the thread pool before stopping the thread OReturns:& the maximal number of unused threads PReturns:( the number of currently unused threads Qinterval: the maximum interval, (in milliseconds) a thread can be idle R maxThreads#: maximal number of unused threads S T U ; < = > ? @ A B C D E F G H I J K L M N O P Q R S ; < = > G N H O I P J K Q L R S M E F A ? @ D B C' ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T UK7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\^_`abcdefghiklmnopqrstvwxyz{|}~     "#$%&'()*+-./012345678;<=>?@ABCFGHIJKLMNOPQRSTUWXYZ[\]_`abcdefgjklmnoprstuvwxyz{~     !"$%&'()*+,-./012456789:;<=>?@CDEFGHIJKLMOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstwxyz{|}~     !"#$%& !"#$%&'()*+,-./0123456789:;<=>?@ABCFGHIJKLMNOQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                       ! " # $ % & ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < > ? @ A B C D E G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y | } ~                          ! $ % & ' ( ) * + . / 0 1 2 3 4 5 6 7 8 ; < = > ? @ A B C D E F G H I J K L M N O P Q R SKSafe*,9:;<=DRT^ V W V W V W V WL7Will Thompson, Iaki Garca Etxebarria and Jonas PlatteLGPL-2.1+Iaki Garca Etxebarria (garetxe@gmail.com)None*,9:;<=DRT^       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ `  !"#$%&'()*+,-./23456789:=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\^_`abcdefghiklmnopqrstvwxyz{|}~     "#$%&'()*+-./012345678;<=>?@ABCFGHIJKLMNOPQRSTUWXYZ[\]_`abcdefgjklmnoprstuvwxyz{~     !"$%&'()*+,-./012456789:;<=>?@CDEFGHIJKLMOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefg     !"#$%&(KLMNOPQRS)TUVWX*YZ[\]^_`+abcd,efghijklmnopqr-stuvwxyz{.|}~/0123456789:     ;< !="#$%&'(>)*+,-./0123456789:;<=>??@A@BCDEFGHIJKLMNAOPBQRSTCUVWXYZ[\]^_`abcdefghijklDmnopqErstuvwxyz{|}~F      G!"#$%&'()*+,-./0123456789:;<=>?H@ABCDEFGHIIJKLMNOPQRSTUVWXYZ[\J]^_`abcdefghijklmnopqrstuvwxyz{|}~ !"#$%&'()*+,-./0123456789:;<=>?@ABCFGHIJKLMNOQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                           ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                            ! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~                        ! " # $ % & ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < > ? @ A B C D E G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y | } ~                          ! $ % & ' ( ) * + . / 0 1 2 3 4 5 6 7 8 ; < = > ? @ A B C D E F G H I J K L M N O P Q R SMMNOPQRSTTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz^^{|}~SSLR                        n n        U           oo??      !"#$%&'()*+,-./0123456789:;<=>?@ABCCDEFGHIJKLMMNOPQRSTUVWWXYZ[\]^_`abcddefghijklm66WWFFnopqrs tuvvwxyz{{|}~        !!!!!!!!!!!!"""""""""""""""""""""""""""""""""""""""""""#j#j#######i####$$$$$$$$$$$$$$$$$$$$$$$$$%%%%%%%%%%%%%%%%%%%%%%%%g%%%%%%%%%%%%%%%%% % % % % %%%%%%&)&)&&&&',',''''(())))) *-*-*!*"*#*$*%*&*'*(*)+*+*+++,,x,x,-,.,y,/,0,1,2,3,4,5,6,7,8,9-v-v-:-;-<-=->-?-z-w-@-A-B-C-D.E.E.F.G.H.I.J.K.L.M.N.O///P/Q/R/S/T/U/V/W/X/Y/Z/[/\/]/^/_/`/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r/s/t/u001}1}1v1w1x1y1z1{2|2|2}2~222222222233444444444444556677888888888888888888899::::::::::::::;;<<==>>1>>>>>>.>>5>>>>+>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> > >>> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> > > > > >>>>>>>>>>>>>>>>>>>>>>>>>>>>>> >!>">#>$>%>&>'>(>)>*>+>,>->.>/>0>1>2>3>4>5>6>7>8>9>:>;><>=>>>?>@>A>B>C>D>E>F>G>H>I>J>K>L>M>N>O>P>Q>R>S>T>U>V>W>X>Y>Z>[>\>]>^>_>`>a>b>c>d>e>f>g>h>i>j>k>l>m>n>o>p>q>r>s>t>u>v7w7x7y7z7{7|7}7~777777777777777777777??????????????????????????????????????????????????~@a@@@@@@@d@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ @ @ @ @@@@@@@@@@@@@@@@@@@ @!@"@#@$@%@&@'@(@)@*@+@,@-@.@/@0@1@2@3@4@5@6@7@8@9@:@;@<@=@>@?@@@A@B@C@@D@E@F@G@H@I@J@K@@L@M@N@O@@@@@P@Q@R@S@T@U@V@W@@@X@Y@Z@[@\@]@^@_@`@@a@@b@@c@@d@e@f@g@h@i@@j@k@@l@@@m@n@o@p@q@r@s@t@u@v@w@x@y@z@{@|@}@~@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@;@9@:@@@@@@@@@@@@@@@@@@@@@@ @ @ @ @ @@@@@@@@@@@@@@@@@@@ @!@"@#@$@'@%@&@'@(@)@*@+@,@-@.@/@0@1@2@3@4@5@6@7@8@9@:@;@<@=@>@?@@@A@B@C@D@E@F@G@H@I@J@K@L@M@N@O@P@Q@R@S@T@U@V@W@X@Y@Z@[@\@]@^@_@`@a@(@b@c@d@e@f@g@h@i@j@k@l@m@n@o@p@q@r@s@t@u@v@w@x@y@z@{@|@}@~@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ @ @ @ @@@@@@@@@@@@@@@@@@@ @!@"@#@$@%@&@'@(@)@*@+@,@-@.@/@0@1@2@3@4@5@6@7@8@9@:@;@<@=@>@?@@@A@B@C@D@E@F@G@H@I@J@K@L@M@N@O@P@Q@R@S@T@U@V@W@X@Y@Z@[@\@]@^@_@`@a@b@c@d@e@f@g@h@i@j@k@l@m@n@o@p@q@r@s@t@u@v@w@x@y@z@{@|@}@~@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAAAAAAAXAABBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB B CCC C C CCCCCCCC !"#$%&'()D*D*D+D,D-D.D/D0D1D2D3D4D5D6D7D8D9D: ; < k l = > ? @ A B C DEEEFEGEHEIEJE2EKELEMENEOEPEQERESETEUEVEWEXEYEZE[E\E]E^E_E`EaEbEcEdEeEfEgEEhEiEjEkElEmEnEoEpEqErEsEtEuEvEwExEyEzE{E|E}E~EEEEEEEEE/EEEEEE#EEEE"EE!EEE$EE EEEEEEEEEEE%E0EEEEEEEEEEE*EEEEEEEEEEEEEEEEEEFFFFFFFmFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF F F F F F F F F F F F F F F F F F F F F F FF F F F F F F F F F F F !F "F #F $F %F &F 'F (F )F *F +F ,FF -F .F /F 0F 1F 2F 3F 4F 5F 6F 7F 8F 9F :F ;F <F =F >F ?F @F AF BF CF8F DF EF FF GF&F HF IF JF KF LF MF NF OF PF QF RF SF TF UF VF WF XF YF ZF [F \F ]F ^F _F `F aF bF cF dF eF fF gF hF iF jF kF lF mF nF oF pF qF rF sF tF uF vF wF xF yF zF {F |F }F ~F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F !F "F #F $F %F &F 'F (F )F *F +F ,F -F .F /F 0F 1F 2F 3F 4F 5F 6F 7F 8F 9F :F ;F <F =F >F ?F @F AF BF CF DF EF FF GF HF IF JF KF LF MF NF OF PF QF RF SF TF UF VF WF XF YF ZF [F \F ]F ^F _F `F aF bF cF dF eF fF gF hF iF jF kF lF mF nF oF pF qF rF sF tF uF vF wF xF yF zF {F |F }F ~F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F F G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G GG G G G G G G G G G G G G G G GAGG G GG G G G G G G G G G G G G G G G G G G G G G G G G G G !G "G #G $G %G &G 'G (G )G *G +G ,G -G .G /G 0G 1G 2G 3G 4GfG 5G 6GuG 7GG 8G 9G :G ;G <G =G >G ?G @G AG BG CG DG EG FGG GG HG IG JG KG LGGG MG NG OG PG QG RG SG TG UG VG WG XG YG ZG7G [G \G ]G ^G _GtG `G aG bG cG dG eG fG gG hG iG jG kG lG mG nG oG pG qG rG sG tG uG vG wG xG yG zGZG {G[G |G }G ~G G G G G G GsGrG G<G G G G G G G G G GG G G GqG G G GG G G G G G G G G@G G G G G G G GG G GbG G GYGcG G G G`G G>G G G G G G GhG G GG_GMGG GG G G G G G G GGeG G G G G G G G G G G G G G G G G G G G G G GG G G G G G G G G G G GpG G G G G G G G G GBG G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G G|G{G GG G G G G G GG G = = = = = = = = = = = = = = != "= #= $= %= &= '= (= )= *= += ,= -=4= .= /=3= 0= 1< 2< 3< 4< 5< 6< 7< 8< 9< :< ;< << =< >< ?< @< A< B< C< D< E< F< G< H9 I9 J9 K9 L9 M9 N9 O9 P9 Q9 R9 S9 T6 U6 V6 W6 X6 Y6 Z6 [6 \6 ]6 ^6 _6 `6 a6 b6 c66 d6 e6 f6 g6 h6 i5 j55 k5 l5 m55 n5 o5 p3 q3 r3 s3 t3 u3 v3 w3 x3 y3 z3 {3 |3 }3 ~3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 33 3 3 3 3 3 3 3 3 3 3 3 0 0 0H0 0 0C00 0 0 0 0I0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 00 0 0 0 0 ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( HHH H H H H H H H H H H H H H H H H H H H H H H H H H H H       =              EDG                    I I I I !I "I #I $I %I &I 'I (I )I *I +I ,I -I .I /I 0I 1I 2I 3I 4I 5I 6I 7I 8I 9I :I ;I <I =I > ? @ A B C D E F G H I J K L M N O P Q R S T UJVJVJ VJ WJ XJ YJ ZJ [J \J ]J ^J _J `J aJ bJ cJ dJ eJ fJ gJ hJ iJ jJ kJJJ lJ mK nK o p q r p q s t u v w x y z { | } ~                                                                                                     ! ! ! ! !!"""""""" " " " " """"""""""""""""""" "!"""#"$"%"&"'"(#)#*#+$,$-$.$/$0$1$2$3$4$5$6$7$8$9$:$;$<$=$>$?$@%A%B%C%D%E%F%G%H%I%J%K%L%M%N%O%P%Q%R%S%T%U%V%W%X%Y%Z%[%\%]%^%_%`%a%b%c%d%e%f%g%h%i%j%k%l%m%n%o%p&q&r's't)u,v,w,x,y,z,{,|,},~,,,,------.........////////////////////////////1111222222222248888888888888888>7777777777???????????????????????????????????????????????      |\];!;";#;$;%;&;';(;);*;+;,;-;.;/;0;1;2;3;4;5;6;7;8;9;:;;;<;=;>;?;@;A;B;CADAEAFAGAHAIAJAKBLBMBNBOBPBQBRBSBTBUBVBWBXBYBZB[B\B]B^B_B`BaBbBcBdBeBfBgBhBiBjBkBlBmBnBoBpBqBrBsBtBuBvBwBxByBzB{B|C}C~D           FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGG G G G G GGGGGGGGGGGGGGGGGGG G!G"G#G$G%G&G'G(G)G*G+G,G-G.G/G0G1G2G3G4G5G6G7G8G9G:G;G<G=G>G?G@GAGBGCGDGEGFGGGHGIGJGKGLGMGNGOGPGQGRGSGTGUGVGWGXGYGZG[G\G]G^G_G`GaGbGcGdGeGfGgGhGiGjGkGlGmGnGoGpGqGrGsGtGuGvGwGxGyGzG{G|G}G~GGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGG G G G G GGGGGGGGGGGGGGGGGGG G!G"G#G$G%G&G'G(G)G*G+G,G-G.G/G0G1G2G3G4G5G6G7G8G9G:G;G<G=G>G?G@GAGBGCGDGEGFGGGHGIGJGKGLGMGNGOGPGQGRGSGTGUGVGW=X=Y=Z=[=\=]=^<_<`<a<b9c9d9e9f9g9h9i9j9k9l9m6n6o6p6q6r6s6t6u6v6w6x6y6z6{6|6}6~6665555555533333333333333330000000000000000000000000000000000IIIIIIIIIIIIIIIIIIIJJJJJJJJJJJJJ | | | | | | | | | | | | | | | | | | |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | ! | " | # | $ | % | & | ' | ( | ) | * | + | , | - | . | / | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | : | ; | < | = | > | ? | @ | A | B | C | D | D | E | E | F | G | H | H |IJ |IJ |IK |IL |IM |\N |\O |\P |\Q |\R |\S |\T |\U |\V |\W |\X |\] |\Y |\Z |\[ |\\ |\] |^_ |^` |^a |^b |^c |^d |^e |^f |^g |^h |^i |^j |^k |^l |^m |^n |^o |^p |^q |^r |^s |^t |^u |^v |^w |^x |^y |^z |^{ |^| |^} |^~ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ |^ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } ~ | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | } | | | | | | | | | | | | | | | | | | | |%gi-glib-2.0.13-BojtDyMc9lNC5R9MiCKrwnGI.GLib.Unions.FloatIEEE754GI.GLib.Unions.DoubleIEEE754GI.GLib.Unions.TokenValueGI.GLib.Unions.MutexGI.GLib.Structs.VariantTypeGI.GLib.Structs.VariantDictGI.GLib.Structs.VariantBuilderGI.GLib.Structs.TreeGI.GLib.Structs.TrashStackGI.GLib.Structs.TimerGI.GLib.Structs.TimeZoneGI.GLib.Structs.ThreadGI.GLib.Structs.TestLogBufferGI.GLib.Structs.TestConfigGI.GLib.Structs.TestCaseGI.GLib.Structs.StringChunkGI.GLib.Structs.StatBufGI.GLib.Structs.SourceFuncs#GI.GLib.Structs.SourceCallbackFuncsGI.GLib.Structs.ScannerConfigGI.GLib.Structs.RegexGI.GLib.Structs.RecMutexGI.GLib.Structs.RandGI.GLib.Structs.RWLockGI.GLib.Structs.PtrArrayGI.GLib.Structs.OptionEntryGI.GLib.Structs.MarkupParserGI.GLib.Structs.MainContextGI.GLib.Structs.MainLoopGI.GLib.Structs.HmacGI.GLib.Structs.HashTableIterGI.GLib.Structs.DirGI.GLib.Structs.CondGI.GLib.Structs.BookmarkFileGI.GLib.Structs.TimeValGI.GLib.Structs.AsyncQueueGI.GLib.Structs.DateTimeGI.GLib.Structs.TestSuiteGI.GLib.Structs.PatternSpecGI.GLib.Structs.MemVTableGI.GLib.Structs.IConvGI.GLib.Structs.DebugKeyGI.GLib.Structs.DataGI.GLib.Structs.BytesGI.GLib.Structs.ByteArrayGI.GLib.Structs.MappedFileGI.GLib.Structs.StringGI.GLib.Structs.SourceGI.GLib.Structs.SequenceIterGI.GLib.Structs.SequenceGI.GLib.Structs.ScannerGI.GLib.Structs.PollFDGI.GLib.Structs.OptionGroupGI.GLib.Structs.OptionContextGI.GLib.Structs.NodeGI.GLib.Structs.MatchInfo"GI.GLib.Structs.MarkupParseContextGI.GLib.Structs.LogFieldGI.GLib.Structs.IOChannelGI.GLib.Structs.HookListGI.GLib.Structs.Hook GI.GLib.FlagsGI.GLib.Structs.KeyFile GI.GLib.EnumsGI.GLib.Structs.ChecksumGI.GLib.Structs.DateGI.GLib.Structs.OnceGI.GLib.Structs.TestLogMsgGI.GLib.ConstantsGI.GLib.CallbacksGI.GLib.FunctionsGI.GLib.Structs.IOFuncsGI.GLib.Structs.QueueGI.GLib.Structs.ThreadPoolGI.GLib.PkgInfovariantTypeStringIsValidfreeGI.GLib.Structs.HashTable HashTableGI.GLib.Structs.VariantvariantGetTypevariantTypeStringScan VariantTypevariantRefSink threadExit ThreadPool MainContextchecksumUpdate getTmpDirmkstempmkdtempData.GI.Base.GErrorGErrorMutexgetApplicationName getPrgnameBookmarkFileErrorgetUserDataDirgetSystemDataDirs FileErrorfileSetContentsstrfreevdateTimeFormatgetCurrentTime timeValAddTimeValtimeZoneNewLocaltimeZoneNewUtc CompareFuncTimeZoneTestCaseconvert localeToUtf8mallocmalloc0reallocstrdup ByteArraybyteArrayFreeToBytesBytes bytesNewTake byteArrayFree asciiTolower asciiToupper SequenceIter regexReplaceregexNewregexCheckReplacement regexMatchAllregexMatchAllFullRegexregexRef regexMatchregexMatchFullGI.GLib.UnionsfileTestformatSizeFullHook IOChanneliOChannelGetFlagsiOChannelSetFlagslogSetFatalMask spawnSync spawnAsyncspawnAsyncWithPipestestTrapSubprocess testTrapFork formatSizeHOOK_FLAG_USER_SHIFTiOChannelSeekPosition MarkupParser OptionArgNoneOptionArgCallbackmatchInfoIsPartialMatchTraverseFlagsAllTraverseFlagsLeavesTraverseFlagsNonLeaves KeyFileError KeyFileFlags MatchInfo matchInfoNext matchInfoFreematchInfoGetMatchCountmatchInfoFetchmatchInfoFetchPosRegexCompileFlagsRegexMatchFlagsChecksum TokenValue iOChannelReadiOChannelWrite iOChannelSeekIOFuncs LogWriterFuncOncescannerGetNextTokengetUserSpecialDir OptionArgFunc$optionContextSetIgnoreUnknownOptionsunicharGetScript getCharset IOCondition IOConditionInIOConditionOutIOFlagsIsReadableIOFlagsIsWritableIOStatusNormal IOStatusEof SeekTypeCur IOStatusAgain IOStatusErrorConvertErrorIllegalSequenceIOFlagsSetMaskIOChannelError IOErrorNoneIOStatus SeekTypeSet SeekTypeEndSeekTypeIOChannelErrorInval ChecksumType dateValidDmy dateStrftime DateMonth DateWeekday onceInitLeave onceInitEnterTimeTypeUniversalTimeTypeStandardTimeTypeDaylightTimeType asciiDtostr ScannerConfigdatalistSetFlags asciiStrtoullOptionArgStringArrayOptionArgFilenameArrayPollFD SourceFuncSource strdelimitTreeoptionGroupSetTranslateFuncSOURCE_CONTINUE SOURCE_REMOVEScannermatchInfoGetRegexmatchInfoGetStringString OptionContext OptionGroupoptionGroupNewNodelogSetWriterFuncLogWriterOutputHandledLogWriterOutputUnhandled ioAddWatchHookListhashTableRemoveNormalizeModeDefaultNormalizeModeAllNormalizeModeDefaultComposeNormalizeModeAllCompose USEC_PER_SEC sourceAttach sourceRemove DestroyNotify UnicodeScriptTestSubprocessFlags TestTrapFlagsLogLevelFlagsLevelDebugSpawnFlagsStdoutToDevNullSpawnFlagsStderrToDevNullSpawnFlagsDoNotReapChildSpawnFlagsSearchPathSpawnErrorFailedSpawnFlagsSearchPathFromEnvpSpawnFlagsLeaveDescriptorsOpenSpawnFlagsChildInheritsStdinSpawnFlagsFileAndArgvZeroGI.GLib.Structs.SListSListmainContextDispatchmainContextIteration mainLoopRunLogLevelFlagsLevelInfo variantPrintLogLevelFlagsLevelErrorLogLevelFlagsLevelCriticalLogLevelFlagsLevelWarningLogLevelFlagsLevelMessagePRIORITY_DEFAULT_IDLEPRIORITY_DEFAULTUserDirectoryDirectoryDesktopFormatSizeFlagsFileTestIsSymlinkFileTestIsRegularFileTestExistsFileTestIsExecutable hmacGetString hmacUnref checksumNewchecksumGetString checksumFreeGI.GLib.Structs.Error errorFree MAJOR_VERSION MINOR_VERSION MICRO_VERSION MAXUINT64MAXINT64MININT64 PRIORITY_HIGHUnixFDSourceFuncUnicodeScriptInvalidCodeUnicodeScriptUnknown TestSuiteSTR_DELIMITERS SpawnFlags PatternSpecDebugKey LogLevelFlags LOG_DOMAINPRIORITY_HIGH_IDLEFileTestDATALIST_FLAGS_MASK hookUnrefhookFreeMarkupParseFlags OptionEntry setPrgname TranslateFuncTokenTypeIdentifierTokenTypeIdentifierNullTokenTypeSymbolmainCurrentSourcemainContextFindSourceByIdgetMonotonicTime SourceFuncsidleAdd timeoutAdd childWatchAddsourceAddUnixFdmainContextGetThreadDefaultmainContextDefaultMainLoopmainContextRefThreadDefault sourceNew sourceGetIdthreadPoolStopUnusedThreadsGI.GLib.StructsGI.GLib FloatIEEE754newZeroFloatIEEE754noFloatIEEE754getFloatIEEE754VFloatsetFloatIEEE754VFloat$fConstructibleFloatIEEE754tag$fWrappedPtrFloatIEEE754 DoubleIEEE754newZeroDoubleIEEE754noDoubleIEEE754getDoubleIEEE754VDoublesetDoubleIEEE754VDouble$fConstructibleDoubleIEEE754tag$fWrappedPtrDoubleIEEE754newZeroTokenValue noTokenValuegetTokenValueVSymbolsetTokenValueVSymbolclearTokenValueVSymbolgetTokenValueVIdentifiersetTokenValueVIdentifierclearTokenValueVIdentifiergetTokenValueVBinarysetTokenValueVBinarygetTokenValueVOctalsetTokenValueVOctalgetTokenValueVIntsetTokenValueVIntgetTokenValueVInt64setTokenValueVInt64getTokenValueVFloatsetTokenValueVFloatgetTokenValueVHexsetTokenValueVHexgetTokenValueVStringsetTokenValueVStringclearTokenValueVStringgetTokenValueVCommentsetTokenValueVCommentclearTokenValueVCommentgetTokenValueVCharsetTokenValueVChargetTokenValueVErrorsetTokenValueVError$fConstructibleTokenValuetag$fWrappedPtrTokenValue newZeroMutexnoMutex mutexClear mutexInit mutexLock mutexTrylock mutexUnlock$fConstructibleMutextag$fWrappedPtrMutex noVariantTypevariantTypeNewvariantTypeNewArrayvariantTypeNewDictEntryvariantTypeNewMaybevariantTypeNewTuplevariantTypeCopyvariantTypeDupStringvariantTypeElementvariantTypeEqualvariantTypeFirstvariantTypeFreevariantTypeGetStringLengthvariantTypeHashvariantTypeIsArrayvariantTypeIsBasicvariantTypeIsContainervariantTypeIsDefinitevariantTypeIsDictEntryvariantTypeIsMaybevariantTypeIsSubtypeOfvariantTypeIsTuplevariantTypeIsVariantvariantTypeKeyvariantTypeNItemsvariantTypeNextvariantTypeValuevariantTypeChecked_$fBoxedObjectVariantType VariantDict noVariantDictvariantDictNewvariantDictClearvariantDictContainsvariantDictEndvariantDictInsertValuevariantDictLookupValuevariantDictRefvariantDictRemovevariantDictUnref$fBoxedObjectVariantDictVariantBuildernoVariantBuildervariantBuilderNewvariantBuilderAddValuevariantBuilderClosevariantBuilderEndvariantBuilderOpenvariantBuilderRefvariantBuilderUnref$fBoxedObjectVariantBuildernoTree treeDestroy treeHeight treeInsert treeLookuptreeLookupExtended treeNnodes treeRemove treeReplace treeSteal treeUnref$fWrappedPtrTree TrashStacknewZeroTrashStack noTrashStackgetTrashStackNextsetTrashStackNextclearTrashStackNexttrashStackHeighttrashStackPeek trashStackPoptrashStackPush$fConstructibleTrashStacktag$fWrappedPtrTrashStackTimernoTimer timerContinue timerDestroy timerElapsed timerReset timerStart timerStop$fWrappedPtrTimerThreadnoThread threadJoin threadRef threadUnrefthreadErrorQuark threadSelf threadYield$fBoxedObjectThread TestLogBuffernewZeroTestLogBuffernoTestLogBuffertestLogBufferFreetestLogBufferPush$fConstructibleTestLogBuffertag$fWrappedPtrTestLogBuffer TestConfignewZeroTestConfig noTestConfiggetTestConfigTestInitializedsetTestConfigTestInitializedgetTestConfigTestQuicksetTestConfigTestQuickgetTestConfigTestPerfsetTestConfigTestPerfgetTestConfigTestVerbosesetTestConfigTestVerbosegetTestConfigTestQuietsetTestConfigTestQuietgetTestConfigTestUndefinedsetTestConfigTestUndefined$fConstructibleTestConfigtag$fWrappedPtrTestConfig noTestCase$fWrappedPtrTestCase StringChunk noStringChunkstringChunkClearstringChunkFreestringChunkInsertstringChunkInsertConststringChunkInsertLen$fWrappedPtrStringChunkStatBuf noStatBuf$fWrappedPtrStatBufSourceCallbackFuncsnewZeroScannerConfignoScannerConfig"getScannerConfigCsetSkipCharacters"setScannerConfigCsetSkipCharacters$clearScannerConfigCsetSkipCharacters#getScannerConfigCsetIdentifierFirst#setScannerConfigCsetIdentifierFirst%clearScannerConfigCsetIdentifierFirst!getScannerConfigCsetIdentifierNth!setScannerConfigCsetIdentifierNth#clearScannerConfigCsetIdentifierNth"getScannerConfigCpairCommentSingle"setScannerConfigCpairCommentSingle$clearScannerConfigCpairCommentSinglegetScannerConfigCaseSensitivesetScannerConfigCaseSensitive getScannerConfigSkipCommentMulti setScannerConfigSkipCommentMulti!getScannerConfigSkipCommentSingle!setScannerConfigSkipCommentSingle getScannerConfigScanCommentMulti setScannerConfigScanCommentMultigetScannerConfigScanIdentifiersetScannerConfigScanIdentifier#getScannerConfigScanIdentifier1char#setScannerConfigScanIdentifier1char"getScannerConfigScanIdentifierNULL"setScannerConfigScanIdentifierNULLgetScannerConfigScanSymbolssetScannerConfigScanSymbolsgetScannerConfigScanBinarysetScannerConfigScanBinarygetScannerConfigScanOctalsetScannerConfigScanOctalgetScannerConfigScanFloatsetScannerConfigScanFloatgetScannerConfigScanHexsetScannerConfigScanHexgetScannerConfigScanHexDollarsetScannerConfigScanHexDollargetScannerConfigScanStringSqsetScannerConfigScanStringSqgetScannerConfigScanStringDqsetScannerConfigScanStringDqgetScannerConfigNumbers2IntsetScannerConfigNumbers2IntgetScannerConfigInt2FloatsetScannerConfigInt2Float!getScannerConfigIdentifier2String!setScannerConfigIdentifier2StringgetScannerConfigChar2TokensetScannerConfigChar2TokengetScannerConfigSymbol2TokensetScannerConfigSymbol2TokengetScannerConfigScope0FallbacksetScannerConfigScope0FallbackgetScannerConfigStoreInt64setScannerConfigStoreInt64$fConstructibleScannerConfigtag$fWrappedPtrScannerConfigRecMutexnewZeroRecMutex noRecMutex recMutexClear recMutexInit recMutexLockrecMutexTrylockrecMutexUnlock$fConstructibleRecMutextag$fWrappedPtrRecMutexRandnoRand randDoublerandDoubleRangerandFreerandInt randIntRange randSetSeedrandSetSeedArray$fWrappedPtrRandRWLock newZeroRWLocknoRWLock rWLockClear rWLockInitrWLockReaderLockrWLockReaderTrylockrWLockReaderUnlockrWLockWriterLockrWLockWriterTrylockrWLockWriterUnlock$fConstructibleRWLocktag$fWrappedPtrRWLockPtrArraynewZeroPtrArray noPtrArraygetPtrArrayPdatasetPtrArrayPdataclearPtrArrayPdatagetPtrArrayLensetPtrArrayLen$fConstructiblePtrArraytag$fBoxedObjectPtrArray noMainLoop mainLoopNewmainLoopGetContextmainLoopIsRunning mainLoopQuit mainLoopRef mainLoopUnref$fBoxedObjectMainLoopHmacnoHmac hmacGetDigest hmacUpdate$fWrappedPtrHmac HashTableIternewZeroHashTableIternoHashTableIterhashTableIterInithashTableIterNexthashTableIterRemovehashTableIterReplacehashTableIterSteal$fConstructibleHashTableItertag$fWrappedPtrHashTableIterDirnoDirdirClose dirReadName dirRewind dirMakeTmp$fWrappedPtrDirCond newZeroCondnoCond condBroadcast condClearcondInit condSignalcondWait condWaitUntil$fConstructibleCondtag$fWrappedPtrCond BookmarkFilenoBookmarkFilebookmarkFileAddApplicationbookmarkFileAddGroupbookmarkFileFreebookmarkFileGetAddedbookmarkFileGetAppInfobookmarkFileGetApplicationsbookmarkFileGetDescriptionbookmarkFileGetGroupsbookmarkFileGetIconbookmarkFileGetIsPrivatebookmarkFileGetMimeTypebookmarkFileGetModifiedbookmarkFileGetSizebookmarkFileGetTitlebookmarkFileGetUrisbookmarkFileGetVisitedbookmarkFileHasApplicationbookmarkFileHasGroupbookmarkFileHasItembookmarkFileLoadFromDatabookmarkFileLoadFromDataDirsbookmarkFileLoadFromFilebookmarkFileMoveItembookmarkFileRemoveApplicationbookmarkFileRemoveGroupbookmarkFileRemoveItembookmarkFileSetAddedbookmarkFileSetAppInfobookmarkFileSetDescriptionbookmarkFileSetGroupsbookmarkFileSetIconbookmarkFileSetIsPrivatebookmarkFileSetMimeTypebookmarkFileSetModifiedbookmarkFileSetTitlebookmarkFileSetVisitedbookmarkFileToDatabookmarkFileToFilebookmarkFileErrorQuark$fWrappedPtrBookmarkFilenewZeroTimeVal noTimeValgetTimeValTvSecsetTimeValTvSecgetTimeValTvUsecsetTimeValTvUsectimeValToIso8601timeValFromIso8601$fConstructibleTimeValtag$fWrappedPtrTimeVal AsyncQueue noAsyncQueueasyncQueueLengthasyncQueueLengthUnlockedasyncQueueLock asyncQueuePopasyncQueuePopUnlockedasyncQueuePushasyncQueuePushFrontasyncQueuePushFrontUnlockedasyncQueuePushUnlockedasyncQueueRefUnlockedasyncQueueRemoveasyncQueueRemoveUnlockedasyncQueueTimedPopasyncQueueTimedPopUnlockedasyncQueueTimeoutPopasyncQueueTimeoutPopUnlockedasyncQueueTryPopasyncQueueTryPopUnlockedasyncQueueUnlockasyncQueueUnrefasyncQueueUnrefAndUnlock$fWrappedPtrAsyncQueueDateTime noDateTime dateTimeNewdateTimeNewFromTimevalLocaldateTimeNewFromTimevalUtcdateTimeNewFromUnixLocaldateTimeNewFromUnixUtcdateTimeNewLocaldateTimeNewNowdateTimeNewNowLocaldateTimeNewNowUtcdateTimeNewUtc dateTimeAdddateTimeAddDaysdateTimeAddFulldateTimeAddHoursdateTimeAddMinutesdateTimeAddMonthsdateTimeAddSecondsdateTimeAddWeeksdateTimeAddYearsdateTimeDifferencedateTimeGetDayOfMonthdateTimeGetDayOfWeekdateTimeGetDayOfYeardateTimeGetHourdateTimeGetMicroseconddateTimeGetMinutedateTimeGetMonthdateTimeGetSeconddateTimeGetSecondsdateTimeGetTimezoneAbbreviationdateTimeGetUtcOffsetdateTimeGetWeekNumberingYeardateTimeGetWeekOfYeardateTimeGetYeardateTimeGetYmddateTimeIsDaylightSavings dateTimeRefdateTimeToLocaldateTimeToTimevaldateTimeToTimezonedateTimeToUnix dateTimeToUtc dateTimeUnrefdateTimeCompare dateTimeEqual dateTimeHash$fBoxedObjectDateTime noTestSuite testSuiteAddtestSuiteAddSuite$fWrappedPtrTestSuite noPatternSpecpatternSpecEqualpatternSpecFree$fWrappedPtrPatternSpec MemVTableIConvnoIConv iConvClose$fWrappedPtrIConvnewZeroDebugKey noDebugKeygetDebugKeyKeysetDebugKeyKeyclearDebugKeyKeygetDebugKeyValuesetDebugKeyValue$fConstructibleDebugKeytag$fWrappedPtrDebugKeyDatanoData$fWrappedPtrDatanoBytesbytesNew bytesCompare bytesEqual bytesGetData bytesGetSize bytesHashbytesNewFromBytesbytesRef bytesUnrefbytesUnrefToArraybytesUnrefToData$fBoxedObjectBytesnewZeroByteArray noByteArraygetByteArrayDatasetByteArrayDatagetByteArrayLensetByteArrayLen byteArrayNewbyteArrayNewTakebyteArrayUnref$fConstructibleByteArraytag$fBoxedObjectByteArray MappedFile noMappedFile mappedFileNewmappedFileNewFromFdmappedFileFreemappedFileGetBytesmappedFileGetContentsmappedFileGetLength mappedFileRefmappedFileUnref$fBoxedObjectMappedFile newZeroStringnoString getStringStr setStringStrclearStringStr getStringLen setStringLengetStringAllocatedLensetStringAllocatedLen stringAppend stringAppendCstringAppendLenstringAppendUnicharstringAppendUriEscapedstringAsciiDown stringAsciiUp stringAssign stringDown stringEqual stringErase stringFreestringFreeToBytes stringHash stringInsert stringInsertCstringInsertLenstringInsertUnicharstringOverwritestringOverwriteLen stringPrependstringPrependCstringPrependLenstringPrependUnichar stringSetSizestringTruncatestringUp$fConstructibleStringtag$fBoxedObjectStringnoSequenceItersequenceIterComparesequenceIterGetPositionsequenceIterIsBeginsequenceIterIsEnd$fWrappedPtrSequenceIterSequence noSequence sequenceFreesequenceGetLengthsequenceIsEmpty sequenceGet sequenceMovesequenceMoveRangesequenceRemovesequenceRemoveRange sequenceSet sequenceSwap$fWrappedPtrSequence newZeroPollFDnoPollFD getPollFDFd setPollFDFdgetPollFDEventssetPollFDEventsgetPollFDReventssetPollFDRevents$fConstructiblePollFDtag$fBoxedObjectPollFD noMatchInfomatchInfoExpandReferencesmatchInfoFetchAllmatchInfoFetchNamedmatchInfoFetchNamedPosmatchInfoMatches matchInfoRefmatchInfoUnref$fBoxedObjectMatchInfoMarkupParseContextLogFieldnewZeroLogField noLogFieldgetLogFieldKeysetLogFieldKeyclearLogFieldKeygetLogFieldValuesetLogFieldValueclearLogFieldValuegetLogFieldLengthsetLogFieldLength$fConstructibleLogFieldtag$fWrappedPtrLogField AsciiType HookFlagMaskIOFlagsMarkupCollectType OptionFlags TraverseFlagsAsciiTypeAlnumAsciiTypeAlphaAsciiTypeCntrlAsciiTypeDigitAsciiTypeGraphAsciiTypeLowerAsciiTypePrintAsciiTypePunctAsciiTypeSpaceAsciiTypeUpperAsciiTypeXdigitAnotherAsciiType FileTestIsDirAnotherFileTestFormatSizeFlagsDefaultFormatSizeFlagsLongFormatFormatSizeFlagsIecUnitsAnotherFormatSizeFlagsHookFlagMaskActiveHookFlagMaskInCallHookFlagMaskMaskAnotherHookFlagMaskIOConditionPriIOConditionErrIOConditionHupIOConditionNvalAnotherIOCondition IOFlagsAppendIOFlagsNonblockIOFlagsIsWriteableIOFlagsIsSeekable IOFlagsMaskIOFlagsGetMaskAnotherIOFlagsKeyFileFlagsNoneKeyFileFlagsKeepCommentsKeyFileFlagsKeepTranslationsAnotherKeyFileFlagsLogLevelFlagsFlagRecursionLogLevelFlagsFlagFatalLogLevelFlagsLevelMaskAnotherLogLevelFlagsMarkupCollectTypeInvalidMarkupCollectTypeStringMarkupCollectTypeStrdupMarkupCollectTypeBooleanMarkupCollectTypeTristateMarkupCollectTypeOptionalAnotherMarkupCollectType+MarkupParseFlagsDoNotUseThisUnsupportedFlag MarkupParseFlagsTreatCdataAsText#MarkupParseFlagsPrefixErrorPositionMarkupParseFlagsIgnoreQualifiedAnotherMarkupParseFlagsOptionFlagsNoneOptionFlagsHiddenOptionFlagsInMainOptionFlagsReverseOptionFlagsNoArgOptionFlagsFilenameOptionFlagsOptionalArgOptionFlagsNoaliasAnotherOptionFlagsRegexCompileFlagsCaselessRegexCompileFlagsMultilineRegexCompileFlagsDotallRegexCompileFlagsExtendedRegexCompileFlagsAnchoredRegexCompileFlagsDollarEndonlyRegexCompileFlagsUngreedyRegexCompileFlagsRawRegexCompileFlagsNoAutoCaptureRegexCompileFlagsOptimizeRegexCompileFlagsFirstlineRegexCompileFlagsDupnamesRegexCompileFlagsNewlineCrRegexCompileFlagsNewlineLfRegexCompileFlagsNewlineCrlfRegexCompileFlagsNewlineAnycrlfRegexCompileFlagsBsrAnycrlf!RegexCompileFlagsJavascriptCompatAnotherRegexCompileFlagsRegexMatchFlagsAnchoredRegexMatchFlagsNotbolRegexMatchFlagsNoteolRegexMatchFlagsNotemptyRegexMatchFlagsPartialRegexMatchFlagsNewlineCrRegexMatchFlagsNewlineLfRegexMatchFlagsNewlineCrlfRegexMatchFlagsNewlineAnyRegexMatchFlagsNewlineAnycrlfRegexMatchFlagsBsrAnycrlfRegexMatchFlagsBsrAnyRegexMatchFlagsPartialSoftRegexMatchFlagsPartialHardRegexMatchFlagsNotemptyAtstartAnotherRegexMatchFlagsSpawnFlagsDefaultSpawnFlagsCloexecPipesAnotherSpawnFlagsTestSubprocessFlagsStdinTestSubprocessFlagsStdoutTestSubprocessFlagsStderrAnotherTestSubprocessFlagsTestTrapFlagsSilenceStdoutTestTrapFlagsSilenceStderrTestTrapFlagsInheritStdinAnotherTestTrapFlagsTraverseFlagsMaskTraverseFlagsLeafsTraverseFlagsNonLeafsAnotherTraverseFlags$fIsGFlagAsciiType$fOrdAsciiType$fEnumAsciiType$fIsGFlagFileTest $fOrdFileTest$fEnumFileTest$fIsGFlagFormatSizeFlags$fOrdFormatSizeFlags$fEnumFormatSizeFlags$fIsGFlagHookFlagMask$fOrdHookFlagMask$fEnumHookFlagMask$fIsGFlagIOCondition$fBoxedFlagsIOCondition$fOrdIOCondition$fEnumIOCondition$fIsGFlagIOFlags $fOrdIOFlags $fEnumIOFlags$fIsGFlagKeyFileFlags$fOrdKeyFileFlags$fEnumKeyFileFlags$fIsGFlagLogLevelFlags$fOrdLogLevelFlags$fEnumLogLevelFlags$fIsGFlagMarkupCollectType$fOrdMarkupCollectType$fEnumMarkupCollectType$fIsGFlagMarkupParseFlags$fOrdMarkupParseFlags$fEnumMarkupParseFlags$fIsGFlagOptionFlags$fOrdOptionFlags$fEnumOptionFlags$fIsGFlagRegexCompileFlags$fOrdRegexCompileFlags$fEnumRegexCompileFlags$fIsGFlagRegexMatchFlags$fOrdRegexMatchFlags$fEnumRegexMatchFlags$fIsGFlagSpawnFlags$fOrdSpawnFlags$fEnumSpawnFlags$fIsGFlagTestSubprocessFlags$fOrdTestSubprocessFlags$fEnumTestSubprocessFlags$fIsGFlagTestTrapFlags$fOrdTestTrapFlags$fEnumTestTrapFlags$fIsGFlagTraverseFlags$fOrdTraverseFlags$fEnumTraverseFlags$fShowTraverseFlags$fEqTraverseFlags$fShowTestTrapFlags$fEqTestTrapFlags$fShowTestSubprocessFlags$fEqTestSubprocessFlags$fShowSpawnFlags$fEqSpawnFlags$fShowRegexMatchFlags$fEqRegexMatchFlags$fShowRegexCompileFlags$fEqRegexCompileFlags$fShowOptionFlags$fEqOptionFlags$fShowMarkupParseFlags$fEqMarkupParseFlags$fShowMarkupCollectType$fEqMarkupCollectType$fShowLogLevelFlags$fEqLogLevelFlags$fShowKeyFileFlags$fEqKeyFileFlags $fShowIOFlags $fEqIOFlags$fShowIOCondition$fEqIOCondition$fShowHookFlagMask$fEqHookFlagMask$fShowFormatSizeFlags$fEqFormatSizeFlags$fShowFileTest $fEqFileTest$fShowAsciiType $fEqAsciiType newZeroNodenoNode getNodeData setNodeData clearNodeData getNodeNext setNodeNext clearNodeNext getNodePrev setNodePrev clearNodePrev getNodeParent setNodeParentclearNodeParentgetNodeChildrensetNodeChildrenclearNodeChildrennodeChildIndexnodeChildPosition nodeDepth nodeDestroynodeIsAncestor nodeMaxHeight nodeNChildren nodeNNodesnodeReverseChildren nodeUnlink$fConstructibleNodetag$fWrappedPtrNodeKeyFile noKeyFile keyFileNewkeyFileGetBooleankeyFileGetBooleanListkeyFileGetCommentkeyFileGetDoublekeyFileGetDoubleListkeyFileGetGroupskeyFileGetInt64keyFileGetIntegerkeyFileGetIntegerListkeyFileGetKeyskeyFileGetLocaleStringkeyFileGetLocaleStringListkeyFileGetStartGroupkeyFileGetStringkeyFileGetStringListkeyFileGetUint64keyFileGetValuekeyFileHasGroupkeyFileLoadFromByteskeyFileLoadFromDatakeyFileLoadFromDataDirskeyFileLoadFromDirskeyFileLoadFromFilekeyFileRemoveCommentkeyFileRemoveGroupkeyFileRemoveKeykeyFileSaveToFilekeyFileSetBooleankeyFileSetBooleanListkeyFileSetCommentkeyFileSetDoublekeyFileSetDoubleListkeyFileSetInt64keyFileSetIntegerkeyFileSetIntegerListkeyFileSetListSeparatorkeyFileSetLocaleStringkeyFileSetLocaleStringListkeyFileSetStringkeyFileSetStringListkeyFileSetUint64keyFileSetValue keyFileToData keyFileUnrefkeyFileErrorQuark$fBoxedObjectKeyFilenoRegexregexGetCaptureCountregexGetCompileFlagsregexGetHasCrOrLfregexGetMatchFlagsregexGetMaxBackrefregexGetMaxLookbehindregexGetPatternregexGetStringNumberregexReplaceLiteral regexSplitregexSplitFull regexUnrefregexErrorQuarkregexEscapeNulregexEscapeStringregexMatchSimpleregexSplitSimple$fBoxedObjectRegex ConvertErrorDateDMY ErrorTypeIOErrorLogWriterOutput MarkupError NormalizeMode OnceStatus OptionArg OptionError RegexError ShellError SliceConfig SpawnError TestFileType TestLogType ThreadError TokenType TraverseTypeUnicodeBreakType UnicodeType UserDirectory VariantClassVariantParseErrorBookmarkFileErrorInvalidUriBookmarkFileErrorInvalidValue!BookmarkFileErrorAppNotRegisteredBookmarkFileErrorUriNotFoundBookmarkFileErrorRead BookmarkFileErrorUnknownEncodingBookmarkFileErrorWriteBookmarkFileErrorFileNotFoundAnotherBookmarkFileErrorChecksumTypeMd5ChecksumTypeSha1ChecksumTypeSha256ChecksumTypeSha512AnotherChecksumTypeConvertErrorNoConversionConvertErrorFailedConvertErrorPartialInputConvertErrorBadUriConvertErrorNotAbsolutePathConvertErrorNoMemoryAnotherConvertError DateDMYDay DateDMYMonth DateDMYYearAnotherDateDMYDateMonthBadMonthDateMonthJanuaryDateMonthFebruaryDateMonthMarchDateMonthApril DateMonthMay DateMonthJune DateMonthJulyDateMonthAugustDateMonthSeptemberDateMonthOctoberDateMonthNovemberDateMonthDecemberAnotherDateMonthDateWeekdayBadWeekdayDateWeekdayMondayDateWeekdayTuesdayDateWeekdayWednesdayDateWeekdayThursdayDateWeekdayFridayDateWeekdaySaturdayDateWeekdaySundayAnotherDateWeekdayErrorTypeUnknownErrorTypeUnexpEofErrorTypeUnexpEofInStringErrorTypeUnexpEofInCommentErrorTypeNonDigitInConstErrorTypeDigitRadixErrorTypeFloatRadixErrorTypeFloatMalformedAnotherErrorTypeFileErrorExistFileErrorIsdirFileErrorAccesFileErrorNametoolongFileErrorNoentFileErrorNotdir FileErrorNxioFileErrorNodev FileErrorRofsFileErrorTxtbsyFileErrorFault FileErrorLoopFileErrorNospcFileErrorNomemFileErrorMfileFileErrorNfile FileErrorBadfFileErrorInval FileErrorPipeFileErrorAgain FileErrorIntr FileErrorIo FileErrorPermFileErrorNosysFileErrorFailedAnotherFileErrorIOChannelErrorFbigIOChannelErrorIoIOChannelErrorIsdirIOChannelErrorNospcIOChannelErrorNxioIOChannelErrorOverflowIOChannelErrorPipeIOChannelErrorFailedAnotherIOChannelError IOErrorAgain IOErrorInvalIOErrorUnknownAnotherIOErrorAnotherIOStatusKeyFileErrorUnknownEncodingKeyFileErrorParseKeyFileErrorNotFoundKeyFileErrorKeyNotFoundKeyFileErrorGroupNotFoundKeyFileErrorInvalidValueAnotherKeyFileErrorAnotherLogWriterOutputMarkupErrorBadUtf8MarkupErrorEmptyMarkupErrorParseMarkupErrorUnknownElementMarkupErrorUnknownAttributeMarkupErrorInvalidContentMarkupErrorMissingAttributeAnotherMarkupErrorNormalizeModeNfdNormalizeModeNfcNormalizeModeNfkdNormalizeModeNfkcAnotherNormalizeModeOnceStatusNotcalledOnceStatusProgressOnceStatusReadyAnotherOnceStatusOptionArgString OptionArgIntOptionArgFilenameOptionArgDoubleOptionArgInt64AnotherOptionArgOptionErrorUnknownOptionOptionErrorBadValueOptionErrorFailedAnotherOptionErrorRegexErrorCompileRegexErrorOptimizeRegexErrorReplaceRegexErrorMatchRegexErrorInternalRegexErrorStrayBackslashRegexErrorMissingControlCharRegexErrorUnrecognizedEscapeRegexErrorQuantifiersOutOfOrderRegexErrorQuantifierTooBig$RegexErrorUnterminatedCharacterClass'RegexErrorInvalidEscapeInCharacterClassRegexErrorRangeOutOfOrderRegexErrorNothingToRepeatRegexErrorUnrecognizedCharacter%RegexErrorPosixNamedClassOutsideClassRegexErrorUnmatchedParenthesis'RegexErrorInexistentSubpatternReferenceRegexErrorUnterminatedCommentRegexErrorExpressionTooLargeRegexErrorMemoryError"RegexErrorVariableLengthLookbehindRegexErrorMalformedCondition$RegexErrorTooManyConditionalBranchesRegexErrorAssertionExpectedRegexErrorUnknownPosixClassName,RegexErrorPosixCollatingElementsNotSupportedRegexErrorHexCodeTooLargeRegexErrorInvalidCondition%RegexErrorSingleByteMatchInLookbehindRegexErrorInfiniteLoop)RegexErrorMissingSubpatternNameTerminator!RegexErrorDuplicateSubpatternNameRegexErrorMalformedPropertyRegexErrorUnknownPropertyRegexErrorSubpatternNameTooLongRegexErrorTooManySubpatternsRegexErrorInvalidOctalValue!RegexErrorTooManyBranchesInDefineRegexErrorDefineRepetion$RegexErrorInconsistentNewlineOptionsRegexErrorMissingBackReference"RegexErrorInvalidRelativeReference2RegexErrorBacktrackingControlVerbArgumentForbidden(RegexErrorUnknownBacktrackingControlVerbRegexErrorNumberTooBigRegexErrorMissingSubpatternNameRegexErrorMissingDigitRegexErrorInvalidDataCharacterRegexErrorExtraSubpatternName1RegexErrorBacktrackingControlVerbArgumentRequiredRegexErrorInvalidControlCharRegexErrorMissingNameRegexErrorNotSupportedInClass"RegexErrorTooManyForwardReferencesRegexErrorNameTooLong RegexErrorCharacterValueTooLargeAnotherRegexErrorAnotherSeekTypeShellErrorBadQuotingShellErrorEmptyStringShellErrorFailedAnotherShellErrorSliceConfigAlwaysMallocSliceConfigBypassMagazinesSliceConfigWorkingSetMsecsSliceConfigColorIncrementSliceConfigChunkSizesSliceConfigContentionCounterAnotherSliceConfigSpawnErrorForkSpawnErrorReadSpawnErrorChdirSpawnErrorAccesSpawnErrorPermSpawnErrorTooBigSpawnError2bigSpawnErrorNoexecSpawnErrorNametoolongSpawnErrorNoentSpawnErrorNomemSpawnErrorNotdirSpawnErrorLoopSpawnErrorTxtbusy SpawnErrorIoSpawnErrorNfileSpawnErrorMfileSpawnErrorInvalSpawnErrorIsdirSpawnErrorLibbadAnotherSpawnErrorTestFileTypeDistTestFileTypeBuiltAnotherTestFileTypeTestLogTypeNoneTestLogTypeErrorTestLogTypeStartBinaryTestLogTypeListCaseTestLogTypeSkipCaseTestLogTypeStartCaseTestLogTypeStopCaseTestLogTypeMinResultTestLogTypeMaxResultTestLogTypeMessageTestLogTypeStartSuiteTestLogTypeStopSuiteAnotherTestLogTypeThreadErrorThreadErrorAgainAnotherThreadErrorAnotherTimeType TokenTypeEofTokenTypeLeftParenTokenTypeRightParenTokenTypeLeftCurlyTokenTypeRightCurlyTokenTypeLeftBraceTokenTypeRightBraceTokenTypeEqualSignTokenTypeComma TokenTypeNoneTokenTypeError TokenTypeCharTokenTypeBinaryTokenTypeOctal TokenTypeInt TokenTypeHexTokenTypeFloatTokenTypeStringTokenTypeCommentSingleTokenTypeCommentMultiAnotherTokenTypeTraverseTypeInOrderTraverseTypePreOrderTraverseTypePostOrderTraverseTypeLevelOrderAnotherTraverseTypeUnicodeBreakTypeMandatoryUnicodeBreakTypeCarriageReturnUnicodeBreakTypeLineFeedUnicodeBreakTypeCombiningMarkUnicodeBreakTypeSurrogateUnicodeBreakTypeZeroWidthSpaceUnicodeBreakTypeInseparableUnicodeBreakTypeNonBreakingGlueUnicodeBreakTypeContingentUnicodeBreakTypeSpaceUnicodeBreakTypeAfterUnicodeBreakTypeBeforeUnicodeBreakTypeBeforeAndAfterUnicodeBreakTypeHyphenUnicodeBreakTypeNonStarterUnicodeBreakTypeOpenPunctuation UnicodeBreakTypeClosePunctuationUnicodeBreakTypeQuotationUnicodeBreakTypeExclamationUnicodeBreakTypeIdeographicUnicodeBreakTypeNumericUnicodeBreakTypeInfixSeparatorUnicodeBreakTypeSymbolUnicodeBreakTypeAlphabeticUnicodeBreakTypePrefixUnicodeBreakTypePostfixUnicodeBreakTypeComplexContextUnicodeBreakTypeAmbiguousUnicodeBreakTypeUnknownUnicodeBreakTypeNextLineUnicodeBreakTypeWordJoinerUnicodeBreakTypeHangulLJamoUnicodeBreakTypeHangulVJamoUnicodeBreakTypeHangulTJamo UnicodeBreakTypeHangulLvSyllable!UnicodeBreakTypeHangulLvtSyllable UnicodeBreakTypeCloseParanthesis*UnicodeBreakTypeConditionalJapaneseStarterUnicodeBreakTypeHebrewLetter!UnicodeBreakTypeRegionalIndicatorAnotherUnicodeBreakTypeUnicodeScriptCommonUnicodeScriptInheritedUnicodeScriptArabicUnicodeScriptArmenianUnicodeScriptBengaliUnicodeScriptBopomofoUnicodeScriptCherokeeUnicodeScriptCopticUnicodeScriptCyrillicUnicodeScriptDeseretUnicodeScriptDevanagariUnicodeScriptEthiopicUnicodeScriptGeorgianUnicodeScriptGothicUnicodeScriptGreekUnicodeScriptGujaratiUnicodeScriptGurmukhiUnicodeScriptHanUnicodeScriptHangulUnicodeScriptHebrewUnicodeScriptHiraganaUnicodeScriptKannadaUnicodeScriptKatakanaUnicodeScriptKhmerUnicodeScriptLaoUnicodeScriptLatinUnicodeScriptMalayalamUnicodeScriptMongolianUnicodeScriptMyanmarUnicodeScriptOghamUnicodeScriptOldItalicUnicodeScriptOriyaUnicodeScriptRunicUnicodeScriptSinhalaUnicodeScriptSyriacUnicodeScriptTamilUnicodeScriptTeluguUnicodeScriptThaanaUnicodeScriptThaiUnicodeScriptTibetanUnicodeScriptCanadianAboriginalUnicodeScriptYiUnicodeScriptTagalogUnicodeScriptHanunooUnicodeScriptBuhidUnicodeScriptTagbanwaUnicodeScriptBrailleUnicodeScriptCypriotUnicodeScriptLimbuUnicodeScriptOsmanyaUnicodeScriptShavianUnicodeScriptLinearBUnicodeScriptTaiLeUnicodeScriptUgariticUnicodeScriptNewTaiLueUnicodeScriptBugineseUnicodeScriptGlagoliticUnicodeScriptTifinaghUnicodeScriptSylotiNagriUnicodeScriptOldPersianUnicodeScriptKharoshthiUnicodeScriptBalineseUnicodeScriptCuneiformUnicodeScriptPhoenicianUnicodeScriptPhagsPaUnicodeScriptNkoUnicodeScriptKayahLiUnicodeScriptLepchaUnicodeScriptRejangUnicodeScriptSundaneseUnicodeScriptSaurashtraUnicodeScriptChamUnicodeScriptOlChikiUnicodeScriptVaiUnicodeScriptCarianUnicodeScriptLycianUnicodeScriptLydianUnicodeScriptAvestanUnicodeScriptBamum UnicodeScriptEgyptianHieroglyphsUnicodeScriptImperialAramaic!UnicodeScriptInscriptionalPahlavi"UnicodeScriptInscriptionalParthianUnicodeScriptJavaneseUnicodeScriptKaithiUnicodeScriptLisuUnicodeScriptMeeteiMayekUnicodeScriptOldSouthArabianUnicodeScriptOldTurkicUnicodeScriptSamaritanUnicodeScriptTaiThamUnicodeScriptTaiVietUnicodeScriptBatakUnicodeScriptBrahmiUnicodeScriptMandaicUnicodeScriptChakmaUnicodeScriptMeroiticCursive UnicodeScriptMeroiticHieroglyphsUnicodeScriptMiaoUnicodeScriptSharadaUnicodeScriptSoraSompengUnicodeScriptTakriUnicodeScriptBassaVahUnicodeScriptCaucasianAlbanianUnicodeScriptDuployanUnicodeScriptElbasanUnicodeScriptGranthaUnicodeScriptKhojkiUnicodeScriptKhudawadiUnicodeScriptLinearAUnicodeScriptMahajaniUnicodeScriptManichaeanUnicodeScriptMendeKikakuiUnicodeScriptModiUnicodeScriptMroUnicodeScriptNabataeanUnicodeScriptOldNorthArabianUnicodeScriptOldPermicUnicodeScriptPahawhHmongUnicodeScriptPalmyreneUnicodeScriptPauCinHauUnicodeScriptPsalterPahlaviUnicodeScriptSiddhamUnicodeScriptTirhutaUnicodeScriptWarangCitiUnicodeScriptAhom!UnicodeScriptAnatolianHieroglyphsUnicodeScriptHatranUnicodeScriptMultaniUnicodeScriptOldHungarianUnicodeScriptSignwritingAnotherUnicodeScriptUnicodeTypeControlUnicodeTypeFormatUnicodeTypeUnassignedUnicodeTypePrivateUseUnicodeTypeSurrogateUnicodeTypeLowercaseLetterUnicodeTypeModifierLetterUnicodeTypeOtherLetterUnicodeTypeTitlecaseLetterUnicodeTypeUppercaseLetterUnicodeTypeSpacingMarkUnicodeTypeEnclosingMarkUnicodeTypeNonSpacingMarkUnicodeTypeDecimalNumberUnicodeTypeLetterNumberUnicodeTypeOtherNumberUnicodeTypeConnectPunctuationUnicodeTypeDashPunctuationUnicodeTypeClosePunctuationUnicodeTypeFinalPunctuationUnicodeTypeInitialPunctuationUnicodeTypeOtherPunctuationUnicodeTypeOpenPunctuationUnicodeTypeCurrencySymbolUnicodeTypeModifierSymbolUnicodeTypeMathSymbolUnicodeTypeOtherSymbolUnicodeTypeLineSeparatorUnicodeTypeParagraphSeparatorUnicodeTypeSpaceSeparatorAnotherUnicodeTypeUserDirectoryDirectoryDocumentsUserDirectoryDirectoryDownloadUserDirectoryDirectoryMusicUserDirectoryDirectoryPictures!UserDirectoryDirectoryPublicShareUserDirectoryDirectoryTemplatesUserDirectoryDirectoryVideosUserDirectoryNDirectoriesAnotherUserDirectoryVariantClassBooleanVariantClassByteVariantClassInt16VariantClassUint16VariantClassInt32VariantClassUint32VariantClassInt64VariantClassUint64VariantClassHandleVariantClassDoubleVariantClassStringVariantClassObjectPathVariantClassSignatureVariantClassVariantVariantClassMaybeVariantClassArrayVariantClassTupleVariantClassDictEntryAnotherVariantClassVariantParseErrorFailed"VariantParseErrorBasicTypeExpected VariantParseErrorCannotInferType%VariantParseErrorDefiniteTypeExpectedVariantParseErrorInputNotAtEnd!VariantParseErrorInvalidCharacter$VariantParseErrorInvalidFormatString"VariantParseErrorInvalidObjectPath!VariantParseErrorInvalidSignature"VariantParseErrorInvalidTypeStringVariantParseErrorNoCommonType!VariantParseErrorNumberOutOfRangeVariantParseErrorNumberTooBigVariantParseErrorTypeError VariantParseErrorUnexpectedTokenVariantParseErrorUnknownKeyword+VariantParseErrorUnterminatedStringConstantVariantParseErrorValueExpectedAnotherVariantParseErrorcatchVariantParseErrorhandleVariantParseErrorcatchThreadErrorhandleThreadErrorcatchSpawnErrorhandleSpawnErrorcatchShellErrorhandleShellErrorcatchRegexErrorhandleRegexErrorcatchOptionErrorhandleOptionErrorcatchMarkupErrorhandleMarkupErrorcatchKeyFileErrorhandleKeyFileErrorcatchIOChannelErrorhandleIOChannelErrorcatchFileErrorhandleFileErrorcatchConvertErrorhandleConvertErrorcatchBookmarkFileErrorhandleBookmarkFileError$fGErrorClassBookmarkFileError$fOrdBookmarkFileError$fEnumBookmarkFileError$fOrdChecksumType$fEnumChecksumType$fGErrorClassConvertError$fOrdConvertError$fEnumConvertError $fOrdDateDMY $fEnumDateDMY$fOrdDateMonth$fEnumDateMonth$fOrdDateWeekday$fEnumDateWeekday$fOrdErrorType$fEnumErrorType$fGErrorClassFileError$fOrdFileError$fEnumFileError$fGErrorClassIOChannelError$fOrdIOChannelError$fEnumIOChannelError $fOrdIOError $fEnumIOError $fOrdIOStatus$fEnumIOStatus$fGErrorClassKeyFileError$fOrdKeyFileError$fEnumKeyFileError$fOrdLogWriterOutput$fEnumLogWriterOutput$fGErrorClassMarkupError$fOrdMarkupError$fEnumMarkupError$fOrdNormalizeMode$fEnumNormalizeMode$fOrdOnceStatus$fEnumOnceStatus$fOrdOptionArg$fEnumOptionArg$fGErrorClassOptionError$fOrdOptionError$fEnumOptionError$fGErrorClassRegexError$fOrdRegexError$fEnumRegexError $fOrdSeekType$fEnumSeekType$fGErrorClassShellError$fOrdShellError$fEnumShellError$fOrdSliceConfig$fEnumSliceConfig$fGErrorClassSpawnError$fOrdSpawnError$fEnumSpawnError$fOrdTestFileType$fEnumTestFileType$fOrdTestLogType$fEnumTestLogType$fGErrorClassThreadError$fOrdThreadError$fEnumThreadError $fOrdTimeType$fEnumTimeType$fOrdTokenType$fEnumTokenType$fOrdTraverseType$fEnumTraverseType$fOrdUnicodeBreakType$fEnumUnicodeBreakType$fOrdUnicodeScript$fEnumUnicodeScript$fOrdUnicodeType$fEnumUnicodeType$fOrdUserDirectory$fEnumUserDirectory$fOrdVariantClass$fEnumVariantClass$fGErrorClassVariantParseError$fOrdVariantParseError$fEnumVariantParseError$fShowVariantParseError$fEqVariantParseError$fShowVariantClass$fEqVariantClass$fShowUserDirectory$fEqUserDirectory$fShowUnicodeType$fEqUnicodeType$fShowUnicodeScript$fEqUnicodeScript$fShowUnicodeBreakType$fEqUnicodeBreakType$fShowTraverseType$fEqTraverseType$fShowTokenType $fEqTokenType$fShowTimeType $fEqTimeType$fShowThreadError$fEqThreadError$fShowTestLogType$fEqTestLogType$fShowTestFileType$fEqTestFileType$fShowSpawnError$fEqSpawnError$fShowSliceConfig$fEqSliceConfig$fShowShellError$fEqShellError$fShowSeekType $fEqSeekType$fShowRegexError$fEqRegexError$fShowOptionError$fEqOptionError$fShowOptionArg $fEqOptionArg$fShowOnceStatus$fEqOnceStatus$fShowNormalizeMode$fEqNormalizeMode$fShowMarkupError$fEqMarkupError$fShowLogWriterOutput$fEqLogWriterOutput$fShowKeyFileError$fEqKeyFileError$fShowIOStatus $fEqIOStatus $fShowIOError $fEqIOError$fShowIOChannelError$fEqIOChannelError$fShowFileError $fEqFileError$fShowErrorType $fEqErrorType$fShowDateWeekday$fEqDateWeekday$fShowDateMonth $fEqDateMonth $fShowDateDMY $fEqDateDMY$fShowConvertError$fEqConvertError$fShowChecksumType$fEqChecksumType$fShowBookmarkFileError$fEqBookmarkFileErrornewZeroIOChannel noIOChanneliOChannelNewFileiOChannelUnixNewiOChannelCloseiOChannelFlushiOChannelGetBufferConditioniOChannelGetBufferSizeiOChannelGetBufferediOChannelGetCloseOnUnrefiOChannelGetEncodingiOChannelGetLineTerm iOChannelInitiOChannelReadCharsiOChannelReadLineiOChannelReadToEndiOChannelReadUnichar iOChannelRefiOChannelSetBufferSizeiOChannelSetBufferediOChannelSetCloseOnUnrefiOChannelSetEncodingiOChannelSetLineTermiOChannelShutdowniOChannelUnixGetFdiOChannelUnrefiOChannelWriteCharsiOChannelWriteUnichariOChannelErrorFromErrnoiOChannelErrorQuark$fConstructibleIOChanneltag$fBoxedObjectIOChannel noChecksum checksumCopy checksumResetchecksumTypeGetLength$fBoxedObjectChecksumDate newZeroDatenoDategetDateJulianDayssetDateJulianDays getDateJulian setDateJulian getDateDmy setDateDmy getDateDay setDateDay getDateMonth setDateMonth getDateYear setDateYeardateNew dateNewDmy dateNewJulian dateAddDays dateAddMonths dateAddYears dateClamp dateClear dateComparedateDaysBetweendateFree dateGetDaydateGetDayOfYeardateGetIso8601WeekOfYear dateGetJuliandateGetMondayWeekOfYear dateGetMonthdateGetSundayWeekOfYeardateGetWeekday dateGetYeardateIsFirstOfMonthdateIsLastOfMonth dateOrder dateSetDay dateSetDmy dateSetJulian dateSetMonth dateSetParse dateSetTime dateSetTimeTdateSetTimeVal dateSetYeardateSubtractDaysdateSubtractMonthsdateSubtractYearsdateToStructTm dateValiddateGetDaysInMonthdateGetMondayWeeksInYeardateGetSundayWeeksInYeardateIsLeapYear dateValidDaydateValidJuliandateValidMonthdateValidWeekday dateValidYear$fConstructibleDatetag$fBoxedObjectDate newZeroOncenoOnce getOnceStatus setOnceStatus getOnceRetval setOnceRetvalclearOnceRetval$fConstructibleOncetag$fWrappedPtrOncenewZeroOptionEntry noOptionEntrygetOptionEntryLongNamesetOptionEntryLongNameclearOptionEntryLongNamegetOptionEntryShortNamesetOptionEntryShortNamegetOptionEntryFlagssetOptionEntryFlagsgetOptionEntryArgsetOptionEntryArggetOptionEntryArgDatasetOptionEntryArgDataclearOptionEntryArgDatagetOptionEntryDescriptionsetOptionEntryDescriptionclearOptionEntryDescriptiongetOptionEntryArgDescriptionsetOptionEntryArgDescriptionclearOptionEntryArgDescription$fConstructibleOptionEntrytag$fWrappedPtrOptionEntry TestLogMsgnewZeroTestLogMsg noTestLogMsggetTestLogMsgLogTypesetTestLogMsgLogTypegetTestLogMsgNStringssetTestLogMsgNStringsgetTestLogMsgStringssetTestLogMsgStringsclearTestLogMsgStringsgetTestLogMsgNNumssetTestLogMsgNNumsgetTestLogMsgNumssetTestLogMsgNumstestLogMsgFree$fConstructibleTestLogMsgtag$fWrappedPtrTestLogMsg noTimeZone timeZoneNewtimeZoneAdjustTimetimeZoneFindIntervaltimeZoneGetAbbreviationtimeZoneGetOffset timeZoneIsDst timeZoneRef timeZoneUnref$fBoxedObjectTimeZoneANALYZER_ANALYZINGASCII_DTOSTR_BUF_SIZE BIG_ENDIAN CSET_A_2_Z CSET_DIGITS CSET_a_2_z DATE_BAD_DAYDATE_BAD_JULIAN DATE_BAD_YEAR DIR_SEPARATORDIR_SEPARATOR_SE GINT16_FORMATGINT16_MODIFIER GINT32_FORMATGINT32_MODIFIER GINT64_FORMATGINT64_MODIFIERGINTPTR_FORMATGINTPTR_MODIFIER GNUC_FUNCTIONGNUC_PRETTY_FUNCTION GSIZE_FORMATGSIZE_MODIFIER GSSIZE_FORMATGSSIZE_MODIFIERGUINT16_FORMATGUINT32_FORMATGUINT64_FORMATGUINTPTR_FORMAT HAVE_GINT64HAVE_GNUC_VARARGSHAVE_GNUC_VISIBILITYHAVE_GROWING_STACKHAVE_ISO_VARARGSIEEE754_DOUBLE_BIASIEEE754_FLOAT_BIASKEY_FILE_DESKTOP_GROUPKEY_FILE_DESKTOP_KEY_ACTIONSKEY_FILE_DESKTOP_KEY_CATEGORIESKEY_FILE_DESKTOP_KEY_COMMENT%KEY_FILE_DESKTOP_KEY_DBUS_ACTIVATABLEKEY_FILE_DESKTOP_KEY_EXEC!KEY_FILE_DESKTOP_KEY_GENERIC_NAMEKEY_FILE_DESKTOP_KEY_HIDDENKEY_FILE_DESKTOP_KEY_ICONKEY_FILE_DESKTOP_KEY_MIME_TYPEKEY_FILE_DESKTOP_KEY_NAME KEY_FILE_DESKTOP_KEY_NOT_SHOW_INKEY_FILE_DESKTOP_KEY_NO_DISPLAY!KEY_FILE_DESKTOP_KEY_ONLY_SHOW_INKEY_FILE_DESKTOP_KEY_PATH#KEY_FILE_DESKTOP_KEY_STARTUP_NOTIFY%KEY_FILE_DESKTOP_KEY_STARTUP_WM_CLASSKEY_FILE_DESKTOP_KEY_TERMINALKEY_FILE_DESKTOP_KEY_TRY_EXECKEY_FILE_DESKTOP_KEY_TYPEKEY_FILE_DESKTOP_KEY_URLKEY_FILE_DESKTOP_KEY_VERSION!KEY_FILE_DESKTOP_TYPE_APPLICATIONKEY_FILE_DESKTOP_TYPE_DIRECTORYKEY_FILE_DESKTOP_TYPE_LINK LITTLE_ENDIANLN10LN2 LOG_2_BASE_10LOG_FATAL_MASKLOG_LEVEL_USER_SHIFTMAXINT16MAXINT32MAXINT8 MAXUINT16 MAXUINT32MAXUINT8MININT16MININT32MININT8 MODULE_SUFFIXOPTION_REMAINING PDP_ENDIANPI PID_FORMATPI_2PI_4 POLLFD_FORMAT PRIORITY_LOWSEARCHPATH_SEPARATORSEARCHPATH_SEPARATOR_S SIZEOF_LONG SIZEOF_SIZE_TSIZEOF_SSIZE_T SIZEOF_VOID_PSQRT2SYSDEF_AF_INETSYSDEF_AF_INET6SYSDEF_AF_UNIXSYSDEF_MSG_DONTROUTESYSDEF_MSG_OOBSYSDEF_MSG_PEEK TIME_SPAN_DAYTIME_SPAN_HOURTIME_SPAN_MILLISECONDTIME_SPAN_MINUTETIME_SPAN_SECOND UNICHAR_MAX_DECOMPOSITION_LENGTH%URI_RESERVED_CHARS_GENERIC_DELIMITERS*URI_RESERVED_CHARS_SUBCOMPONENT_DELIMITERSVA_COPY_AS_ARRAYVERSION_MIN_REQUIREDWIN32_MSG_HANDLEChildWatchFunc_WithClosuresChildWatchFuncC_ChildWatchFuncCompareDataFunc_WithClosuresCompareDataFuncC_CompareDataFunc C_CompareFuncCopyFunc C_CopyFuncDataForeachFunc_WithClosuresDataForeachFuncC_DataForeachFuncC_DestroyNotifyDuplicateFunc_WithClosures DuplicateFuncC_DuplicateFunc EqualFunc C_EqualFuncFreeFunc C_FreeFuncFunc_WithClosuresFuncC_FuncHFunc_WithClosuresHFuncC_HFuncHRFunc_WithClosuresHRFuncC_HRFuncHashFunc C_HashFunc HookCheckFuncC_HookCheckFuncHookCheckMarshallerC_HookCheckMarshallerHookCompareFuncC_HookCompareFuncHookFinalizeFuncC_HookFinalizeFunc HookFindFuncC_HookFindFuncHookFunc C_HookFuncHookMarshallerC_HookMarshallerIOFuncC_IOFuncIOFuncsIoCloseFieldCallbackC_IOFuncsIoCloseFieldCallback!IOFuncsIoCreateWatchFieldCallback#C_IOFuncsIoCreateWatchFieldCallbackIOFuncsIoFreeFieldCallbackC_IOFuncsIoFreeFieldCallbackIOFuncsIoGetFlagsFieldCallback C_IOFuncsIoGetFlagsFieldCallbackIOFuncsIoReadFieldCallbackC_IOFuncsIoReadFieldCallbackIOFuncsIoSeekFieldCallbackC_IOFuncsIoSeekFieldCallbackIOFuncsIoSetFlagsFieldCallback C_IOFuncsIoSetFlagsFieldCallbackIOFuncsIoWriteFieldCallbackC_IOFuncsIoWriteFieldCallbackLogFunc_WithClosuresLogFunc C_LogFuncLogWriterFunc_WithClosuresC_LogWriterFunc0MarkupParserEndElementFieldCallback_WithClosures#MarkupParserEndElementFieldCallback%C_MarkupParserEndElementFieldCallback+MarkupParserErrorFieldCallback_WithClosuresMarkupParserErrorFieldCallback C_MarkupParserErrorFieldCallback1MarkupParserPassthroughFieldCallback_WithClosures$MarkupParserPassthroughFieldCallback&C_MarkupParserPassthroughFieldCallback2MarkupParserStartElementFieldCallback_WithClosures%MarkupParserStartElementFieldCallback'C_MarkupParserStartElementFieldCallback*MarkupParserTextFieldCallback_WithClosuresMarkupParserTextFieldCallbackC_MarkupParserTextFieldCallbackMemVTableCallocFieldCallbackC_MemVTableCallocFieldCallbackMemVTableFreeFieldCallbackC_MemVTableFreeFieldCallbackMemVTableMallocFieldCallbackC_MemVTableMallocFieldCallbackMemVTableReallocFieldCallbackC_MemVTableReallocFieldCallbackMemVTableTryMallocFieldCallback!C_MemVTableTryMallocFieldCallback MemVTableTryReallocFieldCallback"C_MemVTableTryReallocFieldCallbackNodeForeachFuncC_NodeForeachFuncNodeTraverseFuncC_NodeTraverseFuncC_OptionArgFuncOptionErrorFuncC_OptionErrorFuncOptionParseFuncC_OptionParseFuncPollFunc C_PollFunc PrintFunc C_PrintFuncRegexEvalCallback_WithClosuresRegexEvalCallbackC_RegexEvalCallbackScannerMsgFuncC_ScannerMsgFuncSequenceIterCompareFuncC_SequenceIterCompareFunc#SourceCallbackFuncsRefFieldCallback%C_SourceCallbackFuncsRefFieldCallback%SourceCallbackFuncsUnrefFieldCallback'C_SourceCallbackFuncsUnrefFieldCallbackSourceDummyMarshalC_SourceDummyMarshalSourceFunc_WithClosures C_SourceFuncSourceFuncsCheckFieldCallbackC_SourceFuncsCheckFieldCallback SourceFuncsFinalizeFieldCallback"C_SourceFuncsFinalizeFieldCallbackSourceFuncsPrepareFieldCallback!C_SourceFuncsPrepareFieldCallback SpawnChildSetupFunc_WithClosuresSpawnChildSetupFuncC_SpawnChildSetupFuncTestDataFunc_WithClosures TestDataFuncC_TestDataFuncTestFixtureFunc_WithClosuresTestFixtureFuncC_TestFixtureFuncTestFunc C_TestFuncTestLogFatalFunc_WithClosuresTestLogFatalFuncC_TestLogFatalFunc ThreadFunc C_ThreadFuncC_TranslateFunc TraverseFuncC_TraverseFuncUnixFDSourceFunc_WithClosuresC_UnixFDSourceFuncVoidFunc C_VoidFuncmk_ChildWatchFuncmk_CompareDataFuncmk_CompareFunc mk_CopyFuncmk_DataForeachFuncmk_DestroyNotifymk_DuplicateFunc mk_EqualFunc mk_FreeFuncmk_Funcmk_HFunc mk_HRFunc mk_HashFuncmk_HookCheckFuncmk_HookCheckMarshallermk_HookCompareFuncmk_HookFinalizeFuncmk_HookFindFunc mk_HookFuncmk_HookMarshaller mk_IOFuncmk_IOFuncsIoCloseFieldCallback$mk_IOFuncsIoCreateWatchFieldCallbackmk_IOFuncsIoFreeFieldCallback!mk_IOFuncsIoGetFlagsFieldCallbackmk_IOFuncsIoReadFieldCallbackmk_IOFuncsIoSeekFieldCallback!mk_IOFuncsIoSetFlagsFieldCallbackmk_IOFuncsIoWriteFieldCallback mk_LogFuncmk_LogWriterFunc&mk_MarkupParserEndElementFieldCallback!mk_MarkupParserErrorFieldCallback'mk_MarkupParserPassthroughFieldCallback(mk_MarkupParserStartElementFieldCallback mk_MarkupParserTextFieldCallbackmk_MemVTableCallocFieldCallbackmk_MemVTableFreeFieldCallbackmk_MemVTableMallocFieldCallback mk_MemVTableReallocFieldCallback"mk_MemVTableTryMallocFieldCallback#mk_MemVTableTryReallocFieldCallbackmk_NodeForeachFuncmk_NodeTraverseFuncmk_OptionArgFuncmk_OptionErrorFuncmk_OptionParseFunc mk_PollFunc mk_PrintFuncmk_RegexEvalCallbackmk_ScannerMsgFuncmk_SequenceIterCompareFunc&mk_SourceCallbackFuncsRefFieldCallback(mk_SourceCallbackFuncsUnrefFieldCallbackmk_SourceDummyMarshal mk_SourceFunc mk_SourceFuncsCheckFieldCallback#mk_SourceFuncsFinalizeFieldCallback"mk_SourceFuncsPrepareFieldCallbackmk_SpawnChildSetupFuncmk_TestDataFuncmk_TestFixtureFunc mk_TestFuncmk_TestLogFatalFunc mk_ThreadFuncmk_TranslateFuncmk_TraverseFuncmk_UnixFDSourceFunc mk_VoidFuncdynamic_VoidFunc noVoidFuncgenClosure_VoidFunc wrap_VoidFuncdynamic_UnixFDSourceFuncnoUnixFDSourceFuncnoUnixFDSourceFunc_WithClosuresdrop_closures_UnixFDSourceFuncgenClosure_UnixFDSourceFuncwrap_UnixFDSourceFuncdynamic_TraverseFuncnoTraverseFuncgenClosure_TraverseFuncwrap_TraverseFuncdynamic_TranslateFuncnoTranslateFuncgenClosure_TranslateFuncwrap_TranslateFuncdynamic_ThreadFunc noThreadFuncgenClosure_ThreadFuncwrap_ThreadFuncdynamic_TestLogFatalFuncnoTestLogFatalFuncnoTestLogFatalFunc_WithClosuresdrop_closures_TestLogFatalFuncgenClosure_TestLogFatalFuncwrap_TestLogFatalFuncdynamic_TestFunc noTestFuncgenClosure_TestFunc wrap_TestFuncdynamic_TestFixtureFuncnoTestFixtureFuncnoTestFixtureFunc_WithClosuresdrop_closures_TestFixtureFuncgenClosure_TestFixtureFuncwrap_TestFixtureFuncdynamic_TestDataFuncnoTestDataFuncnoTestDataFunc_WithClosuresdrop_closures_TestDataFuncgenClosure_TestDataFuncwrap_TestDataFuncdynamic_SpawnChildSetupFuncnoSpawnChildSetupFunc"noSpawnChildSetupFunc_WithClosures!drop_closures_SpawnChildSetupFuncgenClosure_SpawnChildSetupFuncwrap_SpawnChildSetupFunc'dynamic_SourceFuncsPrepareFieldCallback!noSourceFuncsPrepareFieldCallback*genClosure_SourceFuncsPrepareFieldCallback$wrap_SourceFuncsPrepareFieldCallback(dynamic_SourceFuncsFinalizeFieldCallback"noSourceFuncsFinalizeFieldCallback+genClosure_SourceFuncsFinalizeFieldCallback%wrap_SourceFuncsFinalizeFieldCallback%dynamic_SourceFuncsCheckFieldCallbacknoSourceFuncsCheckFieldCallback(genClosure_SourceFuncsCheckFieldCallback"wrap_SourceFuncsCheckFieldCallbackdynamic_SourceFunc noSourceFuncnoSourceFunc_WithClosuresdrop_closures_SourceFuncgenClosure_SourceFuncwrap_SourceFuncdynamic_SourceDummyMarshalnoSourceDummyMarshalgenClosure_SourceDummyMarshalwrap_SourceDummyMarshal-dynamic_SourceCallbackFuncsUnrefFieldCallback'noSourceCallbackFuncsUnrefFieldCallback0genClosure_SourceCallbackFuncsUnrefFieldCallback*wrap_SourceCallbackFuncsUnrefFieldCallback+dynamic_SourceCallbackFuncsRefFieldCallback%noSourceCallbackFuncsRefFieldCallback.genClosure_SourceCallbackFuncsRefFieldCallback(wrap_SourceCallbackFuncsRefFieldCallbackdynamic_SequenceIterCompareFuncnoSequenceIterCompareFunc"genClosure_SequenceIterCompareFuncwrap_SequenceIterCompareFuncdynamic_ScannerMsgFuncnoScannerMsgFuncgenClosure_ScannerMsgFuncwrap_ScannerMsgFuncdynamic_RegexEvalCallbacknoRegexEvalCallback noRegexEvalCallback_WithClosuresdrop_closures_RegexEvalCallbackgenClosure_RegexEvalCallbackwrap_RegexEvalCallbackdynamic_PrintFunc noPrintFuncgenClosure_PrintFuncwrap_PrintFuncdynamic_PollFunc noPollFuncgenClosure_PollFunc wrap_PollFuncdynamic_OptionParseFuncnoOptionParseFuncdynamic_OptionErrorFuncnoOptionErrorFuncdynamic_OptionArgFuncnoOptionArgFuncdynamic_NodeTraverseFuncnoNodeTraverseFuncgenClosure_NodeTraverseFuncwrap_NodeTraverseFuncdynamic_NodeForeachFuncnoNodeForeachFuncgenClosure_NodeForeachFuncwrap_NodeForeachFunc(dynamic_MemVTableTryReallocFieldCallback"noMemVTableTryReallocFieldCallback+genClosure_MemVTableTryReallocFieldCallback%wrap_MemVTableTryReallocFieldCallback'dynamic_MemVTableTryMallocFieldCallback!noMemVTableTryMallocFieldCallback*genClosure_MemVTableTryMallocFieldCallback$wrap_MemVTableTryMallocFieldCallback%dynamic_MemVTableReallocFieldCallbacknoMemVTableReallocFieldCallback(genClosure_MemVTableReallocFieldCallback"wrap_MemVTableReallocFieldCallback$dynamic_MemVTableMallocFieldCallbacknoMemVTableMallocFieldCallback'genClosure_MemVTableMallocFieldCallback!wrap_MemVTableMallocFieldCallback"dynamic_MemVTableFreeFieldCallbacknoMemVTableFreeFieldCallback%genClosure_MemVTableFreeFieldCallbackwrap_MemVTableFreeFieldCallback$dynamic_MemVTableCallocFieldCallbacknoMemVTableCallocFieldCallback'genClosure_MemVTableCallocFieldCallback!wrap_MemVTableCallocFieldCallback%dynamic_MarkupParserTextFieldCallbacknoMarkupParserTextFieldCallback,noMarkupParserTextFieldCallback_WithClosures+drop_closures_MarkupParserTextFieldCallback-dynamic_MarkupParserStartElementFieldCallback'noMarkupParserStartElementFieldCallback4noMarkupParserStartElementFieldCallback_WithClosures3drop_closures_MarkupParserStartElementFieldCallback,dynamic_MarkupParserPassthroughFieldCallback&noMarkupParserPassthroughFieldCallback3noMarkupParserPassthroughFieldCallback_WithClosures2drop_closures_MarkupParserPassthroughFieldCallback&dynamic_MarkupParserErrorFieldCallback noMarkupParserErrorFieldCallback-noMarkupParserErrorFieldCallback_WithClosures,drop_closures_MarkupParserErrorFieldCallback)genClosure_MarkupParserErrorFieldCallback#wrap_MarkupParserErrorFieldCallback+dynamic_MarkupParserEndElementFieldCallback%noMarkupParserEndElementFieldCallback2noMarkupParserEndElementFieldCallback_WithClosures1drop_closures_MarkupParserEndElementFieldCallbackdynamic_LogWriterFuncnoLogWriterFuncnoLogWriterFunc_WithClosuresdrop_closures_LogWriterFuncgenClosure_LogWriterFuncwrap_LogWriterFuncdynamic_LogFunc noLogFuncnoLogFunc_WithClosuresdrop_closures_LogFuncgenClosure_LogFunc wrap_LogFunc#dynamic_IOFuncsIoWriteFieldCallbacknoIOFuncsIoWriteFieldCallback&dynamic_IOFuncsIoSetFlagsFieldCallback noIOFuncsIoSetFlagsFieldCallback"dynamic_IOFuncsIoSeekFieldCallbacknoIOFuncsIoSeekFieldCallback"dynamic_IOFuncsIoReadFieldCallbacknoIOFuncsIoReadFieldCallback&dynamic_IOFuncsIoGetFlagsFieldCallback noIOFuncsIoGetFlagsFieldCallback)genClosure_IOFuncsIoGetFlagsFieldCallback#wrap_IOFuncsIoGetFlagsFieldCallback"dynamic_IOFuncsIoFreeFieldCallbacknoIOFuncsIoFreeFieldCallback%genClosure_IOFuncsIoFreeFieldCallbackwrap_IOFuncsIoFreeFieldCallback)dynamic_IOFuncsIoCreateWatchFieldCallback#noIOFuncsIoCreateWatchFieldCallback,genClosure_IOFuncsIoCreateWatchFieldCallback&wrap_IOFuncsIoCreateWatchFieldCallback#dynamic_IOFuncsIoCloseFieldCallbacknoIOFuncsIoCloseFieldCallbackdynamic_IOFuncnoIOFuncgenClosure_IOFunc wrap_IOFuncdynamic_HookMarshallernoHookMarshallergenClosure_HookMarshallerwrap_HookMarshallerdynamic_HookFunc noHookFuncgenClosure_HookFunc wrap_HookFuncdynamic_HookFindFuncnoHookFindFuncgenClosure_HookFindFuncwrap_HookFindFuncdynamic_HookFinalizeFuncnoHookFinalizeFuncgenClosure_HookFinalizeFuncwrap_HookFinalizeFuncdynamic_HookCompareFuncnoHookCompareFuncgenClosure_HookCompareFuncwrap_HookCompareFuncdynamic_HookCheckMarshallernoHookCheckMarshallergenClosure_HookCheckMarshallerwrap_HookCheckMarshallerdynamic_HookCheckFuncnoHookCheckFuncgenClosure_HookCheckFuncwrap_HookCheckFuncdynamic_HashFunc noHashFuncgenClosure_HashFunc wrap_HashFuncdynamic_HRFuncnoHRFuncnoHRFunc_WithClosuresdrop_closures_HRFuncgenClosure_HRFunc wrap_HRFunc dynamic_HFuncnoHFuncnoHFunc_WithClosuresdrop_closures_HFuncgenClosure_HFunc wrap_HFunc dynamic_FuncnoFuncnoFunc_WithClosuresdrop_closures_FuncgenClosure_Func wrap_Funcdynamic_FreeFunc noFreeFuncgenClosure_FreeFunc wrap_FreeFuncdynamic_EqualFunc noEqualFuncgenClosure_EqualFuncwrap_EqualFuncdynamic_DuplicateFuncnoDuplicateFuncnoDuplicateFunc_WithClosuresdrop_closures_DuplicateFuncgenClosure_DuplicateFuncwrap_DuplicateFuncdynamic_DestroyNotifynoDestroyNotifygenClosure_DestroyNotifywrap_DestroyNotifydynamic_DataForeachFuncnoDataForeachFuncnoDataForeachFunc_WithClosuresdrop_closures_DataForeachFuncgenClosure_DataForeachFuncwrap_DataForeachFuncdynamic_CopyFunc noCopyFuncgenClosure_CopyFunc wrap_CopyFuncdynamic_CompareFunc noCompareFuncgenClosure_CompareFuncwrap_CompareFuncdynamic_CompareDataFuncnoCompareDataFuncnoCompareDataFunc_WithClosuresdrop_closures_CompareDataFuncgenClosure_CompareDataFuncwrap_CompareDataFuncdynamic_ChildWatchFuncnoChildWatchFuncnoChildWatchFunc_WithClosuresdrop_closures_ChildWatchFuncgenClosure_ChildWatchFuncwrap_ChildWatchFuncvariantGetGtype utf8Validate utf8Substring utf8Struputf8Strreverse utf8Strrchr utf8Strncpy utf8Strlen utf8Strdown utf8Strchr utf8PrevCharutf8PointerToOffsetutf8OffsetToPointer utf8Normalizeutf8GetCharValidated utf8GetCharutf8FindPrevCharutf8FindNextCharutf8CollateKeyForFilenameutf8CollateKey utf8Collate utf8CasefoldusleepuriUnescapeStringuriUnescapeSegmenturiParseSchemeuriListExtractUrisuriEscapeStringunsetenvunlinkunixSignalSourceNew unixSignalAddunixSetFdNonblocking unixOpenPipeunixFdSourceNew unixFdAddFullunixErrorQuarkunicodeScriptToIso15924unicodeScriptFromIso15924unicodeCanonicalOrderingunicodeCanonicalDecompositionunicharXdigitValueunicharValidate unicharTypeunicharToupperunicharTotitleunicharTolowerunicharIszerowidthunicharIsxdigitunicharIswideCjk unicharIswideunicharIsupperunicharIstitleunicharIsspaceunicharIspunctunicharIsprint unicharIsmarkunicharIslowerunicharIsgraphunicharIsdigitunicharIsdefinedunicharIscntrlunicharIsalphaunicharIsalnumunicharGetMirrorCharunicharDigitValueunicharDecomposeunicharComposeunicharCombiningClassunicharBreakType tryReallocN tryRealloc tryMallocN tryMalloc0N tryMalloc0 tryMalloctimeoutSourceNewSecondstimeoutSourceNewtimeoutAddSecondstestTrapReachedTimeouttestTrapHasPassedtestTrapAssertionstestTimerStart testTimerLasttestTimerElapsedtestSubprocesstestSkiptestSetNonfatalAssertions testRunSuitetestRuntestRandIntRange testRandInttestRandDoubleRangetestRandDouble testQueueFreetestQueueDestroytestLogTypeNametestIncomplete testGetDir testFailedtestFailtestExpectMessage testBugBasetestBug"testAssertExpectedMessagesInternal testAddFunctestAddDataFunc strvLength strvGetType strvContainsstrupstrtod strstrLen strsignal strrstrLenstrrstr strreversestrnfillstrndup strncasecmpstrlcpystrlcatstrjoinv stripContextstringSizedNew stringNewLen stringNew strescapestrerrorstrdown strcompressstrcmp0strchugstrchomp strcasecmpstrcanonstrTokenizeAndFold strToAsciistrMatchString strIsAsciistrHash strHasSuffix strHasPrefixstrEqualstpcpyspawnExitErrorQuarkspawnErrorQuarkspawnCommandLineSyncspawnCommandLineAsync spawnClosePidspawnCheckExitStatusspacedPrimesClosestsliceSetConfigsliceGetConfigStatesliceGetConfigsliceFreeChainWithOffset sliceFree1 sliceCopy sliceAlloc0 sliceAlloc shellUnquote shellQuoteshellParseArgvshellErrorQuarksetenvsetErrorLiteralsetApplicationNamermdirreloadUserSpecialDirsCachereallocN randomSetSeedrandomIntRange randomIntrandomDoubleRange randomDoublequarkTryString quarkToStringquarkFromStringquarkFromStaticStringpropagateErrorpollpointerBitUnlockpointerBitTrylockpointerBitLockpatternMatchStringpatternMatchSimple patternMatch pathSkipRootpathIsAbsolutepathGetDirnamepathGetBasenameparseDebugStringoptionErrorQuarkonErrorStackTrace onErrorQuerynullifyPointer mkstempFull mkdtempFullmkdirWithParentsmemdup memSetVtable memProfilememIsSystemMallocmarkupEscapeTextmarkupErrorQuarkmallocNmalloc0N mainDepthlogWriterSupportsColorlogWriterStandardStreamslogWriterJournaldlogWriterIsJournaldlogWriterFormatFieldslogWriterDefault logVariantlogStructuredArray logSetHandlerlogSetAlwaysFatallogRemoveHandlerlogDefaultHandlerlocaleFromUtf8listenv ioCreateWatch internStringinternStaticStringintHashintEqual int64Hash int64Equal idleSourceNewidleRemoveByDataiconvhostnameToUnicodehostnameToAsciihostnameIsNonAsciihostnameIsIpAddresshostnameIsAsciiEncodedgetenvgetUserRuntimeDir getUserNamegetUserConfigDirgetUserCacheDirgetSystemConfigDirs getRealTime getRealNamegetNumProcessorsgetLocaleVariantsgetLanguageNames getHostName getHomeDirgetFilenameCharsets getEnviron getCurrentDir getCodesetformatSizeForDisplayfindProgramInPathfilenameToUtf8 filenameToUrifilenameFromUtf8filenameFromUrifilenameDisplayNamefilenameDisplayBasename fileReadLink fileOpenTmpfileGetContentsfileErrorQuarkfileErrorFromErrnoenvironUnsetenv environSetenv environGetenv dpgettext2 dpgettext doubleHash doubleEqual dngettext directHash directEqualdgettext dcgettextdatasetIdSetDataFulldatasetIdRemoveNoNotifydatasetIdGetDatadatasetDestroydatalistUnsetFlags datalistInitdatalistIdSetDataFulldatalistIdReplaceDatadatalistIdRemoveNoNotifydatalistIdGetDatadatalistGetFlagsdatalistGetData datalistClearconvertWithIconvconvertWithFallbackconvertErrorQuarkcomputeHmacForStringcomputeHmacForDatacomputeHmacForBytescomputeChecksumForStringcomputeChecksumForDatacomputeChecksumForBytesclose clearErrorchildWatchSourceNew checkVersionchdir buildPathvbuildFilenamev bitUnlock bitTrylock bitStorage bitNthMsf bitNthLsfbitLockbasename base64Encodebase64DecodeInplace base64DecodeatomicPointerXoratomicPointerSetatomicPointerOratomicPointerGetatomicPointerCompareAndExchangeatomicPointerAndatomicPointerAdd atomicIntXor atomicIntSet atomicIntOr atomicIntInc atomicIntGetatomicIntExchangeAndAddatomicIntDecAndTestatomicIntCompareAndExchange atomicIntAnd atomicIntAddatexitassertionMessageErrorassertionMessageCmpstrassertionMessage assertWarningasciiXdigitValue asciiStrup asciiStrtoll asciiStrtodasciiStrncasecmp asciiStrdownasciiStrcasecmp asciiFormatdasciiDigitValueaccess newZeroHooknoHook getHookData setHookData clearHookData getHookNext setHookNext clearHookNext getHookPrev setHookPrev clearHookPrevgetHookRefCountsetHookRefCount getHookHookId setHookHookId getHookFlags setHookFlags getHookFunc setHookFunc clearHookFuncgetHookDestroysetHookDestroyclearHookDestroyhookCompareIds hookDestroyhookDestroyLinkhookInsertBefore hookPrepend$fConstructibleHooktag$fWrappedPtrHooknewZeroHookList noHookListgetHookListSeqIdsetHookListSeqIdgetHookListHookSizesetHookListHookSizegetHookListIsSetupsetHookListIsSetupgetHookListHookssetHookListHooksclearHookListHooksgetHookListDummy3setHookListDummy3clearHookListDummy3getHookListFinalizeHooksetHookListFinalizeHookclearHookListFinalizeHook hookListClear hookListInithookListInvokehookListInvokeCheck$fConstructibleHookListtag$fWrappedPtrHookListnoMarkupParseContextmarkupParseContextNewmarkupParseContextEndParsemarkupParseContextFreemarkupParseContextGetElementmarkupParseContextGetUserDatamarkupParseContextParsemarkupParseContextPopmarkupParseContextPushmarkupParseContextRefmarkupParseContextUnref$fBoxedObjectMarkupParseContextnoOptionContextoptionContextAddGroupoptionContextAddMainEntriesoptionContextFreeoptionContextGetDescriptionoptionContextGetHelpoptionContextGetHelpEnabled$optionContextGetIgnoreUnknownOptionsoptionContextGetMainGroupoptionContextGetStrictPosixoptionContextGetSummaryoptionContextParseoptionContextParseStrvoptionContextSetDescriptionoptionContextSetHelpEnabledoptionContextSetMainGroupoptionContextSetStrictPosixoptionContextSetSummaryoptionContextSetTranslateFunc!optionContextSetTranslationDomain$fWrappedPtrOptionContext noOptionGroupoptionGroupAddEntriesoptionGroupFreeoptionGroupRefoptionGroupSetTranslationDomainoptionGroupUnref$fBoxedObjectOptionGroupnewZeroScanner noScannergetScannerUserDatasetScannerUserDataclearScannerUserDatagetScannerMaxParseErrorssetScannerMaxParseErrorsgetScannerParseErrorssetScannerParseErrorsgetScannerInputNamesetScannerInputNameclearScannerInputNamegetScannerQdatasetScannerQdataclearScannerQdatagetScannerConfigsetScannerConfigclearScannerConfiggetScannerTokensetScannerTokengetScannerValuegetScannerLinesetScannerLinegetScannerPositionsetScannerPositiongetScannerNextTokensetScannerNextTokengetScannerNextValuegetScannerNextLinesetScannerNextLinegetScannerNextPositionsetScannerNextPositiongetScannerMsgHandlersetScannerMsgHandlerclearScannerMsgHandlerscannerCurLinescannerCurPositionscannerCurTokenscannerDestroy scannerEofscannerInputFilescannerInputTextscannerLookupSymbolscannerPeekNextTokenscannerScopeAddSymbolscannerScopeLookupSymbolscannerScopeRemoveSymbolscannerSetScopescannerSyncFileOffsetscannerUnexpToken$fConstructibleScannertag$fWrappedPtrScanner newZeroSourcenoSourcesourceAddChildSource sourceAddPoll sourceDestroysourceGetCanRecursesourceGetContextsourceGetCurrentTime sourceGetNamesourceGetPrioritysourceGetReadyTime sourceGetTimesourceIsDestroyedsourceModifyUnixFdsourceQueryUnixFd sourceRefsourceRemoveChildSourcesourceRemovePollsourceRemoveUnixFdsourceSetCallbacksourceSetCallbackIndirectsourceSetCanRecursesourceSetFuncs sourceSetNamesourceSetPrioritysourceSetReadyTime sourceUnrefsourceRemoveByFuncsUserDatasourceRemoveByUserDatasourceSetNameById$fConstructibleSourcetag$fBoxedObjectSourcenewZeroMemVTable noMemVTablegetMemVTableMallocsetMemVTableMallocclearMemVTableMallocgetMemVTableReallocsetMemVTableReallocclearMemVTableReallocgetMemVTableFreesetMemVTableFreeclearMemVTableFreegetMemVTableCallocsetMemVTableCallocclearMemVTableCallocgetMemVTableTryMallocsetMemVTableTryMallocclearMemVTableTryMallocgetMemVTableTryReallocsetMemVTableTryReallocclearMemVTableTryRealloc$fConstructibleMemVTabletag$fWrappedPtrMemVTablenewZeroIOFuncs noIOFuncsgetIOFuncsIoReadsetIOFuncsIoReadclearIOFuncsIoReadgetIOFuncsIoWritesetIOFuncsIoWriteclearIOFuncsIoWritegetIOFuncsIoSeeksetIOFuncsIoSeekclearIOFuncsIoSeekgetIOFuncsIoClosesetIOFuncsIoCloseclearIOFuncsIoClosegetIOFuncsIoCreateWatchsetIOFuncsIoCreateWatchclearIOFuncsIoCreateWatchgetIOFuncsIoFreesetIOFuncsIoFreeclearIOFuncsIoFreegetIOFuncsIoSetFlagssetIOFuncsIoSetFlagsclearIOFuncsIoSetFlagsgetIOFuncsIoGetFlagssetIOFuncsIoGetFlagsclearIOFuncsIoGetFlags$fConstructibleIOFuncstag$fWrappedPtrIOFuncs noMainContextmainContextNewmainContextAcquiremainContextAddPollmainContextCheck$mainContextFindSourceByFuncsUserDatamainContextFindSourceByUserDatamainContextInvokeFullmainContextIsOwnermainContextPendingmainContextPopThreadDefaultmainContextPreparemainContextPushThreadDefaultmainContextQuerymainContextRefmainContextReleasemainContextRemovePollmainContextUnrefmainContextWaitmainContextWakeup$fBoxedObjectMainContextnewZeroMarkupParsernoMarkupParsergetMarkupParserStartElementsetMarkupParserStartElementclearMarkupParserStartElementgetMarkupParserEndElementsetMarkupParserEndElementclearMarkupParserEndElementgetMarkupParserTextsetMarkupParserTextclearMarkupParserTextgetMarkupParserPassthroughsetMarkupParserPassthroughclearMarkupParserPassthroughgetMarkupParserErrorsetMarkupParserErrorclearMarkupParserError$fConstructibleMarkupParsertag$fWrappedPtrMarkupParserQueue newZeroQueuenoQueue getQueueHead setQueueHeadclearQueueHead getQueueTail setQueueTailclearQueueTailgetQueueLengthsetQueueLength queueClear queueFree queueFreeFullqueueGetLength queueIndex queueInit queueIsEmpty queuePeekHead queuePeekNth queuePeekTail queuePopHead queuePopNth queuePopTail queuePushHead queuePushNth queuePushTail queueRemovequeueRemoveAll queueReverse$fConstructibleQueuetag$fWrappedPtrQueuenewZeroSourceCallbackFuncsnoSourceCallbackFuncsgetSourceCallbackFuncsRefsetSourceCallbackFuncsRefclearSourceCallbackFuncsRefgetSourceCallbackFuncsUnrefsetSourceCallbackFuncsUnrefclearSourceCallbackFuncsUnref%$fConstructibleSourceCallbackFuncstag$fWrappedPtrSourceCallbackFuncsnewZeroSourceFuncs noSourceFuncsgetSourceFuncsPreparesetSourceFuncsPrepareclearSourceFuncsPreparegetSourceFuncsChecksetSourceFuncsCheckclearSourceFuncsCheckgetSourceFuncsFinalizesetSourceFuncsFinalizeclearSourceFuncsFinalize$fConstructibleSourceFuncstag$fWrappedPtrSourceFuncsnewZeroThreadPool noThreadPoolgetThreadPoolFuncsetThreadPoolFuncclearThreadPoolFuncgetThreadPoolUserDatasetThreadPoolUserDataclearThreadPoolUserDatagetThreadPoolExclusivesetThreadPoolExclusivethreadPoolFreethreadPoolGetMaxThreadsthreadPoolGetNumThreadsthreadPoolMoveToFrontthreadPoolPushthreadPoolSetMaxThreadsthreadPoolUnprocessedthreadPoolGetMaxIdleTimethreadPoolGetMaxUnusedThreadsthreadPoolGetNumUnusedThreadsthreadPoolSetMaxIdleTimethreadPoolSetMaxUnusedThreads$fConstructibleThreadPooltag$fWrappedPtrThreadPoolpkgConfigVersionsflagsghc-prim GHC.TypesFalseTrueg_mutex_unlockg_mutex_trylock g_mutex_lock g_mutex_init g_mutex_clearbaseGHC.BaseNothing+haskell-gi-base-0.20.4-XzkUxDZnFrtOvlrdDBm4Data.GI.Base.BasicTypesGVariantg_variant_type_string_scang_variant_type_string_is_validg_variant_type_checked_g_variant_type_valueg_variant_type_nextg_variant_type_n_itemsg_variant_type_keyg_variant_type_is_variantg_variant_type_is_tupleg_variant_type_is_subtype_ofg_variant_type_is_maybeg_variant_type_is_dict_entryg_variant_type_is_definiteg_variant_type_is_containerg_variant_type_is_basicg_variant_type_is_arrayg_variant_type_hash g_variant_type_get_string_lengthg_variant_type_freeg_variant_type_firstg_variant_type_equalg_variant_type_elementg_variant_type_dup_stringg_variant_type_copyg_variant_type_new_tupleg_variant_type_new_maybeg_variant_type_new_dict_entryg_variant_type_new_arrayg_variant_type_newc_g_variant_type_get_gtypeg_variant_dict_unrefg_variant_dict_removeg_variant_dict_refg_variant_dict_lookup_valueg_variant_dict_insert_valueg_variant_dict_endg_variant_dict_containsg_variant_dict_clearg_variant_dict_newc_g_variant_dict_get_typeg_variant_builder_unrefg_variant_builder_refg_variant_builder_openg_variant_builder_endg_variant_builder_closeg_variant_builder_add_valueg_variant_builder_newc_g_variant_builder_get_type g_tree_unref g_tree_stealg_tree_replace g_tree_remove g_tree_nnodesg_tree_lookup_extended g_tree_lookup g_tree_insert g_tree_heightg_tree_destroyg_trash_stack_pushg_trash_stack_popg_trash_stack_peekg_trash_stack_height g_timer_stop g_timer_start g_timer_resetg_timer_elapsedg_timer_destroyg_timer_continueg_thread_yield g_thread_self g_thread_exitg_thread_error_quarkg_thread_unref g_thread_ref g_thread_joinc_g_thread_get_typeg_test_log_buffer_pushg_test_log_buffer_freeg_string_chunk_insert_leng_string_chunk_insert_constg_string_chunk_insertg_string_chunk_freeg_string_chunk_clearg_rec_mutex_unlockg_rec_mutex_trylockg_rec_mutex_lockg_rec_mutex_initg_rec_mutex_clearg_rand_set_seed_arrayg_rand_set_seedg_rand_int_range g_rand_int g_rand_freeg_rand_double_range g_rand_doubleg_rw_lock_writer_unlockg_rw_lock_writer_trylockg_rw_lock_writer_lockg_rw_lock_reader_unlockg_rw_lock_reader_trylockg_rw_lock_reader_lockg_rw_lock_initg_rw_lock_clearc_g_ptr_array_get_typeg_main_loop_unrefg_main_loop_rung_main_loop_refg_main_loop_quitg_main_loop_is_runningg_main_loop_get_contextg_main_loop_newc_g_main_loop_get_type g_hmac_update g_hmac_unrefg_hmac_get_stringg_hmac_get_digestg_hash_table_iter_stealg_hash_table_iter_replaceg_hash_table_iter_removeg_hash_table_iter_nextg_hash_table_iter_initg_dir_make_tmp g_dir_rewindg_dir_read_name g_dir_closeg_cond_wait_until g_cond_wait g_cond_signal g_cond_init g_cond_clearg_cond_broadcastg_bookmark_file_error_quarkg_bookmark_file_to_fileg_bookmark_file_to_datag_bookmark_file_set_visitedg_bookmark_file_set_titleg_bookmark_file_set_modifiedg_bookmark_file_set_mime_typeg_bookmark_file_set_is_privateg_bookmark_file_set_icong_bookmark_file_set_groupsg_bookmark_file_set_descriptiong_bookmark_file_set_app_infog_bookmark_file_set_addedg_bookmark_file_remove_itemg_bookmark_file_remove_group"g_bookmark_file_remove_applicationg_bookmark_file_move_itemg_bookmark_file_load_from_file#g_bookmark_file_load_from_data_dirsg_bookmark_file_load_from_datag_bookmark_file_has_itemg_bookmark_file_has_groupg_bookmark_file_has_applicationg_bookmark_file_get_visitedg_bookmark_file_get_urisg_bookmark_file_get_titleg_bookmark_file_get_sizeg_bookmark_file_get_modifiedg_bookmark_file_get_mime_typeg_bookmark_file_get_is_privateg_bookmark_file_get_icong_bookmark_file_get_groupsg_bookmark_file_get_description g_bookmark_file_get_applicationsg_bookmark_file_get_app_infog_bookmark_file_get_addedg_bookmark_file_freeg_bookmark_file_add_groupg_bookmark_file_add_applicationg_time_val_from_iso8601g_time_val_to_iso8601g_time_val_addg_async_queue_unref_and_unlockg_async_queue_unrefg_async_queue_unlockg_async_queue_try_pop_unlockedg_async_queue_try_pop"g_async_queue_timeout_pop_unlockedg_async_queue_timeout_pop g_async_queue_timed_pop_unlockedg_async_queue_timed_popg_async_queue_remove_unlockedg_async_queue_removeg_async_queue_ref_unlockedg_async_queue_push_unlocked!g_async_queue_push_front_unlockedg_async_queue_push_frontg_async_queue_pushg_async_queue_pop_unlockedg_async_queue_popg_async_queue_lockg_async_queue_length_unlockedg_async_queue_lengthg_date_time_hashg_date_time_equalg_date_time_compareg_date_time_unrefg_date_time_to_utcg_date_time_to_unixg_date_time_to_timezoneg_date_time_to_timevalg_date_time_to_localg_date_time_refg_date_time_is_daylight_savingsg_date_time_get_ymdg_date_time_get_yearg_date_time_get_week_of_year#g_date_time_get_week_numbering_yearg_date_time_get_utc_offset%g_date_time_get_timezone_abbreviationg_date_time_get_secondsg_date_time_get_secondg_date_time_get_monthg_date_time_get_minuteg_date_time_get_microsecondg_date_time_get_hourg_date_time_get_day_of_yearg_date_time_get_day_of_weekg_date_time_get_day_of_monthg_date_time_formatg_date_time_differenceg_date_time_add_yearsg_date_time_add_weeksg_date_time_add_secondsg_date_time_add_monthsg_date_time_add_minutesg_date_time_add_hoursg_date_time_add_fullg_date_time_add_daysg_date_time_addg_date_time_new_utcg_date_time_new_now_utcg_date_time_new_now_localg_date_time_new_nowg_date_time_new_localg_date_time_new_from_unix_utcg_date_time_new_from_unix_local g_date_time_new_from_timeval_utc"g_date_time_new_from_timeval_localg_date_time_newc_g_date_time_get_typeg_test_suite_add_suiteg_test_suite_addg_pattern_spec_freeg_pattern_spec_equal g_iconv_closeg_bytes_unref_to_datag_bytes_unref_to_array g_bytes_unref g_bytes_refg_bytes_new_from_bytes g_bytes_hashg_bytes_get_sizeg_bytes_get_data g_bytes_equalg_bytes_compareg_bytes_new_take g_bytes_newc_g_bytes_get_typeg_byte_array_unrefg_byte_array_new_takeg_byte_array_newg_byte_array_free_to_bytesg_byte_array_freec_g_byte_array_get_typeg_mapped_file_unrefg_mapped_file_refg_mapped_file_get_lengthg_mapped_file_get_contentsg_mapped_file_get_bytesg_mapped_file_freeg_mapped_file_new_from_fdg_mapped_file_newc_g_mapped_file_get_type g_string_upg_string_truncateg_string_set_sizeg_string_prepend_unicharg_string_prepend_leng_string_prepend_cg_string_prependg_string_overwrite_leng_string_overwriteg_string_insert_unicharg_string_insert_leng_string_insert_cg_string_insert g_string_hashg_string_free_to_bytes g_string_freeg_string_eraseg_string_equal g_string_downg_string_assigng_string_ascii_upg_string_ascii_downg_string_append_uri_escapedg_string_append_unicharg_string_append_leng_string_append_cg_string_appendc_g_gstring_get_typeg_sequence_iter_is_endg_sequence_iter_is_beging_sequence_iter_get_positiong_sequence_iter_compareg_sequence_swapg_sequence_setg_sequence_remove_rangeg_sequence_removeg_sequence_move_rangeg_sequence_moveg_sequence_getg_sequence_is_emptyg_sequence_get_lengthg_sequence_freec_g_pollfd_get_typeg_match_info_unrefg_match_info_refg_match_info_nextg_match_info_matchesg_match_info_is_partial_matchg_match_info_get_stringg_match_info_get_regexg_match_info_get_match_countg_match_info_freeg_match_info_fetch_posg_match_info_fetch_named_posg_match_info_fetch_namedg_match_info_fetch_allg_match_info_fetchg_match_info_expand_referencesc_g_match_info_get_typec_g_io_condition_get_type g_node_unlinkg_node_reverse_childreng_node_n_nodesg_node_n_childreng_node_max_heightg_node_is_ancestorg_node_destroy g_node_depthg_node_child_positiong_node_child_indexg_key_file_error_quarkg_key_file_unrefg_key_file_to_datag_key_file_set_valueg_key_file_set_uint64g_key_file_set_string_listg_key_file_set_string!g_key_file_set_locale_string_listg_key_file_set_locale_stringg_key_file_set_list_separatorg_key_file_set_integer_listg_key_file_set_integerg_key_file_set_int64g_key_file_set_double_listg_key_file_set_doubleg_key_file_set_commentg_key_file_set_boolean_listg_key_file_set_booleang_key_file_save_to_fileg_key_file_remove_keyg_key_file_remove_groupg_key_file_remove_commentg_key_file_load_from_fileg_key_file_load_from_dirsg_key_file_load_from_data_dirsg_key_file_load_from_datag_key_file_load_from_bytesg_key_file_has_groupg_key_file_get_valueg_key_file_get_uint64g_key_file_get_string_listg_key_file_get_stringg_key_file_get_start_group!g_key_file_get_locale_string_listg_key_file_get_locale_stringg_key_file_get_keysg_key_file_get_integer_listg_key_file_get_integerg_key_file_get_int64g_key_file_get_groupsg_key_file_get_double_listg_key_file_get_doubleg_key_file_get_commentg_key_file_get_boolean_listg_key_file_get_booleang_key_file_newc_g_key_file_get_typeg_regex_split_simpleg_regex_match_simpleg_regex_escape_stringg_regex_escape_nulg_regex_error_quarkg_regex_check_replacement g_regex_unrefg_regex_split_full g_regex_splitg_regex_replace_literalg_regex_replace g_regex_refg_regex_match_fullg_regex_match_all_fullg_regex_match_all g_regex_matchg_regex_get_string_numberg_regex_get_patterng_regex_get_max_lookbehindg_regex_get_max_backrefg_regex_get_match_flagsg_regex_get_has_cr_or_lfg_regex_get_compile_flagsg_regex_get_capture_count g_regex_newc_g_regex_get_typeg_io_channel_error_quarkg_io_channel_error_from_errnog_io_channel_write_unicharg_io_channel_write_charsg_io_channel_writeg_io_channel_unrefg_io_channel_unix_get_fdg_io_channel_shutdowng_io_channel_set_line_termg_io_channel_set_flagsg_io_channel_set_encodingg_io_channel_set_close_on_unrefg_io_channel_set_bufferedg_io_channel_set_buffer_sizeg_io_channel_seek_positiong_io_channel_seekg_io_channel_refg_io_channel_read_unicharg_io_channel_read_to_endg_io_channel_read_lineg_io_channel_read_charsg_io_channel_readg_io_channel_initg_io_channel_get_line_termg_io_channel_get_flagsg_io_channel_get_encodingg_io_channel_get_close_on_unrefg_io_channel_get_bufferedg_io_channel_get_buffer_size!g_io_channel_get_buffer_conditiong_io_channel_flushg_io_channel_closeg_io_channel_unix_newg_io_channel_new_filec_g_io_channel_get_typeg_checksum_type_get_lengthg_checksum_updateg_checksum_resetg_checksum_get_stringg_checksum_freeg_checksum_copyg_checksum_newc_g_checksum_get_typeg_date_valid_yearg_date_valid_weekdayg_date_valid_monthg_date_valid_juliang_date_valid_dmyg_date_valid_dayg_date_strftimeg_date_is_leap_yearg_date_get_sunday_weeks_in_yearg_date_get_monday_weeks_in_yearg_date_get_days_in_month g_date_validg_date_to_struct_tmg_date_subtract_yearsg_date_subtract_monthsg_date_subtract_daysg_date_set_yearg_date_set_time_valg_date_set_time_tg_date_set_timeg_date_set_parseg_date_set_monthg_date_set_juliang_date_set_dmyg_date_set_day g_date_orderg_date_is_last_of_monthg_date_is_first_of_monthg_date_get_yearg_date_get_weekdayg_date_get_sunday_week_of_yearg_date_get_monthg_date_get_monday_week_of_yearg_date_get_juliang_date_get_iso8601_week_of_yearg_date_get_day_of_yearg_date_get_day g_date_freeg_date_days_betweeng_date_compare g_date_clear g_date_clampg_date_add_yearsg_date_add_monthsg_date_add_daysg_date_new_juliang_date_new_dmy g_date_newc_g_date_get_typeg_once_init_leaveg_once_init_enterg_test_log_msg_freeg_time_zone_unrefg_time_zone_refg_time_zone_is_dstg_time_zone_get_offsetg_time_zone_get_abbreviationg_time_zone_find_intervalg_time_zone_adjust_timeg_time_zone_new_utcg_time_zone_new_localg_time_zone_newc_g_time_zone_get_type__dynamic_C_ChildWatchFunc__dynamic_C_CompareDataFunc__dynamic_C_CompareFunc__dynamic_C_CopyFunc__dynamic_C_DataForeachFunc__dynamic_C_DestroyNotify__dynamic_C_DuplicateFunc__dynamic_C_EqualFunc__dynamic_C_FreeFunc__dynamic_C_Func__dynamic_C_HFunc__dynamic_C_HRFunc__dynamic_C_HashFunc__dynamic_C_HookCheckFunc__dynamic_C_HookCheckMarshaller__dynamic_C_HookCompareFunc__dynamic_C_HookFinalizeFunc__dynamic_C_HookFindFunc__dynamic_C_HookFunc__dynamic_C_HookMarshaller__dynamic_C_IOFunc'__dynamic_C_IOFuncsIoCloseFieldCallback-__dynamic_C_IOFuncsIoCreateWatchFieldCallback&__dynamic_C_IOFuncsIoFreeFieldCallback*__dynamic_C_IOFuncsIoGetFlagsFieldCallback&__dynamic_C_IOFuncsIoReadFieldCallback&__dynamic_C_IOFuncsIoSeekFieldCallback*__dynamic_C_IOFuncsIoSetFlagsFieldCallback'__dynamic_C_IOFuncsIoWriteFieldCallback__dynamic_C_LogFunc__dynamic_C_LogWriterFunc/__dynamic_C_MarkupParserEndElementFieldCallback*__dynamic_C_MarkupParserErrorFieldCallback0__dynamic_C_MarkupParserPassthroughFieldCallback1__dynamic_C_MarkupParserStartElementFieldCallback)__dynamic_C_MarkupParserTextFieldCallback(__dynamic_C_MemVTableCallocFieldCallback&__dynamic_C_MemVTableFreeFieldCallback(__dynamic_C_MemVTableMallocFieldCallback)__dynamic_C_MemVTableReallocFieldCallback+__dynamic_C_MemVTableTryMallocFieldCallback,__dynamic_C_MemVTableTryReallocFieldCallback__dynamic_C_NodeForeachFunc__dynamic_C_NodeTraverseFunc__dynamic_C_OptionArgFunc__dynamic_C_OptionErrorFunc__dynamic_C_OptionParseFunc__dynamic_C_PollFunc__dynamic_C_PrintFunc__dynamic_C_RegexEvalCallback__dynamic_C_ScannerMsgFunc#__dynamic_C_SequenceIterCompareFunc/__dynamic_C_SourceCallbackFuncsRefFieldCallback1__dynamic_C_SourceCallbackFuncsUnrefFieldCallback__dynamic_C_SourceDummyMarshal__dynamic_C_SourceFunc)__dynamic_C_SourceFuncsCheckFieldCallback,__dynamic_C_SourceFuncsFinalizeFieldCallback+__dynamic_C_SourceFuncsPrepareFieldCallback__dynamic_C_SpawnChildSetupFunc__dynamic_C_TestDataFunc__dynamic_C_TestFixtureFunc__dynamic_C_TestFunc__dynamic_C_TestLogFatalFunc__dynamic_C_ThreadFunc__dynamic_C_TranslateFunc__dynamic_C_TraverseFunc__dynamic_C_UnixFDSourceFunc__dynamic_C_VoidFuncg_accessg_ascii_digit_valueg_ascii_dtostrg_ascii_formatdg_ascii_strcasecmpg_ascii_strdowng_ascii_strncasecmpg_ascii_strtodg_ascii_strtollg_ascii_strtoull g_ascii_strupg_ascii_tolowerg_ascii_toupperg_ascii_xdigit_valueg_assert_warningg_assertion_messageg_assertion_message_cmpstrg_assertion_message_errorg_atexitg_atomic_int_addg_atomic_int_and!g_atomic_int_compare_and_exchangeg_atomic_int_dec_and_testg_atomic_int_exchange_and_addg_atomic_int_getg_atomic_int_incg_atomic_int_org_atomic_int_setg_atomic_int_xorg_atomic_pointer_addg_atomic_pointer_and%g_atomic_pointer_compare_and_exchangeg_atomic_pointer_getg_atomic_pointer_org_atomic_pointer_setg_atomic_pointer_xorg_base64_decodeg_base64_decode_inplaceg_base64_encode g_basename g_bit_lock g_bit_nth_lsf g_bit_nth_msf g_bit_storage g_bit_trylock g_bit_unlockg_build_filenamev g_build_pathvg_chdirglib_check_versiong_child_watch_add_fullg_child_watch_source_new g_clear_errorg_closeg_compute_checksum_for_bytesg_compute_checksum_for_datag_compute_checksum_for_stringg_compute_hmac_for_bytesg_compute_hmac_for_datag_compute_hmac_for_string g_convertg_convert_error_quarkg_convert_with_fallbackg_convert_with_iconvg_datalist_clearg_datalist_get_datag_datalist_get_flagsg_datalist_id_get_datag_datalist_id_remove_no_notifyg_datalist_id_replace_datag_datalist_id_set_data_fullg_datalist_initg_datalist_set_flagsg_datalist_unset_flagsg_dataset_destroyg_dataset_id_get_datag_dataset_id_remove_no_notifyg_dataset_id_set_data_full g_dcgettext g_dgettextg_direct_equal g_direct_hash g_dngettextg_double_equal g_double_hash g_dpgettext g_dpgettext2g_environ_getenvg_environ_setenvg_environ_unsetenvg_file_error_from_errnog_file_error_quarkg_file_get_contentsg_file_open_tmpg_file_read_linkg_file_set_contents g_file_testg_filename_display_basenameg_filename_display_nameg_filename_from_urig_filename_from_utf8g_filename_to_urig_filename_to_utf8g_find_program_in_path g_format_sizeg_format_size_for_displayg_format_size_fullg_freeg_get_application_name g_get_charset g_get_codesetg_get_current_dirg_get_current_time g_get_environg_get_filename_charsetsg_get_home_dirg_get_host_nameg_get_language_namesg_get_locale_variantsg_get_monotonic_timeg_get_num_processors g_get_prgnameg_get_real_nameg_get_real_timeg_get_system_config_dirsg_get_system_data_dirs g_get_tmp_dirg_get_user_cache_dirg_get_user_config_dirg_get_user_data_dirg_get_user_nameg_get_user_runtime_dirg_get_user_special_dirg_getenvg_hostname_is_ascii_encodedg_hostname_is_ip_addressg_hostname_is_non_asciig_hostname_to_asciig_hostname_to_unicodeg_iconvg_idle_add_fullg_idle_remove_by_datag_idle_source_new g_int64_equal g_int64_hash g_int_equal g_int_hashg_intern_static_stringg_intern_stringg_io_add_watch_fullg_io_create_watch g_listenvg_locale_from_utf8g_locale_to_utf8g_log_default_handlerg_log_remove_handlerg_log_set_always_fatalg_log_set_fatal_maskg_log_set_handler_fullg_log_structured_array g_log_variantg_log_writer_defaultg_log_writer_format_fieldsg_log_writer_is_journaldg_log_writer_journaldg_log_writer_standard_streamsg_log_writer_supports_colorg_main_current_source g_main_depthg_malloc g_malloc0 g_malloc0_n g_malloc_ng_markup_error_quarkg_markup_escape_textg_mem_is_system_malloc g_mem_profileg_mem_set_vtableg_memdupg_mkdir_with_parents g_mkdtempg_mkdtemp_full g_mkstempg_mkstemp_fullg_nullify_pointerg_on_error_queryg_on_error_stack_traceg_option_error_quarkg_parse_debug_stringg_path_get_basenameg_path_get_dirnameg_path_is_absoluteg_path_skip_rootg_pattern_matchg_pattern_match_simpleg_pattern_match_stringg_pointer_bit_lockg_pointer_bit_trylockg_pointer_bit_unlockg_pollg_propagate_errorg_quark_from_static_stringg_quark_from_stringg_quark_to_stringg_quark_try_stringg_random_doubleg_random_double_range g_random_intg_random_int_rangeg_random_set_seed g_realloc g_realloc_n g_reload_user_special_dirs_cacheg_rmdirg_set_application_nameg_set_error_literal g_set_prgnameg_setenvg_shell_error_quarkg_shell_parse_argv g_shell_quoteg_shell_unquote g_slice_allocg_slice_alloc0 g_slice_copy g_slice_free1g_slice_free_chain_with_offsetg_slice_get_configg_slice_get_config_stateg_slice_set_configg_spaced_primes_closest g_spawn_asyncg_spawn_async_with_pipesg_spawn_check_exit_statusg_spawn_close_pidg_spawn_command_line_asyncg_spawn_command_line_syncg_spawn_error_quarkg_spawn_exit_error_quark g_spawn_syncg_stpcpy g_str_equalg_str_has_prefixg_str_has_suffix g_str_hashg_str_is_asciig_str_match_stringg_str_to_asciig_str_tokenize_and_fold g_strcanon g_strcasecmp g_strchomp g_strchug g_strcmp0 g_strcompress g_strdelimit g_strdowng_strdup g_strerror g_strescape g_strfreev g_string_newg_string_new_leng_string_sized_newg_strip_context g_strjoinv g_strlcat g_strlcpy g_strncasecmp g_strndup g_strnfill g_strreverse g_strrstr g_strrstr_len g_strsignal g_strstr_leng_strtodg_strupg_strv_containsg_strv_get_type g_strv_lengthg_test_add_data_funcg_test_add_func(g_test_assert_expected_messages_internal g_test_bugg_test_bug_baseg_test_expect_message g_test_fail g_test_failedg_test_get_dirg_test_incompleteg_test_log_type_nameg_test_queue_destroyg_test_queue_freeg_test_rand_doubleg_test_rand_double_rangeg_test_rand_intg_test_rand_int_range g_test_rung_test_run_suiteg_test_set_nonfatal_assertions g_test_skipg_test_subprocessg_test_timer_elapsedg_test_timer_lastg_test_timer_startg_test_trap_assertionsg_test_trap_forkg_test_trap_has_passedg_test_trap_reached_timeoutg_test_trap_subprocessg_timeout_add_fullg_timeout_add_seconds_fullg_timeout_source_newg_timeout_source_new_seconds g_try_malloc g_try_malloc0g_try_malloc0_ng_try_malloc_n g_try_reallocg_try_realloc_ng_unichar_break_typeg_unichar_combining_classg_unichar_composeg_unichar_decomposeg_unichar_digit_valueg_unichar_get_mirror_charg_unichar_get_scriptg_unichar_isalnumg_unichar_isalphag_unichar_iscntrlg_unichar_isdefinedg_unichar_isdigitg_unichar_isgraphg_unichar_islowerg_unichar_ismarkg_unichar_isprintg_unichar_ispunctg_unichar_isspaceg_unichar_istitleg_unichar_isupperg_unichar_iswideg_unichar_iswide_cjkg_unichar_isxdigitg_unichar_iszerowidthg_unichar_tolowerg_unichar_totitleg_unichar_toupperg_unichar_typeg_unichar_validateg_unichar_xdigit_value!g_unicode_canonical_decompositiong_unicode_canonical_orderingg_unicode_script_from_iso15924g_unicode_script_to_iso15924g_unix_error_quarkg_unix_fd_add_fullg_unix_fd_source_newg_unix_open_pipeg_unix_set_fd_nonblockingg_unix_signal_add_fullg_unix_signal_source_newg_unlink g_unsetenvg_uri_escape_stringg_uri_list_extract_urisg_uri_parse_schemeg_uri_unescape_segmentg_uri_unescape_stringg_usleepg_utf8_casefoldg_utf8_collateg_utf8_collate_keyg_utf8_collate_key_for_filenameg_utf8_find_next_charg_utf8_find_prev_charg_utf8_get_charg_utf8_get_char_validatedg_utf8_normalizeg_utf8_offset_to_pointerg_utf8_pointer_to_offsetg_utf8_prev_char g_utf8_strchrg_utf8_strdown g_utf8_strleng_utf8_strncpyg_utf8_strrchrg_utf8_strreverse g_utf8_strupg_utf8_substringg_utf8_validateg_variant_get_gtype g_hook_unrefg_hook_prependg_hook_insert_before g_hook_freeg_hook_destroy_linkg_hook_destroyg_hook_compare_idsg_hook_list_invoke_checkg_hook_list_invokeg_hook_list_initg_hook_list_clearg_markup_parse_context_unrefg_markup_parse_context_refg_markup_parse_context_pushg_markup_parse_context_popg_markup_parse_context_parse$g_markup_parse_context_get_user_data"g_markup_parse_context_get_elementg_markup_parse_context_free g_markup_parse_context_end_parseg_markup_parse_context_new!c_g_markup_parse_context_get_type'g_option_context_set_translation_domain#g_option_context_set_translate_funcg_option_context_set_summary!g_option_context_set_strict_posixg_option_context_set_main_group+g_option_context_set_ignore_unknown_options!g_option_context_set_help_enabled g_option_context_set_descriptiong_option_context_parse_strvg_option_context_parseg_option_context_get_summary!g_option_context_get_strict_posixg_option_context_get_main_group+g_option_context_get_ignore_unknown_options!g_option_context_get_help_enabledg_option_context_get_help g_option_context_get_descriptiong_option_context_free!g_option_context_add_main_entriesg_option_context_add_groupg_option_group_unref%g_option_group_set_translation_domain!g_option_group_set_translate_funcg_option_group_refg_option_group_freeg_option_group_add_entriesg_option_group_newc_g_option_group_get_typeg_scanner_unexp_tokeng_scanner_sync_file_offsetg_scanner_set_scopeg_scanner_scope_remove_symbolg_scanner_scope_lookup_symbolg_scanner_scope_add_symbolg_scanner_peek_next_tokeng_scanner_lookup_symbolg_scanner_input_textg_scanner_input_fileg_scanner_get_next_token g_scanner_eofg_scanner_destroyg_scanner_cur_tokeng_scanner_cur_positiong_scanner_cur_lineg_source_set_name_by_idg_source_remove_by_user_data"g_source_remove_by_funcs_user_datag_source_removeg_source_unrefg_source_set_ready_timeg_source_set_priorityg_source_set_nameg_source_set_funcsg_source_set_can_recurseg_source_set_callback_indirectg_source_set_callbackg_source_remove_unix_fdg_source_remove_pollg_source_remove_child_source g_source_refg_source_query_unix_fdg_source_modify_unix_fdg_source_is_destroyedg_source_get_timeg_source_get_ready_timeg_source_get_priorityg_source_get_nameg_source_get_idg_source_get_current_timeg_source_get_contextg_source_get_can_recurseg_source_destroyg_source_attachg_source_add_unix_fdg_source_add_pollg_source_add_child_source g_source_newc_g_source_get_type!g_main_context_ref_thread_default!g_main_context_get_thread_defaultg_main_context_defaultg_main_context_wakeupg_main_context_waitg_main_context_unrefg_main_context_remove_pollg_main_context_releaseg_main_context_refg_main_context_query"g_main_context_push_thread_defaultg_main_context_prepare!g_main_context_pop_thread_defaultg_main_context_pendingg_main_context_iterationg_main_context_is_ownerg_main_context_invoke_full'g_main_context_find_source_by_user_data g_main_context_find_source_by_id-g_main_context_find_source_by_funcs_user_datag_main_context_dispatchg_main_context_checkg_main_context_add_pollg_main_context_acquireg_main_context_newc_g_main_context_get_typeg_queue_reverseg_queue_remove_allg_queue_removeg_queue_push_tailg_queue_push_nthg_queue_push_headg_queue_pop_tailg_queue_pop_nthg_queue_pop_headg_queue_peek_tailg_queue_peek_nthg_queue_peek_headg_queue_is_empty g_queue_init g_queue_indexg_queue_get_lengthg_queue_free_full g_queue_free g_queue_clear!g_thread_pool_stop_unused_threads$g_thread_pool_set_max_unused_threadsg_thread_pool_set_max_idle_time$g_thread_pool_get_num_unused_threads$g_thread_pool_get_max_unused_threadsg_thread_pool_get_max_idle_timeg_thread_pool_unprocessedg_thread_pool_set_max_threadsg_thread_pool_pushg_thread_pool_move_to_frontg_thread_pool_get_num_threadsg_thread_pool_get_max_threadsg_thread_pool_freeData.GI.Base.GTypeGType gtypeToCGTypeData.GI.Base.Signalsafteron SignalProxyPropertyNotifyData.GI.Base.ConstructiblenewData.GI.Base.GObjectnew'Data.GI.Base.AttributesgetsetAttrOp:=:=>:~:~>::=::~Data.GI.Base.GVariantgvariantToTuplegvariantFromTuplegvariantToListgvariantFromList gvariantToMapgvariantFromMapgvariantToDictEntrygvariantFromDictEntrygvariantToMaybegvariantFromMaybegvariantFromBytestringgvariantToBytestringgvariantToGVariantgvariantFromGVariantgvariantToSignaturegvariantFromSignaturegvariantSignatureToTextnewGVariantSignaturegvariantToObjectPathgvariantFromObjectPathgvariantObjectPathToTextnewGVariantObjectPathgvariantFromTextgvariantToTextgvariantToDoublegvariantFromDoublegvariantToHandlegvariantFromHandlegvariantToWord64gvariantFromWord64gvariantToInt64gvariantFromInt64gvariantToWord32gvariantFromWord32gvariantToInt32gvariantFromInt32gvariantToWord16gvariantFromWord16gvariantToInt16gvariantFromInt16gvariantToWord8gvariantFromWord8gvariantToBoolgvariantFromBooldisownGVariant unrefGVariantnewGVariantFromPtrwrapGVariantPtrgvariantGetTypeString noGVariant IsGVariant toGVariant fromGVarianttoGVariantFormatStringIsGVariantBasicTypeGVariantSingletGVariantHandleGVariantObjectPathGVariantSignatureGVariantDictEntryData.GI.Base.GValueGValueIsGValuetoGValue fromGValuemaybePokeGError checkGErrorpropagateGErrorhandleGErrorJustDomainhandleGErrorJustcatchGErrorJustDomaincatchGErrorJust gerrorMessage gerrorCode gerrorDomain gerrorNew GErrorDomain GErrorCode GErrorMessage GErrorClassgerrorClassDomainData.GI.Base.BasicConversions mapGSListmapGList mapPtrArray mapGArraymapCArrayWithLengthunpackBoxedArrayWithLengthunpackBlockArrayWithLengthpackBlockArraymapZeroTerminatedCArrayunpackZeroTerminatedPtrArrayunpackPtrArrayWithLengthpackZeroTerminatedPtrArray packPtrArraycstringToByteStringbyteStringToCString cstringToTextwithTextCString textToCStringcstringToStringstringToCStringunpackFileNameArrayWithLength!unpackZeroTerminatedFileNameArraypackZeroTerminatedFileNameArraypackFileNameArrayunpackUTF8CArrayWithLengthunpackZeroTerminatedUTF8CArraypackZeroTerminatedUTF8CArraypackUTF8CArray$unpackMapZeroTerminatedStorableArray unpackMapStorableArrayWithLength"packMapZeroTerminatedStorableArraypackMapStorableArray!unpackZeroTerminatedStorableArrayunpackStorableArrayWithLengthpackZeroTerminatedStorableArraypackStorableArrayunpackZeroTerminatedByteStringunpackByteStringWithLengthpackZeroTerminatedByteStringpackByteStringunpackGHashTablepackGHashTableunpackGByteArraypackGByteArrayunpackGPtrArray packGPtrArray unpackGArray packGArray unpackGSList packGSList unpackGList packGList wordToGFlags gflagsToWord unrefGArray unrefPtrArrayunrefGByteArrayunrefGHashTableData.GI.Base.Closure newCClosure noClosureClosureData.GI.Base.ManagedPtr copyBytesnewPtrwrapPtr disownBoxed freeBoxed copyBoxedPtr copyBoxed wrapBoxednewBoxed disownObject unrefObject wrapObject newObject unsafeCastTocastTotouchManagedPtrunsafeManagedPtrCastPtrunsafeManagedPtrGetPtr withTransientwithManagedPtrListmaybeWithManagedPtrwithManagedPtrdisownManagedPtrnewManagedPtr' newManagedPtrData.GI.Base.GHashTablecstringUnpackPtrcstringPackPtr ptrUnpackPtr ptrPackPtr gDirectHash gDirectEqualgStrHash gStrEqual GHashFunc GEqualFunc g_list_free g_slist_free ManagedPtrmanagedForeignPtrmanagedPtrIsDisownedManagedPtrNewtype BoxedObject boxedType BoxedEnum boxedEnumType BoxedFlagsboxedFlagsType WrappedPtrwrappedPtrCallocwrappedPtrCopywrappedPtrFreeGObject gobjectTypeUnexpectedNullPointerReturnnullPtrErrorMsg NullToNothing nullToNothing GParamSpecIsGFlagGArray GPtrArray GByteArray GHashTableGListGSList PtrWrapped unwrapPtrGDestroyNotifygtypeByteArray gtypeStrv gtypeGType gtypeVariant gtypeInvalid gtypeObject gtypeBoxed gtypeBoolean gtypeDouble gtypeFloat gtypeUInt64 gtypeInt64 gtypeULong gtypeLong gtypeUIntgtypeInt gtypePointer gtypeString gtypeNameCGType