]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/grob-closure.cc
Release: bump Welcome versions.
[lilypond.git] / lily / grob-closure.cc
index 4f6c0adc81f5219836e20c2bb92754f347a20eab..bfafd4c9822e3a7c3f459bfd3c6f9a1ca54d246a 100644 (file)
@@ -1,5 +1,6 @@
 #include "grob.hh"
-#include "simple-closure.hh"
+#include "unpure-pure-container.hh"
+#include "lily-imports.hh"
 
 SCM
 axis_offset_symbol (Axis a)
@@ -29,27 +30,9 @@ axis_parent_positioning (Axis a)
 void
 add_offset_callback (Grob *g, SCM proc, Axis a)
 {
-  SCM data = g->get_property_data (axis_offset_symbol (a));
-  if (!scm_is_number (data)
-      && !ly_is_procedure (data)
-      && !is_simple_closure (data))
-    {
-      g->set_property (axis_offset_symbol (a), proc);
-      return;
-    }
-
-  if (ly_is_procedure (data))
-    data = ly_make_simple_closure (scm_list_1 (data));
-  else if (is_simple_closure (data))
-    data = simple_closure_expression (data);
-
-  SCM plus = ly_lily_module_constant ("+");
-
-  if (ly_is_procedure (proc))
-    proc = ly_make_simple_closure (scm_list_1 (proc));
-
-  SCM expr = scm_list_3 (plus, proc, data);
-  g->set_property (axis_offset_symbol (a), ly_make_simple_closure (expr));
+  SCM sym = axis_offset_symbol (a);
+  SCM data = g->get_property_data (sym);
+  g->set_property (sym, Lily::grob_offset_function (proc, data));
 }
 
 /*
@@ -65,25 +48,7 @@ void
 chain_callback (Grob *g, SCM proc, SCM sym)
 {
   SCM data = g->get_property_data (sym);
-
-  if (ly_is_procedure (data))
-    data = ly_make_simple_closure (scm_list_1 (data));
-  else if (is_simple_closure (data))
-    data = simple_closure_expression (data);
-  else
-    /*
-      Data may be nonnumber. In that case, it is assumed to be
-      undefined.
-    */
-
-    data = SCM_UNDEFINED;
-
-  SCM expr = scm_list_2 (proc, data);
-  g->set_property (sym,
-
-                   // twice: one as a wrapper for grob property routines,
-                   // once for the actual delayed binding.
-                   ly_make_simple_closure (ly_make_simple_closure (expr)));
+  g->set_property (sym, Lily::grob_compose_function (proc, data));
 }
 
 void