2 object-key-dumper.cc -- implement Object_key_dumper
4 source file of the GNU LilyPond music typesetter
6 (c) 2004 Han-Wen Nienhuys <hanwen@xs4all.nl>
10 #include "object-key-dumper.hh"
14 #include "ly-smobs.icc"
17 Object_key_dumper::mark_smob (SCM smob )
19 Object_key_dumper * dumper = (Object_key_dumper*) SCM_CELL_WORD_1 (smob);
21 for (Key_to_key_map::const_iterator i (dumper->serialized_keys_.begin ());
22 i != dumper->serialized_keys_.end();
25 scm_gc_mark ((*i).first->self_scm());
31 Object_key_dumper::print_smob (SCM, SCM port, scm_print_state*)
33 scm_puts ("#<Object_key_dumper>", port);
37 IMPLEMENT_DEFAULT_EQUAL_P(Object_key_dumper);
38 IMPLEMENT_SMOBS(Object_key_dumper);
40 Object_key_dumper::Object_key_dumper ()
42 file_contents_ = SCM_EOL;
48 Object_key_dumper::key_serial (int k)
50 return scm_list_2 (ly_symbol2scm ("key"),
55 Object_key_dumper::serialize_key (Object_key const *key)
57 SCM skey = key->dump();
58 for (SCM s = skey ; scm_is_pair (s) ; s = scm_cdr (s))
60 if (Object_key const * sub_key = unsmob_key (scm_car (s)))
62 scm_set_car_x (s, dump_key (sub_key));
64 else if (Moment *mom = unsmob_moment (scm_car (s)))
67 scm_list_2 (ly_symbol2scm ("unquote"),
72 file_contents_ = scm_cons (scm_list_3 (ly_symbol2scm("define-key"),
73 scm_from_int (next_available_),
77 serialized_keys_[key] = key;
78 key_serial_numbers_[key] = next_available_;
79 SCM retval = key_serial (next_available_);
86 Object_key_dumper::dump_key (Object_key const *key)
88 if (key_serial_numbers_.find (key) != key_serial_numbers_.end ())
90 return key_serial (key_serial_numbers_[key]);
92 else if (Object_key const *serialized = serialized_keys_[key])
94 return key_serial (key_serial_numbers_[ serialized_keys_ [serialized] ]);
97 return serialize_key (key);
101 Object_key_dumper::get_file_contents () const
103 return scm_reverse (file_contents_);
106 LY_DEFINE(ly_make_dumper, "ly:make-dumper",
109 "Create a key dumper. "
112 Object_key_dumper *u = new Object_key_dumper ();
113 SCM x = u->self_scm();
114 scm_gc_unprotect_object (x);
118 LY_DEFINE(ly_dumper_definitions, "ly:dumper-definitions",
121 "Return list of key definitions. "
124 Object_key_dumper *u = unsmob_key_dumper (dumper);
125 SCM_ASSERT_TYPE(u, dumper, SCM_ARG1, __FUNCTION__, "dumper");
126 return u->get_file_contents();
129 LY_DEFINE(ly_dumper_key_serial, "ly:dumper-key-serial",
131 (SCM dumper, SCM key),
132 "Return the key serial number @var{key}. "
135 Object_key_dumper* u = unsmob_key_dumper (dumper);
136 Object_key *k = unsmob_key (key);
137 SCM_ASSERT_TYPE(u, dumper, SCM_ARG1, __FUNCTION__, "dumper");
138 SCM_ASSERT_TYPE(k, key, SCM_ARG2, __FUNCTION__, "key");
139 return u->dump_key (k);
142 Object_key_dumper::~Object_key_dumper()