X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fmover.C;h=82cdce869b6bcaee4f1ea7c2ffaabe1b1e41a10e;hb=35204f8f33d7400a5fefeffea533fb4cb4097211;hp=24950a870691af7de9cd53dc9be1f0402acd73ac;hpb=6c300f72a217722652dc27db9108e1050028979c;p=lyx.git diff --git a/src/mover.C b/src/mover.C index 24950a8706..82cdce869b 100644 --- a/src/mover.C +++ b/src/mover.C @@ -17,11 +17,13 @@ #include "support/lyxlib.h" #include "support/systemcall.h" +#include #include namespace lyx { +using std::ios; using std::string; Movers movers; @@ -29,9 +31,9 @@ Movers system_movers; bool Mover::do_copy(string const & from, string const & to, - string const &) const + string const &, unsigned long int mode) const { - return support::copy(from, to); + return support::copy(from, to, mode); } @@ -43,10 +45,19 @@ bool Mover::do_rename(string const & from, string const & to, bool SpecialisedMover::do_copy(string const & from, string const & to, - string const & latex) const + string const & latex, unsigned long int mode) const { if (command_.empty()) - return Mover::do_copy(from, to, latex); + return Mover::do_copy(from, to, latex, mode); + + if (mode != (unsigned long int)-1) { + std::ofstream ofs(to.c_str(), ios::binary | ios::out | ios::trunc); + if (!ofs) + return false; + ofs.close(); + if (!support::chmod(to, mode)) + return false; + } string command = support::libScriptSearch(command_); command = support::subst(command, "$$i", from); @@ -64,7 +75,7 @@ bool SpecialisedMover::do_rename(string const & from, string const & to, if (command_.empty()) return Mover::do_rename(from, to, latex); - if (!do_copy(from, to, latex)) + if (!do_copy(from, to, latex, (unsigned long int)-1)) return false; return support::unlink(from) == 0; }