Command line option to ignore error msgs

Needed by the test framework
This commit is contained in:
Juergen Spitzmueller 2017-01-11 09:21:13 +01:00
parent d221d1734a
commit 96ffb70cd5
3 changed files with 27 additions and 2 deletions

View File

@ -18,6 +18,7 @@
#include "BufferList.h" #include "BufferList.h"
#include "LaTeX.h" #include "LaTeX.h"
#include "LyXRC.h" #include "LyXRC.h"
#include "LyX.h"
#include "DepTable.h" #include "DepTable.h"
#include "support/debug.h" #include "support/debug.h"
@ -899,8 +900,9 @@ int LaTeX::scanLogFile(TeXErrors & terr)
from_local8bit("pdfTeX Error"), from_local8bit("pdfTeX Error"),
from_local8bit(token), from_local8bit(token),
child_name); child_name);
} else if (prefixIs(token, "Missing character: There is no ") } else if (!ignore_missing_glyphs
&& !contains(token, "nullfont")) { && prefixIs(token, "Missing character: There is no ")
&& !contains(token, "nullfont")) {
// Warning about missing glyph in selected font // Warning about missing glyph in selected font
// may be dataloss (bug 9610) // may be dataloss (bug 9610)
// but can be ignored for 'nullfont' (bug 10394). // but can be ignored for 'nullfont' (bug 10394).

View File

@ -98,6 +98,13 @@ bool use_gui = true;
bool verbose = false; bool verbose = false;
// Do not treat the "missing glyphs" warning of fontspec as an error message.
// The default is false and can be changed with the option
// --ignore-error-message missing_glyphs
// This is used in automated testing.
bool ignore_missing_glyphs = false;
// We default to open documents in an already running instance, provided that // We default to open documents in an already running instance, provided that
// the lyxpipe has been setup. This can be overridden either on the command // the lyxpipe has been setup. This can be overridden either on the command
// line or through preference settings. // line or through preference settings.
@ -1161,6 +1168,10 @@ int parse_help(string const &, string const &, string &)
" specifying whether all files, main file only, or no files,\n" " specifying whether all files, main file only, or no files,\n"
" respectively, are to be overwritten during a batch export.\n" " respectively, are to be overwritten during a batch export.\n"
" Anything else is equivalent to `all', but is not consumed.\n" " Anything else is equivalent to `all', but is not consumed.\n"
"\t--ignore-error-message which\n"
" allows you to ignore specific LaTeX error messages.\n"
" Do not use for final documents! Currently supported values:\n"
" * missing_glyphs: Fontspec `missing glyphs' error.\n"
"\t-n [--no-remote]\n" "\t-n [--no-remote]\n"
" open documents in a new instance\n" " open documents in a new instance\n"
"\t-r [--remote]\n" "\t-r [--remote]\n"
@ -1309,6 +1320,16 @@ int parse_verbose(string const &, string const &, string &)
} }
int parse_ignore_error_message(string const & arg1, string const &, string &)
{
if (arg1 == "missing_glyphs") {
ignore_missing_glyphs = true;
return 1;
}
return 0;
}
int parse_force(string const & arg, string const &, string &) int parse_force(string const & arg, string const &, string &)
{ {
if (arg == "all") { if (arg == "all") {
@ -1358,6 +1379,7 @@ void LyX::easyParse(int & argc, char * argv[])
cmdmap["--remote"] = parse_remote; cmdmap["--remote"] = parse_remote;
cmdmap["-v"] = parse_verbose; cmdmap["-v"] = parse_verbose;
cmdmap["--verbose"] = parse_verbose; cmdmap["--verbose"] = parse_verbose;
cmdmap["--ignore-error-message"] = parse_ignore_error_message;
for (int i = 1; i < argc; ++i) { for (int i = 1; i < argc; ++i) {
map<string, cmd_helper>::const_iterator it map<string, cmd_helper>::const_iterator it

View File

@ -52,6 +52,7 @@ enum OverwriteFiles {
extern bool use_gui; extern bool use_gui;
extern bool verbose; extern bool verbose;
extern bool ignore_missing_glyphs;
extern RunMode run_mode; extern RunMode run_mode;
extern OverwriteFiles force_overwrite; extern OverwriteFiles force_overwrite;