#define TIE_FORMATTING_PROBLEM_HH
#include "drul-array.hh"
-#include "std-vector.hh"
#include "skyline.hh"
-#include "lily-proto.hh"
#include "tie-configuration.hh"
#include "tie-details.hh"
+#include "tuple.hh"
#include <map>
#include <set>
-typedef map< pair<int, int>, Tie_configuration *> Tie_configuration_map;
+typedef map< Tuple<int,4>, Tie_configuration *> Tie_configuration_map;
struct Tie_specification
{
int position_;
Drul_array<Grob*> note_head_drul_;
+ Drul_array<int> column_ranks_;
bool has_manual_position_;
bool has_manual_dir_;
Direction manual_dir_;
Tie_specification ();
+ int column_span () const;
+ void get_tie_manual_settings (Grob *);
};
struct Tie_configuration_variation
Tie_configuration_variation ();
};
+typedef map < Tuple<int, 2>, Skyline> Chord_outline_map;
+typedef map < Tuple<int, 2>, Box> Column_extent_map;
class Tie_formatting_problem
{
- Drul_array< vector<Skyline_entry> > 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<int> dot_positions_;
Interval dot_x_;
vector<Tie_specification> specifications_;
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<int> cols) const;
+ Tie_configuration *generate_configuration (int position, Direction dir, Drul_array<int> cols) const;
vector<Tie_configuration_variation> generate_collision_variations (Ties_configuration const &ties) const;
vector<Tie_configuration_variation> generate_extremal_tie_variations (Ties_configuration const &ties) const;
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 ();
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<Grob*> const &ties);
void from_tie (Grob *tie);
- void from_lv_ties (vector<Grob*> const &);
+ void from_semi_ties (vector<Grob*> const &, Direction head_dir);
void set_chord_outline (vector<Item*>, Direction);
+ void set_column_chord_outline (vector<Item*>, Direction, int rank);
void set_manual_tie_configuration (SCM);
- Interval get_attachment (Real) const;
+ Interval get_attachment (Real, Drul_array<int>) const;
Grob *common_x_refpoint () const;
};