From 5fd143c141defc13ee46a2c89c46aae9ffcc90cc Mon Sep 17 00:00:00 2001 From: mame Date: Tue, 16 Jan 2018 15:12:09 +0000 Subject: node.c: Separately allocate a struct having flexible array git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@61876 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- node.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) (limited to 'node.c') diff --git a/node.c b/node.c index 050f8e4061..263296e962 100644 --- a/node.c +++ b/node.c @@ -1042,22 +1042,22 @@ rb_node_init(NODE *n, enum node_type type, VALUE a0, VALUE a1, VALUE a2) typedef struct node_buffer_elem_struct { struct node_buffer_elem_struct *next; - NODE buf[1]; + NODE buf[FLEX_ARY_LEN]; } node_buffer_elem_t; struct node_buffer_struct { long idx, len; node_buffer_elem_t *head; - node_buffer_elem_t body; /* this should be a last, because body has flexible array */ + node_buffer_elem_t *last; }; static node_buffer_t * rb_node_buffer_new(void) { - node_buffer_t *nb = xmalloc(sizeof(node_buffer_t) + 16 * sizeof(NODE)); + node_buffer_t *nb = xmalloc(sizeof(node_buffer_t) + offsetof(node_buffer_elem_t, buf) + 16 * sizeof(NODE)); nb->idx = 0; nb->len = 16; - nb->head = &nb->body; + nb->head = nb->last = (node_buffer_elem_t*) &nb[1]; nb->head->next = NULL; return nb; } @@ -1067,7 +1067,7 @@ rb_node_buffer_free(node_buffer_t *nb) { node_buffer_elem_t *nbe = nb->head; - while (nbe != &nb->body) { + while (nbe != nb->last) { void *buf = nbe; nbe = nbe->next; xfree(buf); -- cgit v1.2.1