Real ext_len = cached_line_details_[i].extent_.length ();
Real next_rod_height = cur_rod_height + ext_len
+ ((cur_rod_height > 0) ? cached_line_details_[i].padding_: 0);
- Real next_spring_height = cur_spring_height + line_space (cached_line_details_[i]);
+ Real next_spring_height = cur_spring_height + cached_line_details_[i].space_;
Real next_height = next_rod_height + (ragged () ? next_spring_height : 0);
&& cached_line_details_[i-1].page_permission_ == ly_symbol2scm ("force")))
{
cur_rod_height = ext_len;
- cur_spring_height = line_space (cached_line_details_[i]);
+ cur_spring_height = cached_line_details_[i].space_;
cur_page_height = page_height (first_page_num + ret, false);
ret++;
}
#include "page-breaking.hh"
#include "warn.hh"
-/* In order to prevent possible division by zero, we require every line
- to have a spring of non-zero length. */
-Real
-line_space (const Line_details &line)
-{
- return max (0.1, line.space_);
-}
-
void
Page_spacing::calc_force ()
{
- if (rod_height_ + last_line_.bottom_padding_ >= page_height_ || !inverse_spring_k_)
+ if (rod_height_ + last_line_.bottom_padding_ >= page_height_)
force_ = infinity_f;
else
- force_ = (page_height_ - rod_height_ - last_line_.bottom_padding_ - spring_len_) / inverse_spring_k_;
+ force_ = (page_height_ - rod_height_ - last_line_.bottom_padding_ - spring_len_)
+ / max (0.1, inverse_spring_k_);
}
void
rod_height_ += last_line_.padding_;
rod_height_ += line.extent_.length ();
- spring_len_ += line_space (line);
- inverse_spring_k_ += max (0.1, line.inverse_hooke_);
+ spring_len_ += line.space_;
+ inverse_spring_k_ += line.inverse_hooke_;
last_line_ = line;
last_line_ = line;
rod_height_ += line.extent_.length ();
- spring_len_ += line_space (line);
- inverse_spring_k_ += max (0.1, line.inverse_hooke_);
+ spring_len_ += line.space_;
+ inverse_spring_k_ += line.inverse_hooke_;
calc_force ();
}