Fix integer/float/string read: keep value in definition structure
[babeltrace.git] / include / babeltrace / format.h
index 6cae14efc3744ab7de264c7b672321a0857cd3de..151bd65a1e1effd4082c17282efe26682b677d92 100644 (file)
 
 #include <babeltrace/types.h>
 #include <stdint.h>
+#include <stdio.h>
 #include <glib.h>
 
+struct trace_descriptor;
+
 struct format {
        GQuark name;
 
        uint64_t (*uint_read)(struct stream_pos *pos,
-                       const struct type_integer *integer_type);
+               const struct declaration_integer *integer_declaration);
        int64_t (*int_read)(struct stream_pos *pos,
-                       const struct type_integer *integer_type);
+               const struct declaration_integer *integer_declaration);
        void (*uint_write)(struct stream_pos *pos,
-                          const struct type_integer *integer_type,
-                          uint64_t v);
+               const struct declaration_integer *integer_declaration,
+               uint64_t v);
        void (*int_write)(struct stream_pos *pos,
-                         const struct type_integer *integer_type,
-                         int64_t v);
+               const struct declaration_integer *integer_declaration,
+               int64_t v);
 
        void (*float_copy)(struct stream_pos *destp,
-                          struct stream_pos *srcp,
-                          const struct type_float *float_type);
+               struct stream_pos *srcp,
+               const struct declaration_float *float_declaration);
        double (*double_read)(struct stream_pos *pos,
-                             const struct type_float *float_type);
+               const struct declaration_float *float_declaration);
        void (*double_write)(struct stream_pos *pos,
-                            const struct type_float *float_type,
-                            double v);
+               const struct declaration_float *float_declaration,
+               double v);
+       long double (*ldouble_read)(struct stream_pos *pos,
+               const struct declaration_float *float_declaration);
+       void (*ldouble_write)(struct stream_pos *pos,
+               const struct declaration_float *float_declaration,
+               long double v);
 
        void (*string_copy)(struct stream_pos *dest, struct stream_pos *src,
-                           const struct type_string *string_type);
+               const struct declaration_string *string_declaration);
        void (*string_read)(char **dest, struct stream_pos *src,
-                           const struct type_string *string_type);
+               const struct declaration_string *string_declaration);
        void (*string_write)(struct stream_pos *dest, const char *src,
-                            const struct type_string *string_type);
+               const struct declaration_string *string_declaration);
        void (*string_free_temp)(char *string);
 
        /*
@@ -59,29 +67,32 @@ struct format {
         * g_array_unref().
         */
        GArray *(*enum_read)(struct stream_pos *pos,
-                           const struct type_enum *src);
+               const struct declaration_enum *src);
        void (*enum_write)(struct stream_pos *pos,
-                          const struct type_enum *dest,
-                          GQuark q);
+               const struct declaration_enum *dest,
+               GQuark q);
        void (*struct_begin)(struct stream_pos *pos,
-                            const struct type_struct *struct_type);
+               const struct declaration_struct *struct_declaration);
        void (*struct_end)(struct stream_pos *pos,
-                          const struct type_struct *struct_type);
+               const struct declaration_struct *struct_declaration);
        void (*variant_begin)(struct stream_pos *pos,
-                             const struct type_variant *variant_type);
+               const struct declaration_variant *variant_declaration);
        void (*variant_end)(struct stream_pos *pos,
-                           const struct type_variant *variant_type);
+               const struct declaration_variant *variant_declaration);
        void (*array_begin)(struct stream_pos *pos,
-                            const struct type_array *array_type);
+               const struct declaration_array *array_declaration);
        void (*array_end)(struct stream_pos *pos,
-                          const struct type_array *array_type);
+               const struct declaration_array *array_declaration);
        void (*sequence_begin)(struct stream_pos *pos,
-                            const struct type_sequence *sequence_type);
+               const struct declaration_sequence *sequence_declaration);
        void (*sequence_end)(struct stream_pos *pos,
-                          const struct type_sequence *sequence_type);
+               const struct declaration_sequence *sequence_declaration);
+       struct trace_descriptor *(*open_trace)(const char *path, int flags);
+       void (*close_trace)(struct trace_descriptor *descriptor);
 };
 
 struct format *bt_lookup_format(GQuark qname);
+void bt_fprintf_format_list(FILE *fp);
 int bt_register_format(struct format *format);
 
 /* TBD: format unregistration */
This page took 0.026008 seconds and 4 git commands to generate.