#include <libintl.h>
#endif
-#include "lily-guile.hh"
-#include "lily-version.hh"
#include "all-font-metrics.hh"
+#include "file-name.hh"
+#include "file-path.hh"
#include "getopt-long.hh"
+#include "global-ctor.hh"
+#include "kpath.hh"
+#include "lily-guile.hh"
+#include "lily-version.hh"
+#include "main.hh"
#include "misc.hh"
+#include "output-def.hh"
#include "string.hh"
-#include "main.hh"
-#include "file-path.hh"
-#include "input-file-results.hh"
#include "warn.hh"
-#include "lily-guile.hh"
-#include "paper-def.hh"
-#include "midi-def.hh"
-#include "global-ctor.hh"
-#include "kpath.hh"
-
-Array<String> failed_files;
/*
* Global options that can be overridden through command line.
*/
-/* Write dependencies file? */
-bool dependency_global_b = false;
-
-/* Prepend to dependencies */
-String dependency_prefix_global;
-
/* Names of header fields to be dumped to a separate file. */
Array<String> dump_header_fieldnames_global;
/* Verbose progress indication? */
bool verbose_global_b = false;
-/* Scheme code to execute before parsing, after .scm init */
+/* Scheme code to execute before parsing, after .scm init
+ This is where -e arguments are appended to.
+*/
String init_scheme_code_string = "(begin #t ";
+
/*
* Miscellaneous global stuff.
*/
-
-All_font_metrics *all_fonts_global;
-int exit_status_global;
File_path global_path;
-/* Number of current score output block. If there's more than one
- score block, this counter will be added to the output filename. */
-int score_count_global;
-
/*
* File globals.
{_i ("FIELD"), "header", 'H', _i ("write header field to BASENAME.FIELD")},
{_i ("DIR"), "include", 'I', _i ("add DIR to search path")},
{_i ("FILE"), "init", 'i', _i ("use FILE as init file")},
- {0, "dependencies", 'M', _i ("write Makefile dependencies")},
{0, "no-paper", 'm', _i ("produce MIDI output only")},
{_i ("FILE"), "output", 'o', _i ("write output to FILE")},
- {_i ("DIR"), "dep-prefix", 'P', _i ("prepend DIR to dependencies")},
{0, "safe-mode", 's', _i ("run in safe mode")},
{0, "version", 'v', _i ("print version number")},
{0, "verbose", 'V', _i ("be verbose")},
printf ("\n\n");
printf (_ ("LilyPond produces beautiful music notation.").to_str0 ());
printf ("\n");
- printf (_f ("For more information, see %s,", PROGRAM_URL).to_str0 ());
+ printf (_f ("For more information, see %s", PROGRAM_URL).to_str0 ());
printf ("\n\n");
printf (_ ("Options:").to_str0 ());
printf ("\n");
if (char const *lilypond_prefix = getenv ("LILYPONDPREFIX"))
prefix_directory[1] = lilypond_prefix;
- global_path.add ("");
+ global_path.append ("");
/* Adding mf/out make lilypond unchanged source directory, when setting
LILYPONDPREFIX to lilypond-x.y.z */
#if !KPATHSEA
/* Urg: GNU make's $ (word) index starts at 1 */
int i = 1;
- while (global_path.try_add (p + to_string (".") + to_string (i)))
+ while (global_path.try_append (p + to_string (".") + to_string (i)))
i++;
#endif
}
if (verbose_global_b)
dir_info (stderr);
- ly_init_guile ();
+ ly_c_init_guile ();
call_constructors ();
progress_indication ("\n");
all_fonts_global = new All_font_metrics (global_path.to_string ());
init_scheme_code_string += ")";
- gh_eval_str ((char*) init_scheme_code_string.to_str0 ());
+ scm_c_eval_string ((char*) init_scheme_code_string.to_str0 ());
/* We accept multiple independent music files on the command line to
reduce compile time when processing lots of small files.
Starting the GUILE engine is very time consuming. */
- bool first = true;
+
+ SCM files = SCM_EOL;
+ SCM *tail = &files;
while (char const *arg = option_parser->get_next_arg ())
{
-
-#if 0
- /* Code to debug memory leaks. Cannot call from within .ly
- since then we get the protects from the parser state too. */
- static SCM proc;
- if (!proc)
- proc = scm_c_eval_string ("dump-gc-protects");
- scm_gc ();
- scm_call_0 (proc);
-#endif
-
- do_one_file (arg);
- first = false;
+ *tail = scm_cons (scm_makfrom0str (arg), SCM_EOL);
+ tail = SCM_CDRLOC (*tail);
}
delete option_parser;
option_parser = 0;
- /* No FILE arguments is now a usage error to help newbies. If you
- want a filter, you're not a newbie and should know to use file
- argument `-'. */
- if (first)
+ if (files == SCM_EOL)
{
+ /* No FILE arguments is now a usage error to help newbies. If you
+ want a filter, you're not a newbie and should know to use file
+ argument `-'. */
usage ();
exit (2);
}
- if (exit_status_global)
- {
- printf ("Failed files: ");
- for (int i = 0; i < failed_files.size (); i++)
- printf ("%s ", failed_files[i].to_str0 ());
- printf ("\n");
- }
- exit (exit_status_global);
+ SCM result = scm_call_1 (ly_scheme_function ("lilypond-main"), files);
+ (void) result;
+
+
+ /* Unreachable. */
+ exit (0);
}
static void
{
bool help_b = false;
option_parser = new Getopt_long (argc, argv, options_static);
- while (Long_option_init const * opt = (*option_parser) ())
+ while (Long_option_init const *opt = (*option_parser) ())
{
switch (opt->shortname_char_)
{
case 'o':
{
String s = option_parser->optional_argument_str0_;
- Path p = split_path (s);
- if (s != "-" && p.ext.is_empty ())
- p.ext = output_format_global;
- output_name_global = p.to_string ();
+ File_name file_name (s);
+ output_name_global = file_name.to_string ();
}
break;
case 'e':
}
output_format_global = option_parser->optional_argument_str0_;
break;
- case 'P':
- dependency_prefix_global = option_parser->optional_argument_str0_;
- break;
case 'H':
dump_header_fieldnames_global
.push (option_parser->optional_argument_str0_);
break;
case 'I':
- global_path.push (option_parser->optional_argument_str0_);
+ global_path.append (option_parser->optional_argument_str0_);
break;
case 'i':
init_name_global = option_parser->optional_argument_str0_;
case 's':
safe_global_b = true;
break;
- case 'M':
- dependency_global_b = true;
- break;
case 'm':
no_paper_global_b = true;
break;