mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
ENH: allow space char in fileName is now configurable (#1008)
- having whitespace in fileName can be somewhat fragile since it means
that the fileName components do not necessarily correspond to a
'Foam::word'. But in many cases it will work provided that spaces
are not present in the final portion of the simulation directory
itself.
InfoSwitches
{
// Allow space character in fileName (use with caution)
allowSpaceInFileName 0;
}
- now use doClean=true as default for fileName::validate(). Was false.
Unlike fileName::clean() this requires no internal string rewrite
since the characters are being copied. Also handle any path
separator transformations (ie, backslash => forward slash) at the
same time. This makes it resemble the std::filesystem a bit more.
This commit is contained in:
committed by
Andrew Heather
parent
54c10e651d
commit
89245fa796
3
applications/test/fileNameOS/Make/files
Normal file
3
applications/test/fileNameOS/Make/files
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
Test-fileNameOS.C
|
||||||
|
|
||||||
|
EXE = $(FOAM_USER_APPBIN)/Test-fileNameOS
|
||||||
2
applications/test/fileNameOS/Make/options
Normal file
2
applications/test/fileNameOS/Make/options
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
/* EXE_INC = */
|
||||||
|
/* EXE_LIBS = */
|
||||||
106
applications/test/fileNameOS/Test-fileNameOS.C
Normal file
106
applications/test/fileNameOS/Test-fileNameOS.C
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
/*---------------------------------------------------------------------------*\
|
||||||
|
========= |
|
||||||
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||||
|
\\ / O peration |
|
||||||
|
\\ / A nd | Copyright (C) 2019 OpenCFD Ltd.
|
||||||
|
\\/ M anipulation |
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
License
|
||||||
|
This file is part of OpenFOAM.
|
||||||
|
|
||||||
|
OpenFOAM is free software: you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
Application
|
||||||
|
Test-fileNameOS
|
||||||
|
|
||||||
|
Description
|
||||||
|
Test fileName behaviour, potential OS capabilities etc.
|
||||||
|
|
||||||
|
In the distant future could possibly replace parts with C++ filesystem
|
||||||
|
|
||||||
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
#include "argList.H"
|
||||||
|
#include "fileName.H"
|
||||||
|
#include "OSspecific.H"
|
||||||
|
#include "Switch.H"
|
||||||
|
|
||||||
|
#include <csignal>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
|
||||||
|
using namespace Foam;
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
void testDirname(const std::string& rawInput)
|
||||||
|
{
|
||||||
|
fileName input(fileName::validate(rawInput));
|
||||||
|
|
||||||
|
Info<< nl
|
||||||
|
<< "input: " << rawInput << nl
|
||||||
|
<< "fileName:" << input << nl
|
||||||
|
<< " path:" << input.path()
|
||||||
|
<< " name:\"" << input.name() << '"'
|
||||||
|
<< " ext:\"" << input.ext() << '"'
|
||||||
|
<< " components: " << flatOutput(input.components()) << nl;
|
||||||
|
|
||||||
|
if (rawInput.size() != input.size())
|
||||||
|
{
|
||||||
|
Info<< " This would be Fatal with debug > 1" << nl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
// Main program:
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
argList::noParallel();
|
||||||
|
argList::addBoolOption("no-space", "allowSpaceInFileName = false");
|
||||||
|
argList::addBoolOption("with-space", "set allowSpaceInFileName = true");
|
||||||
|
|
||||||
|
#include "setRootCase.H"
|
||||||
|
|
||||||
|
if (args.found("with-space"))
|
||||||
|
{
|
||||||
|
fileName::allowSpaceInFileName = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (args.found("no-space"))
|
||||||
|
{
|
||||||
|
fileName::allowSpaceInFileName = false;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Info<<"fileName with spaces? : "
|
||||||
|
<< Switch(bool(fileName::allowSpaceInFileName)) << nl << nl;
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
testDirname("/abc");
|
||||||
|
testDirname("/abc/with space/name");
|
||||||
|
testDirname("/abc/with space/more space");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Info<< "\nEnd\n" << endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ************************************************************************* //
|
||||||
@ -64,6 +64,9 @@ InfoSwitches
|
|||||||
|
|
||||||
// Allow case-supplied C++ code (#codeStream, codedFixedValue)
|
// Allow case-supplied C++ code (#codeStream, codedFixedValue)
|
||||||
allowSystemOperations 1;
|
allowSystemOperations 1;
|
||||||
|
|
||||||
|
// Allow space character in fileName (use with caution)
|
||||||
|
allowSpaceInFileName 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -648,7 +648,7 @@ void Foam::argList::setCasePaths()
|
|||||||
|
|
||||||
if (optIter.found())
|
if (optIter.found())
|
||||||
{
|
{
|
||||||
caseDir = optIter.val();
|
caseDir = fileName::validate(optIter.val());
|
||||||
caseDir.clean();
|
caseDir.clean();
|
||||||
|
|
||||||
if (caseDir.empty() || caseDir == ".")
|
if (caseDir.empty() || caseDir == ".")
|
||||||
|
|||||||
@ -47,11 +47,19 @@ class Ostream;
|
|||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
char readChar(Istream&);
|
//- Read single character
|
||||||
Istream& operator>>(Istream&, char&);
|
char readChar(Istream& is);
|
||||||
Ostream& operator<<(Ostream&, const char);
|
|
||||||
Ostream& operator<<(Ostream&, const char*);
|
|
||||||
|
|
||||||
|
//- Read single character
|
||||||
|
Istream& operator>>(Istream& is, char& c);
|
||||||
|
|
||||||
|
//- Write single character
|
||||||
|
Ostream& operator<<(Ostream& os, const char c);
|
||||||
|
|
||||||
|
//- Write a nul-terminated C-string
|
||||||
|
Ostream& operator<<(Ostream& os, const char* str);
|
||||||
|
|
||||||
|
//- Test for \em horizontal whitespace
|
||||||
inline bool isspace(char c)
|
inline bool isspace(char c)
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
@ -63,6 +71,7 @@ inline bool isspace(char c)
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
} // End namespace Foam
|
} // End namespace Foam
|
||||||
|
|||||||
@ -32,9 +32,9 @@ License
|
|||||||
|
|
||||||
char Foam::readChar(Istream& is)
|
char Foam::readChar(Istream& is)
|
||||||
{
|
{
|
||||||
char c;
|
char c;
|
||||||
is.read(c);
|
is.read(c);
|
||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -54,9 +54,9 @@ Foam::Ostream& Foam::operator<<(Ostream& os, const char c)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Foam::Ostream& Foam::operator<<(Ostream& os, const char* s)
|
Foam::Ostream& Foam::operator<<(Ostream& os, const char* str)
|
||||||
{
|
{
|
||||||
os.write(s);
|
os.write(str);
|
||||||
os.check(FUNCTION_NAME);
|
os.check(FUNCTION_NAME);
|
||||||
return os;
|
return os;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -36,7 +36,11 @@ License
|
|||||||
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
||||||
|
|
||||||
const char* const Foam::fileName::typeName = "fileName";
|
const char* const Foam::fileName::typeName = "fileName";
|
||||||
int Foam::fileName::debug(debug::debugSwitch(fileName::typeName, 0));
|
int Foam::fileName::debug(Foam::debug::debugSwitch(fileName::typeName, 0));
|
||||||
|
int Foam::fileName::allowSpaceInFileName
|
||||||
|
(
|
||||||
|
Foam::debug::infoSwitch("allowSpaceInFileName", 0)
|
||||||
|
);
|
||||||
const Foam::fileName Foam::fileName::null;
|
const Foam::fileName Foam::fileName::null;
|
||||||
|
|
||||||
|
|
||||||
@ -48,16 +52,27 @@ Foam::fileName Foam::fileName::validate
|
|||||||
const bool doClean
|
const bool doClean
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
// The logic is very similar to stripInvalid,
|
||||||
|
// but silently removes bad characters
|
||||||
|
|
||||||
fileName out;
|
fileName out;
|
||||||
out.resize(s.size());
|
out.resize(s.size());
|
||||||
|
|
||||||
char prev = 0;
|
|
||||||
std::string::size_type len = 0;
|
std::string::size_type len = 0;
|
||||||
|
|
||||||
// Largely as per stripInvalid
|
char prev = 0;
|
||||||
for (auto iter = s.cbegin(); iter != s.cend(); ++iter)
|
for (auto iter = s.cbegin(); iter != s.cend(); ++iter)
|
||||||
{
|
{
|
||||||
const char c = *iter;
|
char c = *iter;
|
||||||
|
|
||||||
|
// Treat raw backslash like a path separator. There is no "normal"
|
||||||
|
// way for these to be there (except for an OS that uses them), but
|
||||||
|
// could also cause issues when writing strings, shell commands etc.
|
||||||
|
|
||||||
|
if (c == '\\')
|
||||||
|
{
|
||||||
|
c = '/';
|
||||||
|
}
|
||||||
|
|
||||||
if (fileName::valid(c))
|
if (fileName::valid(c))
|
||||||
{
|
{
|
||||||
|
|||||||
@ -90,6 +90,9 @@ public:
|
|||||||
//- Debugging
|
//- Debugging
|
||||||
static int debug;
|
static int debug;
|
||||||
|
|
||||||
|
//- Allow space character in fileName. To be used with caution.
|
||||||
|
static int allowSpaceInFileName;
|
||||||
|
|
||||||
//- An empty fileName
|
//- An empty fileName
|
||||||
static const fileName null;
|
static const fileName null;
|
||||||
|
|
||||||
@ -141,14 +144,10 @@ public:
|
|||||||
//- Is this character valid for a fileName?
|
//- Is this character valid for a fileName?
|
||||||
inline static bool valid(char c);
|
inline static bool valid(char c);
|
||||||
|
|
||||||
//- Construct validated fileName (no invalid characters).
|
//- Construct fileName with no invalid characters, possibly applying
|
||||||
// Optionally perform some additional cleanup such as removing
|
//- other transformations such as changing the path separator,
|
||||||
// duplicate or trailing slashes.
|
//- removing duplicate or trailing slashes, etc.
|
||||||
static fileName validate
|
static fileName validate(const std::string& s, const bool doClean=true);
|
||||||
(
|
|
||||||
const std::string& s,
|
|
||||||
const bool doClean=false
|
|
||||||
);
|
|
||||||
|
|
||||||
//- This is a specialized (possibly slower) version of compare()
|
//- This is a specialized (possibly slower) version of compare()
|
||||||
//- that ignores duplicate or trailing slashes.
|
//- that ignores duplicate or trailing slashes.
|
||||||
|
|||||||
@ -102,9 +102,9 @@ inline bool Foam::fileName::valid(char c)
|
|||||||
{
|
{
|
||||||
return
|
return
|
||||||
(
|
(
|
||||||
!isspace(c)
|
c != '"' // string quote
|
||||||
&& c != '"' // string quote
|
&& c != '\'' // string quote
|
||||||
&& c != '\'' // string quote
|
&& (!isspace(c) || (allowSpaceInFileName && c == ' '))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -134,7 +134,10 @@ inline void Foam::fileName::stripInvalid()
|
|||||||
|
|
||||||
inline bool Foam::fileName::isAbsolute(const std::string& str)
|
inline bool Foam::fileName::isAbsolute(const std::string& str)
|
||||||
{
|
{
|
||||||
return !str.empty() && str[0] == '/';
|
return
|
||||||
|
(
|
||||||
|
!str.empty() && str[0] == '/'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user