Fixes Issue 1504, allowing feather beam line breaking.
[lilypond/patrick.git] / lily / context-mod.cc
bloba028930c2ba79d23381992a985f9a421ff39b4b7
1 /*
2 This file is part of LilyPond, the GNU music typesetter.
4 Copyright (C) 2010--2011 Reinhold Kainhofer <reinhold@kainhofer.com>
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.
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.
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/>.
20 #include "context-mod.hh"
22 Context_mod::Context_mod ()
24 mods_ = SCM_EOL;
27 Context_mod::Context_mod (Context_mod const &s)
29 mods_ = s.mods_;
32 #include "ly-smobs.icc"
33 IMPLEMENT_SIMPLE_SMOBS (Context_mod);
34 IMPLEMENT_DEFAULT_EQUAL_P (Context_mod);
36 int
37 Context_mod::print_smob (SCM smob, SCM port, scm_print_state*)
39 Context_mod *me = (Context_mod *) SCM_CELL_WORD_1 (smob);
41 scm_puts ("#<Context_mod ", port);
42 scm_display (me->mods_, port);
43 scm_puts (">", port);
44 return 1;
47 SCM
48 Context_mod::mark_smob (SCM smob)
50 ASSERT_LIVE_IS_ALLOWED ();
52 Context_mod *me = (Context_mod *) SCM_CELL_WORD_1 (smob);
54 scm_gc_mark (me->mods_);
55 return me->mods_;
58 void
59 Context_mod::add_context_mod (SCM mod)
61 mods_ = scm_cons (mod, mods_);
64 void
65 Context_mod::add_context_mods (SCM mods)
67 for (SCM m = mods; scm_is_pair (m); m = scm_cdr (m))
68 add_context_mod (scm_car (m));
71 SCM
72 Context_mod::get_mods () const
74 return scm_reverse (mods_);