diff options
author | Michael Meeks <michael.meeks@collabora.com> | 2015-07-15 14:07:54 +0100 |
---|---|---|
committer | Michael Meeks <michael.meeks@collabora.com> | 2015-07-15 20:39:50 +0100 |
commit | e1d78e123b74d37f95b4075b93202b023b4320e9 (patch) | |
tree | 75b2b1f5b570b131e84e890cbd2b17ae294c5941 | |
parent | d6790de07ff225f9e5b58152d01719e5fbe9e6cd (diff) |
tdf#92764 - make configmgr write less noisy.
Re-factor the TempFile abstraction and add a trivial OStringBuffer to
avoid emitting so many system calls - for writing small fragments of
configuration XML.
Change-Id: Ifbf5982ddb44845b2316087cafab4175a40e03cc
-rw-r--r-- | configmgr/source/winreg.cxx | 9 | ||||
-rw-r--r-- | configmgr/source/writemodfile.cxx | 127 | ||||
-rw-r--r-- | configmgr/source/writemodfile.hxx | 24 |
3 files changed, 102 insertions, 58 deletions
diff --git a/configmgr/source/winreg.cxx b/configmgr/source/winreg.cxx index 455c7119f329..b6baa7fda01c 100644 --- a/configmgr/source/winreg.cxx +++ b/configmgr/source/winreg.cxx @@ -70,7 +70,7 @@ namespace { // </node> // </item> -void dumpWindowsRegistryKey(HKEY hKey, OUString aKeyName, oslFileHandle aFileHandle) +void dumpWindowsRegistryKey(HKEY hKey, OUString aKeyName, TempFile &aFileHandle) { HKEY hCurKey; @@ -200,8 +200,8 @@ bool dumpWindowsRegistry(OUString* pFileURL, WinRegType eType) return false; } - oslFileHandle aFileHandle; - switch (osl::FileBase::createTempFile(0, &aFileHandle, pFileURL)) { + TempFile aFileHandle; + switch (osl::FileBase::createTempFile(0, &aFileHandle.handle, pFileURL)) { case osl::FileBase::E_None: break; case osl::FileBase::E_ACCES: @@ -213,6 +213,7 @@ bool dumpWindowsRegistry(OUString* pFileURL, WinRegType eType) throw css::uno::RuntimeException( "cannot create temporary file"); } + aFileHandle.url = *pFileURL; writeData( aFileHandle, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<oor:items" @@ -221,7 +222,7 @@ bool dumpWindowsRegistry(OUString* pFileURL, WinRegType eType) " xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\">\n"); dumpWindowsRegistryKey(hKey, "", aFileHandle); writeData(aFileHandle, "</oor:items>"); - oslFileError e = osl_closeFile(aFileHandle); + oslFileError e = aFileHandle.closeWithoutUnlink(); if (e != osl_File_E_None) SAL_WARN("configmgr", "osl_closeFile failed with " << +e); RegCloseKey(hKey); diff --git a/configmgr/source/writemodfile.cxx b/configmgr/source/writemodfile.cxx index e73753e81886..dc247e2dbf8b 100644 --- a/configmgr/source/writemodfile.cxx +++ b/configmgr/source/writemodfile.cxx @@ -35,6 +35,7 @@ #include <rtl/ustrbuf.hxx> #include <rtl/ustring.h> #include <rtl/ustring.hxx> +#include <rtl/strbuf.hxx> #include <sal/log.hxx> #include <sal/types.h> #include <xmlreader/span.hxx> @@ -73,18 +74,7 @@ OString convertToUtf8( return s; } -struct TempFile { - OUString url; - oslFileHandle handle; - bool closed; - - TempFile(): handle(0), closed(false) {} - - ~TempFile(); -private: - TempFile(const TempFile&) SAL_DELETED_FUNCTION; - TempFile& operator=(const TempFile&) SAL_DELETED_FUNCTION; -}; +} // anonymous namespace TempFile::~TempFile() { if (handle != 0) { @@ -103,21 +93,66 @@ TempFile::~TempFile() { } } -void writeData_(oslFileHandle handle, char const * begin, sal_Int32 length) { - assert(length >= 0); - sal_uInt64 n; - if ((osl_writeFile(handle, begin, static_cast< sal_uInt32 >(length), &n) != - osl_File_E_None) || - n != static_cast< sal_uInt32 >(length)) - { +oslFileError TempFile::closeWithoutUnlink() { + flush(); + oslFileError e = osl_closeFile(handle); + handle = 0; + closed = true; + return e; +} + +void TempFile::closeAndRename(const OUString &_url) { + oslFileError e = flush(); + if (e != osl_File_E_None) { throw css::uno::RuntimeException( - "write failure"); + "cannot write to " + url); } + e = osl_closeFile(handle); + closed = true; + if (e != osl_File_E_None) { + throw css::uno::RuntimeException( + "cannot close " + url); + } + if (osl::File::move(url, _url) != osl::FileBase::E_None) { + throw css::uno::RuntimeException( + "cannot move " + url); + } + handle = 0; } -void writeValueContent_(oslFileHandle, bool) SAL_DELETED_FUNCTION; +oslFileError TempFile::flush() { + oslFileError e = osl_File_E_None; + if (!buffer.isEmpty()) { + sal_uInt64 nBytesWritten = 0; + e = osl_writeFile(handle, buffer.getStr(), + static_cast< sal_uInt32 >(buffer.getLength()), + &nBytesWritten); + if (nBytesWritten != static_cast< sal_uInt32 >(buffer.getLength())) { + // queue up any error / exception until close. + buffer.remove(0, static_cast< sal_Int32 >( nBytesWritten ) ); + } else { + buffer.setLength(0); + } + } + return e; +} + +void TempFile::writeString(char const *begin, sal_Int32 length) { + buffer.append(begin, length); + if (buffer.getLength() > 0x10000) + flush(); +} + +namespace { + +void writeData_(TempFile &handle, char const * begin, sal_Int32 length) { + assert(length >= 0); + handle.writeString(begin, length); +} + +void writeValueContent_(TempFile &, bool) SAL_DELETED_FUNCTION; // silence lopluign:salbool -void writeValueContent_(oslFileHandle handle, sal_Bool value) { +void writeValueContent_(TempFile &handle, sal_Bool value) { if (value) { writeData_(handle, RTL_CONSTASCII_STRINGPARAM("true")); } else { @@ -125,28 +160,28 @@ void writeValueContent_(oslFileHandle handle, sal_Bool value) { } } -void writeValueContent_(oslFileHandle handle, sal_Int16 value) { +void writeValueContent_(TempFile &handle, sal_Int16 value) { writeData(handle, OString::number(value)); } -void writeValueContent_(oslFileHandle handle, sal_Int32 value) { +void writeValueContent_(TempFile &handle, sal_Int32 value) { writeData(handle, OString::number(value)); } -void writeValueContent_(oslFileHandle handle, sal_Int64 value) { +void writeValueContent_(TempFile &handle, sal_Int64 value) { writeData(handle, OString::number(value)); } -void writeValueContent_(oslFileHandle handle, double value) { +void writeValueContent_(TempFile &handle, double value) { writeData(handle, OString::number(value)); } -void writeValueContent_(oslFileHandle handle, const OUString& value) { +void writeValueContent_(TempFile &handle, const OUString& value) { writeValueContent(handle, value); } void writeValueContent_( - oslFileHandle handle, css::uno::Sequence< sal_Int8 > const & value) + TempFile &handle, css::uno::Sequence< sal_Int8 > const & value) { for (sal_Int32 i = 0; i < value.getLength(); ++i) { static char const hexDigit[16] = { @@ -158,7 +193,7 @@ void writeValueContent_( } template< typename T > void writeSingleValue( - oslFileHandle handle, css::uno::Any const & value) + TempFile &handle, css::uno::Any const & value) { writeData_(handle, RTL_CONSTASCII_STRINGPARAM(">")); T val = T(); @@ -168,7 +203,7 @@ template< typename T > void writeSingleValue( } template< typename T > void writeListValue( - oslFileHandle handle, css::uno::Any const & value) + TempFile &handle, css::uno::Any const & value) { writeData_(handle, RTL_CONSTASCII_STRINGPARAM(">")); css::uno::Sequence< T > val; @@ -183,7 +218,7 @@ template< typename T > void writeListValue( } template< typename T > void writeItemListValue( - oslFileHandle handle, css::uno::Any const & value) + TempFile &handle, css::uno::Any const & value) { writeData_(handle, RTL_CONSTASCII_STRINGPARAM(">")); css::uno::Sequence< T > val; @@ -196,7 +231,7 @@ template< typename T > void writeItemListValue( writeData_(handle, RTL_CONSTASCII_STRINGPARAM("</value>")); } -void writeValue(oslFileHandle handle, Type type, css::uno::Any const & value) { +void writeValue(TempFile &handle, Type type, css::uno::Any const & value) { switch (type) { case TYPE_BOOLEAN: writeSingleValue< sal_Bool >(handle, value); @@ -246,7 +281,7 @@ void writeValue(oslFileHandle handle, Type type, css::uno::Any const & value) { } void writeNode( - Components & components, oslFileHandle handle, + Components & components, TempFile &handle, rtl::Reference< Node > const & parent, OUString const & name, rtl::Reference< Node > const & node) { @@ -364,7 +399,7 @@ void writeNode( } void writeModifications( - Components & components, oslFileHandle handle, + Components & components, TempFile &handle, OUString const & parentPathRepresentation, rtl::Reference< Node > const & parent, OUString const & nodeName, rtl::Reference< Node > const & node, @@ -435,11 +470,11 @@ void writeModifications( } -void writeData(oslFileHandle handle, OString const & text) { +void writeData(TempFile &handle, OString const & text) { writeData_(handle, text.getStr(), text.getLength()); } -void writeAttributeValue(oslFileHandle handle, OUString const & value) { +void writeAttributeValue(TempFile &handle, OUString const & value) { sal_Int32 i = 0; sal_Int32 j = i; for (; j < value.getLength(); ++j) { @@ -484,7 +519,7 @@ void writeAttributeValue(oslFileHandle handle, OUString const & value) { writeData(handle, convertToUtf8(value, i, j - i)); } -void writeValueContent(oslFileHandle handle, OUString const & value) { +void writeValueContent(TempFile &handle, OUString const & value) { sal_Int32 i = 0; sal_Int32 j = i; for (; j < value.getLength(); ++j) { @@ -557,7 +592,7 @@ void writeModFile( "cannot create temporary file in " + dir); } writeData_( - tmp.handle, + tmp, RTL_CONSTASCII_STRINGPARAM( "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<oor:items" " xmlns:oor=\"http://openoffice.org/2001/registry\"" @@ -571,22 +606,12 @@ void writeModFile( j != data.modifications.getRoot().children.end(); ++j) { writeModifications( - components, tmp.handle, "", rtl::Reference< Node >(), j->first, + components, tmp, "", rtl::Reference< Node >(), j->first, data.getComponents().findNode(Data::NO_LAYER, j->first), j->second); } - writeData_(tmp.handle, RTL_CONSTASCII_STRINGPARAM("</oor:items>\n")); - oslFileError e = osl_closeFile(tmp.handle); - tmp.closed = true; - if (e != osl_File_E_None) { - throw css::uno::RuntimeException( - "cannot close " + tmp.url); - } - if (osl::File::move(tmp.url, url) != osl::FileBase::E_None) { - throw css::uno::RuntimeException( - "cannot move " + tmp.url); - } - tmp.handle = 0; + writeData_(tmp, RTL_CONSTASCII_STRINGPARAM("</oor:items>\n")); + tmp.closeAndRename(url); } } diff --git a/configmgr/source/writemodfile.hxx b/configmgr/source/writemodfile.hxx index 12a09a87dc93..ffa5e30ef5de 100644 --- a/configmgr/source/writemodfile.hxx +++ b/configmgr/source/writemodfile.hxx @@ -27,9 +27,27 @@ namespace configmgr { class Components; struct Data; -void writeData(oslFileHandle handle, OString const & text); -void writeAttributeValue(oslFileHandle handle, OUString const & value); -void writeValueContent(oslFileHandle handle, OUString const & value); +struct TempFile { + OUString url; + oslFileHandle handle; + bool closed; + OStringBuffer buffer; + + TempFile(): handle(0), closed(false) {} + ~TempFile(); + void closeAndRename(const OUString &url); + oslFileError flush(); + oslFileError closeWithoutUnlink(); + void writeString(char const *begin, sal_Int32 length); + +private: + TempFile(const TempFile&) SAL_DELETED_FUNCTION; + TempFile& operator=(const TempFile&) SAL_DELETED_FUNCTION; +}; + +void writeData(TempFile &handle, OString const & text); +void writeAttributeValue(TempFile &handle, OUString const & value); +void writeValueContent(TempFile &handle, OUString const & value); void writeModFile( Components & components, OUString const & url, Data const & data); |