]> git.donarmstrong.com Git - lilypond.git/blob - lily/system-start-delimiter-engraver.cc
* lily/include/grob-info.hh (class Grob_info): make data member
[lilypond.git] / lily / system-start-delimiter-engraver.cc
1 /*
2   system-start-delimiter-engraver.cc -- implement System_start_delimiter_engraver
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 2000--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
8
9 #include "system-start-delimiter.hh"
10 #include "engraver.hh"
11 #include "staff-symbol.hh"
12 #include "group-interface.hh"
13 #include "paper-column.hh"
14 #include "output-def.hh"
15 #include "spanner.hh"
16
17 class System_start_delimiter_engraver : public Engraver
18 {
19 public:
20   TRANSLATOR_DECLARATIONS (System_start_delimiter_engraver);
21
22 protected:
23   Spanner *delim_;
24   virtual void acknowledge_grob (Grob_info);
25   virtual void process_music ();
26   virtual void finalize ();
27 };
28
29 void
30 System_start_delimiter_engraver::acknowledge_grob (Grob_info inf)
31 {
32   if (Staff_symbol::has_interface (inf.grob ()))
33     {
34       /*
35         don't add as Axis_group_interface::add_element (delim_, ),
36         because that would set the parent as well */
37
38       Pointer_group_interface::add_grob (delim_, ly_symbol2scm ("elements"), inf.grob ());
39     }
40   else if (System_start_delimiter::has_interface (inf.grob ()))
41     {
42       SCM gl = inf.grob ()->get_property ("glyph");
43       SCM my_gl = delim_->get_property ("glyph");
44
45       /*
46         UGH UGH
47       */
48       if (scm_is_string (gl) && ly_c_equal_p (gl, scm_makfrom0str ("brace"))
49           && scm_is_string (my_gl) && ly_c_equal_p (my_gl, scm_makfrom0str ("bracket")))
50         inf.grob ()->translate_axis (-0.8, X_AXIS); // ugh
51       else if (scm_is_string (gl) && ly_c_equal_p (gl, scm_makfrom0str ("bracket"))
52                && scm_is_string (my_gl) && ly_c_equal_p (my_gl, scm_makfrom0str ("bracket")))
53         {
54           inf.grob ()->translate_axis (-0.8, X_AXIS); // ugh
55           inf.grob ()->set_property ("arch-height",
56                                    scm_make_real (scm_to_double (inf.grob ()->get_property
57                                                                  ("arch-height")) + 0.5));
58         }
59     }
60 }
61
62 System_start_delimiter_engraver::System_start_delimiter_engraver ()
63 {
64   delim_ = 0;
65 }
66
67 void
68 System_start_delimiter_engraver::process_music ()
69 {
70   if (!delim_)
71     {
72       SCM delim_name = get_property ("systemStartDelimiter");
73       delim_ = make_spanner_from_properties (this, delim_name, SCM_EOL,
74                                              ly_symbol2string (delim_name).to_str0 ());
75
76       delim_->set_bound (LEFT, unsmob_grob (get_property ("currentCommandColumn")));
77     }
78 }
79 void
80 System_start_delimiter_engraver::finalize ()
81 {
82   if (delim_)
83     {
84       delim_->set_bound (RIGHT, unsmob_grob (get_property ("currentCommandColumn")));
85     }
86 }
87
88 ADD_TRANSLATOR (System_start_delimiter_engraver,
89                 /* descr */ "Creates a system start delimiter (ie. SystemStart@{Bar, Brace, Bracket@} spanner",
90                 /* creats*/ "SystemStartBar SystemStartBrace SystemStartBracket",
91                 /* accepts */ "",
92                 /* acks  */ "system-start-delimiter-interface staff-symbol-interface",
93                 /* reads */ "systemStartDelimiter",
94                 /* write */ "");