X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fbox.cc;h=6569493419da6a66c44077feab15ea5297c46ee9;hb=77267b700c377fd170abcbf4863728937038eb5e;hp=648c7f7da216d0dc3c05d719e054373f38ac48a0;hpb=bb8a0a5387af94dd2702877256334b160575a730;p=lilypond.git diff --git a/lily/box.cc b/lily/box.cc index 648c7f7da2..6569493419 100644 --- a/lily/box.cc +++ b/lily/box.cc @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 1996--2011 Han-Wen Nienhuys + Copyright (C) 1996--2015 Han-Wen Nienhuys LilyPond is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -23,7 +23,8 @@ void Box::translate (Offset o) { for (Axis i = X_AXIS; i < NO_AXES; incr (i)) - interval_a_[i] += o[i]; + if (!is_empty (i)) + interval_a_[i] += o[i]; } void @@ -33,6 +34,13 @@ Box::unite (Box b) interval_a_[i].unite (b[i]); } +Real +Box::area () const +{ + return interval_a_[X_AXIS].length () + * interval_a_[Y_AXIS].length (); +} + Box::Box () { } @@ -44,6 +52,21 @@ Box::set_empty () interval_a_[Y_AXIS].set_empty (); } +bool +Box::is_empty () const +{ + return is_empty (X_AXIS) && is_empty (Y_AXIS); +} + +bool +Box::is_empty (Axis a) const +{ + Interval empty; + empty.set_empty (); + return interval_a_[a][LEFT] == empty[LEFT] + && interval_a_[a][RIGHT] == empty[RIGHT]; +} + Box::Box (Interval ix, Interval iy) { x () = ix; @@ -90,23 +113,24 @@ Box::widen (Real x, Real y) 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 +Box::intersect (Box b) { - return SCM_EOL; + interval_a_[X_AXIS].intersect (b[X_AXIS]); + interval_a_[Y_AXIS].intersect (b[Y_AXIS]); } -int -Box::print_smob (SCM /* x */, SCM p, scm_print_state *) +// for debugging + +void +Box::print () { - scm_puts ("#", p); - return 1; + printf ("X left %4.4f right %4.4f Y down %4.4f up %4.4f\n", + interval_a_[X_AXIS][LEFT], interval_a_[X_AXIS][RIGHT], + interval_a_[Y_AXIS][DOWN], interval_a_[Y_AXIS][UP]); } + +/****************************************************************/ + + +const char * const Box::type_p_name_ = "ly:box?";