]> git.donarmstrong.com Git - lilypond.git/blob - lily/context-mod.cc
Merge branch 'master' into lilypond/translation
[lilypond.git] / lily / context-mod.cc
1 /*
2   This file is part of LilyPond, the GNU music typesetter.
3
4   Copyright (C) 2010--2011 Reinhold Kainhofer <reinhold@kainhofer.com>
5
6   LilyPond is free software: you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation, either version 3 of the License, or
9   (at your option) any later version.
10
11   LilyPond is distributed in the hope that it will be useful,
12   but WITHOUT ANY WARRANTY; without even the implied warranty of
13   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14   GNU General Public License for more details.
15
16   You should have received a copy of the GNU General Public License
17   along with LilyPond.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include "context-mod.hh"
21
22 Context_mod::Context_mod ()
23 {
24   mods_ = SCM_EOL;
25 }
26
27 Context_mod::Context_mod (Context_mod const &s)
28 {
29   mods_ = s.mods_;
30 }
31
32 #include "ly-smobs.icc"
33 IMPLEMENT_SIMPLE_SMOBS (Context_mod);
34 IMPLEMENT_DEFAULT_EQUAL_P (Context_mod);
35 IMPLEMENT_TYPE_P (Context_mod, "ly:context-mod?");
36
37 int
38 Context_mod::print_smob (SCM smob, SCM port, scm_print_state *)
39 {
40   Context_mod *me = (Context_mod *) SCM_CELL_WORD_1 (smob);
41
42   scm_puts ("#<Context_mod ", port);
43   scm_display (me->mods_, port);
44   scm_puts (">", port);
45   return 1;
46 }
47
48 SCM
49 Context_mod::mark_smob (SCM smob)
50 {
51   ASSERT_LIVE_IS_ALLOWED ();
52
53   Context_mod *me = (Context_mod *) SCM_CELL_WORD_1 (smob);
54
55   scm_gc_mark (me->mods_);
56   return me->mods_;
57 }
58
59 void
60 Context_mod::add_context_mod (SCM mod)
61 {
62   mods_ = scm_cons (mod, mods_);
63 }
64
65 void
66 Context_mod::add_context_mods (SCM mods)
67 {
68   for (SCM m = mods; scm_is_pair (m); m = scm_cdr (m))
69     add_context_mod (scm_car (m));
70 }
71
72 SCM
73 Context_mod::get_mods () const
74 {
75   return scm_reverse (mods_);
76 }
77