mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-12-31 15:46:16 +00:00
Improve fix for bug 3305
* src/LaTeX.C (insertIfExists): Instead of catching all fs exceptions, test for a valid filename before constructing a fs::path. This gets rid of the exceptions because of invalid names, but does still allow other expcetions to be thrown (e.g. because of file system problems). (handleFoundFile): ditto git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@17424 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
5a90cc6871
commit
52727f6f96
46
src/LaTeX.C
46
src/LaTeX.C
@ -758,18 +758,14 @@ namespace {
|
||||
|
||||
bool insertIfExists(FileName const & absname, DepTable & head)
|
||||
{
|
||||
bool exists;
|
||||
try {
|
||||
fs::path const path = absname.toFilesystemEncoding();
|
||||
exists = fs::exists(path) && !fs::is_directory(path);
|
||||
// fs::path may throw an exception if absname is too strange
|
||||
if (!fs::native(absname.toFilesystemEncoding())) {
|
||||
lyxerr[Debug::DEPEND] << '`' << absname.absFilename()
|
||||
<< "' is no valid file name." << endl;
|
||||
return false;
|
||||
}
|
||||
catch (fs::filesystem_error const & fe) {
|
||||
// This was probably no file at all.
|
||||
lyxerr[Debug::DEPEND] << "Got error `" << fe.what()
|
||||
<< "' while checking whether file `" << absname
|
||||
<< "' exists and is no directory." << endl;
|
||||
}
|
||||
if (exists) {
|
||||
fs::path const path(absname.toFilesystemEncoding());
|
||||
if (fs::exists(path) && !fs::is_directory(path)) {
|
||||
head.insert(absname, true);
|
||||
return true;
|
||||
}
|
||||
@ -820,15 +816,13 @@ bool handleFoundFile(string const & ff, DepTable & head)
|
||||
|
||||
// check for spaces
|
||||
while (contains(foundfile, ' ')) {
|
||||
bool exists;
|
||||
try {
|
||||
// fs::path may throw an exception if absname is too strange
|
||||
bool exists = fs::native(absname.toFilesystemEncoding());
|
||||
if (exists)
|
||||
exists = fs::exists(absname.toFilesystemEncoding());
|
||||
}
|
||||
catch (fs::filesystem_error const & fe) {
|
||||
// This was probably no file at all.
|
||||
lyxerr[Debug::DEPEND] << "Got error `" << fe.what()
|
||||
<< "' while checking whether file `"
|
||||
<< absname << "' exists." << endl;
|
||||
else {
|
||||
lyxerr[Debug::DEPEND] << '`' << absname.absFilename()
|
||||
<< "' is no valid file name." << endl;
|
||||
}
|
||||
if (exists)
|
||||
// everything o.k.
|
||||
@ -846,16 +840,14 @@ bool handleFoundFile(string const & ff, DepTable & head)
|
||||
|
||||
// (2) foundfile is in the tmpdir
|
||||
// insert it into head
|
||||
bool exists;
|
||||
try {
|
||||
// fs::path may throw an exception if absname is too strange
|
||||
bool exists = fs::native(absname.toFilesystemEncoding());
|
||||
if (exists) {
|
||||
fs::path const path = absname.toFilesystemEncoding();
|
||||
exists = fs::exists(path) && !fs::is_directory(path);
|
||||
}
|
||||
catch (fs::filesystem_error const & fe) {
|
||||
// This was probably no file at all.
|
||||
lyxerr[Debug::DEPEND] << "Got error `" << fe.what()
|
||||
<< "' while checking whether file `" << absname
|
||||
<< "' exists and is no directory." << endl;
|
||||
} else {
|
||||
lyxerr[Debug::DEPEND] << '`' << absname.absFilename()
|
||||
<< "' is no valid file name." << endl;
|
||||
}
|
||||
if (exists) {
|
||||
static regex unwanted("^.*\\.(aux|log|dvi|bbl|ind|glo)$");
|
||||
|
Loading…
Reference in New Issue
Block a user