source file of the GNU LilyPond music typesetter
- (c) 1997--1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+ (c) 1997--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
*/
#include <stdlib.h>
#include <iostream.h>
#include <assert.h>
#include <locale.h>
+
#include "lily-guile.hh"
#include "lily-version.hh"
-#include "all-fonts.hh"
+#include "all-font-metrics.hh"
#include "proto.hh"
-#include "dimensions.hh"
#include "getopt-long.hh"
#include "misc.hh"
#include "string.hh"
#include "main.hh"
#include "file-path.hh"
-#include "config.hh"
+#include "config.h"
#include "file-results.hh"
#include "debug.hh"
#include "lily-guile.hh"
String distill_inname_str (String name_str, String& ext_r);
+/*
+ Internationalisation kludge in two steps:
+ * use _i () to get entry in POT file
+ * call gettext () explicitely for actual "translation"
+
+ Note: these messages all start with lower case (ie, don't
+ follow regular localisation guidelines).
+ */
Long_option_init theopts[] = {
- {0, "about", 'a'},
- {1, "output", 'o'},
- {0, "warranty", 'w'},
- {0, "help", 'h'},
- {0, "test", 't'},
- {0, "debug", 'd'},
- {1, "init", 'i'},
- {1, "include", 'I'},
- {0, "no-paper", 'm'},
- {0, "dependencies", 'M'}, // like GCC
- {0, "no-timestamps", 'T'}, // why do we have this option?
- {0, "find-old-relative", 'Q'},
- {0, "ignore-version", 'V'},
- {0, "version", 'v'},
- {1, "output-format", 'f'},
- {0, "safe", 's'},
- {0,0,0}
+ {0, "debug", 'd', _i ("enable debugging output")},
+ {_i ("EXT"), "output-format", 'f', _i ("use output format EXT")},
+ {0, "help", 'h', _i ("this help")},
+ {_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 for every input file")},
+ {0, "no-paper", 'm', _i ("produce MIDI output only")},
+ {_i ("BASENAME"), "output", 'o', _i ("write output to BASENAME[-x].extension")},
+ {0, "find-old-relative", 'Q', _i ("show all changes in relative syntax")},
+ {0, "safe", 's', _i ("inhibit file output naming and exporting")},
+ {0, "no-timestamps", 'T', _i ("don't timestamp the output")},
+ {0, "test", 't', _i ("switch on experimental features")},
+ {0, "ignore-version", 'V', _i ("ignore mudela version")},
+ {0, "version", 'v', _i ("print version number")},
+ {0, "warranty", 'w', _i ("show warranty and copyright")},
+ {0,0,0, 0}
};
+void
+identify (ostream* os)
+{
+ *os << gnu_lilypond_version_str () << endl;
+}
+
void
usage ()
{
- cout << _f ("Usage: %s [OPTION]... [FILE]...", "lilypond") << '\n';
- cout << _ ("Typeset music and or play MIDI from FILE or <stdin>");
- cout << '\n';
+ identify (&cout);
+ cout << "\n";
+ cout << _f ("Usage: %s [OPTION]... [FILE]...", "lilypond");
+ cout << "\n\n";
+ cout << _ ("Typeset music and or play MIDI from FILE");
+ cout << "\n\n";
+ cout <<
+_(
+"LilyPond is a music typesetter. It produces beautiful sheet music\n"
+"using a high level description file as input. LilyPond is part of \n"
+"the GNU Project.\n"
+);
+
cout << '\n';
cout << _ ("Options:");
cout << '\n';
- cout << _ (
- " -a, --about about LilyPond\n"
- );
- cout << _ (
- " -d, --debug enable debugging output\n"
- );
- cout << _ (
- " -M, --dependencies write Makefile dependencies for every input file\n"
- );
- cout << _ (
- " -h, --help this help\n"
- );
- cout << _ (
- " -f, --output-format=X use output format X\n"
- );
- cout << _ (
- " -I, --include=DIR add DIR to search path\n"
- );
- cout << _ (
- " -i, --init=FILE use FILE as init file\n"
- );
- cout << _ (
- " -m, --no-paper produce midi output only\n"
- );
- cout << _ (
- " -o, --output=FILE set FILE as default output base\n"
- );
- cout << _ (
- " -Q, --find-old-relative show all changes in relative syntax\n"
- );
- cout << _ (
- " -s, --safe inhibit file output naming and exporting TeX macros\n");
- cout << _ (
- " -t, --test switch on experimental features\n"
- );
- cout << _ (
- " -T, --no-timestamps don't timestamp the output\n"
- );
- cout << _ (
- " -V, --ignore-version ignore mudela version\n"
- );
- cout << _ (
- " -w, --warranty show warranty and copyright\n"
- );
- cout << '\n';
- cout << _ ("GNU LilyPond was compiled with the following settings:");
+ cout << Long_option_init::table_str (theopts);
cout << '\n';
- cout <<
+ cout << _ ("This binary was compiled with the following options:")
+ << " " <<
#ifdef NDEBUG
"NDEBUG "
#endif
#ifdef STRING_UTILS_INLINED
"STRING_UTILS_INLINED "
#endif
- "datadir=" DIR_DATADIR
"\n"
- "localedir=" DIR_LOCALEDIR
-
+ "datadir: `" DIR_DATADIR "'\n"
+ "localedir: `" DIR_LOCALEDIR "'\n"
"\n";
- ;
-
print_mudela_versions (cout);
+ cout << endl;
+
+ cout << _f ("Report bugs to %s", "bug-gnu-music@gnu.org") << endl;
}
void
-about ()
+version ()
{
+ identify (&cout);
cout << '\n';
- cout <<
-#include "BLURB.hh"
- cout << '\n';
- cout << _ ("GNU LilyPond is Free software, see --warranty");
- cout << '\n';
- cout << '\n';
- cout << _f ("Copyright (c) %s by", "1996--1999");
- cout << '\n';
- cout << " " + _ ("Han-Wen Nienhuys <hanwen@cs.uu.nl>") + "\n";
- cout << " " + _ ("Jan Nieuwenhuizen <janneke@gnu.org>") + "\n";
- cout << '\n';
+ cout << _f (""
+ "This is free software. It is covered by the GNU General Public License,\n"
+ "and you are welcome to change it and/or distribute copies of it under\n"
+ "certain conditions. Invoke as `%s --warranty' for more information.\n",
+ "lilypond");
+ cout << endl;
+
+ cout << _f ("Copyright (c) %s by", "1996--2000");
+ cout << "Han-Wen Nienhuys <hanwen@cs.uu.nl>\n"
+ << "Jan Nieuwenhuizen <janneke@gnu.org>\n";
}
void
notice ()
{
cout << '\n';
+ // GNU GNU?
cout << _ ("GNU LilyPond -- The GNU Project music typesetter");
cout << '\n';
- cout << _f ("Copyright (c) %s by", "1996--1999");
+ cout << _f ("Copyright (c) %s by", "1996--2000");
cout << '\n';
- cout << " " + _ ("Han-Wen Nienhuys <hanwen@cs.uu.nl>") + "\n";
- cout << " " + _ ("Jan Nieuwenhuizen <janneke@gnu.org>") + "\n";
+ cout << " Han-Wen Nienhuys <hanwen@cs.uu.nl>\n";
+ cout << " Jan Nieuwenhuizen <janneke@gnu.org>\n";
cout << '\n';
cout << _ (
" This program is free software; you can redistribute it and/or\n"
"USA.\n");
}
-void
-identify ()
-{
- *mlog << gnu_lilypond_version_str () << endl;
-}
-
void
setup_paths ()
{
global_path.parse_path (env_sz);
- char *suffixes[] = {"ly", "afm", "scm", "tfm", "cmtfm", 0};
- for (char **s = suffixes; *s; s++){
- if (!prefix_directory.empty_b())
- global_path.add (prefix_directory + to_str ('/') + String (*s));
- else
- global_path.add (String (DIR_DATADIR) + to_str ('/') + String(*s));
- }
+ char *suffixes[] = {"ly", "afm", "scm", "tfm", "cmtfm", "ps", 0};
+ for (char **s = suffixes; *s; s++)
+ {
+ if (!prefix_directory.empty_b())
+ global_path.add (prefix_directory + to_str ('/') + String (*s));
+ else
+ global_path.add (String (DIR_DATADIR) + to_str ('/') + String(*s));
+ }
}
void
-main_prog (int argc, char **argv)
+main_prog (int, char**)
{
/*
need to do this first. Engravers use lily.scm contents.
*/
- extern void ly_init_protection();
- ly_init_protection();
init_lily_guile ();
- read_lily_scm_file ( "lily.scm");
+ read_lily_scm_file ("lily.scm");
cout << endl;
call_constructors ();
int
main (int argc, char **argv)
{
- identify ();
debug_init (); // should be first
setup_paths ();
oparser_global_p = new Getopt_long(argc, argv,theopts);
while (Long_option_init const * opt = (*oparser_global_p)())
{
- switch (opt->shortname)
+ switch (opt->shortname_ch_)
{
case 'v':
+ version();
exit (0); // we print a version anyway.
break;
case 't':
experimental_features_global_b = true;
- *mlog << "*** enabling experimental features, you're on your own now ***\n";
+ progress_indication ("*** enabling experimental features, you're on your own now ***\n");
break;
case 'o':
outname_str_global = oparser_global_p->optional_argument_ch_C_;
case 'i':
init_str_global = oparser_global_p->optional_argument_ch_C_;
break;
- case 'a':
- about ();
- exit (0);
case 'h':
usage ();
exit (0);
break;
}
}
+ identify (&cerr);
#ifdef WINNT
gh_enter (argc, argv, main_prog);
#else
- gh_enter (argc, argv, (void(*)())main_prog);
+ gh_enter (argc, argv, (void(*)(...))main_prog);
#endif
return 0; // unreachable