X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=lily%2Finclude%2Ftie-formatting-problem.hh;h=5d46129fe592778753e15cd497a3179a5e73e19f;hb=85eb6b81242d79e3d1c23094c8f86a621f8055dd;hp=18eafec4f037efa0e775574608c484aa04d620e8;hpb=849ed54c1a272dac222d975e3c8d3e532aaa8f27;p=lilypond.git diff --git a/lily/include/tie-formatting-problem.hh b/lily/include/tie-formatting-problem.hh index 18eafec4f0..5d46129fe5 100644 --- a/lily/include/tie-formatting-problem.hh +++ b/lily/include/tie-formatting-problem.hh @@ -16,16 +16,18 @@ #include "lily-proto.hh" #include "tie-configuration.hh" #include "tie-details.hh" +#include "tuple.hh" #include #include -typedef map< pair, Tie_configuration *> Tie_configuration_map; +typedef map< Tuple, Tie_configuration *> Tie_configuration_map; struct Tie_specification { int position_; Drul_array note_head_drul_; + Drul_array column_ranks_; bool has_manual_position_; bool has_manual_dir_; @@ -34,6 +36,8 @@ struct Tie_specification Direction manual_dir_; Tie_specification (); + int column_span () const; + void get_tie_manual_settings (Grob *); }; struct Tie_configuration_variation @@ -43,11 +47,14 @@ struct Tie_configuration_variation Tie_configuration_variation (); }; +typedef map < Tuple, vector > Chord_outline_map; +typedef map < Tuple, Box> Column_extent_map; class Tie_formatting_problem { - Drul_array< vector > chord_outlines_; - Drul_array< Box > stem_extents_; - Drul_array< Box > head_extents_; + Chord_outline_map chord_outlines_; + Column_extent_map stem_extents_; + Column_extent_map head_extents_; + set dot_positions_; Interval dot_x_; vector specifications_; @@ -57,8 +64,8 @@ class Tie_formatting_problem Grob *x_refpoint_; - Tie_configuration *get_configuration (int position, Direction dir) const; - Tie_configuration *generate_configuration (int position, Direction dir) const; + Tie_configuration *get_configuration (int position, Direction dir, Drul_array cols) const; + Tie_configuration *generate_configuration (int position, Direction dir, Drul_array cols) const; vector generate_collision_variations (Ties_configuration const &ties) const; vector generate_extremal_tie_variations (Ties_configuration const &ties) const; @@ -77,6 +84,10 @@ class Tie_formatting_problem public: Tie_details details_; void print_ties_configuration (Ties_configuration const *); + + Interval get_stem_extent (int, Direction, Axis) const; + Interval get_head_extent (int, Direction, Axis) const; + public: Tie_formatting_problem (); ~Tie_formatting_problem (); @@ -85,12 +96,14 @@ public: Ties_configuration generate_optimal_chord_configuration (); Ties_configuration generate_ties_configuration (Ties_configuration const &); Tie_configuration find_optimal_tie_configuration (Tie_specification const &) const; + void from_ties (vector const &ties); void from_tie (Grob *tie); - void from_lv_ties (vector const &); + void from_semi_ties (vector const &, Direction head_dir); void set_chord_outline (vector, Direction); + void set_column_chord_outline (vector, Direction, int rank); void set_manual_tie_configuration (SCM); - Interval get_attachment (Real) const; + Interval get_attachment (Real, Drul_array) const; Grob *common_x_refpoint () const; };