about summary refs log tree commit diff stats
path: root/src/structdump.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/structdump.h')
-rw-r--r--src/structdump.h137
1 files changed, 137 insertions, 0 deletions
diff --git a/src/structdump.h b/src/structdump.h
new file mode 100644
index 00000000..876d4576
--- /dev/null
+++ b/src/structdump.h
@@ -0,0 +1,137 @@
+/*
+ *
+ * Some macros to dump out formatted struct's via the trace file.  -KED
+ *
+ */
+#ifndef STRUCTDUMP_H
+#define STRUCTDUMP_H
+
+/* usage: DUMPSTRUCT_LINK(link_ptr, "message"); */
+#define   DUMPSTRUCT_LINK(L,X) \
+CTRACE(tfp, "\n" \
+            "KED:     link_ptr=%08x  sizeof=%d  ["X"]\n" \
+            "link       struct {\n" \
+            "           *lname=%08x\n" \
+            "            lname=|%s|\n" \
+            "          *target=%08x\n" \
+            "           target=|%s|\n" \
+            "        *hightext=%08x\n" \
+            "         hightext=|%s|\n" \
+            "       *hightext2=%08x\n" \
+            "        hightext2=|%s|\n" \
+            " hightext2_offset=%d\n"   \
+            "      inUnderline=%1x\n"  \
+            "               lx=%d\n"   \
+            "               ly=%d\n"   \
+            "             type=%d\n"   \
+            "    anchor_number=%d\n"   \
+            "  anchor_line_num=%d\n"   \
+            "            *form=%08x\n" \
+            "}\n", \
+            (L), sizeof(*((L))), \
+            (L)->lname, (L)->lname, (L)->target, (L)->target, \
+            (L)->hightext, (L)->hightext, (L)->hightext2, (L)->hightext2, \
+            (L)->hightext2_offset, (L)->inUnderline, (L)->lx, (L)->ly, \
+            (L)->type, (L)->anchor_number, (L)->anchor_line_num, (L)->form); \
+CTRACE_FLUSH(tfp);
+
+
+/* usage: DUMPSTRUCT_ANCHOR(anchor_ptr, "message"); */
+#define   DUMPSTRUCT_ANCHOR(A,X) \
+CTRACE(tfp, "\n" \
+            "KED:   anchor_ptr=%08x  sizeof=%d  ["X"]\n" \
+            "TextAnchor struct {\n"    \
+            "            *next=%08x\n" \
+            "           number=%d\n"   \
+            "            start=%d\n"   \
+            "         line_pos=%d\n"   \
+            "           extent=%d\n"   \
+            "         line_num=%d\n"   \
+            "        *hightext=%08x\n" \
+            "         hightext=|%s|\n" \
+            "       *hightext2=%08x\n" \
+            "        hightext2=|%s|\n" \
+            "  hightext2offset=%d\n"   \
+            "        link_type=%d\n"   \
+            "     *input_field=%08x\n" \
+            "      input_field=|%s|\n" \
+            "      show_anchor=%1x\n"  \
+            "      inUnderline=%1x\n"  \
+            "          *anchor=%08x\n" \
+            "}\n", \
+            (A), sizeof(*((A))), \
+            (A)->next, (A)->number, (A)->start, (A)->line_pos, \
+            (A)->extent, (A)->line_num, \
+            (A)->hightext, (A)->hightext, (A)->hightext2, (A)->hightext2, \
+            (A)->hightext2offset, (A)->link_type, \
+            (A)->input_field, (A)->input_field, \
+            (A)->show_anchor, (A)->inUnderline, (A)->anchor); \
+CTRACE_FLUSH(tfp);
+
+
+/* usage: DUMPSTRUCT_FORM(forminfo_ptr, "message"); */
+#define   DUMPSTRUCT_FORMINFO(F,X) \
+CTRACE(tfp, "\n" \
+            "KED: forminfo_ptr=%08x  sizeof=%d  ["X"]\n" \
+            "FormInfo   struct {\n"    \
+            "            *name=%08x\n" \
+            "             name=|%s|\n" \
+            "           number=%d\n"   \
+            "             type=%d\n"   \
+            "           *value=%08x\n" \
+            "            value=|%s|\n" \
+            "      *orig_value=%08x\n" \
+            "       orig_value=|%s|\n" \
+            "             size=%d\n"   \
+            "        maxlength=%d\n"   \
+            "            group=%d\n"   \
+            "        num_value=%d\n"   \
+            "           hrange=%d\n"   \
+            "           lrange=%d\n"   \
+            "     *select_list=%08x\n" \
+            "    submit_action=|%s|\n" \
+            "    submit_method=%d\n"   \
+            "   submit_enctype=|%s|\n" \
+            "     submit_title=|%s|\n" \
+            "         no_cache=%1x\n"  \
+            "  cp_submit_value=|%s|\n" \
+            "orig_submit_value=|%s|\n" \
+            "           size_l=%d\n"   \
+            "         disabled=%d\n"   \
+            "          name_cs=%d\n"   \
+            "         value_cs=%d\n"   \
+            "        accept_cs=|%s|\n" \
+            "}\n", \
+            (F), sizeof(*((F))), \
+            (F)->name, (F)->name, (F)->number, (F)->type, \
+            (F)->value, (F)->value, (F)->orig_value, (F)->orig_value, \
+            (F)->size, (F)->maxlength, (F)->group, (F)->num_value, \
+            (F)->hrange, (F)->lrange, (F)->select_list, (F)->submit_action, \
+            (F)->submit_method, (F)->submit_enctype, (F)->submit_title, \
+            (F)->no_cache, (F)->cp_submit_value, (F)->orig_submit_value, \
+            (F)->size_l, (F)->disabled, (F)->name_cs, (F)->value_cs, \
+            (F)->accept_cs); \
+CTRACE_FLUSH(tfp);
+
+
+/* usage: DUMPSTRUCT_LINE(htline_ptr, "message"); */
+#define   DUMPSTRUCT_LINE(L,X) \
+CTRACE(tfp, "\n" \
+            "KED: htline_ptr=%08x  sizeof=%d  ["X"]\n" \
+            "HTLine struct {\n"    \
+            "        *next=%08x\n" \
+            "        *prev=%08x\n" \
+            "       offset=%d\n"   \
+            "         size=%d\n"   \
+            "  split_after=%1x\n"  \
+            "       bullet=%1x\n"  \
+            "nodef U_C_S\n"        \
+            "       data[]=%08x\n" \
+            "         data=|%s|\n" \
+            "}\n", \
+            (L), sizeof(*((L))), \
+            (L)->next, (L)->prev, (L)->offset, (L)->size, (L)->split_after, \
+            (L)->bullet, (L)->data, (L)->data); \
+CTRACE_FLUSH(tfp);
+
+#endif /* STRUCTDUMP_H */