]> git.donarmstrong.com Git - lilypond.git/blob - lily/group-interface.cc
release: 1.3.25
[lilypond.git] / lily / group-interface.cc
1 /*   
2   group-interface.cc --  implement Group_interface
3   
4   source file of the GNU LilyPond music typesetter
5   
6   (c) 1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7   
8  */
9 #include "group-interface.hh"
10 #include "score-element.hh"
11
12 Group_interface::Group_interface (Score_element const* e)
13 {
14   elt_l_ = (Score_element*)e;
15   name_ = "elements";
16 }
17
18
19 Group_interface::Group_interface (Score_element const *e, String s)
20 {
21   elt_l_ =(Score_element*)e;
22   name_ = s;
23
24 bool
25 Group_interface::has_interface_b () 
26 {
27   SCM el = elt_l_->get_elt_property (name_);
28
29   return el == SCM_EOL || gh_pair_p (el);
30 }
31
32
33 void
34 Group_interface::add_element (Score_element*p) 
35 {
36   p->used_b_ =  true;
37   elt_l_->used_b_ = true;
38   
39   elt_l_->set_elt_property (name_,
40                             gh_cons (p->self_scm_, elt_l_->get_elt_property (name_)));
41 }
42
43 int
44 Group_interface::count ()
45 {
46   return scm_ilength (elt_l_->get_elt_property (name_));
47 }
48
49 void
50 Group_interface::set_interface ()
51 {
52   if (!has_interface_b ())
53     {
54       elt_l_->set_elt_property (name_, SCM_EOL);
55     }
56 }
57
58 Group_interface
59 group (Score_element*s)
60 {
61   Group_interface gi (s);
62   return gi;
63 }