mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-24 17:09:41 +00:00
ControlPrint.cpp
LyXFunc.cpp Quote file paths in printer dialog Fix bug 3915: http://bugzilla.lyx.org/show_bug.cgi?id=3915 (patch from Jürgen and JMarc) git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@18934 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
6e3ecc8a2f
commit
e729c5ffee
@ -989,21 +989,22 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
|
|
||||||
case LFUN_BUFFER_PRINT: {
|
case LFUN_BUFFER_PRINT: {
|
||||||
BOOST_ASSERT(lyx_view_ && lyx_view_->buffer());
|
BOOST_ASSERT(lyx_view_ && lyx_view_->buffer());
|
||||||
string target;
|
// FIXME: cmd.getArg() might fail if one of the arguments
|
||||||
string target_name;
|
// contains double quotes
|
||||||
string command = split(split(argument, target, ' '),
|
string target = cmd.getArg(0);
|
||||||
target_name, ' ');
|
string target_name = cmd.getArg(1);
|
||||||
|
string command = cmd.getArg(2);
|
||||||
|
|
||||||
if (target.empty()
|
if (target.empty()
|
||||||
|| target_name.empty()
|
|| target_name.empty()
|
||||||
|| command.empty()) {
|
|| command.empty()) {
|
||||||
lyxerr << "Unable to parse \""
|
lyxerr << "Unable to parse \""
|
||||||
<< argument << '"' << std::endl;
|
<< argument << '"' << endl;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (target != "printer" && target != "file") {
|
if (target != "printer" && target != "file") {
|
||||||
lyxerr << "Unrecognized target \""
|
lyxerr << "Unrecognized target \""
|
||||||
<< target << '"' << std::endl;
|
<< target << '"' << endl;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1035,7 +1036,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
// case 3: print using a spool
|
// case 3: print using a spool
|
||||||
string const psname =
|
string const psname =
|
||||||
changeExtension(dviname,".ps");
|
changeExtension(dviname,".ps");
|
||||||
command += lyxrc.print_to_file
|
command += ' ' + lyxrc.print_to_file
|
||||||
+ quoteName(psname)
|
+ quoteName(psname)
|
||||||
+ ' '
|
+ ' '
|
||||||
+ quoteName(dviname);
|
+ quoteName(dviname);
|
||||||
@ -1061,7 +1062,7 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
} else {
|
} else {
|
||||||
// case 2: print directly to a printer
|
// case 2: print directly to a printer
|
||||||
if (target_name != "default")
|
if (target_name != "default")
|
||||||
command += lyxrc.print_to_printer + target_name + ' ';
|
command += ' ' + lyxrc.print_to_printer + target_name + ' ';
|
||||||
res = one.startscript(
|
res = one.startscript(
|
||||||
Systemcall::DontWait,
|
Systemcall::DontWait,
|
||||||
command + quoteName(dviname));
|
command + quoteName(dviname));
|
||||||
@ -1069,7 +1070,9 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
|
|
||||||
} else {
|
} else {
|
||||||
// case 1: print to a file
|
// case 1: print to a file
|
||||||
FileName const filename(makeAbsPath(target_name, path));
|
FileName const filename(makeAbsPath(target_name,
|
||||||
|
lyx_view_->buffer()->filePath()));
|
||||||
|
FileName const dvifile(makeAbsPath(dviname, path));
|
||||||
if (fs::exists(filename.toFilesystemEncoding())) {
|
if (fs::exists(filename.toFilesystemEncoding())) {
|
||||||
docstring text = bformat(
|
docstring text = bformat(
|
||||||
_("The file %1$s already exists.\n\n"
|
_("The file %1$s already exists.\n\n"
|
||||||
@ -1079,10 +1082,10 @@ void LyXFunc::dispatch(FuncRequest const & cmd)
|
|||||||
text, 0, 1, _("&Overwrite"), _("&Cancel")) != 0)
|
text, 0, 1, _("&Overwrite"), _("&Cancel")) != 0)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
command += lyxrc.print_to_file
|
command += ' ' + lyxrc.print_to_file
|
||||||
+ quoteName(filename.toFilesystemEncoding())
|
+ quoteName(filename.toFilesystemEncoding())
|
||||||
+ ' '
|
+ ' '
|
||||||
+ quoteName(dviname);
|
+ quoteName(dvifile.toFilesystemEncoding());
|
||||||
res = one.startscript(Systemcall::DontWait,
|
res = one.startscript(Systemcall::DontWait,
|
||||||
command);
|
command);
|
||||||
}
|
}
|
||||||
|
@ -129,7 +129,7 @@ void ControlPrint::dispatchParams()
|
|||||||
command += lyxrc.print_extra_options + ' ';
|
command += lyxrc.print_extra_options + ' ';
|
||||||
}
|
}
|
||||||
|
|
||||||
command += kernel().buffer().params().dvips_options() + ' ';
|
command += kernel().buffer().params().dvips_options();
|
||||||
|
|
||||||
string const target = (pp.target == PrinterParams::PRINTER) ?
|
string const target = (pp.target == PrinterParams::PRINTER) ?
|
||||||
"printer" : "file";
|
"printer" : "file";
|
||||||
@ -138,7 +138,7 @@ void ControlPrint::dispatchParams()
|
|||||||
(pp.printer_name.empty() ? "default" : pp.printer_name) :
|
(pp.printer_name.empty() ? "default" : pp.printer_name) :
|
||||||
pp.file_name;
|
pp.file_name;
|
||||||
|
|
||||||
string const data = target + " " + target_name + " " + command;
|
string const data = target + " \"" + target_name + "\" \"" + command + '"';
|
||||||
kernel().dispatch(FuncRequest(getLfun(), data));
|
kernel().dispatch(FuncRequest(getLfun(), data));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user