Skip to content

Commit

Permalink
Add MXML_ALLOC_SIZE define (Issue #318)
Browse files Browse the repository at this point in the history
  • Loading branch information
michaelrsweet committed Apr 21, 2024
1 parent 0c97db4 commit 002c34f
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 8 deletions.
6 changes: 4 additions & 2 deletions CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,12 @@ Changes in Mini-XML
Changes in Mini-XML 4.0.3
-------------------------

- The configure script now defaults the `DSOFLAGS` value to `LDFLAGS` if not
set (Issue #325)
- Now default the `DSOFLAGS` value to `LDFLAGS` in the configure script
(Issue #325)
- Now install the man page as "mxml4" to allow parallel installation of Mini-XML
4.x and 3.x (Issue #324)
- Added `MXML_ALLOC_SIZE` define to control the allocation increment for
attributes and indices (Issue #318)
- Fixed `mxmlSetDeclarationf` implementation (Issue #322)


Expand Down
12 changes: 8 additions & 4 deletions mxml-attr.c
Original file line number Diff line number Diff line change
Expand Up @@ -250,11 +250,15 @@ mxml_set_attr(mxml_node_t *node, // I - Element node
}

// Add a new attribute...
if ((attr = realloc(node->value.element.attrs, (node->value.element.num_attrs + 1) * sizeof(_mxml_attr_t))) == NULL)
return (false);
if ((node->value.element.num_attrs % MXML_ALLOC_SIZE) == 0)
{
if ((attr = realloc(node->value.element.attrs, (node->value.element.num_attrs + MXML_ALLOC_SIZE) * sizeof(_mxml_attr_t))) == NULL)
return (false);

node->value.element.attrs = attr;
}

node->value.element.attrs = attr;
attr += node->value.element.num_attrs;
attr = node->value.element.attrs + node->value.element.num_attrs;

if ((attr->name = _mxml_strcopy(name)) == NULL)
return (false);
Expand Down
4 changes: 2 additions & 2 deletions mxml-index.c
Original file line number Diff line number Diff line change
Expand Up @@ -247,15 +247,15 @@ mxmlIndexNew(mxml_node_t *node, // I - XML node tree
{
if (ind->num_nodes >= ind->alloc_nodes)
{
if ((temp = realloc(ind->nodes, (ind->alloc_nodes + 64) * sizeof(mxml_node_t *))) == NULL)
if ((temp = realloc(ind->nodes, (ind->alloc_nodes + MXML_ALLOC_SIZE) * sizeof(mxml_node_t *))) == NULL)
{
// Unable to allocate memory for the index, so abort...
mxmlIndexDelete(ind);
return (NULL);
}

ind->nodes = temp;
ind->alloc_nodes += 64;
ind->alloc_nodes += MXML_ALLOC_SIZE;
}

ind->nodes[ind->num_nodes ++] = current;
Expand Down
3 changes: 3 additions & 0 deletions mxml-private.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,9 @@
# else
# define MXML_DEBUG(...)
# endif // DEBUG
# ifndef MXML_ALLOC_SIZE
# define MXML_ALLOC_SIZE 16 // Allocation increment
# endif // !MXML_ALLOC_SIZE
# define MXML_TAB 8 // Tabs every N columns


Expand Down

0 comments on commit 002c34f

Please sign in to comment.