From 76c5e99d92cd0e4bf6ac8fe6067ecb8e5c2b017f Mon Sep 17 00:00:00 2001 From: midipix Date: Sat, 17 Feb 2024 05:21:44 +0000 Subject: ar mode: utility: armap symbol printing: added the -Wregex switch. --- src/arbits/output/slbt_ar_output_symbols.c | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) (limited to 'src/arbits/output') diff --git a/src/arbits/output/slbt_ar_output_symbols.c b/src/arbits/output/slbt_ar_output_symbols.c index b709755..cfd0be8 100644 --- a/src/arbits/output/slbt_ar_output_symbols.c +++ b/src/arbits/output/slbt_ar_output_symbols.c @@ -6,6 +6,7 @@ #include #include +#include #include #include #include @@ -24,13 +25,26 @@ static int slbt_ar_output_symbols_posix( const struct slbt_fd_ctx * fdctx) { int fdout; + const char * regex; const char ** symv; + regex_t regctx; + regmatch_t pmatch[2] = {0}; fdout = fdctx->fdout; + if ((regex = dctx->cctx->regex)) + if (regcomp(®ctx,regex,REG_NEWLINE)) + return SLBT_CUSTOM_ERROR( + dctx, + SLBT_ERR_FLOW_ERROR); + for (symv=mctx->symstrv; *symv; symv++) - if (slbt_dprintf(fdout,"%s\n",*symv) < 0) - return SLBT_SYSTEM_ERROR(dctx,0); + if (!regex || !regexec(®ctx,*symv,1,pmatch,0)) + if (slbt_dprintf(fdout,"%s\n",*symv) < 0) + return SLBT_SYSTEM_ERROR(dctx,0); + + if (regex) + regfree(®ctx); return 0; } -- cgit v1.2.3