diff options
Diffstat (limited to 'src/structdump.h')
-rw-r--r-- | src/structdump.h | 137 |
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 */ |