diff options
author | midipix <writeonce@midipix.org> | 2024-02-17 01:21:32 +0000 |
---|---|---|
committer | midipix <writeonce@midipix.org> | 2024-02-17 01:21:32 +0000 |
commit | d9285e9ec4ea0e8e39cf953985ad30fd415a5b5f (patch) | |
tree | 62083f6dd090d232b79ac443c1c33a8632a7f047 | |
parent | 7ffcb591bd686006e325722b45c1fe91d1ff3eff (diff) | |
download | slibtool-d9285e9ec4ea0e8e39cf953985ad30fd415a5b5f.tar.bz2 slibtool-d9285e9ec4ea0e8e39cf953985ad30fd415a5b5f.tar.xz |
archiver output: added slbt_ar_output_symbols() [currently -Wposix only].
-rw-r--r-- | project/common.mk | 1 | ||||
-rw-r--r-- | src/arbits/output/slbt_ar_output_symbols.c | 78 |
2 files changed, 79 insertions, 0 deletions
diff --git a/project/common.mk b/project/common.mk index 50aa738..f385191 100644 --- a/project/common.mk +++ b/project/common.mk @@ -9,6 +9,7 @@ API_SRCS = \ src/arbits/slbt_armap_sysv_64.c \ src/arbits/output/slbt_ar_output_arname.c \ src/arbits/output/slbt_ar_output_members.c \ + src/arbits/output/slbt_ar_output_symbols.c \ src/driver/slbt_amain.c \ src/driver/slbt_driver_ctx.c \ src/driver/slbt_host_params.c \ diff --git a/src/arbits/output/slbt_ar_output_symbols.c b/src/arbits/output/slbt_ar_output_symbols.c new file mode 100644 index 0000000..b709755 --- /dev/null +++ b/src/arbits/output/slbt_ar_output_symbols.c @@ -0,0 +1,78 @@ +/*******************************************************************/ +/* slibtool: a skinny libtool implementation, written in C */ +/* Copyright (C) 2016--2024 SysDeer Technologies, LLC */ +/* Released under the Standard MIT License; see COPYING.SLIBTOOL. */ +/*******************************************************************/ + +#include <time.h> +#include <locale.h> +#include <inttypes.h> +#include <slibtool/slibtool.h> +#include <slibtool/slibtool_output.h> +#include "slibtool_driver_impl.h" +#include "slibtool_dprintf_impl.h" +#include "slibtool_errinfo_impl.h" +#include "slibtool_ar_impl.h" + +#define SLBT_PRETTY_FLAGS (SLBT_PRETTY_YAML \ + | SLBT_PRETTY_POSIX \ + | SLBT_PRETTY_HEXDATA) + +static int slbt_ar_output_symbols_posix( + const struct slbt_driver_ctx * dctx, + struct slbt_archive_meta_impl * mctx, + const struct slbt_fd_ctx * fdctx) +{ + int fdout; + const char ** symv; + + fdout = fdctx->fdout; + + for (symv=mctx->symstrv; *symv; symv++) + if (slbt_dprintf(fdout,"%s\n",*symv) < 0) + return SLBT_SYSTEM_ERROR(dctx,0); + + return 0; +} + +static int slbt_ar_output_symbols_yaml( + const struct slbt_driver_ctx * dctx, + struct slbt_archive_meta_impl * mctx, + const struct slbt_fd_ctx * fdctx) +{ + (void)dctx; + (void)mctx; + (void)fdctx; + + return 0; +} + +int slbt_ar_output_symbols(const struct slbt_archive_meta * meta) +{ + struct slbt_archive_meta_impl * mctx; + const struct slbt_driver_ctx * dctx; + struct slbt_fd_ctx fdctx; + + mctx = slbt_archive_meta_ictx(meta); + dctx = (slbt_archive_meta_ictx(meta))->dctx; + + if (slbt_get_driver_fdctx(dctx,&fdctx) < 0) + return SLBT_NESTED_ERROR(dctx); + + if (!meta->a_memberv) + return 0; + + switch (dctx->cctx->fmtflags & SLBT_PRETTY_FLAGS) { + case SLBT_PRETTY_YAML: + return slbt_ar_output_symbols_yaml( + dctx,mctx,&fdctx); + + case SLBT_PRETTY_POSIX: + return slbt_ar_output_symbols_posix( + dctx,mctx,&fdctx); + + default: + return slbt_ar_output_symbols_yaml( + dctx,mctx,&fdctx); + } +} |