diff options
author | Lennart Poettering <lennart@poettering.net> | 2010-01-20 02:35:46 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2010-01-20 02:35:46 +0100 |
commit | ceed357001a7543c62468c5b943cf80c2a644252 (patch) | |
tree | e090c9e85a953615d3a108f2bc64a9fbc763acc8 /name.c | |
parent | e5b5ae50f02d7814f37b15329da2adce0fb30825 (diff) |
improve dump output
Diffstat (limited to 'name.c')
-rw-r--r-- | name.c | 40 |
1 files changed, 25 insertions, 15 deletions
@@ -405,7 +405,7 @@ const char* name_id(Name *n) { return set_first(n->meta.names); } -void name_dump(Name *n, FILE *f) { +void name_dump(Name *n, FILE *f, const char *prefix) { static const char* const state_table[_NAME_STATE_MAX] = { [NAME_STUB] = "stub", @@ -432,15 +432,18 @@ void name_dump(Name *n, FILE *f) { assert(n); + if (!prefix) + prefix = ""; + fprintf(f, - "Name %s\n" - "\tDescription: %s\n" - "\tName State: %s\n", - name_id(n), - n->meta.description ? n->meta.description : name_id(n), - state_table[n->meta.state]); - - fprintf(f, "\tNames: "); + "%sName %s:\n" + "%s\tDescription: %s\n" + "%s\tName State: %s\n", + prefix, name_id(n), + prefix, n->meta.description ? n->meta.description : name_id(n), + prefix, state_table[n->meta.state]); + + fprintf(f, "%s\tNames: ", prefix); SET_FOREACH(t, n->meta.names, state) fprintf(f, "%s ", t); fprintf(f, "\n"); @@ -457,10 +460,10 @@ void name_dump(Name *n, FILE *f) { t = s; fprintf(f, - "\tAddress: %s\n" - "\tSocket State: %s\n", - t, - socket_state_table[n->socket.state]); + "%s\tAddress: %s\n" + "%s\tSocket State: %s\n", + prefix, t, + prefix, socket_state_table[n->socket.state]); free(s); break; @@ -471,7 +474,14 @@ void name_dump(Name *n, FILE *f) { } if (n->meta.job) { - fprintf(f, "\t"); - job_dump(n->meta.job, f); + char *p; + + if (asprintf(&p, "%s\t", prefix) >= 0) + prefix = p; + else + p = NULL; + + job_dump(n->meta.job, f, prefix); + free(p); } } |