skalibs

Mirror/fork of https://skarnet.org/software/skalibs/
git clone https://ccx.te2000.cz/git/skalibs
Log | Files | Refs | README | LICENSE

commit 83ff0ca30e725c25b8b7e6d78ff17246caf29cf8
parent d452fcefe0220893ef1a8f868640809b4766480c
Author: Josiah Frentsos via skaware <skaware@list.skarnet.org>
Date:   Thu, 19 Oct 2023 13:01:43 -0400

Fix envalloc_merge

Currently, envalloc_merge incorrectly passes the total number of
environment entries to env_mergen as the number of modifs.

Signed-off-by: Josiah Frentsos <jfrent@tilde.team>

Diffstat:
Msrc/libenvexec/envalloc_merge.c | 5+++--
1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/src/libenvexec/envalloc_merge.c b/src/libenvexec/envalloc_merge.c @@ -7,9 +7,10 @@ int envalloc_merge (genalloc *v, char const *const *envp, size_t envlen, char const *modifs, size_t modiflen) { - size_t n = envlen + 1 + byte_count(modifs, modiflen, '\0') ; + size_t modifn = byte_count(modifs, modiflen, '\0') ; + size_t n = envlen + 1 + modifn ; if (!genalloc_readyplus(char const *, v, n)) return 0 ; - n = env_mergen(genalloc_s(char const *, v) + genalloc_len(char const *, v), n, envp, envlen, modifs, modiflen, n) ; + n = env_mergen(genalloc_s(char const *, v) + genalloc_len(char const *, v), n, envp, envlen, modifs, modiflen, modifn) ; genalloc_setlen(char const *, v, genalloc_len(char const *, v) + n) ; return 1 ; }