X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fsimple-spacer.hh;h=71b1045acad3258367239265ab21403fe939fd22;hb=0b544cfb7332615ef809b71b57ab656741311ae1;hp=47e8080ced6cb9b122e04210d3f7641da26ccb5f;hpb=3df9923cfb65cc141b68b7258c965da417cba6d7;p=lilypond.git diff --git a/lily/include/simple-spacer.hh b/lily/include/simple-spacer.hh index 47e8080ced..71b1045aca 100644 --- a/lily/include/simple-spacer.hh +++ b/lily/include/simple-spacer.hh @@ -1,9 +1,20 @@ /* - simple-spacer.hh -- declare Simple_spacer + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 1999--2014 Han-Wen Nienhuys - (c) 1999--2006 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 + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + 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. + + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . */ #ifndef SIMPLE_SPACER_HH @@ -11,30 +22,9 @@ #include "std-vector.hh" #include "lily-proto.hh" +#include "spring.hh" #include "smobs.hh" -struct Spring_description -{ - Real ideal_; - Real inverse_hooke_; - Real block_force_; - - Real length (Real force) const; - Spring_description (); - - bool is_sane () const; - - bool operator> (const Spring_description &s) const - { - return block_force_ > s.block_force_; - } - - bool operator< (const Spring_description &s) const - { - return block_force_ < s.block_force_; - } -}; - class Simple_spacer { public: @@ -42,23 +32,25 @@ public: void solve (Real line_len, bool ragged); void add_rod (int l, int r, Real dist); - void add_spring (Real, Real); + void add_spring (Spring const &); Real range_ideal_len (int l, int r) const; - Real range_stiffness (int l, int r) const; - Real configuration_length () const; + Real range_stiffness (int l, int r, bool stretch) const; + Real configuration_length (Real) const; vector spring_positions () const; - Real force (); - bool fits (); + void set_force (Real force); + Real force () const; + Real force_penalty (bool ragged) const; + bool fits () const; - DECLARE_SIMPLE_SMOBS (Simple_spacer,); + DECLARE_SIMPLE_SMOBS (Simple_spacer); private: Real expand_line (); Real compress_line (); Real rod_force (int l, int r, Real dist); - vector springs_; + vector springs_; Real line_len_; Real force_; bool ragged_; @@ -66,16 +58,15 @@ private: }; /* returns a vector of dimensions breaks.size () * breaks.size () */ -vector get_line_forces (vector const &columns, - vector breaks, - Real line_len, - Real indent, - bool ragged); - -Column_x_positions get_line_configuration (vector const &columns, - Real line_len, - Real indent, - bool ragged); +vector get_line_forces (vector const &columns, + Real line_len, + Real indent, + bool ragged); + +Column_x_positions get_line_configuration (vector const &columns, + Real line_len, + Real indent, + bool ragged); #endif /* SIMPLE_SPACER_HH */