]> git.donarmstrong.com Git - lilypond.git/blob - lily/context-mod.cc
Run grand-replace (issue 3765)
[lilypond.git] / lily / context-mod.cc
1 /*
2   This file is part of LilyPond, the GNU music typesetter.
3
4   Copyright (C) 2010--2014 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 Context_mod::Context_mod (SCM mod_list)
33 {
34   mods_ = scm_reverse (mod_list);
35 }
36
37 #include "ly-smobs.icc"
38 IMPLEMENT_SIMPLE_SMOBS (Context_mod);
39 IMPLEMENT_DEFAULT_EQUAL_P (Context_mod);
40 IMPLEMENT_TYPE_P (Context_mod, "ly:context-mod?");
41
42 int
43 Context_mod::print_smob (SCM smob, SCM port, scm_print_state *)
44 {
45   Context_mod *me = (Context_mod *) SCM_CELL_WORD_1 (smob);
46
47   scm_puts ("#<Context_mod ", port);
48   scm_display (me->get_mods (), port);
49   scm_puts (">", port);
50   return 1;
51 }
52
53 SCM
54 Context_mod::mark_smob (SCM smob)
55 {
56   ASSERT_LIVE_IS_ALLOWED (smob);
57
58   Context_mod *me = (Context_mod *) SCM_CELL_WORD_1 (smob);
59
60   return me->mods_;
61 }
62
63 void
64 Context_mod::add_context_mod (SCM mod)
65 {
66   mods_ = scm_cons (mod, mods_);
67 }
68
69 void
70 Context_mod::add_context_mods (SCM mods)
71 {
72   for (SCM m = mods; scm_is_pair (m); m = scm_cdr (m))
73     add_context_mod (scm_car (m));
74 }
75
76 SCM
77 Context_mod::get_mods () const
78 {
79   return scm_reverse (mods_);
80 }
81