diff options
author | midipix <writeonce@midipix.org> | 2024-02-18 17:39:03 +0000 |
---|---|---|
committer | midipix <writeonce@midipix.org> | 2024-02-18 17:39:03 +0000 |
commit | 9feb47215a7730a9efcbacc25d8ff02e861a8527 (patch) | |
tree | bbc64a7003192e318244708c77bf42126ef28008 | |
parent | 0006f718b62316336a9f27a008ea8525173a5b56 (diff) | |
download | slibtool-9feb47215a7730a9efcbacc25d8ff02e861a8527.tar.bz2 slibtool-9feb47215a7730a9efcbacc25d8ff02e861a8527.tar.xz |
ar mode: pretty printer: coff archives: filter out __imp_ prefixed symbols.
-rw-r--r-- | src/arbits/output/slbt_ar_output_mapfile.c | 9 | ||||
-rw-r--r-- | src/arbits/output/slbt_ar_output_symbols.c | 9 |
2 files changed, 12 insertions, 6 deletions
diff --git a/src/arbits/output/slbt_ar_output_mapfile.c b/src/arbits/output/slbt_ar_output_mapfile.c index f2c2a9b..1c5534e 100644 --- a/src/arbits/output/slbt_ar_output_mapfile.c +++ b/src/arbits/output/slbt_ar_output_mapfile.c @@ -21,6 +21,7 @@ static int slbt_ar_output_mapfile_impl( int fdout) { bool fsort; + bool fcoff; const char * regex; const char ** symv; const char ** symstrv; @@ -28,6 +29,7 @@ static int slbt_ar_output_mapfile_impl( regmatch_t pmatch[2] = {{0,0},{0,0}}; fsort = !(dctx->cctx->fmtflags & SLBT_OUTPUT_ARCHIVE_NOSORT); + fcoff = (mctx->ofmtattr == AR_OBJECT_ATTR_COFF); if (slbt_dprintf(fdout,"{\n" "\t" "global:\n") < 0) return SLBT_SYSTEM_ERROR(dctx,0); @@ -45,9 +47,10 @@ static int slbt_ar_output_mapfile_impl( symstrv = fsort ? mctx->mapstrv : mctx->symstrv; for (symv=symstrv; *symv; symv++) - if (!regex || !regexec(®ctx,*symv,1,pmatch,0)) - if (slbt_dprintf(fdout,"\t\t%s;\n",*symv) < 0) - return SLBT_SYSTEM_ERROR(dctx,0); + if (!fcoff || strncmp(*symv,"__imp_",6)) + if (!regex || !regexec(®ctx,*symv,1,pmatch,0)) + if (slbt_dprintf(fdout,"\t\t%s;\n",*symv) < 0) + return SLBT_SYSTEM_ERROR(dctx,0); if (regex) regfree(®ctx); diff --git a/src/arbits/output/slbt_ar_output_symbols.c b/src/arbits/output/slbt_ar_output_symbols.c index 148e0b1..0598d2e 100644 --- a/src/arbits/output/slbt_ar_output_symbols.c +++ b/src/arbits/output/slbt_ar_output_symbols.c @@ -26,6 +26,7 @@ static int slbt_ar_output_symbols_posix( { int fdout; bool fsort; + bool fcoff; const char * regex; const char ** symv; const char ** symstrv; @@ -34,6 +35,7 @@ static int slbt_ar_output_symbols_posix( fdout = fdctx->fdout; fsort = !(dctx->cctx->fmtflags & SLBT_OUTPUT_ARCHIVE_NOSORT); + fcoff = (mctx->ofmtattr == AR_OBJECT_ATTR_COFF); if (fsort && !mctx->mapstrv) if (slbt_update_mapstrv(dctx,mctx) < 0) @@ -48,9 +50,10 @@ static int slbt_ar_output_symbols_posix( symstrv = fsort ? mctx->mapstrv : mctx->symstrv; for (symv=symstrv; *symv; symv++) - if (!regex || !regexec(®ctx,*symv,1,pmatch,0)) - if (slbt_dprintf(fdout,"%s\n",*symv) < 0) - return SLBT_SYSTEM_ERROR(dctx,0); + if (!fcoff || strncmp(*symv,"__imp_",6)) + 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); |