]> git.donarmstrong.com Git - lilypond.git/blob - lily/system-start-delimiter-engraver.cc
patch::: 1.3.141.jcn3
[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--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7   
8  */
9
10
11 #include "system-start-delimiter.hh"
12 #include "engraver.hh"
13 #include "staff-symbol.hh"
14 #include "group-interface.hh"
15 #include "paper-column.hh"
16 #include "paper-def.hh"
17 #include "spanner.hh"
18
19 class System_start_delimiter_engraver : public Engraver
20 {
21 public:
22   VIRTUAL_COPY_CONS (Translator);
23   System_start_delimiter_engraver ();
24
25 protected:
26   Spanner * delim_;
27   virtual void acknowledge_grob (Grob_info);
28   virtual void initialize ();
29   virtual void finalize ();
30 };
31
32 ADD_THIS_TRANSLATOR (System_start_delimiter_engraver);
33
34 void
35 System_start_delimiter_engraver::acknowledge_grob (Grob_info inf)
36 {
37   if (Staff_symbol::has_interface (inf.elem_l_))
38     {
39       /*
40         don't add as Axis_group_interface::add_element (delim_,),
41         because that would set the parent as well */
42           
43       Pointer_group_interface::add_element (delim_, "elements", inf.elem_l_);
44     }
45   else if (System_start_delimiter::has_interface (inf.elem_l_))
46     {
47       SCM gl = inf.elem_l_->get_grob_property ("glyph");
48       SCM my_gl = delim_->get_grob_property ("glyph");
49
50       /*
51         UGH UGH
52        */
53       if (gh_symbol_p (gl) && gl  == ly_symbol2scm ("brace")
54           && gh_symbol_p (my_gl) && my_gl == ly_symbol2scm ("bracket"))
55         inf.elem_l_->translate_axis (-1.0, X_AXIS); // ugh
56       else if (gh_symbol_p (gl) && gl  == ly_symbol2scm ("bracket")
57                && gh_symbol_p (my_gl) && my_gl == ly_symbol2scm ("bracket"))
58         {
59           inf.elem_l_->translate_axis ( -0.8, X_AXIS); // ugh
60           inf.elem_l_->set_grob_property ("arch-height",
61           gh_double2scm(gh_scm2double(inf.elem_l_->get_grob_property
62                                       ("arch-height"))+0.5));
63         }
64     }
65
66 }
67
68 System_start_delimiter_engraver::System_start_delimiter_engraver ()
69 {
70   delim_ = 0;
71 }
72
73 void
74 System_start_delimiter_engraver::initialize ()
75 {
76   delim_ = new Spanner (get_property ("SystemStartDelimiter"));
77
78   delim_->set_bound (LEFT, unsmob_grob (get_property ("currentCommandColumn")));
79
80
81   announce_grob (delim_,0);
82 }
83
84 void
85 System_start_delimiter_engraver::finalize ()
86 {
87   delim_->set_bound (RIGHT, unsmob_grob (get_property ("currentCommandColumn")));
88   typeset_grob (delim_);
89 }
90