summaryrefslogtreecommitdiff
path: root/xmlreader
diff options
context:
space:
mode:
Diffstat (limited to 'xmlreader')
-rw-r--r--xmlreader/inc/xmlreader/xmlreader.hxx6
-rw-r--r--xmlreader/source/xmlreader.cxx23
2 files changed, 27 insertions, 2 deletions
diff --git a/xmlreader/inc/xmlreader/xmlreader.hxx b/xmlreader/inc/xmlreader/xmlreader.hxx
index b6de02734e84..1d3faf05c0c2 100644
--- a/xmlreader/inc/xmlreader/xmlreader.hxx
+++ b/xmlreader/inc/xmlreader/xmlreader.hxx
@@ -44,6 +44,10 @@ public:
com::sun::star::container::NoSuchElementException,
com::sun::star::uno::RuntimeException));
+ //string is not copied so must persist for lifetime
+ //of XmlReader
+ explicit XmlReader(const char * str, sal_uInt64 len) SAL_THROW(());
+
~XmlReader();
enum { NAMESPACE_NONE = -2, NAMESPACE_UNKNOWN = -1, NAMESPACE_XML = 0 };
@@ -170,6 +174,8 @@ private:
SAL_DLLPRIVATE int toNamespaceId(NamespaceIris::size_type pos);
+ SAL_DLLPRIVATE void init();
+
rtl::OUString fileUrl_;
oslFileHandle fileHandle_;
sal_uInt64 fileSize_;
diff --git a/xmlreader/source/xmlreader.cxx b/xmlreader/source/xmlreader.cxx
index fcf6e157a246..e297cd176c53 100644
--- a/xmlreader/source/xmlreader.cxx
+++ b/xmlreader/source/xmlreader.cxx
@@ -96,19 +96,38 @@ XmlReader::XmlReader(rtl::OUString const & fileUrl)
rtl::OUString::valueOf(static_cast< sal_Int32 >(e)) + ")"),
css::uno::Reference< css::uno::XInterface >());
}
+ init();
+ pos_ = static_cast< char * >(fileAddress_);
+ end_ = pos_ + fileSize_;
+}
+
+XmlReader::XmlReader(const char * str, sal_uInt64 len)
+ SAL_THROW(())
+ : fileHandle_(NULL)
+ , fileSize_(len)
+ , fileAddress_(NULL)
+{
+ init();
+ pos_ = str;
+ end_ = pos_ + fileSize_;
+}
+
+void XmlReader::init()
+{
namespaceIris_.push_back(
Span(
RTL_CONSTASCII_STRINGPARAM(
"http://www.w3.org/XML/1998/namespace")));
namespaces_.push_back(
NamespaceData(Span(RTL_CONSTASCII_STRINGPARAM("xml")), NAMESPACE_XML));
- pos_ = static_cast< char * >(fileAddress_);
- end_ = pos_ + fileSize_;
state_ = STATE_CONTENT;
firstAttribute_ = true;
}
XmlReader::~XmlReader() {
+ if (!fileHandle_)
+ return;
+
oslFileError e = osl_unmapMappedFile(fileHandle_, fileAddress_, fileSize_);
if (e != osl_File_E_None) {
SAL_WARN(