source file of the LilyPond music typesetter
- (c) 1997--2001 Jan Nieuwenhuizen <janneke@gnu.org>
+ (c) 1997--2002 Jan Nieuwenhuizen <janneke@gnu.org>
Han-Wen Nienhuys <hanwen@cs.uu.nl>
*/
{
durlog_i_ = 0;
dots_i_ = 0;
- factor_ = Moment (1,1);
+ factor_ = Rational (1,1);
}
Duration::Duration (int l, int d)
{
durlog_i_ = l;
dots_i_ = d;
- factor_ = Moment (1,1);
+ factor_ = Rational (1,1);
}
Duration
Rational mom (1 << abs (durlog_i_));
if (durlog_i_> 0)
- mom = Moment (1)/mom;
+ mom = Rational (1)/mom;
Rational delta = mom;
for (int d = dots_i_; d; d--)
{
- delta /= Moment (2);
+ delta /= Rational (2);
mom += delta;
}
Duration::str () const
{
String s = to_str (durlog_i_) + to_str ('.', dots_i_);
- if (factor_ != Moment (1,1))
+ if (factor_ != Moment (Rational (1,1)))
{
s += "*" + factor_.str ();
}
IMPLEMENT_TYPE_P (Duration, "duration?");
-IMPLEMENT_UNSMOB (Duration, duration);
SCM
Duration::mark_smob (SCM)
int
Duration::print_smob (SCM s, SCM port, scm_print_state *)
{
- Duration *r = (Duration *) gh_cdr (s);
+ Duration *r = (Duration *) ly_cdr (s);
scm_puts ("#<Duration ", port);
scm_display (ly_str02scm (r->str ().ch_C ()), port);
SCM
Duration::equal_p (SCM a , SCM b)
{
- Duration *p = (Duration *) gh_cdr (a);
- Duration *q = (Duration *) gh_cdr (b);
+ Duration *p = (Duration *) ly_cdr (a);
+ Duration *q = (Duration *) ly_cdr (b);
bool eq = p->dots_i_ == q->dots_i_
&& p->durlog_i_ == q->durlog_i_
static void
add_funcs ()
{
- scm_make_gsubr ("make-duration", 2, 0, 0, (Scheme_function_unknown)make_duration);
+ scm_c_define_gsubr ("make-duration", 2, 0, 0,
+ (Scheme_function_unknown)make_duration);
}
ADD_SCM_INIT_FUNC (duration, add_funcs);