Fix: warn, and don't assert, when reading a value outside enum range
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Wed, 11 Apr 2012 11:41:30 +0000 (07:41 -0400)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Wed, 11 Apr 2012 11:41:30 +0000 (07:41 -0400)
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
formats/ctf/types/enum.c

index c2b50fd532f1b3736a360f1e4bdab5e9cf80c66f..e0a2b4d49d9cfc9049caa6c8011c0bb410f081c0 100644 (file)
@@ -19,6 +19,7 @@
  */
 
 #include <babeltrace/ctf/types.h>
+#include <inttypes.h>
 #include <stdint.h>
 #include <glib.h>
 
@@ -38,13 +39,21 @@ int ctf_enum_read(struct stream_pos *ppos, struct definition *definition)
        ret = ctf_integer_read(ppos, &integer_definition->p);
        if (ret)
                return ret;
-       if (!integer_declaration->signedness)
+       if (!integer_declaration->signedness) {
                qs = enum_uint_to_quark_set(enum_declaration,
                        integer_definition->value._unsigned);
-       else
+               if (!qs) {
+                       fprintf(stderr, "[warning] Unknown value %" PRIu64 " in enum.\n",
+                               integer_definition->value._unsigned);
+               }
+       } else {
                qs = enum_int_to_quark_set(enum_declaration,
                        integer_definition->value._signed);
-       assert(qs);
+               if (!qs) {
+                       fprintf(stderr, "[warning] Unknown value %" PRId64 " in enum.\n",
+                               integer_definition->value._signed);
+               }
+       }
        /* unref previous quark set */
        if (enum_definition->value)
                g_array_unref(enum_definition->value);
This page took 0.025172 seconds and 4 git commands to generate.