summaryrefslogtreecommitdiff
path: root/node.c
diff options
context:
space:
mode:
authormame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-01-16 15:12:09 +0000
committermame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2018-01-16 15:12:09 +0000
commit5fd143c141defc13ee46a2c89c46aae9ffcc90cc (patch)
tree5c668a0fec5d8dfdd89edabfb2b76139ff9ebfcc /node.c
parent96268c1dbddd223f1b782e55c237cdca2989fde6 (diff)
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
Diffstat (limited to 'node.c')
-rw-r--r--node.c10
1 files changed, 5 insertions, 5 deletions
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);