X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fsimple-spacer.hh;h=935cb94c6c260e72872b9261d34282f6432984ef;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=39d9a3f853062cfd3eab5f0654fddd30f9e01fd2;hpb=582186f60e5103f11a0cc54cc5dfb3319b9ea114;p=lilypond.git diff --git a/lily/include/simple-spacer.hh b/lily/include/simple-spacer.hh index 39d9a3f853..935cb94c6c 100644 --- a/lily/include/simple-spacer.hh +++ b/lily/include/simple-spacer.hh @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 1999--2006 Han-Wen Nienhuys + (c) 1999--2008 Han-Wen Nienhuys */ #ifndef SIMPLE_SPACER_HH @@ -11,30 +11,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 +21,24 @@ 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 range_stiffness (int l, int r, bool stretch) const; Real configuration_length (Real) const; vector spring_positions () const; 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_; @@ -67,7 +47,6 @@ 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);