X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=lily%2Fbox.cc;h=e44f166dbce2800bd31ce04aa21b3fb079c6894c;hb=5abcafda2b8fb3310f8917fff292e1e7b7d60a7d;hp=6f8bf3439496eadd80957e6f92615494fa2a8752;hpb=c5402461ab1d1cdbaa684b0e55d4851f0e28e37a;p=lilypond.git diff --git a/lily/box.cc b/lily/box.cc index 6f8bf34394..e44f166dbc 100644 --- a/lily/box.cc +++ b/lily/box.cc @@ -3,54 +3,50 @@ source file of the GNU LilyPond music typesetter - (c) 1996--2000 Han-Wen Nienhuys + (c) 1996--2007 Han-Wen Nienhuys */ #include "box.hh" -#include "array.hh" void Box::translate (Offset o) { - for (Axis i=X_AXIS; i < NO_AXES; incr(i)) + for (Axis i = X_AXIS; i < NO_AXES; incr (i)) interval_a_[i] += o[i]; } void Box::unite (Box b) { - for (Axis i=X_AXIS; i < NO_AXES; incr(i)) + for (Axis i = X_AXIS; i < NO_AXES; incr (i)) interval_a_[i].unite (b[i]); } -/** - Initialize to empty. - */ -Box::Box() -{ +Box::Box () +{ } void Box::set_empty () { interval_a_[X_AXIS].set_empty (); - interval_a_[Y_AXIS].set_empty (); + interval_a_[Y_AXIS].set_empty (); } Box::Box (Interval ix, Interval iy) { - x() = ix; - y() = iy; + x () = ix; + y () = iy; } Interval & -Box::operator[] (Axis a) +Box::operator [] (Axis a) { return interval_a_[a]; } Interval -Box::operator[] (Axis a)const +Box::operator [] (Axis a) const { return interval_a_[a]; } @@ -61,3 +57,47 @@ Box::scale (Real s) interval_a_[X_AXIS] *= s; interval_a_[Y_AXIS] *= s; } + +void +Box::add_point (Offset o) +{ + interval_a_[X_AXIS].add_point (o[X_AXIS]); + interval_a_[Y_AXIS].add_point (o[Y_AXIS]); +} + +Offset +Box::center () const +{ + return Offset (interval_a_[X_AXIS].center (), + interval_a_[Y_AXIS].center ()); +} + +void +Box::widen (Real x, Real y) +{ + interval_a_[X_AXIS].widen (x); + interval_a_[Y_AXIS].widen (y); +} + +/****************************************************************/ + +#include "ly-smobs.icc" + +IMPLEMENT_SIMPLE_SMOBS (Box); +IMPLEMENT_TYPE_P (Box, "ly:box?"); +IMPLEMENT_DEFAULT_EQUAL_P (Box); + +SCM +Box::mark_smob (SCM x) +{ + (void)x; + return SCM_EOL; +} + +int +Box::print_smob (SCM x, SCM p, scm_print_state*) +{ + (void)x; + scm_puts ("#", p); + return 1; +}