2 object-key-dumper.cc -- implement Object_key_dumper
4 source file of the GNU LilyPond music typesetter
6 (c) 2004--2005 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 Object_key_dumper::~Object_key_dumper()