projects
/
babeltrace.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add out-of-bound checks
[babeltrace.git]
/
formats
/
ctf-text
/
types
/
struct.c
diff --git
a/formats/ctf-text/types/struct.c
b/formats/ctf-text/types/struct.c
index cd63fe99551cbaaf4f45d210f10772011856cc2f..760f1727d4f37d4968b8f2456d2e9dacec2cc168 100644
(file)
--- a/
formats/ctf-text/types/struct.c
+++ b/
formats/ctf-text/types/struct.c
@@
-19,19
+19,25
@@
#include <babeltrace/ctf-text/types.h>
#include <stdio.h>
#include <babeltrace/ctf-text/types.h>
#include <stdio.h>
-
void
ctf_text_struct_write(struct stream_pos *ppos, struct definition *definition)
+
int
ctf_text_struct_write(struct stream_pos *ppos, struct definition *definition)
{
struct ctf_text_stream_pos *pos = ctf_text_pos(ppos);
{
struct ctf_text_stream_pos *pos = ctf_text_pos(ppos);
+ int ret;
if (!pos->dummy) {
if (!pos->dummy) {
- print_pos_tabs(pos);
- fprintf(pos->fp, "{\n");
+ if (pos->depth >= 0) {
+ print_pos_tabs(pos);
+ fprintf(pos->fp, "{\n");
+ }
pos->depth++;
}
pos->depth++;
}
- struct_rw(ppos, definition);
+
ret =
struct_rw(ppos, definition);
if (!pos->dummy) {
pos->depth--;
if (!pos->dummy) {
pos->depth--;
- print_pos_tabs(pos);
- fprintf(pos->fp, "}\n");
+ if (pos->depth >= 0) {
+ print_pos_tabs(pos);
+ fprintf(pos->fp, "}\n");
+ }
}
}
+ return ret;
}
}
This page took
0.024139 seconds
and
4
git commands to generate.