feat: hectic C: generic result
This commit is contained in:
@@ -25,8 +25,8 @@ char *struct_to_debug_str(Arena *arena, char *name, Struct *self, PtrSet *visite
|
||||
|
||||
char *result = arena_alloc(arena, MEM_KiB);
|
||||
STRUCT_TO_DEBUG_STR(arena, result, Struct, name, self, visited, 3,
|
||||
NUMBER_TO_DEBUG_STR(arena, "a", self->a),
|
||||
NUMBER_TO_DEBUG_STR(arena, "b", self->b),
|
||||
INT_TO_DEBUG_STR(arena, "a", self->a),
|
||||
INT_TO_DEBUG_STR(arena, "b", self->b),
|
||||
struct_to_debug_str(arena, "next", self->next, visited)
|
||||
);
|
||||
return result;
|
||||
@@ -37,8 +37,8 @@ char *struct2_to_debug_str(Arena *arena, char *name, Struct2 *self, PtrSet *visi
|
||||
|
||||
char *result = arena_alloc(arena, MEM_KiB);
|
||||
STRUCT_TO_DEBUG_STR(arena, result, Struct2, name, self, visited, 5,
|
||||
NUMBER_TO_DEBUG_STR(arena, "a", self->a),
|
||||
NUMBER_TO_DEBUG_STR(arena, "f", self->f),
|
||||
INT_TO_DEBUG_STR(arena, "a", self->a),
|
||||
FLOAT_TO_DEBUG_STR(arena, "f", self->f),
|
||||
STRING_TO_DEBUG_STR(arena, "c", self->c),
|
||||
struct_to_debug_str(arena, "other", self->other, visited),
|
||||
struct2_to_debug_str(arena, "left", self->left, visited)
|
||||
@@ -74,7 +74,7 @@ void test_struct2_to_debug_str(Arena *arena) {
|
||||
char *result = struct2_to_debug_str(arena, "struct2", &test_struct2, visited);
|
||||
raise_notice("result: %s", result);
|
||||
char *check = arena_alloc(arena, MEM_KiB);
|
||||
sprintf(check, "Struct2 struct2 = {a = 1, f = 3, c = %p \"hello\", Struct other = {a = 1, b = 2, Struct next = {cycle detected} %p} %p, Struct2 left = NULL} %p", (void*)test_struct2.c,(void*)&test_struct, (void*)&test_struct, (void*)&test_struct2);
|
||||
sprintf(check, "Struct2 struct2 = {a = 1, f = 3.140000, c = %p \"hello\", Struct other = {a = 1, b = 2, Struct next = {cycle detected} %p} %p, Struct2 left = NULL} %p", (void*)test_struct2.c,(void*)&test_struct, (void*)&test_struct, (void*)&test_struct2);
|
||||
raise_notice("check: %s", check);
|
||||
assert(strcmp(result, check) == 0);
|
||||
}
|
||||
|
||||
16
package/c/hectic/test/02-logger-rules
Executable file
16
package/c/hectic/test/02-logger-rules
Executable file
@@ -0,0 +1,16 @@
|
||||
#include "hectic.h"
|
||||
#include <assert.h>
|
||||
|
||||
int main(void) {
|
||||
printf("%sRunning %s%s%s\n", OPTIONAL_COLOR(COLOR_GREEN), OPTIONAL_COLOR(COLOR_CYAN), __FILE__, OPTIONAL_COLOR(COLOR_RESET));
|
||||
init_logger();
|
||||
|
||||
Arena arena = arena_init(MEM_MiB);
|
||||
|
||||
char *rules = arena_alloc(&arena, MEM_KiB);
|
||||
strcpy(rules, "trace:file:test.c:100-150");
|
||||
|
||||
arena_free(&arena);
|
||||
printf("%sAll tests passed %s%s%s\n", OPTIONAL_COLOR(COLOR_GREEN), OPTIONAL_COLOR(COLOR_CYAN), __FILE__, OPTIONAL_COLOR(COLOR_RESET));
|
||||
return 0;
|
||||
}
|
||||
Reference in New Issue
Block a user