]> git.donarmstrong.com Git - lilypond.git/commitdiff
cleanups; add warning if accidental order not found.
authorHan-Wen Nienhuys <hanwen@xs4all.nl>
Sat, 23 Dec 2006 21:32:04 +0000 (22:32 +0100)
committerHan-Wen Nienhuys <hanwen@xs4all.nl>
Sat, 23 Dec 2006 21:32:04 +0000 (22:32 +0100)
lily/key-engraver.cc

index 54c9832cc8ebd74a00b3c44f540775d665706ad6..b317764fecfb0f29695bf12b4978845dbd34e952 100644 (file)
@@ -179,22 +179,30 @@ Key_engraver::read_event (Stream_event const *r)
   if (!scm_is_pair (p))
     return;
 
-  SCM n = scm_list_copy (p);
   SCM accs = SCM_EOL;
-  for (SCM s = get_property ("keyAlterationOrder");
-       scm_is_pair (s); s = scm_cdr (s))
+
+  SCM alist = scm_list_copy (p);
+  SCM order = get_property ("keyAlterationOrder");
+  for (SCM s = order;
+       scm_is_pair (s) && scm_is_pair (alist); s = scm_cdr (s))
     {
-      if (scm_is_pair (scm_member (scm_car (s), n)))
+      SCM head = scm_member (scm_car (s), alist);
+      
+      if (scm_is_pair (head))
        {
-         accs = scm_cons (scm_car (s), accs);
-         n = scm_delete_x (scm_car (s), n);
+         accs = scm_cons (scm_car (head), accs);
+         alist = scm_delete_x (scm_car (head), alist);
        }
     }
 
-  for (SCM s = n; scm_is_pair (s); s = scm_cdr (s))
-    if (ly_scm2rational (scm_cdar (s)))
-      accs = scm_cons (scm_car (s), accs);
-
+  if (scm_is_pair (alist))
+    {
+      r->origin ()->warning ("No ordering for key signature alterations");
+      for (SCM s = alist; scm_is_pair (s); s = scm_cdr (s))
+       if (ly_scm2rational (scm_cdar (s)))
+         accs = scm_cons (scm_car (s), accs);
+    }
+  
   context ()->set_property ("keySignature", accs);
   context ()->set_property ("tonic",
                            r->get_property ("tonic"));