From d0ac693824f69c24abdfd1fbce68494f38cfe121 Mon Sep 17 00:00:00 2001 From: Kai Tietz Date: Mon, 13 Feb 2012 20:42:07 +0000 Subject: [PATCH] * deffilep.y (find_export_in_list): Set is_indent for first or last element, if identical. (find_import_in_list): Likewise. --- ld/ChangeLog | 6 ++++++ ld/deffilep.y | 24 ++++++++++++++++++++---- 2 files changed, 26 insertions(+), 4 deletions(-) diff --git a/ld/ChangeLog b/ld/ChangeLog index 56e07775102..5919b2d7462 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,9 @@ +2012-02-13 Kai Tietz + + * deffilep.y (find_export_in_list): Set is_indent for + first or last element, if identical. + (find_import_in_list): Likewise. + 2012-02-11 Kai Tietz * deffilep.y (%union): New type id_const. diff --git a/ld/deffilep.y b/ld/deffilep.y index b192100f78c..f66ca2d37f3 100644 --- a/ld/deffilep.y +++ b/ld/deffilep.y @@ -622,13 +622,21 @@ find_export_in_list (def_file_export *b, int max, if (!max) return 0; if ((e = cmp_export_elem (b, ex_name, in_name, its_name, ord)) <= 0) - return 0; + { + if (!e) + *is_ident = 1; + return 0; + } if (max == 1) return 1; if ((e = cmp_export_elem (b + (max - 1), ex_name, in_name, its_name, ord)) > 0) return max; else if (!e || max == 2) - return max - 1; + { + if (!e) + *is_ident = 1; + return max - 1; + } l = 0; r = max - 1; while (l < r) { @@ -757,13 +765,21 @@ find_import_in_list (def_file_import *b, int max, if (!max) return 0; if ((e = cmp_import_elem (b, ex_name, in_name, module, ord)) <= 0) - return 0; + { + if (!e) + *is_ident = 1; + return 0; + } if (max == 1) return 1; if ((e = cmp_import_elem (b + (max - 1), ex_name, in_name, module, ord)) > 0) return max; else if (!e || max == 2) - return max - 1; + { + if (!e) + *is_ident = 1; + return max - 1; + } l = 0; r = max - 1; while (l < r) { -- 2.30.2