diff options
author | osnola <alonso@loria.fr> | 2017-04-02 09:53:44 +0200 |
---|---|---|
committer | David Tardon <dtardon@redhat.com> | 2017-04-02 13:42:20 +0200 |
commit | 8988c925ce07395478fbbb10d25fd6c0a10fead5 (patch) | |
tree | 4770a03c18e2db296681297b4ef77322aa3dd522 /writerperfect/source/common/WPXSvInputStream.cxx | |
parent | b0067c89e6b2a4e29465d9da9a731ae30a66dce6 (diff) |
libstaroffice import filter improvements
+ add support for presentation file (i.e. the file created will StarImpress
are now open as presentation).
+ modify the OLE parser to be similar to the librevenge OLE parser,
ie. the librevenge parser ignores the first character of a filename if
this is a control character...
Change-Id: I913a70cba29839d43dac58d5e00dbebfc4d28abc
Diffstat (limited to 'writerperfect/source/common/WPXSvInputStream.cxx')
-rw-r--r-- | writerperfect/source/common/WPXSvInputStream.cxx | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/writerperfect/source/common/WPXSvInputStream.cxx b/writerperfect/source/common/WPXSvInputStream.cxx index 4c4998cbaca7..4137cd6f5425 100644 --- a/writerperfect/source/common/WPXSvInputStream.cxx +++ b/writerperfect/source/common/WPXSvInputStream.cxx @@ -105,7 +105,7 @@ const rtl::OUString concatPath(const rtl::OUString &lhs, const rtl::OUString &rh struct OLEStreamData { - explicit OLEStreamData(const rtl::OString &rName); + OLEStreamData(const rtl::OString &rName, const rtl::OString &rvngName); SotStorageStreamRefWrapper stream; @@ -115,6 +115,12 @@ struct OLEStreamData * produce const char* from it. */ rtl::OString name; + /** librevenge name of the stream. + * + * This is not @c rtl::OUString, because we need to be able to + * produce const char* from it. + */ + rtl::OString RVNGname; }; typedef std::unordered_map<rtl::OUString, std::size_t, rtl::OUStringHash> NameMap_t; @@ -158,9 +164,10 @@ public: bool mbInitialized; }; -OLEStreamData::OLEStreamData(const rtl::OString &rName) +OLEStreamData::OLEStreamData(const rtl::OString &rName, const rtl::OString &rvngName) : stream() , name(rName) + , RVNGname(rvngName) { } @@ -197,7 +204,7 @@ tools::SvRef<SotStorageStream> OLEStorageImpl::getStream(const rtl::OUString &rP return tools::SvRef<SotStorageStream>(); if (!maStreams[aIt->second].stream.ref.is()) - maStreams[aIt->second].stream.ref = createStream(aPath); + maStreams[aIt->second].stream.ref = createStream(rtl::OStringToOUString(maStreams[aIt->second].name, RTL_TEXTENCODING_UTF8)); return maStreams[aIt->second].stream.ref; } @@ -220,8 +227,13 @@ void OLEStorageImpl::traverse(const tools::SvRef<SotStorage> &rStorage, const rt { if (aIt->IsStream()) { - maStreams.push_back(OLEStreamData(rtl::OUStringToOString(concatPath(rPath, aIt->GetName()), RTL_TEXTENCODING_UTF8))); - maNameMap[concatPath(rPath, aIt->GetName())] = maStreams.size() - 1; + rtl::OUString baseName=aIt->GetName(), rvngName=baseName; + // librevenge::RVNGOLEStream ignores the first character when is a control code, so ... + if (!rvngName.isEmpty() && rvngName.toChar()<32) + rvngName=rvngName.copy(1); + maStreams.push_back(OLEStreamData(rtl::OUStringToOString(concatPath(rPath, baseName), RTL_TEXTENCODING_UTF8), + rtl::OUStringToOString(concatPath(rPath, rvngName), RTL_TEXTENCODING_UTF8))); + maNameMap[concatPath(rPath, rvngName)] = maStreams.size() - 1; } else if (aIt->IsStorage()) { @@ -590,7 +602,7 @@ const char *WPXSvInputStreamImpl::subStreamName(const unsigned id) if (mpOLEStorage->maStreams.size() <= id) return nullptr; - return mpOLEStorage->maStreams[id].name.getStr(); + return mpOLEStorage->maStreams[id].RVNGname.getStr(); } mxSeekable->seek(0); |