X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fchord-name.cc;h=620075396f4cc924be6c0a710319ea0a175a7a4c;hb=b55303a78f027962dbebf62dbe396325f3b6e1a5;hp=3bc56b107e10252c2d8faa0ce169e8582f2a8f21;hpb=87aedc5e4e7c56bb54a29f604eafc177a37e3f05;p=lilypond.git diff --git a/lily/chord-name.cc b/lily/chord-name.cc index 3bc56b107e..620075396f 100644 --- a/lily/chord-name.cc +++ b/lily/chord-name.cc @@ -3,152 +3,67 @@ source file of the GNU LilyPond music typesetter - (c) 1999--2000 Jan Nieuwenhuizen + (c) 1999--2002 Jan Nieuwenhuizen */ #include "chord-name.hh" -#include "musical-request.hh" -#include "warn.hh" -#include "debug.hh" #include "molecule.hh" #include "paper-def.hh" -#include "lookup.hh" +#include "font-interface.hh" +#include "grob.hh" +#include "paper-column.hh" +#include "system.hh" #include "staff-symbol-referencer.hh" +#include "text-item.hh" - -/* - TODO: move text lookup out of Chord_name - */ - -/* - word is roman text or styled text: - "text" - ("style" . "text") - */ -/* - UGH. remove Dictionary< > - */ -Molecule -Chord_name::ly_word2molecule (SCM word) const +MAKE_SCHEME_CALLBACK (Chord_name,after_line_breaking,1); +SCM +Chord_name::after_line_breaking (SCM smob) { - Dictionary option_dict; // junkme - if (gh_pair_p (word)) + Item* me = unsmob_item (smob); + assert (me); + + SCM s = me->get_grob_property ("begin-of-line-visible"); + if (to_boolean (s)) { - SCM options = gh_cdr (word); - word = gh_car (word); - while (gh_pair_p (options)) - { - SCM option = gh_car (options); - if (option != SCM_UNDEFINED && option != SCM_BOOL_F - && gh_pair_p (option)) - { - SCM key = gh_car (option); - SCM val = gh_cdr (option); - String k; - if (gh_symbol_p (key)) - k = ly_symbol2string (key); - else if (gh_string_p (key)) - k = ly_scm2string (key); - else - continue; - option_dict[k] = val; - } - options = gh_cdr (options); - } + if (Paper_column::rank_i (me->column_l ()) - + me->line_l ()->spanned_rank_iv ()[LEFT] > 1) + me->suicide (); } - Real ex = lookup_l ()->text ("", "x", paper_l ()).extent - ()[Y_AXIS].length (); - if (gh_string_p (word)) - { - String w = ly_scm2string (word); - Molecule mol; - Offset offset; + return SCM_UNSPECIFIED; +} - int size = 0; - if (option_dict.elem_b ("size")) - size = gh_scm2int (option_dict["size"]); +MAKE_SCHEME_CALLBACK (Chord_name,brew_molecule,1); +SCM +Chord_name::brew_molecule (SCM smob) +{ + Grob *me = unsmob_grob (smob); + SCM style = me->get_grob_property ("style"); - String style; - if (option_dict.elem_b ("style")) - style = ly_scm2string (option_dict["style"]); + if (!gh_symbol_p (style)) + style = ly_symbol2scm ("banter"); - if (option_dict.elem_b ("type") - && ly_scm2string (option_dict["type"]) == "super") - { - Real super_y = ex / 2; - //super_y += -acc.extent ()[Y_AXIS][MIN]; - offset = Offset (0, super_y); - if (!size) - size = -2; - } - if (option_dict.elem_b ("offset")) - { - // hmm - SCM s = option_dict["offset"]; - if (gh_pair_p (s)) - offset = Offset (gh_scm2double (gh_car (s)), - gh_scm2double (gh_cdr (s))) * ex; - } - if (option_dict.elem_b ("font") - && ly_scm2string (option_dict["font"]) == "feta") - mol = paper_l ()->lookup_l (size)->afm_find (w); - else - mol = paper_l ()->lookup_l (size)->text (style, w, paper_l ()); + SCM chord = me->get_grob_property ("chord"); + SCM func = me->get_grob_property ("chord-name-function"); + SCM text = gh_call2 (func, style, chord); - mol.translate (offset); - return mol; - } - return Molecule (); -} + SCM properties = Font_interface::font_alist_chain (me); + Molecule mol = Text_item::text2molecule (me, text, properties); -/* - ;; text: list of word - ;; word: string + optional list of property - ;; property: align, kern, font (?), size - */ -Molecule -Chord_name::ly_text2molecule (SCM text) const -{ - Molecule mol; - if (gh_list_p (text)) + SCM space = me->get_grob_property ("word-space"); + if (gh_number_p (space)) { - while (gh_cdr (text) != SCM_EOL) - { - Molecule m = ly_word2molecule (gh_car (text)); - if (!m.empty_b ()) - mol.add_at_edge (X_AXIS, RIGHT, m, 0); - text = gh_cdr (text); - } - text = gh_car (text); - } - Molecule m = ly_word2molecule (text); - if (!m.empty_b ()) - mol.add_at_edge (X_AXIS, RIGHT, m, 0); - return mol; -} - -Molecule -Chord_name::do_brew_molecule () const -{ - SCM style = get_elt_property ("style"); - if (style == SCM_UNDEFINED) - style = ly_str02scm ("banter"); - - SCM inversion = get_elt_property ("inversion"); - if (inversion == SCM_UNDEFINED) - inversion = SCM_BOOL_F; + Molecule m; + m.set_empty (false); + mol.add_at_edge (X_AXIS, RIGHT, m, gh_scm2double (space)* + Staff_symbol_referencer::staff_space (me)); + } - SCM bass = get_elt_property ("bass"); - if (bass == SCM_UNDEFINED) - bass = SCM_BOOL_F; + return mol.smobbed_copy (); +} - SCM pitches = get_elt_property ("pitches"); - SCM text = scm_eval (gh_list (ly_symbol2scm ("chord::user-name"), - style, - ly_quote_scm (pitches), - ly_quote_scm (gh_cons (inversion, bass)), - SCM_UNDEFINED)); +ADD_INTERFACE (Chord_name, "chord-name-interface", + "generate a chord name", + "pitches chord chord-name-function inversion bass begin-of-line-visible"); - return ly_text2molecule (text); -}