]> git.donarmstrong.com Git - lilypond.git/commitdiff
input.cc: implement with_location (SCM loc, SCM proc, ...)
authorDavid Kastrup <dak@gnu.org>
Sat, 4 Jul 2015 14:31:47 +0000 (16:31 +0200)
committerDavid Kastrup <dak@gnu.org>
Mon, 6 Jul 2015 11:41:42 +0000 (13:41 +0200)
lily/include/input.hh
lily/input.cc

index 7177baad0ad06dedd5bc847049c3de33a83882fa..b77db2d66f547051ca07fd51cdb615dfbc34126d 100644 (file)
@@ -73,4 +73,12 @@ protected:
 
 extern Input dummy_input_global;
 
+// The parser calls syntax functions with a lot of arguments
+SCM with_location (SCM loc, SCM proc);
+SCM with_location (SCM loc, SCM proc, SCM);
+SCM with_location (SCM loc, SCM proc, SCM, SCM);
+SCM with_location (SCM loc, SCM proc, SCM, SCM, SCM);
+SCM with_location (SCM loc, SCM proc, SCM, SCM, SCM, SCM);
+SCM with_location (SCM loc, SCM proc, SCM, SCM, SCM, SCM, SCM);
+
 #endif // INPUT_HH
index adf0e227ad7818044e3d6db9cc9a261d070e4521..b6aed9e2d1296b74182d9aca7f2921c6f9a04001 100644 (file)
@@ -23,6 +23,7 @@
 using namespace std;
 
 #include "international.hh"
+#include "lily-imports.hh"
 #include "program-option.hh"
 #include "source-file.hh"
 #include "sources.hh"
@@ -218,3 +219,104 @@ Input::end () const
 {
   return end_;
 }
+
+static SCM
+with_location_hook_0 (void *it)
+{
+  SCM *args = static_cast <SCM *> (it);
+  return scm_call_0 (args[0]);
+}
+
+SCM
+with_location (SCM loc, SCM proc)
+{
+  return scm_c_with_fluid (Lily::f_location,
+                           unsmob<Input> (loc) ? loc : SCM_BOOL_F,
+                           with_location_hook_0,
+                           static_cast <void *> (&proc));
+}
+
+static SCM
+with_location_hook_1 (void *it)
+{
+  SCM *args = static_cast <SCM *> (it);
+  return scm_call_1 (args[0], args[1]);
+}
+
+SCM
+with_location (SCM loc, SCM proc, SCM arg1)
+{
+  SCM args[] = { proc, arg1 };
+  return scm_c_with_fluid (Lily::f_location,
+                           unsmob<Input> (loc) ? loc : SCM_BOOL_F,
+                           with_location_hook_1,
+                           static_cast <void *> (&args));
+}
+
+static SCM
+with_location_hook_2 (void *it)
+{
+  SCM *args = static_cast <SCM *> (it);
+  return scm_call_2 (args[0], args[1], args[2]);
+}
+
+SCM
+with_location (SCM loc, SCM proc, SCM arg1, SCM arg2)
+{
+  SCM args[] = { proc, arg1, arg2 };
+  return scm_c_with_fluid (Lily::f_location,
+                           unsmob<Input> (loc) ? loc : SCM_BOOL_F,
+                           with_location_hook_2,
+                           static_cast <void *> (&args));
+}
+
+static SCM
+with_location_hook_3 (void *it)
+{
+  SCM *args = static_cast <SCM *> (it);
+  return scm_call_3 (args[0], args[1], args[2], args[3]);
+}
+
+SCM
+with_location (SCM loc, SCM proc, SCM arg1, SCM arg2, SCM arg3)
+{
+  SCM args[] = { proc, arg1, arg2, arg3 };
+  return scm_c_with_fluid (Lily::f_location,
+                           unsmob<Input> (loc) ? loc : SCM_BOOL_F,
+                           with_location_hook_3,
+                           static_cast <void *> (&args));
+}
+
+static SCM
+with_location_hook_4 (void *it)
+{
+  SCM *args = static_cast <SCM *> (it);
+  return scm_call_4 (args[0], args[1], args[2], args[3], args[4]);
+}
+
+SCM
+with_location (SCM loc, SCM proc, SCM arg1, SCM arg2, SCM arg3, SCM arg4)
+{
+  SCM args[] = { proc, arg1, arg2, arg3, arg4 };
+  return scm_c_with_fluid (Lily::f_location,
+                           unsmob<Input> (loc) ? loc : SCM_BOOL_F,
+                           with_location_hook_4,
+                           static_cast <void *> (&args));
+}
+
+static SCM
+with_location_hook_n (void *it)
+{
+  SCM *args = static_cast <SCM *> (it);
+  return scm_apply_0 (args[0], args[1]);
+}
+
+SCM
+with_location (SCM loc, SCM proc, SCM arg1, SCM arg2, SCM arg3, SCM arg4, SCM arg5)
+{
+  SCM args[] = { proc, scm_list_5 (arg1, arg2, arg3, arg4, arg5) };
+  return scm_c_with_fluid (Lily::f_location,
+                           unsmob<Input> (loc) ? loc : SCM_BOOL_F,
+                           with_location_hook_n,
+                           static_cast <void *> (&args));
+}