From: Nick Clifton Date: Mon, 1 Aug 2005 16:54:07 +0000 (+0000) Subject: (alphafunc): Remove and replace usage with nfunc. X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=3836c5e31d47ec5559c9d806f205dd0c6cf70220;p=pf3gnuchains%2Fpf3gnuchains3x.git (alphafunc): Remove and replace usage with nfunc. (nfunc): Fix sorting of fastcall symbols when --kill-at is used. --- diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 41dd0042f5..4d3128696e 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,8 @@ +2005-08-01 Filip Navara + + * dlltool.c (alphafunc): Remove and replace usage with nfunc. + (nfunc): Fix sorting of fastcall symbols when --kill-at is used. + 2005-07-25 H.J. Lu * readelf.c (dump_relocations): Handle SHN_X86_64_LCOMMON. diff --git a/binutils/dlltool.c b/binutils/dlltool.c index eda8e3cb18..512cf7b02a 100644 --- a/binutils/dlltool.c +++ b/binutils/dlltool.c @@ -699,7 +699,6 @@ static int nfunc (const void *, const void *); static void remove_null_names (export_type **); static void process_duplicates (export_type **); static void fill_ordinals (export_type **); -static int alphafunc (const void *, const void *); static void mangle_defs (void); static void usage (FILE *, int); static void inform (const char *, ...) ATTRIBUTE_PRINTF_1; @@ -2828,8 +2827,16 @@ nfunc (const void *a, const void *b) { export_type *ap = *(export_type **) a; export_type *bp = *(export_type **) b; + const char *an = ap->name; + const char *bn = bp->name; - return (strcmp (ap->name, bp->name)); + if (killat) + { + an = (an[0] == '@') ? an + 1 : an; + bn = (bn[0] == '@') ? bn + 1 : bn; + } + + return (strcmp (an, bn)); } static void @@ -2973,15 +2980,6 @@ fill_ordinals (export_type **d_export_vec) } } -static int -alphafunc (const void *av, const void *bv) -{ - const export_type **a = (const export_type **) av; - const export_type **b = (const export_type **) bv; - - return strcmp ((*a)->name, (*b)->name); -} - static void mangle_defs (void) { @@ -3017,7 +3015,7 @@ mangle_defs (void) d_exports_lexically[i] = 0; - qsort (d_exports_lexically, i, sizeof (export_type *), alphafunc); + qsort (d_exports_lexically, i, sizeof (export_type *), nfunc); /* Fill exp entries with their hint values. */ for (i = 0; i < d_nfuncs; i++)