On Wed, Nov 11, 2020 at 9:33 AM Phillip Wood <phillip.wood123@xxxxxxxxx> wrote: > > Hi Elijah > > On 06/11/2020 00:24, Elijah Newren via GitGitGadget wrote: > > From: Elijah Newren <newren@xxxxxxxxx> > > > > For heavy users of strmaps, allowing the keys and entries to be > > allocated from a memory pool can provide significant overhead savings. > > Add an option to strmap_init_with_options() to specify a memory pool. > > [...] > > diff --git a/strmap.h b/strmap.h > > index c8c4d7c932..dda928703d 100644 > > --- a/strmap.h > > +++ b/strmap.h > > @@ -3,8 +3,10 @@ > > > > #include "hashmap.h" > > > > +struct mempool; > > I think this is a typo - I assume you wanted to declare `struct > mem_pool` but it's not strictly necessary as you're only adding a > pointer to the struct below. > > Best Wishes > > Phillip Indeed, thanks. > > > struct strmap { > > struct hashmap map; > > + struct mem_pool *pool; > > unsigned int strdup_strings:1; > > }; > > > > @@ -37,9 +39,10 @@ void strmap_init(struct strmap *map); > > > > /* > > * Same as strmap_init, but for those who want to control the memory management > > - * carefully instead of using the default of strdup_strings=1. > > + * carefully instead of using the default of strdup_strings=1 and pool=NULL. > > */ > > void strmap_init_with_options(struct strmap *map, > > + struct mem_pool *pool, > > int strdup_strings); > > > > /* > > @@ -137,9 +140,10 @@ static inline void strintmap_init(struct strintmap *map, int default_value) > > > > static inline void strintmap_init_with_options(struct strintmap *map, > > int default_value, > > + struct mem_pool *pool, > > int strdup_strings) > > { > > - strmap_init_with_options(&map->map, strdup_strings); > > + strmap_init_with_options(&map->map, pool, strdup_strings); > > map->default_value = default_value; > > } > > > > @@ -221,9 +225,10 @@ static inline void strset_init(struct strset *set) > > } > > > > static inline void strset_init_with_options(struct strset *set, > > + struct mem_pool *pool, > > int strdup_strings) > > { > > - strmap_init_with_options(&set->map, strdup_strings); > > + strmap_init_with_options(&set->map, pool, strdup_strings); > > } > > > > static inline void strset_clear(struct strset *set) > >