Thank you. I merged these. The tests run through. I won’t tag a release just yet and will wait for the remaining work to be completed. Best, -Michael > On 20 Aug 2020, at 18:28, Stefan Schantl wrote: > > This function is used to the stored countries of a database, which > easily can be assigned to an array. > > Signed-off-by: Stefan Schantl > --- > src/perl/Location.xs | 42 ++++++++++++++++++++++++++++++++++++++++-- > 1 file changed, 40 insertions(+), 2 deletions(-) > > diff --git a/src/perl/Location.xs b/src/perl/Location.xs > index 5693744..3c347db 100644 > --- a/src/perl/Location.xs > +++ b/src/perl/Location.xs > @@ -6,11 +6,10 @@ > #include > #include > > - > #include > #include > #include > - > +#include > > MODULE = Location PACKAGE = Location > > @@ -119,6 +118,45 @@ get_license(db) > OUTPUT: > RETVAL > > +void > +database_countries(db) > + struct loc_database* db; > + > + PPCODE: > + // Create Database enumerator > + struct loc_database_enumerator* enumerator; > + int err = loc_database_enumerator_new(&enumerator, db, LOC_DB_ENUMERATE_COUNTRIES); > + > + if (err) { > + croak("Could not create a database enumerator\n"); > + } > + > + // Init and enumerate first country. > + struct loc_country* country; > + err = loc_database_enumerator_next_country(enumerator, &country); > + if (err) { > + croak("Could not enumerate next country\n"); > + } > + > + while (country) { > + // Extract the country code. > + const char* ccode = loc_country_get_code(country); > + > + // Push country code. > + XPUSHs(sv_2mortal(newSVpv(ccode, 2))); > + > + // Unref country pointer. > + loc_country_unref(country); > + > + // Enumerate next item. > + err = loc_database_enumerator_next_country(enumerator, &country); > + if (err) { > + croak("Could not enumerate next country\n"); > + } > + } > + > + loc_database_enumerator_unref(enumerator); > + > # > # Lookup functions > # > -- > 2.20.1 >