summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Kaganski <mike.kaganski@collabora.com>2024-02-19 11:05:55 +0600
committerAndras Timar <andras.timar@collabora.com>2024-02-21 18:08:10 +0100
commit2b34eb19bf038e24cb9d32d52d0575f1b3d229c0 (patch)
treead8962dae4d444c8d9d908292f6718a3af451d70
parent0b4bf75ffca6ad9b3c359e973aa8a46d67a66625 (diff)
tdf#159769: always make sure that default temporary directory exists
This basically undoes commit 4743a32b4f991c57e4b8a66adf035b1808ca793a (only need to create the folder for temp files once, 2022-05-18). To avoid the overhead in TempFileFast, it now uses a new function to get the path, which doesn't check that path exists. Change-Id: I9c910a55dc4992058a7168690561b02d682b5e56 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/163576 Tested-by: Jenkins Reviewed-by: Mike Kaganski <mike.kaganski@collabora.com> (cherry picked from commit 0b58f1a41bf8d58426f16e47f86d313172ad4585) Reviewed-on: https://gerrit.libreoffice.org/c/core/+/163541 Reviewed-by: Michael Stahl <michael.stahl@allotropia.de>
-rw-r--r--unotools/source/ucbhelper/tempfile.cxx91
1 files changed, 48 insertions, 43 deletions
diff --git a/unotools/source/ucbhelper/tempfile.cxx b/unotools/source/ucbhelper/tempfile.cxx
index 992ff8814d7f..3003cea9ac0a 100644
--- a/unotools/source/ucbhelper/tempfile.cxx
+++ b/unotools/source/ucbhelper/tempfile.cxx
@@ -46,13 +46,23 @@ using namespace osl;
namespace
{
- OUString gTempNameBase_Impl;
+OUString gTempNameBase_Impl;
+
+OUString ensureTrailingSlash(const OUString& url)
+{
+ if (!url.isEmpty() && !url.endsWith("/"))
+ return url + "/";
+ return url;
}
-namespace utl
+OUString stripTrailingSlash(const OUString& url)
{
+ if (url.endsWith("/"))
+ return url.copy(0, url.getLength() - 1);
+ return url;
+}
-static OUString getParentName( std::u16string_view aFileName )
+OUString getParentName( std::u16string_view aFileName )
{
size_t lastIndex = aFileName.rfind( '/' );
OUString aParent;
@@ -71,17 +81,14 @@ static OUString getParentName( std::u16string_view aFileName )
return aParent;
}
-static bool ensuredir( const OUString& rUnqPath )
+bool ensuredir( const OUString& rUnqPath )
{
OUString aPath;
if ( rUnqPath.isEmpty() )
return false;
// remove trailing slash
- if ( rUnqPath.endsWith("/") )
- aPath = rUnqPath.copy( 0, rUnqPath.getLength() - 1 );
- else
- aPath = rUnqPath;
+ aPath = stripTrailingSlash(rUnqPath);
// HACK: create directory on a mount point with nobrowse option
// returns ENOSYS in any case !!
@@ -115,7 +122,24 @@ static bool ensuredir( const OUString& rUnqPath )
return bSuccess;
}
-static OUString ConstructTempDir_Impl( const OUString* pParent, bool bCreateParentDirs )
+const OUString& getTempNameBase_Impl()
+{
+ if (gTempNameBase_Impl.isEmpty())
+ {
+ OUString ustrTempDirURL;
+ osl::FileBase::RC rc = osl::File::getTempDirURL(ustrTempDirURL);
+ if (rc == osl::FileBase::E_None)
+ {
+ gTempNameBase_Impl = ensureTrailingSlash(ustrTempDirURL);
+ ensuredir(gTempNameBase_Impl);
+ }
+ }
+ assert(gTempNameBase_Impl.isEmpty() || gTempNameBase_Impl.endsWith("/"));
+ DBG_ASSERT(!gTempNameBase_Impl.isEmpty(), "No TempDir!");
+ return gTempNameBase_Impl;
+}
+
+OUString ConstructTempDir_Impl( const OUString* pParent, bool bCreateParentDirs )
{
OUString aName;
@@ -147,29 +171,15 @@ static OUString ConstructTempDir_Impl( const OUString* pParent, bool bCreatePare
if ( aName.isEmpty() )
{
- if (gTempNameBase_Impl.isEmpty())
- {
- OUString ustrTempDirURL;
- ::osl::FileBase::RC rc = ::osl::File::getTempDirURL(
- ustrTempDirURL );
- if (rc == ::osl::FileBase::E_None)
- gTempNameBase_Impl = ustrTempDirURL;
- ensuredir( aName );
- }
// if no parent or invalid parent : use default directory
- DBG_ASSERT( !gTempNameBase_Impl.isEmpty(), "No TempDir!" );
- aName = gTempNameBase_Impl;
+ aName = getTempNameBase_Impl();
+ ensuredir(aName); // tdf#159769: always make sure it exists
}
// Make sure that directory ends with a separator
- if( !aName.isEmpty() && !aName.endsWith("/") )
- aName += "/";
-
- return aName;
+ return ensureTrailingSlash(aName);
}
-namespace {
-
class Tokens {
public:
virtual bool next(OUString *) = 0;
@@ -233,12 +243,8 @@ private:
sal_uInt32 m_count;
};
-}
-
sal_uInt32 UniqueTokens::globalValue = SAL_MAX_UINT32;
-namespace
-{
class TempDirCreatedObserver : public DirectoryCreationObserver
{
public:
@@ -248,9 +254,8 @@ namespace
osl_File_Attribute_OwnWrite | osl_File_Attribute_OwnExe );
};
};
-};
-static OUString lcl_createName(
+OUString lcl_createName(
std::u16string_view rLeadingChars, Tokens & tokens, std::u16string_view pExtension,
const OUString* pParent, bool bDirectory, bool bKeep, bool bLock,
bool bCreateParentDirs )
@@ -326,7 +331,7 @@ static OUString lcl_createName(
return OUString();
}
-static OUString CreateTempName_Impl( const OUString* pParent, bool bKeep, bool bDir = true )
+OUString CreateTempName_Impl( const OUString* pParent, bool bKeep, bool bDir = true )
{
OUString aEyeCatcher = "lu";
#ifdef UNX
@@ -351,7 +356,7 @@ static OUString CreateTempName_Impl( const OUString* pParent, bool bKeep, bool b
false, false);
}
-static OUString CreateTempNameFast()
+OUString CreateTempNameFast()
{
OUString aEyeCatcher = "lu";
#ifdef UNX
@@ -372,12 +377,16 @@ static OUString CreateTempNameFast()
aEyeCatcher += aPidString;
#endif
- OUString aName = ConstructTempDir_Impl( /*pParent*/nullptr, /*bCreateParentDirs*/false ) + aEyeCatcher;
+ OUString aName = getTempNameBase_Impl() + aEyeCatcher;
tools::Guid aGuid(tools::Guid::Generate);
return aName + aGuid.getOUString() + ".tmp" ;
}
+}
+
+namespace utl
+{
OUString CreateTempName()
{
@@ -538,11 +547,8 @@ OUString SetTempNameBaseDirectory( const OUString &rBaseName )
if( rBaseName.isEmpty() )
return OUString();
- OUString aUnqPath( rBaseName );
-
// remove trailing slash
- if ( rBaseName.endsWith("/") )
- aUnqPath = rBaseName.copy( 0, rBaseName.getLength() - 1 );
+ OUString aUnqPath(stripTrailingSlash(rBaseName));
// try to create the directory
bool bRet = false;
@@ -558,16 +564,15 @@ OUString SetTempNameBaseDirectory( const OUString &rBaseName )
if ( bRet )
{
// append own internal directory
- OUString &rTempNameBase_Impl = gTempNameBase_Impl;
- rTempNameBase_Impl = rBaseName + "/";
+ gTempNameBase_Impl = ensureTrailingSlash(rBaseName);
TempFileNamed aBase( {}, true );
if ( aBase.IsValid() )
// use it in case of success
- rTempNameBase_Impl = aBase.aName;
+ gTempNameBase_Impl = ensureTrailingSlash(aBase.aName);
// return system path of used directory
- FileBase::getSystemPathFromFileURL( rTempNameBase_Impl, aTmp );
+ FileBase::getSystemPathFromFileURL(gTempNameBase_Impl, aTmp);
}
return aTmp;