diff options
author | Jo-Philipp Wich <jo@mein.io> | 2022-10-18 09:51:57 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-10-18 09:51:57 +0200 |
commit | 9a882f4222c23436f275f404df5d17f77b241e05 (patch) | |
tree | 8b9888fd3a07a6090ef4edf8e0634281326400d9 | |
parent | f956e92bb5a5fa3268835f472b92c8d84c807db0 (diff) | |
parent | 00af065057a0e9c10ce6a6475acc47920790c2a9 (diff) |
Merge pull request #118 from jow-/fs-read-getdelim
fs: expose `getdelim()` functionality through `fd.read()`
-rw-r--r-- | lib/fs.c | 13 |
1 files changed, 11 insertions, 2 deletions
@@ -73,8 +73,9 @@ uc_fs_read_common(uc_vm_t *vm, size_t nargs, const char *type) if (ucv_type(limit) == UC_STRING) { lstr = ucv_string_get(limit); + llen = ucv_string_length(limit); - if (!strcmp(lstr, "line")) { + if (llen == 4 && !strcmp(lstr, "line")) { llen = getline(&p, &rlen, *fp); if (llen == -1) @@ -82,7 +83,7 @@ uc_fs_read_common(uc_vm_t *vm, size_t nargs, const char *type) len = (size_t)llen; } - else if (!strcmp(lstr, "all")) { + else if (llen == 3 && !strcmp(lstr, "all")) { while (true) { rlen = fread(buf, 1, sizeof(buf), *fp); @@ -102,6 +103,14 @@ uc_fs_read_common(uc_vm_t *vm, size_t nargs, const char *type) break; } } + else if (llen == 1) { + llen = getdelim(&p, &rlen, *lstr, *fp); + + if (llen == -1) + err_return(errno); + + len = (size_t)llen; + } else { return NULL; } |