/*
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
{
if (scm_integer_p (k) == SCM_BOOL_T)
{
- o = scm_to_int (k);
- if (o >= 0)
- return (vsize) o;
+ int i = scm_to_int (k);
+ if (i >= 0)
+ return (vsize) i;
}
return o;
}
SCM
ly_rational2scm (Rational r)
{
+ if (r.is_infinity ())
+ if (r > Rational(0))
+ return scm_inf ();
+ else
+ return scm_difference (scm_inf (), SCM_UNDEFINED);
+
return scm_divide (scm_from_int64 (r.numerator ()),
scm_from_int64 (r.denominator ()));
}
Rational
ly_scm2rational (SCM r)
{
+ if (scm_is_true (scm_inf_p (r)))
+ {
+ if (scm_is_true (scm_positive_p (r)))
+ {
+ Rational r;
+ r.set_infinite (1);
+ return r;
+ }
+ else
+ {
+ Rational r;
+ r.set_infinite (-1);
+ return r;
+ }
+ }
+
return Rational (scm_to_int64 (scm_numerator (r)),
scm_to_int64 (scm_denominator (r)));
}
Rational
robust_scm2rational (SCM n, Rational rat)
{
- if (ly_is_fraction (n))
+ if (scm_is_real (n)
+ && (scm_is_true (scm_exact_p (n))
+ || scm_is_true (scm_inf_p (n))))
return ly_scm2rational (n);
else
return rat;