/*
This file is part of LilyPond, the GNU music typesetter.
- Copyright (C) 1998--2011 Jan Nieuwenhuizen <janneke@gnu.org>
+ Copyright (C) 1998--2012 Jan Nieuwenhuizen <janneke@gnu.org>
Han-Wen Nienhuys <hanwen@xs4all.nl>
LilyPond is free software: you can redistribute it and/or modify
/*
Ugh. this is not very efficient.
*/
- SCM str = scm_symbol_to_string (s);
- return ly_scm2string (str);
+ return ly_scm2string (scm_symbol_to_string (s));
+}
+
+string
+robust_symbol2string (SCM sym, string str)
+{
+ return scm_is_symbol (sym) ? ly_symbol2string (sym) : str;
}
string
bool
is_direction (SCM s)
{
- if (scm_is_integer (s))
+ if (scm_is_number (s))
{
int i = scm_to_int (s);
return i >= -1 && i <= 1;
Interval
ly_scm2interval (SCM p)
{
- return is_number_pair (p) ?
- Interval (scm_to_double (scm_car (p)),
- scm_to_double (scm_cdr (p))) :
- Interval (0, 0);
+ return Interval (scm_to_double (scm_car (p)),
+ scm_to_double (scm_cdr (p)));
}
Drul_array<Real>
Offset
ly_scm2offset (SCM s)
{
- return is_number_pair (s) ?
- Offset (scm_to_double (scm_car (s)),
- scm_to_double (scm_cdr (s))) :
- Offset (0, 0);
+ return Offset (scm_to_double (scm_car (s)),
+ scm_to_double (scm_cdr (s)));
}
Offset
/*
ALIST
*/
-// This one is used nowhere.
-bool
-ly_is_alist_equal (SCM a, SCM b)
-{
- if (!scm_is_pair (a) || !scm_is_pair (b))
- return false;
- for (SCM s = a; scm_is_pair (s); s = scm_cdr (s))
- {
- SCM key = scm_caar (s);
- SCM val = scm_cdar (s);
- SCM l = scm_assoc (key, b);
-
- if (scm_is_false (l) || !ly_is_equal (scm_cdr (l), val))
- return false;
- }
- return true;
-}
-
SCM
ly_alist_vals (SCM alist)
{
return x;
}
+vector<Real>
+ly_scm2floatvector (SCM l)
+{
+ vector<Real> floats;
+ for (SCM s = l; scm_is_pair (s); s = scm_cdr (s))
+ floats.push_back (robust_scm2double (scm_car (s), 0.0));
+ return floats;
+}
+
+SCM
+ly_floatvector2scm (vector<Real> v)
+{
+ SCM l = SCM_EOL;
+ SCM *tail = &l;
+ for (vsize i = 0; i < v.size (); i++)
+ {
+ *tail = scm_cons (scm_from_double (v[i]), SCM_EOL);
+ tail = SCM_CDRLOC (*tail);
+ }
+ return l;
+}
+
string
robust_scm2string (SCM k, string s)
{
return o;
}
+vsize
+robust_scm2vsize (SCM k, vsize o)
+{
+ if (scm_integer_p (k) == SCM_BOOL_T)
+ {
+ int i = scm_to_int (k);
+ if (i >= 0)
+ return (vsize) i;
+ }
+ return o;
+}
+
SCM
ly_rational2scm (Rational r)
{