#include "offset.hh"
#include "interval.hh"
#include "pitch.hh"
+#include "dimensions.hh"
SCM
ly_last (SCM list)
return result;
}
-SCM
-ly_gulp_file (SCM fn)
+LY_DEFINE(ly_gulp_file, "ly-gulp-file", 1,0, 0,
+ (SCM name),
+ "Read the file named @var{name}, and return its contents in a string. The
+file is looked up using the lilypond search path.
+
+")
{
- return ly_str02scm (gulp_file_to_string (ly_scm2string (fn)).ch_C ());
+ return ly_str02scm (gulp_file_to_string (ly_scm2string (name)).ch_C ());
}
/**
Read a file, and shove it down GUILE. GUILE also has file read
functions, but you can't fiddle with the path of those.
- */
+
+
+ TODO: JUNKME.
+*/
void
read_lily_scm_file (String fn)
{
return s;
}
-SCM
-ly_warning (SCM str)
+LY_DEFINE(ly_warning,"ly-warn", 1, 0, 0,
+ (SCM str),"Scheme callable function to issue the warning @code{msg}.
+")
{
assert (gh_string_p (str));
warning ("lily-guile: " + ly_scm2string (str));
return SCM_BOOL_T;
}
-SCM
-ly_isdir_p (SCM s)
+LY_DEFINE(ly_isdir_p, "dir?", 1,0, 0, (SCM s),
+ "type predicate. A direction is a -1, 0 or 1, where -1 represents left or
+down and 1 represents right or up.
+")
{
if (gh_number_p (s))
{
}
SCM
-ly_interval2scm (Interval i)
+ly_interval2scm (Drul_array<Real> i)
{
return gh_cons (gh_double2scm (i[LEFT]),
gh_double2scm (i[RIGHT]));
*/
-SCM
-ly_number2string (SCM s)
+LY_DEFINE(ly_number2string, "ly-number->string", 1, 0,0,
+ (SCM s),
+ " converts @var{num} to a string without generating many decimals. It
+leaves a space at the end.
+")
{
assert (gh_number_p (s));
#include "version.hh"
-SCM
-ly_version ()
+LY_DEFINE(ly_version, "ly-version", 0, 0, 0, (),
+ "Return the current lilypond version as a list, e.g.
+@code{(1 3 127 uu1)}.
+")
{
char const* vs = "\' (" MAJOR_VERSION " " MINOR_VERSION " " PATCH_LEVEL " " MY_PATCH_LEVEL ")" ;
return gh_eval_str ((char*)vs);
}
-static void
-init_functions ()
+LY_DEFINE(ly_unit, "ly-unit", 0, 0, 0, (),
+ "Return the unit used for lengths as a string.")
{
- scm_c_define_gsubr ("ly-warn", 1, 0, 0,
- (Scheme_function_unknown)ly_warning);
- scm_c_define_gsubr ("ly-version", 0, 0, 0,
- (Scheme_function_unknown)ly_version);
- scm_c_define_gsubr ("ly-gulp-file", 1,0, 0,
- (Scheme_function_unknown)ly_gulp_file);
- scm_c_define_gsubr ("dir?", 1,0, 0, (Scheme_function_unknown)ly_isdir_p);
- scm_c_define_gsubr ("ly-number->string", 1, 0,0,
- (Scheme_function_unknown) ly_number2string);
+ return ly_str02scm (INTERNAL_UNIT);
+}
+LY_DEFINE(ly_verbose, "ly-verbose", 0, 0, 0, (),
+ "Return whether lilypond is being run in verbose mode.")
+{
+ return gh_bool2scm (verbose_global_b);
+}
+static void
+init_functions ()
+{
#ifdef TEST_GC
scm_c_hook_add (&scm_before_mark_c_hook, greet_sweep, 0, 0);
scm_c_hook_add (&scm_before_sweep_c_hook, wave_sweep_goodbye, 0, 0);
}
/*
- LIST has the form "sym1 sym2 sym3"
+ LIST has the form "sym1 sym2 sym3\nsym4\nsym5"
+
+ i.e. \n and ' ' can be used interchangeably as separators.
*/
SCM
parse_symbol_list (const char * list)
char * s = strdup (list);
char *orig = s;
SCM create_list = SCM_EOL;
+
+ for (char * p = s; *p; p++)
+ {
+ if (*p == '\n')
+ *p = ' ' ;
+ }
+
if (!s[0] )
s = 0;
+
+
while (s)
{
char *next = strchr (s, ' ');
return gh_cons ( scm_reverse_x (before, SCM_EOL), after);
}
+