Update.
authorUlrich Drepper <drepper@redhat.com>
Sat, 22 Jul 2000 04:25:38 +0000 (04:25 +0000)
committerUlrich Drepper <drepper@redhat.com>
Sat, 22 Jul 2000 04:25:38 +0000 (04:25 +0000)
symbols and elements be named in reorder-after instructions.

ChangeLog
locale/programs/ld-collate.c

index eb0269bedaa98a1bd6a9639e3d541f1de9c62a2d..ec60f4a9c409c0173e035d5a287657693b4b58a1 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,7 +1,7 @@
 2000-07-21  Ulrich Drepper  <drepper@redhat.com>
 
        * locale/programs/ld-collate.c (collate_read): Allow collating
-       symbols be named in reorder-after instructions.
+       symbols and elements be named in reorder-after instructions.
        Reported by Yoshito Kawada <KAWADA@jp.ibm.com>.
 
        * locale/programs/ld-collate.c (handle_ellipsis): Test for
index fc5b4479325dffb639438169044cd4965f185133..125356dadb9e02962dfe87ce68bb37038d7e590a 100644 (file)
@@ -3385,6 +3385,25 @@ error while adding equivalent collating symbol"));
                          no_error = 0;
                        }
                    }
+                 else if (find_entry (&collate->elem_table,
+                                      arg->val.str.startmb,
+                                      arg->val.str.lenmb,
+                                      (void **) &insp) == 0)
+                   {
+                     if (insp->last != NULL || insp->next != NULL)
+                       collate->cursor = insp;
+                     else
+                       {
+                         /* This is a collating element but its position
+                            is not yet defined.  */
+                         lr_error (ldfile, _("\
+%s: order for collating element %.*s not yet defined"),
+                                   "LC_COLLATE", (int) arg->val.str.lenmb,
+                                   arg->val.str.startmb);
+                         collate->cursor = NULL;
+                         no_error = 0;
+                       }
+                   }
                  else
                    {
                      /* This is bad.  The symbol after which we have to