Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/docs/typelib-format.txt
blob: 68125cdf91c569310120547cd53c57ac67f117c2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
GObject binary typelib for introspection
-----------------------------------------

Version 0.9

Changes since 0.8:
- Add class struct concept to ObjectBlob
- Add is_class_struct bit to StructBlob

Changes since 0.7:
- Add dependencies

Changes since 0.6:
- rename metadata to typelib, to follow xpcom terminology

Changes since 0.5:
- basic type cleanup:
  + remove GString
  + add [u]int, [u]long, [s]size_t
  + rename string to utf8, add filename
- allow blob_type to be zero for non-local entries

Changes since 0.4:
- add a UnionBlob

Changes since 0.3:
- drop short_name for ValueBlob

Changes since 0.2:
- make inline types 4 bytes after all, remove header->types and allow
  types to appear anywhere
- allow error domains in the directory

Changes since 0.1:

- drop comments about _GOBJ_METADATA
- drop string pool, strings can appear anywhere
- use 'blob' as collective name for the various blob types
- rename 'type' field in blobs to 'blob_type'
- rename 'type_name' and 'type_init' fields to 'gtype_name', 'gtype_init'
- shrink directory entries to 12 bytes 
- merge struct and boxed blobs
- split interface blobs into enum, object and interface blobs
- add an 'unregistered' flag to struct and enum blobs
- add a 'wraps_vfunc' flag to function blobs and link them to 
  the vfuncs they wrap
- restrict value blobs to only occur inside enums and flags again
- add constant blobs, allow them toplevel, in interfaces and in objects
- rename 'receiver_owns_value' and 'receiver_owns_container' to
  'transfer_ownership' and 'transfer_container_ownership'
- add a 'struct_offset' field to virtual function and field blobs
- add 'dipper' and 'optional' flags to arg blobs
- add a 'true_stops_emit' flag to signal blobs
- add variable blob sizes to header
- store offsets to signature blobs instead of including them directly
- change the type offset to be measured in words rather than bytes


Typelib
--------

The format of GObject typelib is strongly influenced by the Mozilla XPCOM 
format. 

Some of the differences to XPCOM include:
- Type information is stored not quite as compactly (XPCOM stores it inline 
  in function descriptions in variable-sized blobs of 1 to n bytes. We store 
  16 bits of type information for each parameter, which is enough to encode 
  simple types inline. Complex (e.g. recursive) types are stored out of line 
  in a separate list of types.
- String and complex type data is stored outside of typelib entry blobs, 
  references are stored as offsets relative to the start of the typelib. 
  One possibility is to store the strings and types in a pools at the end 
  of the typelib.

Overview
--------

The typelib has the following general format.

typelib ::= header, directory, blobs, annotations

directory ::= list of entries

entry ::= blob type, name, namespace, offset

blob ::= function|callback|struct|boxed|enum|flags|object|interface|constant|errordomain|union

annotations ::= list of annotations, sorted by offset 

annotation ::= offset, key, value


Details
-------

We describe the fragments that make up the typelib in the form of C structs 
(although some fall short of being valid C structs since they contain multiple
flexible arrays).

Header (70 bytes)

struct Header 
{
  gchar[16] magic;
  guint8    major_version;
  guint8    minor_version;
  guint16   reserved;

  guint16   n_entries;
  guint16   n_local_entries;
  guint32   directory;
  guint32   annotations;

  guint32   dependencies;

  guint32   size;
  guint32   namespace;
  guint32   nsversion;
  
  guint16   entry_blob_size;        /* 12 */
  guint16   function_blob_size;     /* 16 */
  guint16   callback_blob_size;     /* 12 */
  guint16   signal_blob_size;       /* 12 */
  guint16   vfunc_blob_size;        /* 16 */
  guint16   arg_blob_size;          /* 12 */
  guint16   property_blob_size;     /* 12 */
  guint16   field_blob_size;        /* 12 */  
  guint16   value_blob_size;        /* 16 */
  guint16   constant_blob_size;     /* 20 */
  guint16   error_domain_blob_size; /* 16 */
  guint16   annotation_blob_size;   /* 12 */

  guint16   signature_blob_size;    /*  4 */
  guint16   enum_blob_size;         /* 20 */
  guint16   struct_blob_size;       /* 20 */
  guint16   object_blob_size;       /* 32 */
  guint16   interface_blob_size;    /* 28 */
  guint16   union_blob_size;        /* 28 */
}

magic:    The string "GOBJ\nMETADATA\r\n\032". This was inspired by XPCOM, 
          which in turn borrowed from PNG.

major_version, 
minor_version: 
          The version of the typelib format. Minor version changes indicate 
          compatible changes and should still allow the typelib to be parsed 
          by a parser designed for the same major_version.
      
n_entries: 
          The number of entries in the directory. 

n_local_entries:
	  The number of entries referring to blobs in this typelib. The
	  local entries must occur before the unresolved entries.

directory: 
          Offset of the directory in the typelib. 
          FIXME: need to specify if and how the directory is sorted

annotations: 
          Offset of the list of annotations in the typelib.

dependencies:
          Offset of a single string, which is the list of
          dependencies, separated by the '|' character.  The
          dependencies are required in order to avoid having programs
          consuming a typelib check for an "Unresolved" type return
          from every API call.

size:     The size of the typelib.

namespace:
          Offset of the namespace string in the typelib. 
nsversion:
          Offset of the namespace version string in the typelib. 

entry_blob_size:
function_blob_size:
callback_blob_size:
signal_blob_size:
vfunc_blob_size:
arg_blob_size:
property_blob_size:
field_blob_size:
value_blob_size:
annotation_blob_size:
constant_blob_size:
          The sizes of fixed-size blobs. Recording this information here
          allows to write parser which continue to work if the format is
          extended by adding new fields to the end of the fixed-size blobs.

signature_blob_size: 
enum_blob_size:
struct_blob_size:
interface_blob_size:
          For variable-size blobs, the size of the struct up to the first
          flexible array member. Recording this information here allows to 
          write parser which continue to work if the format is extended by 
          adding new fields before the first flexible array member in 
          variable-size blobs.


Directory entry (12 bytes)

References to directory entries are stored as 1-based 16-bit indexes.

struct DirectoryEntry 
{
  guint16 blob_type;

  guint   is_local : 1;
  guint   reserved :15;

  guint32 name;
  guint32 offset;
}

blob_type:
          The type of blob this entry points to:
	  0 unknown (allowed only for non-local entries)
          1 function
          2 callback
          3 struct
          4 boxed
          5 enum
          6 flags
          7 object
          8 interface
          9 constant
	 10 errordomain
	 	 

is_local: Whether this entry refers to a blob in this typelib.

name:     The name of the entry.

offset:   If is_local is set, this is the offset of the blob in the typelib.
          Otherwise, it is the offset of the namespace in which the blob has
          to be looked up by name.


All blobs pointed to by a directory entry start with the same layout for 
the first 8 bytes (the reserved flags may be used by some blob types)

struct InterfacePrefix 
{
  guint16 blob_type; 
  guint   deprecated : 1;
  guint   reserved   :15;
  guint32 name;
}

blob_type: 
          An integer specifying the type of the blob, see DirectoryEntry 
          for details.

deprecated: 
          Whether the blob is deprecated.

name:     The name of the blob.


The SignatureBlob is shared between Functions, 
Callbacks, Signals and VirtualFunctions.

SignatureBlob (8 + 12 * n_arguments bytes)

struct SignatureBlob 
{
  SimpleTypeBlob    return_type;

  guint             may_return_null              : 1;
  guint             caller_owns_return_value     : 1;
  guint             caller_owns_return_container : 1;
  guint             reserved                     :13;

  guint16           n_arguments;

  ArgBlob[]         arguments;
}
 

return_type:
          Describes the type of the return value. See details below.

may_return_null:
          Only relevant for pointer types. Indicates whether the caller
          must expect NULL as a return value.

caller_owns_return_value:
          If set, the caller is responsible for freeing the return value
          if it is no longer needed.

caller_owns_return_container:
          This flag is only relevant if the return type is a container type.
          If the flag is set, the caller is resonsible for freeing the 
          container, but not its contents.
                     
n_arguments:
          The number of arguments that this function expects, also the length 
          of the array of ArgBlobs.

arguments: 
          An array of ArgBlob for the arguments of the function.


FunctionBlob (20 bytes)

struct FunctionBlob 
{
  guint16 blob_type;  /* 1 */

  guint   deprecated     : 1;
  guint   is_setter      : 1; 
  guint   is_getter      : 1;
  guint   is_constructor : 1;
  guint   wraps_vfunc    : 1;
  guint   throws         : 1;
  guint   index          :10;

  guint32 name;
  guint32 c_name;
  guint32 signature;
  guint   is_static      : 1;
  guint   reserved       : 31;
}

c_name:   The symbol which can be used to obtain the function pointer with 
          dlsym().

deprecated
          The function is deprecated.

is_setter
          The function is a setter for a property. Language bindings may 
          prefer to not bind individual setters and rely on the generic 
          g_object_set().

is_getter
          The function is a getter for a property. Language bindings may 
          prefer to not bind individual getters and rely on the generic 
          g_object_get().

is_constructor
          The function acts as a constructor for the object it is contained 
          in. 

wraps_vfunc: 
          The function is a simple wrapper for a virtual function.

index:    Index of the property that this function is a setter or getter of 
          in the array of properties of the containing interface, or index
          of the virtual function that this function wraps.

signature: 
          Offset of the SignatureBlob describing the parameter types and the 
          return value type.

is_static
          The function is a "static method"; in other words it's a pure
	  function whose name is conceptually scoped to the object.


CallbackBlob (12 bytes)

struct CallbackBlob 
{
  guint16 blob_type;  /* 2 */

  guint   deprecated : 1;
  guint   reserved   :15;

  guint32 name;
  guint32 signature;
}

signature: 
          Offset of the SignatureBlob describing the parameter types and the 
          return value type.


ArgBlob (12 bytes)

struct ArgBlob 
{
  guint32 name;

  guint          in                           : 1;
  guint          out                          : 1;
  guint          dipper                       : 1;
  guint          allow_none                   : 1;
  guint          optional                     : 1;
  guint          transfer_ownership           : 1;
  guint          transfer_container_ownership : 1;
  guint          is_return_value              : 1;
  guint          scope                        : 3;
  guint          reserved                     :21:

  gint8        closure;
  gint8        destroy;

  SimpleTypeBlob arg_type;
}

name:     A suggested name for the parameter. 

in:       The parameter is an input to the function

out:      The parameter is used to return an output of the function. 
          Parameters can be both in and out. Out parameters implicitly 
          add another level of indirection to the parameter type. Ie if 
          the type is uint32 in an out parameter, the function actually 
          takes an uint32*.

dipper:   The parameter is a pointer to a struct or object that will 
          receive an output of the function. 

allow_none:
          Only meaningful for types which are passed as pointers.
          For an in parameter, indicates if it is ok to pass NULL in, for 
          an out parameter, whether it may return NULL. Note that NULL is a 
          valid GList and GSList value, thus allow_none will normally be set
          for parameters of these types.

optional:          
          For an out parameter, indicates that NULL may be passed in
          if the value is not needed.

transfer_ownership:
          For an in parameter, indicates that the function takes over 
          ownership of the parameter value. For an out parameter, it 
          indicates that the caller is responsible for freeing the return 
          value.

transfer_container_ownership:
          For container types, indicates that the ownership of the container, 
          but not of its contents is transferred. This is typically the case 
          for out parameters returning lists of statically allocated things.

is_return_value:
          The parameter should be considered the return value of the function. 
          Only out parameters can be marked as return value, and there can be 
          at most one per function call. If an out parameter is marked as 
          return value, the actual return value of the function should be 
          either void or a boolean indicating the success of the call.

scope: 
	  If the parameter is of a callback type, this denotes the scope
	  of the user_data and the callback function pointer itself
	  (for languages that emit code at run-time).

	    0 invalid -- the argument is not of callback type
	    1 call -- the callback and associated user_data is 
	      only used during the call to this function
	    2 object -- the callback and associated user_data is 
	      used until the object containing this method is destroyed
	    3 async -- the callback and associated user_data is 
	      only used until the callback is invoked, and the callback 
	      is invoked always exactly once.
	    4 notified -- the callback and and associated user_data is
	      used until the caller is notfied via the destroy_notify

closure:
	  Index of the closure (user_data) parameter associated with the callback, 
	  or -1.

destroy:
	  Index of the destroy notfication callback parameter associated with 
	  the callback, or -1.

arg_type:
          Describes the type of the parameter. See details below.


Types are specified by four bytes. If the three high bytes are zero,
the low byte describes a basic type, otherwise the 32bit number is an
offset which points to a TypeBlob.


SimpleTypeBlob (4 bytes)

union SimpleTypeBlob 
{
  struct 
  {
    guint  reserved   :24;      /* 0 */
    guint  is_pointer : 1;
    guint  reserved   : 2;
    guint  tag        : 5;
  };
  guint32 offset;
}

is_pointer: 
          indicates whether the type is passed by reference. 

tag:      specifies what kind of type is described, as follows:
          0  void
          1  boolean (booleans are passed as ints)
          2  int8
          3  uint8
          4  int16
          5  uint16
          6  int32
          7  uint32
          8  int64
          9  uint64
         10  int
         11  uint 
         12  long
         13  ulong
         14  ssize_t
         15  size_t
         16  float
         17  double
	 18  time_t
	 19  GType
         20  utf8     (these are zero-terminated char[] and assumed to be 
                       in UTF-8)
         21  filename (these are zero-terminated char[] and assumed to be
                       in the GLib filename encoding)

         For utf8 and filename is_pointer will always be set.

offset:  Offset relative to header->types that points to a TypeBlob. 
         Unlike other offsets, this is in words (ie 32bit units) rather
         than bytes.


TypeBlob (4 or more bytes)

union TypeBlob
{
  ArrayTypeBlob        array_type;
  InterfaceTypeBlob    interface_type;
  ParameterTypeBlob    parameter_type;  
  ErrorTypeBlob        error_type;  
}


ArrayTypeBlob (4 bytes)

Arrays have a tag value of 20. They are passed by reference, thus is_pointer 
is always 1.

struct ArrayTypeBlob 
{
  guint          is_pointer      :1; /* 1 */
  guint          reserved        :2;
  guint          tag             :5; /* 20 */
  guint          zero_terminated :1;
  guint          has_length      :1;
  guint          length          :6;  

  SimpleTypeBlob type;
}

zero_terminated: 
          Indicates that the array must be terminated by a suitable NULL 
          value. 

has_length: 
          Indicates that length points to a parameter specifying the length 
          of the array. If both has_length and zero_terminated are set, the 
          convention is to pass -1 for the length if the array is 
          zero-terminated. 
          FIXME: what does this mean for types of field and properties ?

length:   The index of the parameter which is used to pass the length of the 
          array. The parameter must be an integer type and have the same 
          direction as this one. 

type:     The type of the array elements.


InterfaceTypeBlob (4 bytes)

struct InterfaceTypeBlob 
{
  guint   is_pointer :1; 
  guint   reserved   :2;
  guint   tag        :5; /* 21 */
  guint8  reserved;

  guint16 interface;
}

Types which are described by an entry in the typelib have a tag value of 21. 
If the interface is an enum of flags type, is_pointer is 0, otherwise it is 1.

interface: 
          Index of the directory entry for the interface.
    

ParameterTypeBlob (4 + n * 4 bytes)

GLists have a tag value of 22, GSLists have a tag value of 23, GHashTables have a
tag value of 24. They are passed by reference, thus is_pointer is always 1.

struct ParameterTypeBlob 
{
  guint          is_pointer :1; /* 1 */
  guint          reserved   :2;
  guint          tag        :5; /* 22, 23 or 24 */
  guint          reserved   :8;

  guint16        n_types;

  SimpleTypeBlob type[];
}

n_types:  The number of parameter types to follow.

type:     Describes the type of the list elements.


ErrorTypeBlob (4 + 2 * n_domains bytes)

struct ErrorTypeBlob
{
  guint           is_pointer :1; /* 1 */
  guint           reserved   :2;
  guint           tag        :5; /* 25 */
  
  guint8          reserved;

  guint16         n_domains;

  guint16         domains[];
}

n_domains:
          The number of domains to follow

domains:  Indices of the directory entries for the error domains


ErrorDomainBlob (16 bytes)

struct ErrorDomainBlob
{
  guint16        blob_type;  /* 10 */

  guint          deprecated     : 1;
  guint          reserved       :15; 

  guint32        name;

  guint32        get_quark;
  guint16        error_codes;
}

get_quark:
          The symbol name of the function which must be called to obtain the 
          GQuark for the error domain.

error_codes:
          Index of the InterfaceBlob describing the enumeration which lists
          the possible error codes.


PropertyBlob (12 bytes)

struct PropertyBlob
{
  guint32        name;

  guint          deprecated     : 1;
  guint          readable       : 1;
  guint          writable       : 1;
  guint          construct      : 1;
  guint          construct_only : 1;
  guint          reserved       :27

  SimpleTypeBlob type;
}

name:     The name of the property. 

readable:
writable: 
construct: 
construct_only: 
          The ParamFlags used when registering the property.

type:     Describes the type of the property.


SignalBlob (12 bytes)

struct SignalBlob 
{
  guint32 name;

  guint   deprecated        : 1;
  guint   run_first         : 1;
  guint   run_last          : 1;
  guint   run_cleanup       : 1;
  guint   no_recurse        : 1;
  guint   detailed          : 1;
  guint   action            : 1;
  guint   no_hooks          : 1;
  guint   has_class_closure : 1;
  guint   true_stops_emit   : 1;
  guint   reserved          : 5;

  guint16 class_closure;
  guint32 signature; 
}

name:     The name of the signal.

run_first:
run_last:
run_cleanup:
no_recurse:
detailed:
action:
no_hooks: The flags used when registering the signal.

has_class_closure: 
          Set if the signal has a class closure.

true_stops_emit:
          Whether the signal has true-stops-emit semantics          

class_closure: 
          The index of the class closure in the list of virtual functions
          of the object or interface on which the signal is defined.

signature: 
          Offset of the SignatureBlob describing the parameter types and the 
          return value type.


VirtualFunctionBlob (16 bytes)

struct VirtualFunctionBlob 
{
  guint32 name;

  guint   must_chain_up           : 1;
  guint   must_be_implemented     : 1;
  guint   must_not_be_implemented : 1;
  guint   is_class_closure        : 1;
  guint   reserved                :12;

  guint16 signal;
  guint16 struct_offset;
  guint16 reserved;  
  guint32 signature;
}

name:     The name of the virtual function.

must_chain_up:
          If set, every implementation of this virtual function must
          chain up to the implementation of the parent class. 

must_be_implemented:
          If set, every derived class must override this virtual function.

must_not_be_implemented:
          If set, derived class must not override this virtual function.

is_class_closure:
          Set if this virtual function is the class closure of a signal.

signal: 
          The index of the signal in the list of signals of the object or 
	  interface to which this virtual function belongs.

struct_offset:
          The offset of the function pointer in the class struct. The value
	  0xFFFF indicates that the struct offset is unknown.

signature: 
          Offset of the SignatureBlob describing the parameter types and the 
          return value type.


FieldBlob (12 bytes)

struct FieldBlob 
{
  guint32        name;

  guint          readable : 1; 
  guint          writable : 1;
  guint          reserved : 6;
  guint8         bits;
  
  guint16        struct_offset;      
	
  SimpleTypeBlob type;
}

name:     The name of the field.

readable:
writable: How the field may be accessed.

bits:     If this field is part of a bitfield, the number of bits which it
          uses, otherwise 0.

struct_offset:
          The offset of the field in the struct. The value 0xFFFF indicates
	  that the struct offset is unknown.

type:     The type of the field.


ValueBlob (12 bytes)

Values commonly occur in enums and flags.

struct ValueBlob
{
  guint   deprecated : 1;
  guint   reserved   :31;
  guint32 name;

  guint32 value;
}

value:    The numerical value;


GTypeBlob (8 bytes)

struct GTypeBlob 
{
  guint32 gtype_name;
  guint32 gtype_init;
}

gtype_name: 
          The name under which the type is registered with GType.

gtype_init:
          The symbol name of the get_type() function which registers the type.


StructBlob (20 + 8 * n_fields + x * n_functions)

struct StructBlob 
{
  guint16      blob_type; /* 3: struct, 4: boxed */
  guint        deprecated   : 1;
  guint        unregistered : 1;
  guint        alignment    : 6;
  guint        is_class_struct : 1
  guint        reserved     : 7;
  guint32      name;

  GTypeBlob    gtype;

  guint32      size;

  guint16      n_fields;
  guint16      n_functions;

  FieldBlob    fields[];   
  FunctionBlob functions[];  
}

unregistered: 
          If this is set, the type is not registered with GType.

alignment:
	  The byte boundary that the struct is aligned to in memory
	  
is_class_struct:
	Whether this structure is the "class structure" for a GObject

size:	  The size of the struct in bytes.

gtype:    For types which are registered with GType, contains the 
          information about the GType. Otherwise unused.

n_fields: 
n_functions: 
          The lengths of the arrays.

fields:   An array of n_fields FieldBlobs. 

functions:
          An array of n_functions FunctionBlobs. The described functions 
          should be considered as methods of the struct. 


EnumBlob (20 + 16 * n_values)

struct EnumBlob
{
  guint16   blob_type;  /* 5: enum, 6: flags */
  guint     deprecated   : 1; 
  guint     unregistered : 1;
  guint     storage_type : 5;
  guint     reserved     : 9;
  guint32   name; 

  GTypeBlob gtype;

  guint16   n_values;
  guint16   reserved;

  ValueBlob values[];    
}

unregistered: 
          If this is set, the type is not registered with GType.

storage_type:
	  The tag of the type used for the enum in the C ABI
	  (will be a signed or unsigned integral type)

gtype:    For types which are registered with GType, contains the 
          information about the GType. Otherwise unused.

n_values:
          The lengths of the values arrays.

values:   Describes the enum values. 


ObjectBlob (36 + x bytes)

struct ObjectBlob
{
  guint16 blob_type;  /* 7 */
  guint   deprecated   : 1;
  guint   abstract     : 1;
  guint   reserved     :14;
  guint32 name; 

  GTypeBlob gtype;

  guint16 parent;
  guint16 class_struct;

  guint16 n_interfaces;
  guint16 n_fields;
  guint16 n_properties;
  guint16 n_methods;
  guint16 n_signals;
  guint16 n_virtual_functions;
  guint16 n_constants;

  guint16 interfaces[];
 
  FieldBlob           fields[];
  PropertyBlob        properties[];
  FunctionBlob        methods[];
  SignalBlob          signals[];
  VirtualFunctionBlob virtual_functions[];
  ConstantBlob        constants[];
} 

gtype:    Contains the information about the GType.

parent:   The directory index of the parent type. This is only set for 
          objects. If an object does not have a parent, it is zero.

n_interfaces:
n_fields: 
n_properties:
n_methods:
n_signals:
n_virtual_functions:
n_constants:
          The lengths of the arrays.

Up to 16bits of padding may be inserted between the arrays to ensure that they
start on a 32bit boundary.

interfaces:
          An array of indices of directory entries for the implemented 
          interfaces.

fields:   Describes the fields. 

functions: 
          Describes the methods, constructors, setters and getters. 

properties:
          Describes the properties. 

signals:  Describes the signals. 

virtual_functions:
          Describes the virtual functions. 

constants:
          Describes the constants.


InterfaceBlob (28 + x bytes)

struct InterfaceBlob
{
  guint16 blob_type;  /* 8 */
  guint   deprecated   : 1; 
  guint   reserved     :15;
  guint32 name; 

  GTypeBlob gtype;

  guint16 n_prerequisites;
  guint16 n_properties;
  guint16 n_methods;
  guint16 n_signals;
  guint16 n_virtual_functions;
  guint16 n_constants;  

  guint16 prerequisites[];
 
  PropertyBlob        properties[];
  FunctionBlob        methods[];
  SignalBlob          signals[];
  VirtualFunctionBlob virtual_functions[];
  ConstantBlob        constants[];
} 

n_prerequisites:
n_properties:
n_methods:
n_signals:
n_virtual_functions:
n_constants:
          The lengths of the arrays.

Up to 16bits of padding may be inserted between the arrays to ensure that they
start on a 32bit boundary.

prerequisites:
          An array of indices of directory entries for required interfaces.

functions: 
          Describes the methods, constructors, setters and getters. 

properties:
          Describes the properties. 

signals:  Describes the signals. 

virtual_functions:
          Describes the virtual functions. 

constants:
          Describes the constants.


ConstantBlob (20 bytes)

struct ConstantBlob
{
  guint16        blob_type;  /* 9 */
  guint          deprecated   : 1; 
  guint          reserved     :15;
  guint32        name; 

  SimpleTypeBlob type;
  guint32        size;
  guint32        offset;
}

type:     The type of the value. In most cases this should be a numeric
          type or string.

size:     The size of the value in bytes.

offset:   The offset of the value in the typelib.


AnnotationBlob (12 bytes)

struct AnnotationBlob
{ 
  guint32 offset;
  guint32 name;
  guint32 value;
}

offset:   The offset of the typelib entry to which this annotation refers. 
          Annotations are kept sorted by offset, so that the annotations 
          of an entry can be found by a binary search.

name:     The name of the annotation, a string.

value:    The value of the annotation (also a string)


UnionBlob (28 + x bytes)

struct UnionBlob 
{  
  guint16      blob_type;  /* 11 */
  guint        deprecated    : 1;
  guint        unregistered  : 1;
  guint        discriminated : 1;
  guint        alignment     : 6;
  guint        reserved      : 7;
  guint32      name;

  GTypeBlob    gtype;

  guint32      size;

  guint16      n_fields;
  guint16      n_functions;

  gint32       discriminator_offset; 
  SimpleTypeBlob discriminator_type;

  FieldBlob    fields[];   
  FunctionBlob functions[];  
  ConstantBlob discriminator_values[]
}

unregistered: 
          If this is set, the type is not registered with GType.

discriminated: 
          Is set if the union is discriminated

alignment:
	  The byte boundary that the union is aligned to in memory

size:	  The size of the union in bytes.

gtype:    For types which are registered with GType, contains the 
          information about the GType. Otherwise unused.

n_fields: Length of the arrays

discriminator_offset: 
          Offset from the beginning of the union where the
	  discriminator of a discriminated union is located.
	  The value 0xFFFF indicates that the discriminator offset
	  is unknown.

discriminator_type: 
          Type of the discriminator 

discriminator_values:
          On discriminator value per field

fields:   Array of FieldBlobs describing the alternative
          branches of the union