*
* Enumeration mapping strings (quarks) from/to integers.
*
- * Copyright 2010, 2011 - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
+ * Copyright 2010-2011 EfficiOS Inc. and Linux Foundation
+ *
+ * Author: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
int i, ret;
int field_nr_saved;
+ if (!print_field(definition))
+ return 0;
+
if (pos->dummy)
return 0;
fprintf(pos->fp, " ");
if (pos->print_names)
fprintf(pos->fp, "%s = ",
- g_quark_to_string(definition->name));
+ rem_(g_quark_to_string(definition->name)));
field_nr_saved = pos->field_nr;
pos->field_nr = 0;
fprintf(pos->fp, "(");
pos->depth++;
- ret = generic_rw(ppos, &integer_definition->p);
- fprintf(pos->fp, ":");
-
qs = enum_definition->value;
- assert(qs);
- pos->field_nr = 0;
- for (i = 0; i < qs->len; i++) {
- GQuark q = g_array_index(qs, GQuark, i);
- const char *str = g_quark_to_string(q);
+ if (qs) {
+ for (i = 0; i < qs->len; i++) {
+ GQuark q = g_array_index(qs, GQuark, i);
+ const char *str = g_quark_to_string(q);
- assert(str);
- if (pos->field_nr++ != 0)
- fprintf(pos->fp, ",");
- fprintf(pos->fp, " ");
- fprintf(pos->fp, "%s", str);
+ assert(str);
+ if (pos->field_nr++ != 0)
+ fprintf(pos->fp, ",");
+ fprintf(pos->fp, " ");
+ fprintf(pos->fp, "%s", str);
+ }
+ } else {
+ fprintf(pos->fp, " <unknown>");
}
+
+ pos->field_nr = 0;
+ fprintf(pos->fp, " :");
+ ret = generic_rw(ppos, &integer_definition->p);
+
pos->depth--;
fprintf(pos->fp, " )");
pos->field_nr = field_nr_saved;