From e343a687474e1f4f8837852dfafc30c8736bafab Mon Sep 17 00:00:00 2001 From: midipix Date: Sat, 28 Nov 2015 14:26:12 -0500 Subject: pretty printer: improved yaml support (import libraries, ,exported symbols). --- src/output/pe_output_export_symbols.c | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'src/output/pe_output_export_symbols.c') diff --git a/src/output/pe_output_export_symbols.c b/src/output/pe_output_export_symbols.c index d52bfe4..e6f4d5c 100644 --- a/src/output/pe_output_export_symbols.c +++ b/src/output/pe_output_export_symbols.c @@ -5,8 +5,23 @@ #include #include +#include #include "perk_output_impl.h" +static void pretty_header(const struct pe_common_ctx * cctx, FILE * fout) +{ + if (cctx->fmtflags & PERK_PRETTY_YAML) + fputs("exports:\n",fout); +} + +static void pretty_export_item(const struct pe_common_ctx * cctx, const char * name, FILE * fout) +{ + if (cctx->fmtflags & PERK_PRETTY_YAML) + fprintf(fout,"- %s\n",name); + else + fprintf(fout,"%s\n",name); +} + int pe_output_export_symbols( const struct pe_image_meta * m, const struct pe_common_ctx * cctx, @@ -23,11 +38,16 @@ int pe_output_export_symbols( if (!(fout = pe_output_prolog(cctx,fout,&ftmp))) return -1; + pretty_header(cctx,fout); + offset = m->hedata->virtual_addr - m->hedata->ptr_to_raw_data; symrva = (uint32_t *)((uintptr_t)m->image.addr + (m->edata.name_ptr_rva - offset)); for (i=0; iedata.num_of_name_ptrs; i++) - fprintf(fout,"%s\n",(char *)((uintptr_t)m->image.addr + symrva[i] - offset)); + pretty_export_item( + cctx, + (char *)((uintptr_t)m->image.addr + symrva[i] - offset), + fout); return pe_output_epilog(0,ftmp); } -- cgit v1.2.3