projects
/
babeltrace.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add base integer attribute, and use it in ctf-text
[babeltrace.git]
/
include
/
babeltrace
/
types.h
diff --git
a/include/babeltrace/types.h
b/include/babeltrace/types.h
index cb0044e0471d57e73453452ac60657b3e717674b..33311a683dae1056ff48928b4f4f0e3f83a788a4 100644
(file)
--- a/
include/babeltrace/types.h
+++ b/
include/babeltrace/types.h
@@
-31,6
+31,7
@@
/* Preallocate this many fields for structures */
#define DEFAULT_NR_STRUCT_FIELDS 8
/* Preallocate this many fields for structures */
#define DEFAULT_NR_STRUCT_FIELDS 8
+struct ctf_stream;
struct stream_pos;
struct format;
struct definition;
struct stream_pos;
struct format;
struct definition;
@@
-100,7
+101,9
@@
struct declaration {
struct definition {
struct declaration *declaration;
int index; /* Position of the definition in its container */
struct definition {
struct declaration *declaration;
int index; /* Position of the definition in its container */
+ GQuark name; /* Field name in its container (or 0 if unset) */
int ref; /* number of references to the definition */
int ref; /* number of references to the definition */
+ GQuark path;
};
typedef int (*rw_dispatch)(struct stream_pos *pos,
};
typedef int (*rw_dispatch)(struct stream_pos *pos,
@@
-110,6
+113,8
@@
typedef int (*rw_dispatch)(struct stream_pos *pos,
struct stream_pos {
/* read/write dispatch table. Specific to plugin used for stream. */
rw_dispatch *rw_table; /* rw dispatch table */
struct stream_pos {
/* read/write dispatch table. Specific to plugin used for stream. */
rw_dispatch *rw_table; /* rw dispatch table */
+ int (*event_cb)(struct stream_pos *pos,
+ struct ctf_stream *stream);
};
static inline
};
static inline
@@
-133,6
+138,7
@@
struct declaration_integer {
size_t len; /* length, in bits. */
int byte_order; /* byte order */
int signedness;
size_t len; /* length, in bits. */
int byte_order; /* byte order */
int signedness;
+ int base; /* Base for pretty-printing: 2, 8, 10, 16 */
};
struct definition_integer {
};
struct definition_integer {
@@
-239,11
+245,6
@@
struct declaration_field {
struct declaration *declaration;
};
struct declaration *declaration;
};
-struct field {
- GQuark name;
- struct definition *definition;
-};
-
struct declaration_struct {
struct declaration p;
GHashTable *fields_by_name; /* Tuples (field name, field index) */
struct declaration_struct {
struct declaration p;
GHashTable *fields_by_name; /* Tuples (field name, field index) */
@@
-255,7
+256,7
@@
struct definition_struct {
struct definition p;
struct declaration_struct *declaration;
struct definition_scope *scope;
struct definition p;
struct declaration_struct *declaration;
struct definition_scope *scope;
- G
Array *fields; /* Array of struct field
*/
+ G
PtrArray *fields; /* Array of pointers to struct definition
*/
};
struct declaration_untagged_variant {
};
struct declaration_untagged_variant {
@@
-277,8
+278,8
@@
struct definition_variant {
struct declaration_variant *declaration;
struct definition_scope *scope;
struct definition *enum_tag;
struct declaration_variant *declaration;
struct definition_scope *scope;
struct definition *enum_tag;
- G
Array *fields; /* Array of struct field
*/
- struct
field *current_field;
/* Last field read */
+ G
PtrArray *fields; /* Array of pointers to struct definition
*/
+ struct
definition *current_field;
/* Last field read */
};
struct declaration_array {
};
struct declaration_array {
@@
-292,7
+293,7
@@
struct definition_array {
struct definition p;
struct declaration_array *declaration;
struct definition_scope *scope;
struct definition p;
struct declaration_array *declaration;
struct definition_scope *scope;
- G
Array *elems; /* struct field
*/
+ G
PtrArray *elems; /* Array of pointers to struct definition
*/
};
struct declaration_sequence {
};
struct declaration_sequence {
@@
-307,7
+308,7
@@
struct definition_sequence {
struct declaration_sequence *declaration;
struct definition_scope *scope;
struct definition_integer *len;
struct declaration_sequence *declaration;
struct definition_scope *scope;
struct definition_integer *len;
- G
Array *elems; /* struct field
*/
+ G
PtrArray *elems; /* Array of pointers to struct definition
*/
};
int register_declaration(GQuark declaration_name,
};
int register_declaration(GQuark declaration_name,
@@
-363,6
+364,14
@@
void set_dynamic_definition_scope(struct definition *definition,
const char *root_name);
void free_definition_scope(struct definition_scope *scope);
const char *root_name);
void free_definition_scope(struct definition_scope *scope);
+GQuark new_definition_path(struct definition_scope *parent_scope, GQuark field_name);
+
+static inline
+int compare_definition_path(struct definition *definition, GQuark path)
+{
+ return definition->path == path;
+}
+
void declaration_ref(struct declaration *declaration);
void declaration_unref(struct declaration *declaration);
void declaration_ref(struct declaration *declaration);
void declaration_unref(struct declaration *declaration);
@@
-370,7
+379,8
@@
void definition_ref(struct definition *definition);
void definition_unref(struct definition *definition);
struct declaration_integer *integer_declaration_new(size_t len, int byte_order,
void definition_unref(struct definition *definition);
struct declaration_integer *integer_declaration_new(size_t len, int byte_order,
- int signedness, size_t alignment);
+ int signedness, size_t alignment,
+ int base);
/*
* mantissa_len is the length of the number of bytes represented by the mantissa
/*
* mantissa_len is the length of the number of bytes represented by the mantissa
@@
-419,7
+429,8
@@
struct declaration_string *
string_declaration_new(enum ctf_string_encoding encoding);
struct declaration_struct *
string_declaration_new(enum ctf_string_encoding encoding);
struct declaration_struct *
- struct_declaration_new(struct declaration_scope *parent_scope);
+ struct_declaration_new(struct declaration_scope *parent_scope,
+ uint64_t min_align);
void struct_declaration_add_field(struct declaration_struct *struct_declaration,
const char *field_name,
struct declaration *field_declaration);
void struct_declaration_add_field(struct declaration_struct *struct_declaration,
const char *field_name,
struct declaration *field_declaration);
@@
-434,10
+445,11
@@
int struct_declaration_lookup_field_index(struct declaration_struct *struct_decl
struct declaration_field *
struct_declaration_get_field_from_index(struct declaration_struct *struct_declaration,
int index);
struct declaration_field *
struct_declaration_get_field_from_index(struct declaration_struct *struct_declaration,
int index);
-struct
field
*
+struct
definition
*
struct_definition_get_field_from_index(struct definition_struct *struct_definition,
int index);
int struct_rw(struct stream_pos *pos, struct definition *definition);
struct_definition_get_field_from_index(struct definition_struct *struct_definition,
int index);
int struct_rw(struct stream_pos *pos, struct definition *definition);
+uint64_t struct_declaration_len(struct declaration_struct *struct_declaration);
/*
* The tag enumeration is validated to ensure that it contains only mappings
/*
* The tag enumeration is validated to ensure that it contains only mappings
@@
-465,7
+477,7
@@
int variant_definition_set_tag(struct definition_variant *variant,
* field returned only valid as long as the variant structure is not appended
* to.
*/
* field returned only valid as long as the variant structure is not appended
* to.
*/
-struct
field
*variant_get_current_field(struct definition_variant *variant);
+struct
definition
*variant_get_current_field(struct definition_variant *variant);
int variant_rw(struct stream_pos *pos, struct definition *definition);
/*
int variant_rw(struct stream_pos *pos, struct definition *definition);
/*
@@
-497,4
+509,4
@@
int sequence_rw(struct stream_pos *pos, struct definition *definition);
*/
void append_scope_path(const char *path, GArray *q);
*/
void append_scope_path(const char *path, GArray *q);
-#endif /* _BABELTRACE_
declaration
S_H */
+#endif /* _BABELTRACE_
TYPE
S_H */
This page took
0.025945 seconds
and
4
git commands to generate.