Jan Nieuwenhuizen <janneke@gnu.org>
*/
+#include "lily-parser.hh"
+#include "text-metrics.hh"
#include "book.hh"
-#include "grob-selector.hh"
+#include "lilypond-key.hh"
#include "file-name.hh"
#include "file-path.hh"
#include "lily-version.hh"
#include "ly-module.hh"
#include "main.hh"
#include "lily-lexer.hh"
-#include "lily-parser.hh"
#include "output-def.hh"
#include "paper-book.hh"
#include "parser.hh"
#include "source.hh"
#include "warn.hh"
-
Lily_parser::Lily_parser (Sources *sources)
{
book_count_ = 0;
void
Lily_parser::parse_file (String init, String name, String out_name)
{
+ if (output_backend_global == "tex")
+ {
+ try_load_text_metrics (out_name);
+ }
+
lexer_ = new Lily_lexer (sources_);
scm_gc_unprotect_object (lexer_->self_scm ());
// TODO: use $parser
set_yydebug (0);
lexer_->new_input (init, sources_);
-#ifdef TWEAK
+
File_name f (name);
String s = global_path.find (f.base_ + ".twy");
- if (s == "")
- Grob_selector::set_tweaks (SCM_EOL);
- else
- {
- s = gulp_file_to_string (s, false);
- SCM tweaks = scm_eval_string (scm_makfrom0str (s.to_str0 ()));
- Grob_selector::set_tweaks (tweaks);
- }
-#endif
+ s = gulp_file_to_string (s, false);
+ scm_eval_string (scm_makfrom0str (s.to_str0 ()));
/* Read .ly IN_FILE, lex, parse, write \score blocks from IN_FILE to
OUT_FILE (unless IN_FILE redefines output file name). */
do_yyparse ();
-
+
if (!define_spots_.is_empty ())
{
define_spots_.top ().warning (_ ("Braces don't match"));
if (!define_spots_.is_empty ())
{
- define_spots_.top ().warning (_ ("Braces don't match"));
- error_level_ = 1;
+ if (define_spots_.is_empty()
+ && !error_level_ )
+ programming_error ("Braces don't match, but error_level_ not set.");
}
error_level_ = error_level_ | lexer_->error_level_;
/* UGH. */
SCM val = SCM_BOOL_F;
if (ly_symbol2scm ("line-column") == what)
- val = ly_scheme_function ("line-column-location");
+ val = ly_lily_module_constant ("line-column-location");
else if (what == ly_symbol2scm ("line"))
- val = ly_scheme_function ("line-location");
+ val = ly_lily_module_constant ("line-location");
scm_module_define (global_lily_module, ly_symbol2scm ("point-and-click"),
val);
SCM_ASSERT_TYPE (scm_is_symbol (symbol), symbol, SCM_ARG2, __FUNCTION__, "symbol");
SCM_ASSERT_TYPE (parser, parser_smob, SCM_ARG2, __FUNCTION__, "parser");
- SCM val= parser->lexer_->lookup_identifier (ly_scm2string (scm_symbol_to_string (symbol)));
+ SCM val = parser->lexer_->lookup_identifier (ly_scm2string (scm_symbol_to_string (symbol)));
if (val != SCM_UNDEFINED)
return val;
else
Lily_parser *parser = unsmob_my_lily_parser (parser_smob);
Score *score = unsmob_score (score_smob);
+ Object_key * key = new Lilypond_general_key (0, score->user_key_, 0);
+
if (score->error_found_)
return SCM_UNSPECIFIED;
for (int i = 0; i < score->defs_.size (); i++)
default_rendering (score->get_music (), score->defs_[i]->self_scm (),
paper,
- header, os);
+ header, os,
+ key->self_scm ());
if (score->defs_.is_empty ())
{
Output_def *layout = get_layout (parser);
default_rendering (score->get_music(), layout->self_scm (),
get_paper (parser)->self_scm (),
- header, os);
+ header, os, key->self_scm ());
scm_gc_unprotect_object (layout->self_scm ());
}
+
+ scm_gc_unprotect_object (key->self_scm ());
return SCM_UNSPECIFIED;
}
(*c)++;
Output_def *layout = get_layout (parser);
-
Paper_book* pb = book->process (outname.to_string (), layout);
+
if (pb)
{
pb->output (outname.to_string ());