diff options
| author | Laurent Bercot <ska-skaware@skarnet.org> | 2025-11-10 05:18:13 +0000 |
|---|---|---|
| committer | Laurent Bercot <ska-skaware@skarnet.org> | 2025-11-10 05:18:13 +0000 |
| commit | b07efdfd3b24122f825ac0a54277d308f010eafb (patch) | |
| tree | ebee1f7146174ff896349db2230af5e547e98670 /src | |
| parent | 32ac3aa6ac8f0dc9a240611a3696c0e5510b841d (diff) | |
| download | skalibs-b07efdfd3b24122f825ac0a54277d308f010eafb.tar.gz | |
Add string_index
Diffstat (limited to 'src')
| -rw-r--r-- | src/include/skalibs/skamisc.h | 2 | ||||
| -rw-r--r-- | src/libstddjb/string_index.c | 30 |
2 files changed, 32 insertions, 0 deletions
diff --git a/src/include/skalibs/skamisc.h b/src/include/skalibs/skamisc.h index 6a03e7a..89d7744 100644 --- a/src/include/skalibs/skamisc.h +++ b/src/include/skalibs/skamisc.h @@ -7,6 +7,7 @@ #include <skalibs/buffer.h> #include <skalibs/stralloc.h> +#include <skalibs/genalloc.h> extern stralloc satmp ; @@ -37,5 +38,6 @@ extern ssize_t string_unquote_nodelim (char *, char const *, size_t) ; extern int string_unquote_withdelim (char *, size_t *, char const *, size_t, size_t *, char const *, size_t) ; extern int string_format (stralloc *, char const *, char const *, char const *const *) ; +extern int string_index (char *, size_t, size_t, char, genalloc *) ; #endif diff --git a/src/libstddjb/string_index.c b/src/libstddjb/string_index.c new file mode 100644 index 0000000..c352e77 --- /dev/null +++ b/src/libstddjb/string_index.c @@ -0,0 +1,30 @@ +/* ISC license. */ + +#include <skalibs/genalloc.h> +#include <skalibs/skamisc.h> + +int string_index (char *s, size_t start, size_t len, char delim, genalloc *indices) +{ + size_t origlen = genalloc_len(size_t, indices) ; + size_t pos = start ; + int wasnull = !indices->s ; + int inword = 0 ; + + for (size_t i = start ; i < len ; i++) + { + if (s[i] == delim) + { + s[i] = 0 ; + if (!genalloc_append(size_t, indices, &pos)) goto err ; + inword = 0 ; + } + else if (!inword) { pos = i ; inword = 1 ; } + } + if (inword) goto err ; + return 1 ; + + err: + if (wasnull) genalloc_free(size_t, indices) ; + else genalloc_setlen(size_t, indices, origlen) ; + return 0 ; +} |
