X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fdimension-cache.cc;h=33294db5e62cd37c9a3253554b083f94f6b023de;hb=47db9a3883d726ca53e2133a3b2298f78dd6a32e;hp=b7cf04207ab51be2a3d77eaf46161421b7608f9a;hpb=59e4ae99bad964d00dc167919779301c5ec2a535;p=lilypond.git diff --git a/lily/dimension-cache.cc b/lily/dimension-cache.cc index b7cf04207a..33294db5e6 100644 --- a/lily/dimension-cache.cc +++ b/lily/dimension-cache.cc @@ -1,171 +1,68 @@ -/* - dimension-cache.cc -- implement Dimension_cache - - source file of the GNU LilyPond music typesetter - - (c) 1998--1999 Han-Wen Nienhuys - */ +/* + This file is part of LilyPond, the GNU music typesetter. -#include "dimension-cache.hh" -#include "parray.hh" -#include "graphical-element.hh" + Copyright (C) 1998--2015 Han-Wen Nienhuys -Dimension_cache::Dimension_cache (Dimension_cache const &d) -{ - init(); - callback_l_ = d.callback_l_; - empty_b_ = d.empty_b_; - basic_offset_ = d.basic_offset_; - extra_offset_ = d.extra_offset_; - off_valid_b_ = d.off_valid_b_; - off_callbacks_ = d.off_callbacks_; -} + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. -Dimension_cache::Dimension_cache () -{ - init(); -} + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. -void -Dimension_cache::init() -{ - callback_l_ =0; - - basic_offset_ =0.0; - extra_offset_ =0.0; - - elt_l_ = 0; - dim_.set_empty (); - parent_l_ =0; - valid_b_ = false; - empty_b_ = false; - off_valid_b_ = false; -} + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . +*/ +#include "dimension-cache.hh" -void -Dimension_cache::invalidate () -{ - off_valid_b_ =false; - valid_b_ = false; -} - - -void -Dimension_cache::set_offset (Real x) -{ - // ugh! - /* - - UGH ! UGH ! - - */ - - extra_offset_ = x; -} - -void -Dimension_cache::translate (Real x) -{ - extra_offset_ += x; -} - -Real -Dimension_cache::relative_coordinate (Dimension_cache *refp) const -{ - if (refp == this) - return 0.0; - - /* - We catch PARENT_L_ == nil case with this, but we crash if we did - not ask for the absolute coordinate (ie. REFP == nil.) - - */ - if (refp == parent_l_) - return get_offset (); - else - return get_offset () + parent_l_->relative_coordinate (refp); -} +#include "warn.hh" +#include "grob.hh" -Axis -Dimension_cache::axis () const +Dimension_cache::Dimension_cache (Dimension_cache const &d) { - if (elt_l_-> dim_cache_[X_AXIS] == this) - return X_AXIS; - else - return Y_AXIS; + init (); + offset_ = d.offset_ ? new Real (*d.offset_) : 0; + parent_ = d.parent_; + extent_ = d.extent_ ? new Interval (*d.extent_) : 0; } -Real -Dimension_cache::get_offset () const +Dimension_cache & +Dimension_cache::operator = (Dimension_cache const &d) { - if (!off_valid_b_) - { - Dimension_cache *d = (Dimension_cache*) this; - - d->basic_offset_ =0.0; - d->off_valid_b_ = true; - for (int i=0; i < off_callbacks_.size (); i++) - d->basic_offset_ += (*off_callbacks_[i]) (d); - } - - return basic_offset_ + extra_offset_; + clear (); + offset_ = d.offset_ ? new Real (*d.offset_) : 0; + parent_ = d.parent_; + extent_ = d.extent_ ? new Interval (*d.extent_) : 0; + return *this; } -Dimension_cache * -Dimension_cache::common_refpoint (Dimension_cache const* s) const +Dimension_cache::Dimension_cache () { - Link_array my_groups; - for (Dimension_cache const *c = this; c ; c = c->parent_l_) - my_groups.push ((Dimension_cache*)c); - - Dimension_cache const *common=0; - - for (Dimension_cache const * d = s; !common && d; d = d->parent_l_) - common = (Dimension_cache const*)my_groups.find_l (d); - - return (Dimension_cache*) common; + init (); } - - void -Dimension_cache::set_empty (bool b) +Dimension_cache::init () { - if (empty_b_ != b) - { - empty_b_ = b; - if (!empty_b_) - invalidate (); - } -} + offset_ = 0; + extent_ = 0; + parent_ = 0; +} -Interval -Dimension_cache::get_dim () const +Dimension_cache::~Dimension_cache () { - Interval r; - if (empty_b_) - { - r.set_empty (); - return r; - } - - if (!valid_b_) - { - Dimension_cache *nc = ((Dimension_cache*)this); - nc->dim_= (*callback_l_ ) (nc); - nc->valid_b_ = true; - } - - r=dim_; - - return r; + clear (); } void -Dimension_cache::set_callback (Dim_cache_callback c) +Dimension_cache::clear () { - callback_l_ =c; + delete extent_; + delete offset_; + extent_ = 0; + offset_ = 0; } - -