X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FChktex.cpp;h=2db47b44c5b6968085dec793f09f11f8654293fc;hb=313d9fa4d056ed213607500076c1bd391a563b6d;hp=8683203d3b040b959aaf11244972a9932066a991;hpb=0778007050fd1b951f4ed03126893fb390f28b64;p=lyx.git diff --git a/src/Chktex.cpp b/src/Chktex.cpp index 8683203d3b..2db47b44c5 100644 --- a/src/Chktex.cpp +++ b/src/Chktex.cpp @@ -21,8 +21,6 @@ #include "support/lstrings.h" #include "support/Systemcall.h" -#include - using namespace std; using namespace lyx::support; @@ -31,22 +29,27 @@ namespace lyx { Chktex::Chktex(string const & chktex, string const & f, string const & p) : cmd(chktex), file(f), path(p) -{ -} +{} int Chktex::run(TeXErrors &terr) { - // run bibtex - string log = onlyFilename(changeExtension(file, ".log")); + // run chktex + string log = onlyFileName(changeExtension(file, ".log")); string tmp = cmd + " -q -v0 -b0 -x " + file + " -o " + log; Systemcall one; int result = one.startscript(Systemcall::Wait, tmp); - if (result == 0) { - result = scanLogFile(terr); - } else { + // ChkTeX (as of v. 1.7.7) has the following return values: + // 0 = EXIT_SUCCESS : program ran successfully, nothing to report + // 1 = EXIT_FAILURE : program ran unsucessfully + // 2 = EXIT_WARNINGS : program ran successfully, only warnings to report + // 3 = EXIT_ERRORS : program ran successfully, errors to report + // We only check for EXIT_FAILURE here, since older versions of ChkTeX + // returned 0 also in case 2 and 3. + if (result == EXIT_FAILURE) result = -1; - } + else + result = scanLogFile(terr); return result; } @@ -55,15 +58,11 @@ int Chktex::scanLogFile(TeXErrors & terr) { int retval = 0; - // FIXME: Find out whether onlyFilename() is really needed, - // or whether makeAbsPath(onlyFilename()) is a noop here - FileName const tmp(makeAbsPath(onlyFilename(changeExtension(file, ".log")))); + // FIXME: Find out whether onlyFileName() is really needed, + // or whether makeAbsPath(onlyFileName()) is a noop here + FileName const tmp(makeAbsPath(onlyFileName(changeExtension(file, ".log")))); -#if USE_BOOST_FORMAT - boost::basic_format msg(_("ChkTeX warning id # %1$d")); -#else - docstring const msg(_("ChkTeX warning id # ")); -#endif + docstring const msg(_("ChkTeX warning id # %1$s")); docstring token; // FIXME UNICODE // We have no idea what the encoding of the error file is @@ -82,13 +81,7 @@ int Chktex::scanLogFile(TeXErrors & terr) int const lineno = convert(line); -#if USE_BOOST_FORMAT - msg % warno; - terr.insertError(lineno, msg.str(), warning); - msg.clear(); -#else - terr.insertError(lineno, msg + warno, warning); -#endif + terr.insertError(lineno, bformat(msg, warno), warning); ++retval; }