]> git.donarmstrong.com Git - lilypond.git/blob - lily/scheme-listener.cc
Merge branch 'issue4082'
[lilypond.git] / lily / scheme-listener.cc
1 /*
2   This file is part of LilyPond, the GNU music typesetter.
3
4   Copyright (C) 2006--2014 Erik Sandberg  <mandolaerik@gmail.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 "scheme-listener.hh"
21
22 IMPLEMENT_LISTENER (Scheme_listener, call)
23 void
24 Scheme_listener::call (SCM ev)
25 {
26   scm_call_1 (callback_, ev);
27 }
28
29
30 Scheme_listener::Scheme_listener (SCM c)
31 {
32   callback_ = SCM_EOL;
33   smobify_self ();
34   callback_ = c;
35 }
36
37 SCM
38 Scheme_listener::mark_smob (SCM obj)
39 {
40   Scheme_listener *me = (Scheme_listener *) SCM_CELL_WORD_1 (obj);
41   return me->callback_;
42 }
43
44 int
45 Scheme_listener::print_smob (SCM obj, SCM p, scm_print_state *)
46 {
47   Scheme_listener *me = (Scheme_listener *) SCM_CELL_WORD_1 (obj);
48   scm_puts ("#<Scheme_listener ", p);
49   scm_write (me->callback_, p);
50   scm_puts (">", p);
51   return 1;
52 }
53
54 Scheme_listener::~Scheme_listener ()
55 {
56 }