summaryrefslogtreecommitdiff
path: root/sw
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2017-07-06 10:31:19 +0100
committerCaolán McNamara <caolanm@redhat.com>2017-07-06 15:19:24 +0200
commitaff5cd7ed5d1cbe05975365d7aa9aff74fe5a861 (patch)
treed7d9fd50eb0cc00c57e813a64f3976008f02ecaa /sw
parent29277d4adf6e37cf201f11f3de704197feae494a (diff)
ofz: fix some leaks
Change-Id: Ia5961336fc399b079814cbcf66d47a465f5ba789 Reviewed-on: https://gerrit.libreoffice.org/39638 Reviewed-by: Caolán McNamara <caolanm@redhat.com> Tested-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'sw')
-rw-r--r--sw/source/filter/ww8/ww8glsy.cxx19
-rw-r--r--sw/source/filter/ww8/ww8glsy.hxx10
-rw-r--r--sw/source/filter/ww8/ww8graf.cxx6
-rw-r--r--sw/source/filter/ww8/ww8graf2.cxx2
-rw-r--r--sw/source/filter/ww8/ww8par.cxx134
-rw-r--r--sw/source/filter/ww8/ww8par.hxx4
-rw-r--r--sw/source/filter/ww8/ww8par2.cxx4
-rw-r--r--sw/source/filter/ww8/ww8par6.cxx22
8 files changed, 101 insertions, 100 deletions
diff --git a/sw/source/filter/ww8/ww8glsy.cxx b/sw/source/filter/ww8/ww8glsy.cxx
index e632f576aa6e..1a9ffb66e77f 100644
--- a/sw/source/filter/ww8/ww8glsy.cxx
+++ b/sw/source/filter/ww8/ww8glsy.cxx
@@ -35,9 +35,10 @@
#include "ww8par.hxx"
#include "ww8par2.hxx"
-WW8Glossary::WW8Glossary(tools::SvRef<SotStorageStream> &refStrm, sal_uInt8 nVersion,
- SotStorage *pStg)
- : pGlossary(nullptr), rStrm(refStrm), xStg(pStg), nStrings(0)
+WW8Glossary::WW8Glossary(tools::SvRef<SotStorageStream> &refStrm, sal_uInt8 nVersion, SotStorage *pStg)
+ : rStrm(refStrm)
+ , xStg(pStg)
+ , nStrings(0)
{
refStrm->SetEndian(SvStreamEndian::LITTLE);
WW8Fib aWwFib(*refStrm, nVersion);
@@ -50,7 +51,7 @@ WW8Glossary::WW8Glossary(tools::SvRef<SotStorageStream> &refStrm, sal_uInt8 nVer
if (xTableStream.is() && ERRCODE_NONE == xTableStream->GetError())
{
xTableStream->SetEndian(SvStreamEndian::LITTLE);
- pGlossary.reset( new WW8GlossaryFib(*refStrm, nVersion, aWwFib) );
+ xGlossary.reset(new WW8GlossaryFib(*refStrm, nVersion, aWwFib));
}
}
}
@@ -191,17 +192,17 @@ bool WW8Glossary::MakeEntries(SwDoc *pD, SwTextBlocks &rBlocks,
bool WW8Glossary::Load( SwTextBlocks &rBlocks, bool bSaveRelFile )
{
bool bRet=false;
- if (pGlossary && pGlossary->IsGlossaryFib() && rBlocks.StartPutMuchBlockEntries())
+ if (xGlossary && xGlossary->IsGlossaryFib() && rBlocks.StartPutMuchBlockEntries())
{
//read the names of the autotext entries
std::vector<OUString> aStrings;
std::vector<ww::bytes> aData;
rtl_TextEncoding eStructCharSet =
- WW8Fib::GetFIBCharset(pGlossary->m_chseTables, pGlossary->m_lid);
+ WW8Fib::GetFIBCharset(xGlossary->m_chseTables, xGlossary->m_lid);
- WW8ReadSTTBF(true, *xTableStream, pGlossary->m_fcSttbfglsy,
- pGlossary->m_lcbSttbfglsy, 0, eStructCharSet, aStrings, &aData );
+ WW8ReadSTTBF(true, *xTableStream, xGlossary->m_fcSttbfglsy,
+ xGlossary->m_lcbSttbfglsy, 0, eStructCharSet, aStrings, &aData );
rStrm->Seek(0);
@@ -223,7 +224,7 @@ bool WW8Glossary::Load( SwTextBlocks &rBlocks, bool bSaveRelFile )
aPamo.GetPoint()->nContent.Assign(aIdx.GetNode().GetContentNode(),
0);
std::unique_ptr<SwWW8ImplReader> xRdr(new SwWW8ImplReader(
- pGlossary->m_nVersion, xStg.get(), rStrm.get(), *pD, rBlocks.GetBaseURL(),
+ xGlossary->m_nVersion, xStg.get(), rStrm.get(), *pD, rBlocks.GetBaseURL(),
true, false, *aPamo.GetPoint()));
xRdr->LoadDoc(this);
bRet = MakeEntries(pD, rBlocks, bSaveRelFile, aStrings, aData);
diff --git a/sw/source/filter/ww8/ww8glsy.hxx b/sw/source/filter/ww8/ww8glsy.hxx
index e617fa0083d1..9018a806781e 100644
--- a/sw/source/filter/ww8/ww8glsy.hxx
+++ b/sw/source/filter/ww8/ww8glsy.hxx
@@ -60,15 +60,17 @@ class WW8Glossary
public:
WW8Glossary( tools::SvRef<SotStorageStream> &refStrm, sal_uInt8 nVersion, SotStorage *pStg);
bool Load( SwTextBlocks &rBlocks, bool bSaveRelFile );
- WW8GlossaryFib *GetFib() {
- return pGlossary.get();
+ std::shared_ptr<WW8GlossaryFib>& GetFib()
+ {
+ return xGlossary;
}
- sal_uInt16 GetNoStrings() const {
+ sal_uInt16 GetNoStrings() const
+ {
return nStrings;
}
private:
- std::unique_ptr<WW8GlossaryFib> pGlossary;
+ std::shared_ptr<WW8GlossaryFib> xGlossary;
tools::SvRef<SotStorageStream> xTableStream;
tools::SvRef<SotStorageStream> &rStrm;
tools::SvRef<SotStorage> xStg;
diff --git a/sw/source/filter/ww8/ww8graf.cxx b/sw/source/filter/ww8/ww8graf.cxx
index 4932fee0776b..e68dff6d9044 100644
--- a/sw/source/filter/ww8/ww8graf.cxx
+++ b/sw/source/filter/ww8/ww8graf.cxx
@@ -862,7 +862,7 @@ bool SwWW8ImplReader::GetTxbxTextSttEndCp(WW8_CP& rStartCp, WW8_CP& rEndCp,
sal_Int32 SwWW8ImplReader::GetRangeAsDrawingString(OUString& rString, long nStartCp, long nEndCp, ManTypes eType)
{
WW8_CP nOffset = 0;
- m_pWwFib->GetBaseCp(eType, &nOffset); //TODO: check return value
+ m_xWwFib->GetBaseCp(eType, &nOffset); //TODO: check return value
OSL_ENSURE(nStartCp <= nEndCp, "+where's the graphic text (7)?");
if (nStartCp == nEndCp)
@@ -2391,7 +2391,7 @@ bool SwWW8ImplReader::IsObjectLayoutInTableCell( const sal_uInt32 nLayoutInTable
if ( m_bVer8 )
{
- const sal_uInt16 nWWVersion = m_pWwFib->m_nProduct & 0xE000;
+ const sal_uInt16 nWWVersion = m_xWwFib->m_nProduct & 0xE000;
switch ( nWWVersion )
{
case 0x0000: // version 8 aka Microsoft Word 97
@@ -2441,7 +2441,7 @@ SwFrameFormat* SwWW8ImplReader::Read_GrafLayer( long nGrafAnchorCp )
::SetProgressState(m_nProgress, m_pDocShell); // Update
m_nDrawCpO = 0;
- m_bDrawCpOValid = m_pWwFib->GetBaseCp(m_xPlcxMan->GetManType() == MAN_HDFT ? MAN_TXBX_HDFT : MAN_TXBX, &m_nDrawCpO);
+ m_bDrawCpOValid = m_xWwFib->GetBaseCp(m_xPlcxMan->GetManType() == MAN_HDFT ? MAN_TXBX_HDFT : MAN_TXBX, &m_nDrawCpO);
GrafikCtor();
diff --git a/sw/source/filter/ww8/ww8graf2.cxx b/sw/source/filter/ww8/ww8graf2.cxx
index 25934119c376..3283e4a27c4c 100644
--- a/sw/source/filter/ww8/ww8graf2.cxx
+++ b/sw/source/filter/ww8/ww8graf2.cxx
@@ -273,7 +273,7 @@ bool SwWW8ImplReader::ReadGrafFile(OUString& rFileName, Graphic*& rpGraphic,
if (!bOk || pSt->GetError() || !aWMF.GetActionSize())
return false;
- if (m_pWwFib->m_envr != 1) // !MAC as creator
+ if (m_xWwFib->m_envr != 1) // !MAC as creator
{
rpGraphic = new Graphic( aWMF );
return true;
diff --git a/sw/source/filter/ww8/ww8par.cxx b/sw/source/filter/ww8/ww8par.cxx
index 5b965e1df6a1..fcf2ebc7973e 100644
--- a/sw/source/filter/ww8/ww8par.cxx
+++ b/sw/source/filter/ww8/ww8par.cxx
@@ -461,7 +461,7 @@ Sttb::getStringAtIndex( sal_uInt32 index )
}
SwMSDffManager::SwMSDffManager( SwWW8ImplReader& rRdr, bool bSkipImages )
- : SvxMSDffManager(*rRdr.m_pTableStream, rRdr.GetBaseURL(), rRdr.m_pWwFib->m_fcDggInfo,
+ : SvxMSDffManager(*rRdr.m_pTableStream, rRdr.GetBaseURL(), rRdr.m_xWwFib->m_fcDggInfo,
rRdr.m_pDataStream, nullptr, 0, COL_WHITE, rRdr.m_pStrm, bSkipImages),
rReader(rRdr), pFallbackStream(nullptr)
{
@@ -1131,7 +1131,7 @@ void SwWW8ImplReader::Read_StyleCode( sal_uInt16, const sal_uInt8* pData, short
return;
}
sal_uInt16 nColl = 0;
- if (m_pWwFib->GetFIBVersion() <= ww::eWW2)
+ if (m_xWwFib->GetFIBVersion() <= ww::eWW2)
nColl = *pData;
else
nColl = SVBT16ToShort(pData);
@@ -1889,7 +1889,7 @@ void SwWW8ImplReader::ImportDop()
// COMPATIBILITY FLAGS END
// Import magic doptypography information, if its there
- if (m_pWwFib->m_nFib > 105)
+ if (m_xWwFib->m_nFib > 105)
ImportDopTypography(m_xWDop->doptypography);
// disable form design mode to be able to use imported controls directly
@@ -2128,7 +2128,7 @@ long SwWW8ImplReader::Read_And(WW8PLCFManResult* pRes)
if (sal_uInt8 * pExtended = m_xPlcxMan->GetExtendedAtrds()) // Word < 2002 has no date data for comments
{
sal_uLong nIndex = pSD->GetIdx() & 0xFFFF; // Index is (stupidly) multiplexed for WW8PLCFx_SubDocs
- if (m_pWwFib->m_lcbAtrdExtra/18 > nIndex)
+ if (m_xWwFib->m_lcbAtrdExtra/18 > nIndex)
nDateTime = SVBT32ToUInt32(*reinterpret_cast<SVBT32*>(pExtended+(nIndex*18)));
}
@@ -2214,7 +2214,7 @@ void SwWW8ImplReader::Read_HdFtText(WW8_CP nStart, WW8_CP nLen, SwFrameFormat* p
bool SwWW8ImplReader::isValid_HdFt_CP(WW8_CP nHeaderCP) const
{
// Each CP of Plcfhdd MUST be less than FibRgLw97.ccpHdd
- return (nHeaderCP < m_pWwFib->m_ccpHdr && nHeaderCP >= 0);
+ return (nHeaderCP < m_xWwFib->m_ccpHdr && nHeaderCP >= 0);
}
bool SwWW8ImplReader::HasOwnHeaderFooter(sal_uInt8 nWhichItems, sal_uInt8 grpfIhdt,
@@ -2347,7 +2347,7 @@ void SwWW8ImplReader::Read_HdFt(int nSect, const SwPageDesc *pPrev,
bool wwSectionManager::SectionIsProtected(const wwSection &rSection) const
{
- return (mrReader.m_pWwFib->m_fReadOnlyRecommended && !rSection.IsNotProtected());
+ return (mrReader.m_xWwFib->m_fReadOnlyRecommended && !rSection.IsNotProtected());
}
void wwSectionManager::SetHdFt(wwSection &rSection, int nSect,
@@ -4141,7 +4141,6 @@ SwWW8ImplReader::SwWW8ImplReader(sal_uInt8 nVersionPara, SotStorage* pStorage,
, m_pPreviousNumPaM(nullptr)
, m_pPrevNumRule(nullptr)
, m_pPostProcessAttrsInfo(nullptr)
- , m_pWwFib(nullptr)
, m_aTextNodesHavingFirstLineOfstSet()
, m_aTextNodesHavingLeftIndentSet()
, m_pAktColl(nullptr)
@@ -4615,9 +4614,9 @@ void wwExtraneousParas::delete_all_from_doc()
void SwWW8ImplReader::StoreMacroCmds()
{
- if (m_pWwFib->m_lcbCmds)
+ if (m_xWwFib->m_lcbCmds)
{
- m_pTableStream->Seek(m_pWwFib->m_fcCmds);
+ m_pTableStream->Seek(m_xWwFib->m_fcCmds);
uno::Reference < embed::XStorage > xRoot(m_pDocShell->GetStorage());
@@ -4630,10 +4629,10 @@ void SwWW8ImplReader::StoreMacroCmds()
xRoot->openStreamElement( SL::aMSMacroCmds, embed::ElementModes::READWRITE );
std::unique_ptr<SvStream> xOutStream(::utl::UcbStreamHelper::CreateStream(xStream));
- sal_uInt32 lcbCmds = std::min<sal_uInt32>(m_pWwFib->m_lcbCmds, m_pTableStream->remainingSize());
+ sal_uInt32 lcbCmds = std::min<sal_uInt32>(m_xWwFib->m_lcbCmds, m_pTableStream->remainingSize());
std::unique_ptr<sal_uInt8[]> xBuffer(new sal_uInt8[lcbCmds]);
- m_pWwFib->m_lcbCmds = m_pTableStream->ReadBytes(xBuffer.get(), lcbCmds);
- xOutStream->WriteBytes(xBuffer.get(), m_pWwFib->m_lcbCmds);
+ m_xWwFib->m_lcbCmds = m_pTableStream->ReadBytes(xBuffer.get(), lcbCmds);
+ xOutStream->WriteBytes(xBuffer.get(), m_xWwFib->m_lcbCmds);
}
catch (...)
{
@@ -4646,8 +4645,8 @@ void SwWW8ImplReader::ReadDocVars()
std::vector<OUString> aDocVarStrings;
std::vector<ww::bytes> aDocVarStringIds;
std::vector<OUString> aDocValueStrings;
- WW8ReadSTTBF(!m_bVer67, *m_pTableStream, m_pWwFib->m_fcStwUser,
- m_pWwFib->m_lcbStwUser, m_bVer67 ? 2 : 0, m_eStructCharSet,
+ WW8ReadSTTBF(!m_bVer67, *m_pTableStream, m_xWwFib->m_fcStwUser,
+ m_xWwFib->m_lcbStwUser, m_bVer67 ? 2 : 0, m_eStructCharSet,
aDocVarStrings, &aDocVarStringIds, &aDocValueStrings);
if (!m_bVer67) {
uno::Reference<document::XDocumentPropertiesSupplier> xDPS(
@@ -4688,8 +4687,9 @@ void SwWW8ImplReader::ReadDocInfo()
xDPS->getDocumentProperties());
OSL_ENSURE(xDocProps.is(), "DocumentProperties is null");
- if (xDocProps.is()) {
- if ( m_pWwFib->m_fDot )
+ if (xDocProps.is())
+ {
+ if ( m_xWwFib->m_fDot )
{
OUString sTemplateURL;
SfxMedium* pMedium = m_pDocShell->GetMedium();
@@ -4702,11 +4702,11 @@ void SwWW8ImplReader::ReadDocInfo()
xDocProps->setTemplateURL( sTemplateURL );
}
}
- else if (m_pWwFib->m_lcbSttbfAssoc) // not a template, and has a SttbfAssoc
+ else if (m_xWwFib->m_lcbSttbfAssoc) // not a template, and has a SttbfAssoc
{
long nCur = m_pTableStream->Tell();
Sttb aSttb;
- m_pTableStream->Seek( m_pWwFib->m_fcSttbfAssoc ); // point at tgc record
+ m_pTableStream->Seek(m_xWwFib->m_fcSttbfAssoc); // point at tgc record
if (!aSttb.Read( *m_pTableStream ) )
SAL_WARN("sw.ww8", "** Read of SttbAssoc data failed!!!! ");
m_pTableStream->Seek( nCur ); // return to previous position, is that necessary?
@@ -4876,12 +4876,12 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
::ww8::WW8FibData * pFibData = new ::ww8::WW8FibData();
- if (m_pWwFib->m_fReadOnlyRecommended)
+ if (m_xWwFib->m_fReadOnlyRecommended)
pFibData->setReadOnlyRecommended(true);
else
pFibData->setReadOnlyRecommended(false);
- if (m_pWwFib->m_fWriteReservation)
+ if (m_xWwFib->m_fWriteReservation)
pFibData->setWriteReservation(true);
else
pFibData->setWriteReservation(false);
@@ -4891,11 +4891,11 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
m_rDoc.getIDocumentExternalData().setExternalData(::sw::tExternalDataType::FIB, pExternalFibData);
::sw::tExternalDataPointer pSttbfAsoc
- (new ::ww8::WW8Sttb<ww8::WW8Struct>(*m_pTableStream, m_pWwFib->m_fcSttbfAssoc, m_pWwFib->m_lcbSttbfAssoc));
+ (new ::ww8::WW8Sttb<ww8::WW8Struct>(*m_pTableStream, m_xWwFib->m_fcSttbfAssoc, m_xWwFib->m_lcbSttbfAssoc));
m_rDoc.getIDocumentExternalData().setExternalData(::sw::tExternalDataType::STTBF_ASSOC, pSttbfAsoc);
- if (m_pWwFib->m_fWriteReservation || m_pWwFib->m_fReadOnlyRecommended)
+ if (m_xWwFib->m_fWriteReservation || m_xWwFib->m_fReadOnlyRecommended)
{
SwDocShell * pDocShell = m_rDoc.GetDocShell();
if (pDocShell)
@@ -4924,18 +4924,18 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
RedlineFlags eMode = RedlineFlags::ShowInsert;
- m_xSprmParser.reset(new wwSprmParser(*m_pWwFib));
+ m_xSprmParser.reset(new wwSprmParser(*m_xWwFib));
// Set handy helper variables
- m_bVer6 = (6 == m_pWwFib->m_nVersion);
- m_bVer7 = (7 == m_pWwFib->m_nVersion);
+ m_bVer6 = (6 == m_xWwFib->m_nVersion);
+ m_bVer7 = (7 == m_xWwFib->m_nVersion);
m_bVer67 = m_bVer6 || m_bVer7;
- m_bVer8 = (8 == m_pWwFib->m_nVersion);
+ m_bVer8 = (8 == m_xWwFib->m_nVersion);
- m_eTextCharSet = WW8Fib::GetFIBCharset(m_pWwFib->m_chse, m_pWwFib->m_lid);
- m_eStructCharSet = WW8Fib::GetFIBCharset(m_pWwFib->m_chseTables, m_pWwFib->m_lid);
+ m_eTextCharSet = WW8Fib::GetFIBCharset(m_xWwFib->m_chse, m_xWwFib->m_lid);
+ m_eStructCharSet = WW8Fib::GetFIBCharset(m_xWwFib->m_chseTables, m_xWwFib->m_lid);
- m_bWWBugNormal = m_pWwFib->m_nProduct == 0xc03d;
+ m_bWWBugNormal = m_xWwFib->m_nProduct == 0xc03d;
if (!m_bNewDoc)
aSttNdIdx = m_pPaM->GetPoint()->nNode;
@@ -4943,11 +4943,11 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
::StartProgress(STR_STATSTR_W4WREAD, 0, 100, m_pDocShell);
// read Font Table
- m_xFonts.reset(new WW8Fonts(*m_pTableStream, *m_pWwFib));
+ m_xFonts.reset(new WW8Fonts(*m_pTableStream, *m_xWwFib));
// Document Properties
- m_xWDop.reset(new WW8Dop(*m_pTableStream, m_pWwFib->m_nFib, m_pWwFib->m_fcDop,
- m_pWwFib->m_lcbDop));
+ m_xWDop.reset(new WW8Dop(*m_pTableStream, m_xWwFib->m_nFib, m_xWwFib->m_fcDop,
+ m_xWwFib->m_lcbDop));
if (m_bNewDoc)
ImportDop();
@@ -4955,19 +4955,19 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
/*
Import revisioning data: author names
*/
- if( m_pWwFib->m_lcbSttbfRMark )
+ if( m_xWwFib->m_lcbSttbfRMark )
{
- ReadRevMarkAuthorStrTabl( *m_pTableStream,
- m_pWwFib->m_fcSttbfRMark,
- m_pWwFib->m_lcbSttbfRMark, m_rDoc );
+ ReadRevMarkAuthorStrTabl(*m_pTableStream,
+ m_xWwFib->m_fcSttbfRMark,
+ m_xWwFib->m_lcbSttbfRMark, m_rDoc);
}
// Initialize our String/ID map for Linked Sections
std::vector<OUString> aLinkStrings;
std::vector<ww::bytes> aStringIds;
- WW8ReadSTTBF(!m_bVer67, *m_pTableStream, m_pWwFib->m_fcSttbFnm,
- m_pWwFib->m_lcbSttbFnm, m_bVer67 ? 2 : 0, m_eStructCharSet,
+ WW8ReadSTTBF(!m_bVer67, *m_pTableStream, m_xWwFib->m_fcSttbFnm,
+ m_xWwFib->m_lcbSttbFnm, m_bVer67 ? 2 : 0, m_eStructCharSet,
aLinkStrings, &aStringIds);
for (size_t i=0; i < aLinkStrings.size() && i < aStringIds.size(); ++i)
@@ -4993,7 +4993,7 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
BEFORE the import of the lists !!
*/
::SetProgressState(m_nProgress, m_pDocShell); // Update
- m_xStyles.reset(new WW8RStyle(*m_pWwFib, this)); // Styles
+ m_xStyles.reset(new WW8RStyle(*m_xWwFib, this)); // Styles
m_xStyles->Import();
/*
@@ -5008,7 +5008,7 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
if (!m_vColl.empty())
SetOutlineStyles();
- m_xSBase.reset(new WW8ScannerBase(m_pStrm,m_pTableStream,m_pDataStream,m_pWwFib));
+ m_xSBase.reset(new WW8ScannerBase(m_pStrm,m_pTableStream,m_pDataStream, m_xWwFib.get()));
static const SvxNumType eNumTA[16] =
{
@@ -5049,8 +5049,8 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
m_rDoc.SetEndNoteInfo( aInfo );
}
- if( m_pWwFib->m_lcbPlcfhdd )
- m_xHdFt.reset(new WW8PLCF_HdFt(m_pTableStream, *m_pWwFib, *m_xWDop));
+ if (m_xWwFib->m_lcbPlcfhdd)
+ m_xHdFt.reset(new WW8PLCF_HdFt(m_pTableStream, *m_xWwFib, *m_xWDop));
if (!m_bNewDoc)
{
@@ -5082,7 +5082,7 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
// loop for each glossary entry and add dummy section node
if (pGloss)
{
- WW8PLCF aPlc(*m_pTableStream, m_pWwFib->m_fcPlcfglsy, m_pWwFib->m_lcbPlcfglsy, 0);
+ WW8PLCF aPlc(*m_pTableStream, m_xWwFib->m_fcPlcfglsy, m_xWwFib->m_lcbPlcfglsy, 0);
WW8_CP nStart, nEnd;
void* pDummy;
@@ -5106,7 +5106,7 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
{
if (m_bNewDoc && m_pStg && !pGloss) /*meaningless for a glossary */
{
- m_pDocShell->SetIsTemplate( m_pWwFib->m_fDot ); // point at tgc record
+ m_pDocShell->SetIsTemplate( m_xWwFib->m_fDot ); // point at tgc record
uno::Reference<document::XDocumentPropertiesSupplier> const
xDocPropSupp(m_pDocShell->GetModel(), uno::UNO_QUERY_THROW);
uno::Reference< document::XDocumentProperties > xDocProps( xDocPropSupp->getDocumentProperties(), uno::UNO_QUERY_THROW );
@@ -5146,7 +5146,7 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
bool bRet = aBasicImporter.import( m_pDocShell->GetMedium()->GetInputStream() );
lcl_createTemplateToProjectEntry( xPrjNameCache, sCreatedFrom, aBasicImporter.getProjectName() );
- WW8Customizations aCustomisations( m_pTableStream, *m_pWwFib );
+ WW8Customizations aCustomisations( m_pTableStream, *m_xWwFib );
aCustomisations.Import( m_pDocShell );
if( bRet )
@@ -5155,7 +5155,7 @@ ErrCode SwWW8ImplReader::CoreLoad(WW8Glossary *pGloss)
StoreMacroCmds();
}
m_bOnLoadingMain = true;
- ReadText(0, m_pWwFib->m_ccpText, MAN_MAINTEXT);
+ ReadText(0, m_xWwFib->m_ccpText, MAN_MAINTEXT);
m_bOnLoadingMain = false;
}
@@ -5367,7 +5367,7 @@ ErrCode SwWW8ImplReader::SetSubStreams(tools::SvRef<SotStorageStream> &rTableStr
{
ErrCode nErrRet = ERRCODE_NONE;
// 6 stands for "6 OR 7", 7 stands for "ONLY 7"
- switch (m_pWwFib->m_nVersion)
+ switch (m_xWwFib->m_nVersion)
{
case 6:
case 7:
@@ -5383,7 +5383,7 @@ ErrCode SwWW8ImplReader::SetSubStreams(tools::SvRef<SotStorageStream> &rTableStr
}
rTableStream = m_pStg->OpenSotStream(
- m_pWwFib->m_fWhichTableStm ? SL::a1Table : SL::a0Table,
+ m_xWwFib->m_fWhichTableStm ? SL::a1Table : SL::a0Table,
StreamMode::STD_READ);
m_pTableStream = rTableStream.get();
@@ -5641,11 +5641,11 @@ ErrCode SwWW8ImplReader::LoadThroughDecryption(WW8Glossary *pGloss)
{
ErrCode nErrRet = ERRCODE_NONE;
if (pGloss)
- m_pWwFib = pGloss->GetFib();
+ m_xWwFib = pGloss->GetFib();
else
- m_pWwFib = new WW8Fib(*m_pStrm, m_nWantedVersion);
+ m_xWwFib.reset(new WW8Fib(*m_pStrm, m_nWantedVersion));
- if (m_pWwFib->m_nFibError)
+ if (m_xWwFib->m_nFibError)
nErrRet = ERR_SWG_READ_ERROR;
tools::SvRef<SotStorageStream> xTableStream, xDataStream;
@@ -5662,16 +5662,16 @@ ErrCode SwWW8ImplReader::LoadThroughDecryption(WW8Glossary *pGloss)
bool bDecrypt = false;
enum {RC4CryptoAPI, RC4, XOR, Other} eAlgo = Other;
- if (m_pWwFib->m_fEncrypted && !nErrRet)
+ if (m_xWwFib->m_fEncrypted && !nErrRet)
{
if (!pGloss)
{
bDecrypt = true;
- if (8 != m_pWwFib->m_nVersion)
+ if (8 != m_xWwFib->m_nVersion)
eAlgo = XOR;
else
{
- if (m_pWwFib->m_nKey != 0)
+ if (m_xWwFib->m_nKey != 0)
eAlgo = XOR;
else
{
@@ -5702,17 +5702,17 @@ ErrCode SwWW8ImplReader::LoadThroughDecryption(WW8Glossary *pGloss)
case XOR:
{
msfilter::MSCodec_XorWord95 aCtx;
- uno::Sequence< beans::NamedValue > aEncryptionData = InitXorWord95Codec( aCtx, *pMedium, m_pWwFib );
+ uno::Sequence< beans::NamedValue > aEncryptionData = InitXorWord95Codec(aCtx, *pMedium, m_xWwFib.get());
// if initialization has failed the EncryptionData should be empty
- if ( aEncryptionData.getLength() && aCtx.VerifyKey( m_pWwFib->m_nKey, m_pWwFib->m_nHash ) )
+ if (aEncryptionData.getLength() && aCtx.VerifyKey(m_xWwFib->m_nKey, m_xWwFib->m_nHash))
{
nErrRet = ERRCODE_NONE;
pTempMain = MakeTemp(aDecryptMain);
m_pStrm->Seek(0);
size_t nUnencryptedHdr =
- (8 == m_pWwFib->m_nVersion) ? 0x44 : 0x34;
+ (8 == m_xWwFib->m_nVersion) ? 0x44 : 0x34;
sal_uInt8 *pIn = new sal_uInt8[nUnencryptedHdr];
nUnencryptedHdr = m_pStrm->ReadBytes(pIn, nUnencryptedHdr);
aDecryptMain.WriteBytes(pIn, nUnencryptedHdr);
@@ -5814,9 +5814,8 @@ ErrCode SwWW8ImplReader::LoadThroughDecryption(WW8Glossary *pGloss)
{
m_pStrm = &aDecryptMain;
- delete m_pWwFib;
- m_pWwFib = new WW8Fib(*m_pStrm, m_nWantedVersion);
- if (m_pWwFib->m_nFibError)
+ m_xWwFib.reset(new WW8Fib(*m_pStrm, m_nWantedVersion));
+ if (m_xWwFib->m_nFibError)
nErrRet = ERR_SWG_READ_ERROR;
}
}
@@ -5828,8 +5827,7 @@ ErrCode SwWW8ImplReader::LoadThroughDecryption(WW8Glossary *pGloss)
delete pTempTable;
delete pTempData;
- if (!pGloss)
- delete m_pWwFib;
+ m_xWwFib.reset();
return nErrRet;
}
@@ -5983,16 +5981,16 @@ void SwWW8ImplReader::SetOutlineStyles()
const OUString* SwWW8ImplReader::GetAnnotationAuthor(sal_uInt16 nIdx)
{
- if (!m_pAtnNames && m_pWwFib->m_lcbGrpStAtnOwners)
+ if (!m_pAtnNames && m_xWwFib->m_lcbGrpStAtnOwners)
{
// Determine authors: can be found in the TableStream
m_pAtnNames = new std::vector<OUString>;
SvStream& rStrm = *m_pTableStream;
long nOldPos = rStrm.Tell();
- rStrm.Seek( m_pWwFib->m_fcGrpStAtnOwners );
+ rStrm.Seek( m_xWwFib->m_fcGrpStAtnOwners );
- long nRead = 0, nCount = m_pWwFib->m_lcbGrpStAtnOwners;
+ long nRead = 0, nCount = m_xWwFib->m_lcbGrpStAtnOwners;
while (nRead < nCount && rStrm.good())
{
if( m_bVer67 )
@@ -6019,10 +6017,10 @@ const OUString* SwWW8ImplReader::GetAnnotationAuthor(sal_uInt16 nIdx)
void SwWW8ImplReader::GetSmartTagInfo(SwFltRDFMark& rMark)
{
- if (!m_pSmartTagData && m_pWwFib->m_lcbFactoidData)
+ if (!m_pSmartTagData && m_xWwFib->m_lcbFactoidData)
{
m_pSmartTagData.reset(new WW8SmartTagData);
- m_pSmartTagData->Read(*m_pTableStream, m_pWwFib->m_fcFactoidData, m_pWwFib->m_lcbFactoidData);
+ m_pSmartTagData->Read(*m_pTableStream, m_xWwFib->m_fcFactoidData, m_xWwFib->m_lcbFactoidData);
}
if (!m_pSmartTagData)
@@ -6373,7 +6371,7 @@ bool SwMSDffManager::GetOLEStorageName(sal_uInt32 nOLEId, OUString& rStorageName
nStartCp += rReader.m_nDrawCpO;
nEndCp += rReader.m_nDrawCpO;
WW8PLCFx_Cp_FKP* pChp = rReader.m_xPlcxMan->GetChpPLCF();
- wwSprmParser aSprmParser(*rReader.m_pWwFib);
+ wwSprmParser aSprmParser(*rReader.m_xWwFib);
while (nStartCp <= nEndCp && !nPictureId)
{
if (!pChp->SeekPos( nStartCp))
diff --git a/sw/source/filter/ww8/ww8par.hxx b/sw/source/filter/ww8/ww8par.hxx
index 9e5d7b7405e8..87692b8ebfe4 100644
--- a/sw/source/filter/ww8/ww8par.hxx
+++ b/sw/source/filter/ww8/ww8par.hxx
@@ -1193,7 +1193,7 @@ private:
WW8PostProcessAttrsInfo * m_pPostProcessAttrsInfo;
- WW8Fib* m_pWwFib;
+ std::shared_ptr<WW8Fib> m_xWwFib;
std::unique_ptr<WW8Fonts> m_xFonts;
std::unique_ptr<WW8Dop> m_xWDop;
std::unique_ptr<WW8ListManager> m_xLstManager;
@@ -1852,7 +1852,7 @@ public: // really private, but can only be done public
/// Seek to the end of the table with pPap, returns true on success.
bool SearchTableEnd(WW8PLCFx_Cp_FKP* pPap) const;
- const WW8Fib& GetFib() const { return *m_pWwFib; }
+ const WW8Fib& GetFib() const { return *m_xWwFib; }
SwDoc& GetDoc() const { return m_rDoc; }
sal_uInt16 GetNAktColl() const { return m_nAktColl; }
void SetNAktColl( sal_uInt16 nColl ) { m_nAktColl = nColl; }
diff --git a/sw/source/filter/ww8/ww8par2.cxx b/sw/source/filter/ww8/ww8par2.cxx
index d7fb08669837..a3cdf54b00f5 100644
--- a/sw/source/filter/ww8/ww8par2.cxx
+++ b/sw/source/filter/ww8/ww8par2.cxx
@@ -4363,7 +4363,7 @@ void WW8RStyle::ImportOldFormatStyles()
}
rtl_TextEncoding eStructChrSet = WW8Fib::GetFIBCharset(
- pIo->m_pWwFib->m_chseTables, pIo->m_pWwFib->m_lid);
+ pIo->m_xWwFib->m_chseTables, pIo->m_xWwFib->m_lid);
sal_uInt16 cstcStd(0);
rSt.ReadUInt16( cstcStd );
@@ -4578,7 +4578,7 @@ void WW8RStyle::Import()
if( pIo->m_nIniFlags & WW8FL_NO_STYLES )
return;
- if (pIo->m_pWwFib->GetFIBVersion() <= ww::eWW2)
+ if (pIo->m_xWwFib->GetFIBVersion() <= ww::eWW2)
ImportOldFormatStyles();
else
ImportNewFormatStyles();
diff --git a/sw/source/filter/ww8/ww8par6.cxx b/sw/source/filter/ww8/ww8par6.cxx
index a88248dd30de..73646998052f 100644
--- a/sw/source/filter/ww8/ww8par6.cxx
+++ b/sw/source/filter/ww8/ww8par6.cxx
@@ -839,7 +839,7 @@ void wwSectionManager::CreateSep(const long nTextPos)
aLastSection = maSegments.back();
//Here
- sal_uInt16 nLIdx = ( ( (sal_uInt16)mrReader.m_pWwFib->m_lid & 0xff ) == 0x9 ) ? 1 : 0;
+ sal_uInt16 nLIdx = ( ( (sal_uInt16)mrReader.m_xWwFib->m_lid & 0xff ) == 0x9 ) ? 1 : 0;
//BEGIN read section values
wwSection aNewSection(*mrReader.m_pPaM->GetPoint());
@@ -1652,7 +1652,7 @@ void WW8FlyPara::ReadFull(sal_uInt8 nOrigSp29, SwWW8ImplReader* pIo)
do{ // block for quick exit
if( nSp45 != 0 /* || nSp28 != 0 */ )
break; // bGrafApo only automatic for height
- if( pIo->m_pWwFib->m_fComplex )
+ if( pIo->m_xWwFib->m_fComplex )
break; // (*pPap)++ does not work for FastSave
// -> for FastSave, no test for graphics APO
SvStream* pIoStrm = pIo->m_pStrm;
@@ -2853,7 +2853,7 @@ void SwWW8ImplReader::Read_BoldUsw( sal_uInt16 nId, const sal_uInt8* pData, shor
RES_CHRATR_CTL_WEIGHT, RES_CHRATR_CTL_POSTURE
};
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
sal_uInt8 nI;
// the attribute number for "double strike-through" breaks rank
@@ -3018,7 +3018,7 @@ pattern which has significance for those types of properties.
void SwWW8ImplReader::Read_AmbiguousSPRM(sal_uInt16 nId, const sal_uInt8* pData,
short nLen)
{
- if (m_pWwFib->m_wIdent >= 0xa697 && m_pWwFib->m_wIdent <= 0xa699)
+ if (m_xWwFib->m_wIdent >= 0xa697 && m_xWwFib->m_wIdent <= 0xa699)
{
Read_FontCode(nId, pData, nLen);
}
@@ -3038,7 +3038,7 @@ void SwWW8ImplReader::Read_BoldBiDiUsw(sal_uInt16 nId, const sal_uInt8* pData,
};
sal_uInt8 nI;
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
if (eVersion <= ww::eWW2)
nI = static_cast< sal_uInt8 >(nId - 80);
else if (eVersion < ww::eWW8)
@@ -3126,7 +3126,7 @@ void SwWW8ImplReader::SetToggleBiDiAttr(sal_uInt8 nAttrId, bool bOn)
void SwWW8ImplReader::SetToggleAttr(sal_uInt8 nAttrId, bool bOn)
{
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
switch (nAttrId)
{
@@ -3313,7 +3313,7 @@ bool SwWW8ImplReader::ConvertSubToGraphicPlacement()
void SwWW8ImplReader::Read_SubSuperProp( sal_uInt16, const sal_uInt8* pData, short nLen )
{
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
if (nLen < (eVersion <= ww::eWW2 ? 1 : 2))
{
@@ -3732,7 +3732,7 @@ void SwWW8ImplReader::Read_FontCode( sal_uInt16 nId, const sal_uInt8* pData, sho
return ;
}
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
if (nLen < 2) // end of attribute
{
@@ -3774,7 +3774,7 @@ void SwWW8ImplReader::Read_FontSize( sal_uInt16 nId, const sal_uInt8* pData, sho
return ;
}
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
if (nLen < (eVersion <= ww::eWW2 ? 1 : 2)) // end of attribute
{
@@ -4169,7 +4169,7 @@ void SwWW8ImplReader::Read_LineSpace( sal_uInt16, const sal_uInt8* pData, short
if (m_bStyNormal && m_bWWBugNormal)
return;
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
if (nLen < (eVersion <= ww::eWW2 ? 3 : 4))
{
@@ -6298,7 +6298,7 @@ const wwSprmDispatcher *GetWW8SprmDispatcher()
const SprmReadInfo& SwWW8ImplReader::GetSprmReadInfo(sal_uInt16 nId) const
{
- ww::WordVersion eVersion = m_pWwFib->GetFIBVersion();
+ ww::WordVersion eVersion = m_xWwFib->GetFIBVersion();
const wwSprmDispatcher *pDispatcher;
if (eVersion <= ww::eWW2)
pDispatcher = GetWW2SprmDispatcher();