The backslash is the escape character used in our parser. Hence,
when used as a path separator on Windows, it has to be itself
escaped or the path enclosed in either double or single quotes.
Windows users are maybe trained to quote paths containing spaces
but not paths with backslashes. So, we automatically escape the
backslashes when they are not already enclosed in quotes.

(cherry picked from commit 4c9df62c6c)
This commit is contained in:
Enrico Forestieri 2018-12-14 11:41:16 +01:00
parent 759769131a
commit 3e9a1c2da7
2 changed files with 24 additions and 0 deletions

View File

@ -697,6 +697,28 @@ bool Formats::view(Buffer const & buffer, FileName const & filename,
string command = format->viewer();
// Escape backslashes if not already in double or single quotes.
// We cannot simply quote the whole command as there may be arguments.
if (contains(command, '\\')) {
bool inquote1 = false;
bool inquote2 = false;
string::iterator cit = command.begin();
for (; cit != command.end(); ++cit) {
switch (*cit) {
case '"':
inquote1 = !inquote1;
break;
case '\'':
inquote2 = !inquote2;
break;
case '\\':
if (!inquote1 && !inquote2)
cit = ++command.insert(cit, '\\');
break;
}
}
}
if (format_name == "dvi" &&
!lyxrc.view_dvi_paper_option.empty()) {
string paper_size = buffer.params().paperSizeName(BufferParams::XDVI);

View File

@ -61,6 +61,8 @@ What's new
- Fix on-screen display of macros whose name is a single non-letter symbol
(part of bug 11158).
- Do not swallow backspaces in custom viewer/editor paths (bug 9622).
* INTERNALS