(c) 1997--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>
*/
-#include <stdlib.h>
-#include <stdio.h>
-#include <assert.h>
-#include <locale.h>
-#include <string.h>
+#include "main.hh"
+
+#include <cassert>
+#include <clocale>
+#include <cstring>
-#include "config.h"
+#include "config.hh"
#if HAVE_GETTEXT
#include <libintl.h>
#endif
-#include "lily-guile.hh"
-#include "lily-version.hh"
#include "all-font-metrics.hh"
+#include "file-name.hh"
#include "getopt-long.hh"
-#include "misc.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;
+#include "lily-guile.hh"
+#include "lily-version.hh"
+#include "misc.hh"
+#include "output-def.hh"
+#include "warn.hh"
+#include "freetype.hh"
/*
* 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;
/* Name of initialisation file. */
String init_name_global;
-/* Do not calculate and write paper output? */
-bool no_paper_global_b = false;
+/* Do not calculate and write layout output? */
+bool no_layout_global_b = false;
/* Selected output format.
- One of tex, ps, scm, as. */
+ One of tex, ps, scm, as.
+*/
String output_format_global = "tex";
/* Current output name. */
/* 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 ";
+bool make_pdf = false;
+bool make_dvi = false;
+bool make_ps = false;
+bool make_png = false;
+bool make_preview = false;
+bool make_pages = true;
+bool make_tex = false;
/*
* 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.
" Han-Wen Nienhuys <hanwen@cs.uu.nl>\n"
" Jan Nieuwenhuizen <janneke@gnu.org>\n";
-static char const *PROGRAM_NAME = "lilypond-bin";
+static char const *PROGRAM_NAME = "lilypond";
static char const *PROGRAM_URL = "http://lilypond.org";
static char const *NOTICE =
_i ("This program is free software. It is covered by the GNU General Public\n"
"License and you are welcome to change it and/or distribute copies of it\n"
- "under certain conditions. Invoke as `lilypond-bin --warranty' for more\n"
+ "under certain conditions. Invoke as `lilypond --warranty' for more\n"
"information.\n");
static char const *WARRANTY =
static Long_option_init options_static[] =
{
{_i ("EXPR"), "evaluate", 'e',
- _i ("set options, use -e '(ly-option-usage)' for help")},
- /* Bug in option parser: --output=foe is taken as an abbreviation
+ _i ("set option, use -e '(ly:option-usage)' for help")},
+ /* Bug in option parser: --output =foe is taken as an abbreviation
for --output-format. */
- {_i ("EXT"), "format", 'f', _i ("use output format EXT")},
+ {_i ("EXT"), "format", 'f', _i ("select back-end to use")},
{0, "help", 'h', _i ("print this help")},
{_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")},
+ {0, "no-layout", '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, "preview", 'p', _i ("generate a preview")},
+ {0, "no-pages", 0, _i ("don't generate full pages")},
+ {0, "png", 0, _i ("generate PNG")},
+ {0, "ps", 0, _i ("generate PostScript")},
+ {0, "dvi", 0, _i ("generate DVI")},
+ {0, "pdf", 0, _i ("generate PDF (default)")},
+ {0, "tex", 0, _i ("generate TeX")},
{0, "safe-mode", 's', _i ("run in safe mode")},
{0, "version", 'v', _i ("print version number")},
{0, "verbose", 'V', _i ("be verbose")},
dir_info (FILE *out)
{
fputs ("\n", out);
- fprintf (out, "lilypond_datadir: `%s'\n", LILYPOND_DATADIR);
- fprintf (out, "local_lilypond_datadir: `%s'\n", LOCAL_LILYPOND_DATADIR);
- fprintf (out, "localedir: `%s'\n", LOCALEDIR);
+ fprintf (out, "LILYPOND_DATADIR =\"%s\"\n", LILYPOND_DATADIR);
+ fprintf (out, "LOCAL_LILYPOND_DATADIR =\"\%s\"\n", LOCAL_LILYPOND_DATADIR);
+ fprintf (out, "LOCALEDIR =\"%s\"\n", LOCALEDIR);
char *lilypond_prefix = getenv ("LILYPONDPREFIX");
- fprintf (out, "LILYPONDPREFIX: `%s'\n",
+ fprintf (out, "LILYPONDPREFIX =\"%s\"\n",
(lilypond_prefix ? lilypond_prefix : ""));
}
identify (FILE *out)
{
fputs (gnu_lilypond_version_string ().to_str0 (), out);
+ fputs ("\n", out);
}
static void
notice ()
{
identify (stdout);
- printf ("\n");
printf (_f (NOTICE, PROGRAM_NAME).to_str0 ());
printf ("\n");
copyright ();
usage ()
{
/* No version number or newline here. It confuses help2man. */
- printf (_f ("Usage: %s [OPTIONS]... FILE...", PROGRAM_NAME).to_str0 ());
+ printf (_f ("Usage: %s [OPTION]... FILE...", PROGRAM_NAME).to_str0 ());
printf ("\n\n");
printf (_ ("Typeset music and/or produce MIDI from FILE.").to_str0 ());
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 */
- char *suffixes[] = {"ly", "afm", "mf/out", "scm", "tfm", "ps", 0};
+ char *suffixes[] = {"ly", "otf", "mf/out", "scm", "tfm", "ps", "svg", 0};
for (unsigned i = 0; prefix_directory[i]; i++)
for (char **s = suffixes; *s; s++)
#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
}
scm_c_eval_string (s.to_str0 ());
}
+static void
+determine_output_options ()
+{
+ bool found_gnome = (output_format_global == "gnome");
+ bool found_svg = (output_format_global == "svg");
+ bool found_tex = (output_format_global == "tex");
+
+
+ if (make_pdf || make_png)
+ {
+ make_ps = true;
+ }
+ if (make_ps && found_tex)
+ {
+ make_dvi = true;
+ }
+ if (make_dvi && found_tex)
+ {
+ make_tex = true;
+ }
+ if (!found_gnome
+ && !found_svg
+ && !(make_dvi
+ || make_tex
+ || make_ps
+ || make_png
+ || make_pdf))
+ {
+ make_pdf = true;
+ make_ps = true;
+ if (found_tex)
+ {
+ make_dvi = true;
+ make_tex = true;
+ }
+ }
+}
+
+void init_global_tweak_registry ();
+
static void
main_with_guile (void *, int, char **)
{
if (verbose_global_b)
dir_info (stderr);
- ly_init_guile ();
+ ly_c_init_guile ();
call_constructors ();
- progress_indication ("\n");
-
+ init_global_tweak_registry ();
+ init_freetype ();
+ determine_output_options ();
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 ());
-
- bool first = true;
+ 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. */
+
+ SCM files = SCM_EOL;
+ SCM *tail = &files;
while (char const *arg = option_parser->get_next_arg ())
{
- 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 */
- 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_lily_module_constant ("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 0:
+ if (String (opt->longname_str0_) == "png")
+ make_png = true;
+ else if (String (opt->longname_str0_) == "pdf")
+ make_pdf = true;
+ else if (String (opt->longname_str0_) == "ps")
+ make_ps = true;
+ else if (String (opt->longname_str0_) == "dvi")
+ make_dvi = true;
+ else if (String (opt->longname_str0_) == "tex")
+ make_tex = true;
+ else if (String (opt->longname_str0_) == "preview")
+ make_preview = true;
+ else if (String (opt->longname_str0_) == "no-pages")
+ make_pages = false;
+ break;
+
case 'v':
notice ();
exit (0);
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;
+ no_layout_global_b = true;
+ break;
+ case 'p':
+ make_preview = true;
break;
default:
+ programming_error (to_string ("unhandled short option: %c",
+ opt->shortname_char_));
assert (false);
break;
}
if (help_b)
{
+ identify (stdout);
usage ();
if (verbose_global_b)
dir_info (stdout);
int
main (int argc, char **argv)
{
- setup_localisation ();
+ setup_localisation ();
setup_paths ();
parse_argv (argc, argv);
+ identify (stderr);
initialize_kpathsea (argv[0]);
scm_boot_guile (argc, argv, main_with_guile, 0);