]> git.donarmstrong.com Git - lilypond.git/blob - lily/include/tie-formatting-problem.hh
* scm/define-music-types.scm (music-descriptions): add RepeatTieEvent
[lilypond.git] / lily / include / tie-formatting-problem.hh
1 /*
2   tie-formatting-problem.hh -- declare Tie_formatting_problem
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 2005--2006 Han-Wen Nienhuys <hanwen@xs4all.nl>
7
8 */
9
10 #ifndef TIE_FORMATTING_PROBLEM_HH
11 #define TIE_FORMATTING_PROBLEM_HH
12
13 #include "drul-array.hh"
14 #include "std-vector.hh"
15 #include "skyline.hh"
16 #include "lily-proto.hh"
17 #include "tie-configuration.hh"
18 #include "tie-details.hh"
19
20 #include <map>
21 #include <set>
22
23 typedef map< pair<int, int>, Tie_configuration *> Tie_configuration_map;
24
25 struct Tie_specification
26 {
27   int position_;
28   Drul_array<Grob*> note_head_drul_;
29   
30   bool has_manual_position_;
31   bool has_manual_dir_;
32   
33   Real manual_position_;
34   Direction manual_dir_;
35   
36   Tie_specification ();
37 };
38
39 struct Tie_configuration_variation
40 {
41   int index_;
42   Tie_configuration *suggestion_;
43   Tie_configuration_variation ();
44 };
45
46 class Tie_formatting_problem
47 {
48   Drul_array< vector<Skyline_entry> > chord_outlines_;
49   Drul_array< Box > stem_extents_;
50   Drul_array< Box > head_extents_;
51   set<int> dot_positions_;
52   Interval dot_x_;
53   vector<Tie_specification> specifications_;
54   
55   Tie_configuration_map possibilities_;
56
57   Grob *x_refpoint_;
58
59   
60   Tie_configuration *get_configuration (int position, Direction dir) const;
61   Tie_configuration *generate_configuration (int position, Direction dir) const;
62   vector<Tie_configuration_variation> generate_collision_variations (Ties_configuration const &ties) const;
63   vector<Tie_configuration_variation> generate_extremal_tie_variations (Ties_configuration const &ties) const;
64
65   void score_configuration (Tie_configuration *) const;
66   Real score_aptitude (Tie_configuration *, Tie_specification const &,
67                        Ties_configuration *, int) const;
68   void score_ties_aptitude (Ties_configuration *ties) const;
69   void score_ties_configuration (Ties_configuration *ties) const;
70   void set_ties_config_standard_directions (Ties_configuration *tie_configs_ptr);
71   void score_ties (Ties_configuration *) const;
72   
73   Ties_configuration generate_base_chord_configuration ();
74   Ties_configuration find_best_variation (Ties_configuration const &base,
75                                           vector<Tie_configuration_variation> vars);
76
77 public:
78   Tie_details details_;
79   void print_ties_configuration (Ties_configuration const *);
80 public:
81   Tie_formatting_problem ();
82   ~Tie_formatting_problem ();
83
84   Tie_specification get_tie_specification (int) const;
85   Ties_configuration generate_optimal_chord_configuration ();
86   Ties_configuration generate_ties_configuration (Ties_configuration const &);
87   Tie_configuration find_optimal_tie_configuration (Tie_specification const &) const;
88   void from_ties (vector<Grob*> const &ties);
89   void from_tie (Grob *tie);
90   void from_semi_ties (vector<Grob*> const &, Direction head_dir);
91   void set_chord_outline (vector<Item*>, Direction);
92   void set_manual_tie_configuration (SCM);
93   Interval get_attachment (Real) const;
94   Grob *common_x_refpoint () const;
95 };
96
97 #endif /* TIE_FORMATTING_PROBLEM_HH */