diff options
author | Adam Co <rattles2013@gmail.com> | 2013-08-29 17:16:44 +0300 |
---|---|---|
committer | Miklos Vajna <vmiklos@collabora.co.uk> | 2013-10-22 09:53:53 +0200 |
commit | c2ccd20c0fd92bddfff76447754541705e3eb8f3 (patch) | |
tree | cd912865f00efcfd559530bc6ff1bfbeb57065cf /sw/source | |
parent | 30823bce29b4e5007cf045e9923a2f2e749ab091 (diff) |
fdo#44689: fix for specific case of page restart-value 0
This bug fix is for roundtripping a DOCX that has
a specific 'start value' for the page numbers.
In most cases LO imports it ok.
However - until now - Word allowed you to start page number
from 0, while LO only allowed starting page numbers from 1.
This was because the 'start value' was stored in an 'unsigned int',
and the value '0' was used to mark 'there is no start value'.
This patch changes the way the 'start value' is stored
from 'unsigned int' to 'optional unsigned int'.
This way - if there is no value applied - the variable will hold NULL.
However - if a value is set - it can be 0 or more.
This meant also tweaking all the places that used to get this value,
so that now they handle an 'optional uint', instead of a 'uint'.
Conflicts:
sw/source/ui/inc/break.hxx
sw/source/ui/inc/wrtsh.hxx
sw/source/ui/shells/textsh1.cxx
sw/source/ui/utlui/uitool.cxx
sw/source/ui/wrtsh/wrtsh1.cxx
Change-Id: I6ad9d90e03b42c58eed2271477df43c20ad6f20a
Reviewed-on: https://gerrit.libreoffice.org/5681
Diffstat (limited to 'sw/source')
31 files changed, 198 insertions, 90 deletions
diff --git a/sw/source/core/crsr/findattr.cxx b/sw/source/core/crsr/findattr.cxx index 006e2106bff8..7aef37b180ac 100644 --- a/sw/source/core/crsr/findattr.cxx +++ b/sw/source/core/crsr/findattr.cxx @@ -40,6 +40,7 @@ #include <pamtyp.hxx> #include <swundo.hxx> #include <crsskip.hxx> +#include <boost/optional.hpp> using namespace ::com::sun::star; using namespace ::com::sun::star::lang; @@ -60,10 +61,26 @@ int CmpAttr( const SfxPoolItem& rItem1, const SfxPoolItem& rItem2 ) return ((SvxColorItem&)rItem1).GetValue().IsRGBEqual( ((SvxColorItem&)rItem2).GetValue() ); case RES_PAGEDESC: - return ((SwFmtPageDesc&)rItem1).GetNumOffset() == - ((SwFmtPageDesc&)rItem2).GetNumOffset() && - ((SwFmtPageDesc&)rItem1).GetPageDesc() == - ((SwFmtPageDesc&)rItem2).GetPageDesc(); + bool bNumOffsetEqual = false; + ::boost::optional<sal_uInt16> oNumOffset1 = ((SwFmtPageDesc&)rItem1).GetNumOffset(); + ::boost::optional<sal_uInt16> oNumOffset2 = ((SwFmtPageDesc&)rItem1).GetNumOffset(); + if (!oNumOffset1 && !oNumOffset2) + { + bNumOffsetEqual = true; + } + else if (oNumOffset1 && oNumOffset2) + { + bNumOffsetEqual = oNumOffset1.get() == oNumOffset2.get(); + } + else + { + bNumOffsetEqual = false; + } + + if (bNumOffsetEqual == false) + return false; + + return ((SwFmtPageDesc&)rItem1).GetPageDesc() == ((SwFmtPageDesc&)rItem2).GetPageDesc(); } return rItem1 == rItem2; } diff --git a/sw/source/core/fields/docufld.cxx b/sw/source/core/fields/docufld.cxx index 33b80dae9c7b..39673515d7ee 100644 --- a/sw/source/core/fields/docufld.cxx +++ b/sw/source/core/fields/docufld.cxx @@ -115,7 +115,7 @@ OUString SwPageNumberFieldType::Expand( sal_uInt32 nFmt, short nOff, sal_uInt32 nTmpFmt = (SVX_NUM_PAGEDESC == nFmt) ? (sal_uInt32)nNumberingType : nFmt; int const nTmp = nPageNumber + nOff; - if (0 >= nTmp || SVX_NUM_NUMBER_NONE == nTmpFmt || (!bVirtuell && nTmp > nMaxPage)) + if (0 > nTmp || SVX_NUM_NUMBER_NONE == nTmpFmt || (!bVirtuell && nTmp > nMaxPage)) return OUString(); if( SVX_NUM_CHAR_SPECIAL == nTmpFmt ) diff --git a/sw/source/core/frmedt/fedesc.cxx b/sw/source/core/frmedt/fedesc.cxx index 23750cc3c441..32bebf49c416 100644 --- a/sw/source/core/frmedt/fedesc.cxx +++ b/sw/source/core/frmedt/fedesc.cxx @@ -65,7 +65,7 @@ void SwFEShell::ChgCurPageDesc( const SwPageDesc& rDesc ) SwPageFrm *pPage = GetCurrFrm()->FindPageFrm(); const SwFrm *pFlow = 0; - sal_uInt16 nPageNmOffset = 0; + ::boost::optional<sal_uInt16> oPageNumOffset; OSL_ENSURE( !GetCrsr()->HasMark(), "ChgCurPageDesc only without selection!"); @@ -81,7 +81,7 @@ void SwFEShell::ChgCurPageDesc( const SwPageDesc& rDesc ) if( rPgDesc.GetPageDesc() ) { // wir haben ihn den Schlingel - nPageNmOffset = rPgDesc.GetNumOffset(); + oPageNumOffset = rPgDesc.GetNumOffset(); break; } } @@ -101,7 +101,7 @@ void SwFEShell::ChgCurPageDesc( const SwPageDesc& rDesc ) // use pagenumber SwFmtPageDesc aNew( &rDesc ); - aNew.SetNumOffset( nPageNmOffset ); + aNew.SetNumOffset( oPageNumOffset ); if ( pFlow->IsInTab() ) GetDoc()->SetAttr( aNew, *(SwFmt*)pFlow->FindTabFrm()->GetFmt() ); diff --git a/sw/source/core/frmedt/fews.cxx b/sw/source/core/frmedt/fews.cxx index 8f884de47691..4d2412239fd6 100644 --- a/sw/source/core/frmedt/fews.cxx +++ b/sw/source/core/frmedt/fews.cxx @@ -427,9 +427,9 @@ sal_uInt16 SwFEShell::GetPageOffset() const { if ( pFlow->IsInTab() ) pFlow = pFlow->FindTabFrm(); - const sal_uInt16 nOffset = pFlow->GetAttrSet()->GetPageDesc().GetNumOffset(); - if ( nOffset ) - return nOffset; + ::boost::optional<sal_uInt16> oNumOffset = pFlow->GetAttrSet()->GetPageDesc().GetNumOffset(); + if ( oNumOffset ) + return oNumOffset.get(); } pPage = (SwPageFrm*)pPage->GetPrev(); } diff --git a/sw/source/core/layout/atrfrm.cxx b/sw/source/core/layout/atrfrm.cxx index 843395964c1a..e5b1ac662139 100644 --- a/sw/source/core/layout/atrfrm.cxx +++ b/sw/source/core/layout/atrfrm.cxx @@ -550,7 +550,7 @@ SfxPoolItem* SwFmtCntnt::Clone( SfxItemPool* ) const SwFmtPageDesc::SwFmtPageDesc( const SwFmtPageDesc &rCpy ) : SfxPoolItem( RES_PAGEDESC ), SwClient( (SwPageDesc*)rCpy.GetPageDesc() ), - nNumOffset( rCpy.nNumOffset ), + oNumOffset( rCpy.oNumOffset ), nDescNameIdx( rCpy.nDescNameIdx ), pDefinedIn( 0 ) { @@ -559,7 +559,7 @@ SwFmtPageDesc::SwFmtPageDesc( const SwFmtPageDesc &rCpy ) SwFmtPageDesc::SwFmtPageDesc( const SwPageDesc *pDesc ) : SfxPoolItem( RES_PAGEDESC ), SwClient( (SwPageDesc*)pDesc ), - nNumOffset( 0 ), + oNumOffset( boost::none ), nDescNameIdx( 0xFFFF ), // IDX_NO_VALUE pDefinedIn( 0 ) { @@ -569,7 +569,7 @@ SwFmtPageDesc &SwFmtPageDesc::operator=(const SwFmtPageDesc &rCpy) { if (rCpy.GetPageDesc()) RegisterToPageDesc(*const_cast<SwPageDesc*>(rCpy.GetPageDesc())); - nNumOffset = rCpy.nNumOffset; + oNumOffset = rCpy.oNumOffset; nDescNameIdx = rCpy.nDescNameIdx; pDefinedIn = 0; @@ -587,7 +587,7 @@ int SwFmtPageDesc::operator==( const SfxPoolItem& rAttr ) const { OSL_ENSURE( SfxPoolItem::operator==( rAttr ), "keine gleichen Attribute" ); return ( pDefinedIn == ((SwFmtPageDesc&)rAttr).pDefinedIn ) && - ( nNumOffset == ((SwFmtPageDesc&)rAttr).nNumOffset ) && + ( oNumOffset == ((SwFmtPageDesc&)rAttr).oNumOffset ) && ( GetPageDesc() == ((SwFmtPageDesc&)rAttr).GetPageDesc() ); } @@ -668,7 +668,17 @@ bool SwFmtPageDesc::QueryValue( uno::Any& rVal, sal_uInt8 nMemberId ) const switch ( nMemberId ) { case MID_PAGEDESC_PAGENUMOFFSET: - rVal <<= (sal_Int16)GetNumOffset(); + { + ::boost::optional<sal_uInt16> oOffset = GetNumOffset(); + if (oOffset) + { + rVal <<= (sal_Int16)oOffset.get(); + } + else + { + rVal.clear(); + } + } break; case MID_PAGEDESC_PAGEDESCNAME: diff --git a/sw/source/core/layout/flowfrm.cxx b/sw/source/core/layout/flowfrm.cxx index e54c17c87ee4..68f94648a9ea 100644 --- a/sw/source/core/layout/flowfrm.cxx +++ b/sw/source/core/layout/flowfrm.cxx @@ -897,7 +897,7 @@ sal_Bool SwFrm::WrongPageDesc( SwPageFrm* pNew ) else if( !pDesc->GetLeftFmt() ) nTmp = 1; else if( rFmtDesc.GetNumOffset() ) - nTmp = rFmtDesc.GetNumOffset(); + nTmp = rFmtDesc.GetNumOffset().get(); } } diff --git a/sw/source/core/layout/laycache.cxx b/sw/source/core/layout/laycache.cxx index ebd9e722aa2e..5a525763ade3 100644 --- a/sw/source/core/layout/laycache.cxx +++ b/sw/source/core/layout/laycache.cxx @@ -621,17 +621,25 @@ bool SwLayHelper::CheckInsertPage() if ( bBrk || pDesc ) { - sal_uInt16 nPgNum = 0; + ::boost::optional<sal_uInt16> oPgNum; if ( !pDesc ) + { pDesc = rpPage->GetPageDesc()->GetFollow(); + + SwFmtPageDesc rFollowDesc( pDesc ); + oPgNum = rFollowDesc.GetNumOffset(); + if ( oPgNum ) + ((SwRootFrm*)rpPage->GetUpper())->SetVirtPageNum(sal_True); + } else { - if ( 0 != (nPgNum = rDesc.GetNumOffset()) ) + oPgNum = rDesc.GetNumOffset(); + if ( oPgNum ) ((SwRootFrm*)rpPage->GetUpper())->SetVirtPageNum(sal_True); } bool bNextPageOdd = !rpPage->OnRightPage(); bool bInsertEmpty = false; - if( nPgNum && bNextPageOdd != ( ( nPgNum % 2 ) != 0 ) ) + if( oPgNum && bNextPageOdd != ( ( oPgNum.get() % 2 ) != 0 ) ) { bNextPageOdd = !bNextPageOdd; bInsertEmpty = true; diff --git a/sw/source/core/layout/newfrm.cxx b/sw/source/core/layout/newfrm.cxx index c246dbb44b4b..960fec7cd494 100644 --- a/sw/source/core/layout/newfrm.cxx +++ b/sw/source/core/layout/newfrm.cxx @@ -524,28 +524,32 @@ void SwRootFrm::Init( SwFrmFmt* pFmt ) // Get hold of PageDesc (either via FrmFmt of the first node or the initial one). SwPageDesc *pDesc = 0; - sal_uInt16 nPgNum = 1; + ::boost::optional<sal_uInt16> oPgNum; if ( pTblNd ) { const SwFmtPageDesc &rDesc = pTblNd->GetTable().GetFrmFmt()->GetPageDesc(); pDesc = (SwPageDesc*)rDesc.GetPageDesc(); //#19104# respect the page number offset!! - bIsVirtPageNum = 0 != ( nPgNum = rDesc.GetNumOffset() ); + oPgNum = rDesc.GetNumOffset(); + if (oPgNum) + bIsVirtPageNum = true; } else if ( pNode ) { const SwFmtPageDesc &rDesc = pNode->GetSwAttrSet().GetPageDesc(); pDesc = (SwPageDesc*)rDesc.GetPageDesc(); //#19104# respect the page number offset!! - bIsVirtPageNum = 0 != ( nPgNum = rDesc.GetNumOffset() ); + oPgNum = rDesc.GetNumOffset(); + if (oPgNum) + bIsVirtPageNum = true; } else bIsVirtPageNum = sal_False; if ( !pDesc ) pDesc = &pDoc->GetPageDesc( 0 ); - const bool bOdd = !nPgNum || 0 != ( nPgNum % 2 ); - bool bFirst = !nPgNum || 1 == nPgNum; + const bool bOdd = !oPgNum || 0 != ( oPgNum.get() % 2 ); + bool bFirst = !oPgNum || 1 == oPgNum.get(); // Create a page and put it in the layout SwPageFrm *pPage = ::InsertNewPage( *pDesc, this, bOdd, bFirst, false, sal_False, 0 ); diff --git a/sw/source/core/layout/pagechg.cxx b/sw/source/core/layout/pagechg.cxx index a231fd1496b9..533b2fb0ed64 100644 --- a/sw/source/core/layout/pagechg.cxx +++ b/sw/source/core/layout/pagechg.cxx @@ -1277,7 +1277,8 @@ SwPageFrm *SwFrm::InsertPage( SwPageFrm *pPrevPage, sal_Bool bFtn ) pDesc = rDesc.GetPageDesc(); if ( rDesc.GetNumOffset() ) { - bWishedOdd = rDesc.GetNumOffset() % 2 ? true : false; + ::boost::optional<sal_uInt16> oNumOffset = rDesc.GetNumOffset(); + bWishedOdd = (oNumOffset ? oNumOffset.get() : 0) % 2 ? true : false; //Die Gelegenheit nutzen wir um das Flag an der Root zu pflegen. pRoot->SetVirtPageNum( sal_True ); } diff --git a/sw/source/core/layout/trvlfrm.cxx b/sw/source/core/layout/trvlfrm.cxx index 9b9205eb1532..14eb6459c57f 100644 --- a/sw/source/core/layout/trvlfrm.cxx +++ b/sw/source/core/layout/trvlfrm.cxx @@ -1731,7 +1731,7 @@ sal_Bool SwFrm::WannaRightPage() const const SwFrm *pFlow = pPage->FindFirstBodyCntnt(); const SwPageDesc *pDesc = 0; - sal_uInt16 nPgNum = 0; + ::boost::optional<sal_uInt16> oPgNum; if ( pFlow ) { if ( pFlow->IsInTab() ) @@ -1741,7 +1741,7 @@ sal_Bool SwFrm::WannaRightPage() const { const SwFmtPageDesc& rPgDesc = pFlow->GetAttrSet()->GetPageDesc(); pDesc = rPgDesc.GetPageDesc(); - nPgNum = rPgDesc.GetNumOffset(); + oPgNum = rPgDesc.GetNumOffset(); } } if ( !pDesc ) @@ -1759,8 +1759,8 @@ sal_Bool SwFrm::WannaRightPage() const } OSL_ENSURE( pDesc, "No pagedescriptor" ); sal_Bool bOdd; - if( nPgNum ) - bOdd = (nPgNum % 2) ? sal_True : sal_False; + if( oPgNum ) + bOdd = (oPgNum.get() % 2) ? sal_True : sal_False; else { bOdd = pPage->OnRightPage(); @@ -1839,8 +1839,17 @@ sal_uInt16 SwFrm::GetVirtPageNum() const } } if ( pFrm ) - return nPhyPage - pFrm->GetPhyPageNum() + - pFrm->GetAttrSet()->GetPageDesc().GetNumOffset(); + { + ::boost::optional<sal_uInt16> oNumOffset = pFrm->GetAttrSet()->GetPageDesc().GetNumOffset(); + if (oNumOffset) + { + return nPhyPage - pFrm->GetPhyPageNum() + oNumOffset.get(); + } + else + { + return nPhyPage - pFrm->GetPhyPageNum(); + } + } return nPhyPage; } diff --git a/sw/source/filter/ww8/attributeoutputbase.hxx b/sw/source/filter/ww8/attributeoutputbase.hxx index a528d28cb034..75e847aa9fc6 100644 --- a/sw/source/filter/ww8/attributeoutputbase.hxx +++ b/sw/source/filter/ww8/attributeoutputbase.hxx @@ -26,6 +26,7 @@ #include <rtl/textenc.h> #include <editeng/svxenum.hxx> #include <tools/solar.h> +#include <boost/optional.hpp> #include <swtypes.hxx> #include <wrtswtbl.hxx> @@ -315,8 +316,7 @@ public: /// The style of the page numbers. /// - /// nPageRestartNumberr being 0 means no restart. - virtual void SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber ) = 0; + virtual void SectionPageNumbering( sal_uInt16 nNumType, ::boost::optional<sal_uInt16> oPageRestartNumber ) = 0; /// The type of breaking. virtual void SectionType( sal_uInt8 nBreakCode ) = 0; diff --git a/sw/source/filter/ww8/docxattributeoutput.cxx b/sw/source/filter/ww8/docxattributeoutput.cxx index 53f15b293e78..f010a7c232ed 100644 --- a/sw/source/filter/ww8/docxattributeoutput.cxx +++ b/sw/source/filter/ww8/docxattributeoutput.cxx @@ -3905,15 +3905,15 @@ static OString impl_NumberingType( sal_uInt16 nNumberingType ) return aType; } -void DocxAttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber ) +void DocxAttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, ::boost::optional<sal_uInt16> oPageRestartNumber ) { // FIXME Not called properly with page styles like "First Page" FastAttributeList* pAttr = m_pSerializer->createAttrList(); - // 0 means no restart: then don't output that attribute if 0 - if ( nPageRestartNumber > 0 ) - pAttr->add( FSNS( XML_w, XML_start ), OString::number( nPageRestartNumber ) ); + // -1 means no restart: then don't output that attribute if it is negative + if ( oPageRestartNumber ) + pAttr->add( FSNS( XML_w, XML_start ), OString::number( oPageRestartNumber.get() ) ); // nNumType corresponds to w:fmt. See WW8Export::GetNumId() for more precisions OString aFmt( impl_NumberingType( nNumType ) ); diff --git a/sw/source/filter/ww8/docxattributeoutput.hxx b/sw/source/filter/ww8/docxattributeoutput.hxx index 29dec70b1972..5e8f90f2d180 100644 --- a/sw/source/filter/ww8/docxattributeoutput.hxx +++ b/sw/source/filter/ww8/docxattributeoutput.hxx @@ -272,8 +272,7 @@ public: /// The style of the page numbers. /// - /// nPageRestartNumberr being 0 means no restart. - virtual void SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber ); + virtual void SectionPageNumbering( sal_uInt16 nNumType, ::boost::optional<sal_uInt16> oPageRestartNumber ); /// The type of breaking. virtual void SectionType( sal_uInt8 nBreakCode ); diff --git a/sw/source/filter/ww8/rtfattributeoutput.cxx b/sw/source/filter/ww8/rtfattributeoutput.cxx index a0ce1d7ba6d1..1b466e6a9f42 100644 --- a/sw/source/filter/ww8/rtfattributeoutput.cxx +++ b/sw/source/filter/ww8/rtfattributeoutput.cxx @@ -1233,14 +1233,14 @@ void RtfAttributeOutput::SectionBiDi( bool bBiDi ) m_rExport.Strm() << (bBiDi ? OOO_STRING_SVTOOLS_RTF_RTLSECT : OOO_STRING_SVTOOLS_RTF_LTRSECT); } -void RtfAttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber ) +void RtfAttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, ::boost::optional<sal_uInt16> oPageRestartNumber ) { SAL_INFO("sw.rtf", OSL_THIS_FUNC); - if (nPageRestartNumber > 0) + if ( oPageRestartNumber ) { m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_PGNSTARTS); - m_aSectionBreaks.append((sal_Int32)nPageRestartNumber); + m_aSectionBreaks.append((sal_Int32)oPageRestartNumber.get()); m_aSectionBreaks.append(OOO_STRING_SVTOOLS_RTF_PGNRESTART); } diff --git a/sw/source/filter/ww8/rtfattributeoutput.hxx b/sw/source/filter/ww8/rtfattributeoutput.hxx index 0ec6cbff643a..5bbded266556 100644 --- a/sw/source/filter/ww8/rtfattributeoutput.hxx +++ b/sw/source/filter/ww8/rtfattributeoutput.hxx @@ -181,8 +181,7 @@ public: /// The style of the page numbers. /// - /// nPageRestartNumberr being 0 means no restart. - virtual void SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber ); + virtual void SectionPageNumbering( sal_uInt16 nNumType, ::boost::optional<sal_uInt16> oPageRestartNumber ); /// The type of breaking. virtual void SectionType( sal_uInt8 nBreakCode ); diff --git a/sw/source/filter/ww8/rtfexport.cxx b/sw/source/filter/ww8/rtfexport.cxx index 58e6bc79be0a..92f0d0214b46 100644 --- a/sw/source/filter/ww8/rtfexport.cxx +++ b/sw/source/filter/ww8/rtfexport.cxx @@ -1112,7 +1112,7 @@ void RtfExport::OutPageDescription( const SwPageDesc& rPgDsc, bool bWriteReset, } // numbering type - AttrOutput().SectionPageNumbering(pAktPageDesc->GetNumType().GetNumberingType(), 0); + AttrOutput().SectionPageNumbering(pAktPageDesc->GetNumType().GetNumberingType(), boost::none); pAktPageDesc = pSave; SAL_INFO("sw.rtf", OSL_THIS_FUNC << " end"); diff --git a/sw/source/filter/ww8/wrtw8sty.cxx b/sw/source/filter/ww8/wrtw8sty.cxx index 8d40b97c23f2..ede643bd7c0d 100644 --- a/sw/source/filter/ww8/wrtw8sty.cxx +++ b/sw/source/filter/ww8/wrtw8sty.cxx @@ -1177,8 +1177,9 @@ void MSWordSections::AppendSection( const SwFmtPageDesc& rPD, if (HeaderFooterWritten()) { return; // #i117955# prevent new sections in endnotes } - WW8_SepInfo aI( rPD.GetPageDesc(), pSectionFmt, nLnNumRestartNo, - rPD.GetNumOffset(), &rNd ); + + WW8_SepInfo aI( rPD.GetPageDesc(), pSectionFmt, nLnNumRestartNo, rPD.GetNumOffset(), &rNd ); + aSects.push_back( aI ); NeedsDocumentProtected( aI ); } @@ -1502,7 +1503,7 @@ void WW8AttributeOutput::SectionBiDi( bool bBiDi ) } } -void WW8AttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber ) +void WW8AttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, ::boost::optional<sal_uInt16> oPageRestartNumber ) { // sprmSNfcPgn sal_uInt8 nb = WW8Export::GetNumId( nNumType ); @@ -1512,7 +1513,7 @@ void WW8AttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 n m_rWW8Export.pO->push_back( 147 ); m_rWW8Export.pO->push_back( nb ); - if ( nPageRestartNumber ) + if ( oPageRestartNumber ) { // sprmSFPgnRestart if ( m_rWW8Export.bWrtWW8 ) @@ -1526,7 +1527,7 @@ void WW8AttributeOutput::SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 n SwWW8Writer::InsUInt16( *m_rWW8Export.pO, NS_sprm::LN_SPgnStart ); else m_rWW8Export.pO->push_back( 161 ); - SwWW8Writer::InsUInt16( *m_rWW8Export.pO, nPageRestartNumber ); + SwWW8Writer::InsUInt16( *m_rWW8Export.pO, oPageRestartNumber.get() ); } } @@ -1793,7 +1794,7 @@ void MSWordExportBase::SectionProperties( const WW8_SepInfo& rSepInfo, WW8_PdAtt pISet = pOldI; // then the rest of the settings from PageDesc - AttrOutput().SectionPageNumbering( pPd->GetNumType().GetNumberingType(), rSepInfo.nPgRestartNo ); + AttrOutput().SectionPageNumbering( pPd->GetNumType().GetNumberingType(), rSepInfo.oPgRestartNo ); // werden es nur linke oder nur rechte Seiten? if ( 2 == nBreakCode ) diff --git a/sw/source/filter/ww8/wrtww8.hxx b/sw/source/filter/ww8/wrtww8.hxx index 87d2c1d91a9c..5506b4e6c071 100644 --- a/sw/source/filter/ww8/wrtww8.hxx +++ b/sw/source/filter/ww8/wrtww8.hxx @@ -23,6 +23,7 @@ #include <tools/solar.h> // UINTXX #include <tools/gen.hxx> #include <editeng/editdata.hxx> +#include <boost/optional.hpp> #include <map> #include <vector> @@ -151,17 +152,17 @@ struct WW8_SepInfo const SwNode* pPDNd; const SwTxtNode* pNumNd; sal_uLong nLnNumRestartNo; - sal_uInt16 nPgRestartNo; + ::boost::optional<sal_uInt16> oPgRestartNo; WW8_SepInfo() - : pPageDesc(0), pSectionFmt(0), pPDNd(0), pNumNd(0), nLnNumRestartNo(0), nPgRestartNo(0) + : pPageDesc(0), pSectionFmt(0), pPDNd(0), pNumNd(0), nLnNumRestartNo(0), oPgRestartNo(boost::none) {} WW8_SepInfo( const SwPageDesc* pPD, const SwSectionFmt* pFmt, - sal_uLong nLnRestart, sal_uInt16 nPgRestart = 0, const SwNode* pNd = NULL ) + sal_uLong nLnRestart, ::boost::optional<sal_uInt16> oPgRestart = boost::none, const SwNode* pNd = NULL ) : pPageDesc( pPD ), pSectionFmt( pFmt ), pPDNd( pNd ), pNumNd( 0 ), - nLnNumRestartNo( nLnRestart ), nPgRestartNo( nPgRestart ) + nLnNumRestartNo( nLnRestart ), oPgRestartNo( oPgRestart ) {} bool IsProtected() const; diff --git a/sw/source/filter/ww8/ww8attributeoutput.hxx b/sw/source/filter/ww8/ww8attributeoutput.hxx index d1f4c9b89a54..81691cb508f7 100644 --- a/sw/source/filter/ww8/ww8attributeoutput.hxx +++ b/sw/source/filter/ww8/ww8attributeoutput.hxx @@ -169,8 +169,7 @@ public: /// The style of the page numbers. /// - /// nPageRestartNumberr being 0 means no restart. - virtual void SectionPageNumbering( sal_uInt16 nNumType, sal_uInt16 nPageRestartNumber ); + virtual void SectionPageNumbering( sal_uInt16 nNumType, ::boost::optional<sal_uInt16> oPageRestartNumber ); /// The type of breaking. virtual void SectionType( sal_uInt8 nBreakCode ); diff --git a/sw/source/filter/xml/xmlexpit.cxx b/sw/source/filter/xml/xmlexpit.cxx index c6c5e3a41e02..c215a7bb93a7 100644 --- a/sw/source/filter/xml/xmlexpit.cxx +++ b/sw/source/filter/xml/xmlexpit.cxx @@ -1004,14 +1004,16 @@ bool SvXMLExportItemMapper::QueryXMLValue( if( MID_PAGEDESC_PAGENUMOFFSET==nMemberId ) { - sal_Int32 const number(pPageDesc->GetNumOffset()); - if (0 >= number) + ::boost::optional<sal_uInt16> oNumOffset = pPageDesc->GetNumOffset(); + if (oNumOffset) { - aOut.append(GetXMLToken(XML_AUTO)); + // #i114163# positiveInteger only! + sal_Int32 const number(oNumOffset.get()); + ::sax::Converter::convertNumber(aOut, number); } - else // #i114163# positiveInteger only! + else { - ::sax::Converter::convertNumber(aOut, number); + aOut.append(GetXMLToken(XML_AUTO)); } bOk = true; } diff --git a/sw/source/ui/app/appenv.cxx b/sw/source/ui/app/appenv.cxx index 76a37ca4cb97..63b614a6637a 100644 --- a/sw/source/ui/app/appenv.cxx +++ b/sw/source/ui/app/appenv.cxx @@ -302,7 +302,7 @@ void SwModule::InsertEnv( SfxRequest& rReq ) pSh->SetTblAttr( aBreakSet ); } else - pSh->InsertPageBreak(0, sal_False); + pSh->InsertPageBreak(0, boost::none); pSh->SttEndDoc(sal_True); } else diff --git a/sw/source/ui/chrdlg/break.cxx b/sw/source/ui/chrdlg/break.cxx index fb0cd627366d..37fa66cdb384 100644 --- a/sw/source/ui/chrdlg/break.cxx +++ b/sw/source/ui/chrdlg/break.cxx @@ -49,7 +49,11 @@ void SwBreakDlg::Apply() if(0 != nPos && LISTBOX_ENTRY_NOTFOUND != nPos) { aTemplate = m_pPageCollBox->GetSelectEntry(); - nPgNum = m_pPageNumBox->IsChecked() ? (sal_uInt16)m_pPageNumEdit->GetValue() : 0; + oPgNum = boost::none; + if (m_pPageNumBox->IsChecked()) + { + oPgNum = (sal_uInt16)m_pPageNumEdit->GetValue(); + } } } } @@ -129,7 +133,7 @@ SwBreakDlg::SwBreakDlg( Window *pParent, SwWrtShell &rS ) : SvxStandardDialog(pParent, "BreakDialog", "modules/swriter/ui/insertbreak.ui") , rSh(rS) , nKind(0) - , nPgNum(0) + , oPgNum(boost::none) , bHtmlMode(0 != ::GetHtmlMode(rS.GetView().GetDocShell())) { get(m_pLineBtn, "linerb"); diff --git a/sw/source/ui/dialog/swdlgfact.cxx b/sw/source/ui/dialog/swdlgfact.cxx index 32a4b9a26cb9..bfd44dddbf40 100644 --- a/sw/source/ui/dialog/swdlgfact.cxx +++ b/sw/source/ui/dialog/swdlgfact.cxx @@ -218,7 +218,7 @@ sal_uInt16 AbstractSwBreakDlg_Impl:: GetKind() return pDlg->GetKind(); } -sal_uInt16 AbstractSwBreakDlg_Impl:: GetPageNumber() +::boost::optional<sal_uInt16> AbstractSwBreakDlg_Impl:: GetPageNumber() { return pDlg->GetPageNumber(); } diff --git a/sw/source/ui/dialog/swdlgfact.hxx b/sw/source/ui/dialog/swdlgfact.hxx index 8f3dd7290ade..fc80b86a4af8 100644 --- a/sw/source/ui/dialog/swdlgfact.hxx +++ b/sw/source/ui/dialog/swdlgfact.hxx @@ -40,6 +40,8 @@ class SwSplitTblDlg; #include "itabenum.hxx" +#include <boost/optional.hpp> + namespace sw { class DropDownFieldDialog; @@ -105,9 +107,9 @@ class VclAbstractDialog_Impl : public VclAbstractDialog class AbstractSwBreakDlg_Impl : public AbstractSwBreakDlg { DECL_ABSTDLG_BASE(AbstractSwBreakDlg_Impl,SwBreakDlg) - virtual OUString GetTemplateName(); - virtual sal_uInt16 GetKind(); - virtual sal_uInt16 GetPageNumber(); + virtual OUString GetTemplateName(); + virtual sal_uInt16 GetKind(); + virtual ::boost::optional<sal_uInt16> GetPageNumber(); }; class AbstractSplitTableDialog_Impl : public AbstractSplitTableDialog // add for diff --git a/sw/source/ui/inc/break.hxx b/sw/source/ui/inc/break.hxx index 9c427853ebaa..98b0db845bb0 100644 --- a/sw/source/ui/inc/break.hxx +++ b/sw/source/ui/inc/break.hxx @@ -1,3 +1,4 @@ + /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. @@ -29,6 +30,8 @@ #include <vcl/field.hxx> +#include <boost/optional.hpp> + class SwWrtShell; class SwBreakDlg: public SvxStandardDialog @@ -44,7 +47,7 @@ class SwBreakDlg: public SvxStandardDialog OUString aTemplate; sal_uInt16 nKind; - sal_uInt16 nPgNum; + ::boost::optional<sal_uInt16> oPgNum; sal_Bool bHtmlMode; @@ -64,7 +67,7 @@ public: OUString GetTemplateName() { return aTemplate; } sal_uInt16 GetKind() { return nKind; } - sal_uInt16 GetPageNumber() { return nPgNum; } + ::boost::optional<sal_uInt16> GetPageNumber() { return oPgNum; } }; #endif diff --git a/sw/source/ui/inc/wrtsh.hxx b/sw/source/ui/inc/wrtsh.hxx index 3c6f7a373821..31d4f55cffd8 100644 --- a/sw/source/ui/inc/wrtsh.hxx +++ b/sw/source/ui/inc/wrtsh.hxx @@ -26,6 +26,7 @@ #include <swurl.hxx> #include <IMark.hxx> #include "navmgr.hxx" +#include <boost/optional.hpp> class Window; class SbxArray; @@ -294,7 +295,7 @@ typedef sal_Bool (SwWrtShell:: *FNSimpleMove)(); sal_Bool bRule = sal_False ); void InsertByWord( const OUString & ); - void InsertPageBreak(const OUString *pPageDesc = 0, sal_uInt16 nPgNum = 0 ); + void InsertPageBreak(const OUString *pPageDesc = 0, ::boost::optional<sal_uInt16> pPgNum = boost::none ); void InsertLineBreak(); void InsertColumnBreak(); void InsertFootnote(const OUString &, sal_Bool bEndNote = sal_False, sal_Bool bEdit = sal_True ); diff --git a/sw/source/ui/misc/titlepage.cxx b/sw/source/ui/misc/titlepage.cxx index bf75f3faecc7..21f3b51a99b9 100644 --- a/sw/source/ui/misc/titlepage.cxx +++ b/sw/source/ui/misc/titlepage.cxx @@ -38,7 +38,9 @@ namespace const SfxPoolItem* pItem(0); if (SFX_ITEM_SET == aSet.GetItemState( RES_PAGEDESC, sal_True, &pItem ) && pItem) { - rPageNo = ((const SwFmtPageDesc *)pItem)->GetNumOffset(); + ::boost::optional<sal_uInt16> oNumOffset = ((const SwFmtPageDesc *)pItem)->GetNumOffset(); + if (oNumOffset) + rPageNo = oNumOffset.get(); if (ppPageFmtDesc) (*ppPageFmtDesc) = (const SwFmtPageDesc *)(pItem->Clone()); bRet = true; @@ -58,8 +60,30 @@ namespace lcl_GetPageDesc(pSh, nDontCare, &pPageFmtDesc); //If we want a new number then set it, otherwise reuse the existing one - sal_uInt16 nPgNo = nNewNumber ? - nNewNumber : ( pPageFmtDesc ? pPageFmtDesc->GetNumOffset() : 0 ); + sal_uInt16 nPgNo; + if (nNewNumber) + { + nPgNo = nNewNumber; + } + else + { + if (pPageFmtDesc) + { + ::boost::optional<sal_uInt16> oNumOffset = pPageFmtDesc->GetNumOffset(); + if (oNumOffset) + { + nPgNo = oNumOffset.get(); + } + else + { + nPgNo = 0; + } + } + else + { + nPgNo = 0; + } + } //If we want a new descriptior then set it, otherwise reuse the existing one if (!pNewDesc) diff --git a/sw/source/ui/shells/textsh1.cxx b/sw/source/ui/shells/textsh1.cxx index d0b2fbce227e..5f7e8ae93fe7 100644 --- a/sw/source/ui/shells/textsh1.cxx +++ b/sw/source/ui/shells/textsh1.cxx @@ -525,17 +525,19 @@ void SwTextShell::Execute(SfxRequest &rReq) } case FN_INSERT_BREAK_DLG: { - sal_uInt16 nKind=0, nPageNumber=0; + sal_uInt16 nKind=0; + ::boost::optional<sal_uInt16> oPageNumber; OUString aTemplateName; if ( pItem ) { nKind = ((SfxInt16Item*)pItem)->GetValue(); SFX_REQUEST_ARG( rReq, pTemplate, SfxStringItem, FN_PARAM_1 , sal_False ); SFX_REQUEST_ARG( rReq, pNumber, SfxUInt16Item, FN_PARAM_2 , sal_False ); + SFX_REQUEST_ARG( rReq, pIsNumberFilled, SfxBoolItem, FN_PARAM_3, sal_False ); if ( pTemplate ) aTemplateName = pTemplate->GetValue(); - if ( pNumber ) - nPageNumber = pNumber->GetValue(); + if ( pNumber && pIsNumberFilled && pIsNumberFilled->GetValue() ) + oPageNumber = pNumber->GetValue(); } else { @@ -548,10 +550,21 @@ void SwTextShell::Execute(SfxRequest &rReq) { nKind = pDlg->GetKind(); aTemplateName = pDlg->GetTemplateName(); - nPageNumber = pDlg->GetPageNumber(); - rReq.AppendItem( SfxInt16Item( FN_INSERT_BREAK_DLG, nKind ) ); - rReq.AppendItem( SfxUInt16Item( FN_PARAM_2, nPageNumber ) ); + oPageNumber = pDlg->GetPageNumber(); + + sal_Bool bIsNumberFilled = sal_False; + sal_uInt16 nPageNumber = 0; + + if (oPageNumber) + { + bIsNumberFilled = sal_True; + nPageNumber = oPageNumber.get(); + } + + rReq.AppendItem( SfxInt16Item ( FN_INSERT_BREAK_DLG, nKind ) ); rReq.AppendItem( SfxStringItem( FN_PARAM_1, aTemplateName ) ); + rReq.AppendItem( SfxUInt16Item( FN_PARAM_2, nPageNumber ) ); + rReq.AppendItem( SfxBoolItem ( FN_PARAM_3, bIsNumberFilled ) ); rReq.Done(); } else @@ -569,7 +582,7 @@ void SwTextShell::Execute(SfxRequest &rReq) { rWrtSh.StartAllAction(); if( !aTemplateName.isEmpty() ) - rWrtSh.InsertPageBreak( &aTemplateName, nPageNumber ); + rWrtSh.InsertPageBreak( &aTemplateName, oPageNumber ); else rWrtSh.InsertPageBreak(); rWrtSh.EndAllAction(); diff --git a/sw/source/ui/table/tabledlg.cxx b/sw/source/ui/table/tabledlg.cxx index 41fa3dcec582..4614e2b93cdc 100644 --- a/sw/source/ui/table/tabledlg.cxx +++ b/sw/source/ui/table/tabledlg.cxx @@ -1515,7 +1515,14 @@ void SwTextFlowPage::Reset( const SfxItemSet& rSet ) { OUString sPageDesc; const SwPageDesc* pDesc = ((const SwFmtPageDesc*)pItem)->GetPageDesc(); - m_pPageNoNF->SetValue(((const SwFmtPageDesc*)pItem)->GetNumOffset()); + + //m_pPageNoNF->SetValue(((const SwFmtPageDesc*)pItem)->GetNumOffset()); + ::boost::optional<sal_uInt16> oNumOffset = ((const SwFmtPageDesc*)pItem)->GetNumOffset(); + if (oNumOffset) + m_pPageNoNF->SetValue(oNumOffset.get()); + else + m_pPageNoNF->Enable(sal_False); + if(pDesc) sPageDesc = pDesc->GetName(); if ( !sPageDesc.isEmpty() && diff --git a/sw/source/ui/utlui/uitool.cxx b/sw/source/ui/utlui/uitool.cxx index 26281cfe4c7e..e0c4a36fb1c4 100644 --- a/sw/source/ui/utlui/uitool.cxx +++ b/sw/source/ui/utlui/uitool.cxx @@ -619,7 +619,7 @@ void SwToSfxPageDescAttr( SfxItemSet& rCoreSet ) { const SfxPoolItem* pItem = 0; OUString aName; - sal_uInt16 nPageNum = 0; + ::boost::optional<sal_uInt16> oNumOffset; bool bPut = true; switch( rCoreSet.GetItemState( RES_PAGEDESC, sal_True, &pItem ) ) { @@ -628,7 +628,7 @@ void SwToSfxPageDescAttr( SfxItemSet& rCoreSet ) if( ((SwFmtPageDesc*)pItem)->GetPageDesc() ) { aName = ((SwFmtPageDesc*)pItem)->GetPageDesc()->GetName(); - nPageNum = ((SwFmtPageDesc*)pItem)->GetNumOffset(); + oNumOffset = ((SwFmtPageDesc*)pItem)->GetNumOffset(); } rCoreSet.ClearItem( RES_PAGEDESC ); // Page number @@ -641,8 +641,12 @@ void SwToSfxPageDescAttr( SfxItemSet& rCoreSet ) default: bPut = false; } - SfxUInt16Item aPageNum( SID_ATTR_PARA_PAGENUM, nPageNum ); - rCoreSet.Put( aPageNum ); + + if (oNumOffset) + { + SfxUInt16Item aPageNum( SID_ATTR_PARA_PAGENUM, oNumOffset.get() ); + rCoreSet.Put( aPageNum ); + } if(bPut) rCoreSet.Put( SvxPageModelItem( aName, sal_True, SID_ATTR_PARA_MODEL ) ); diff --git a/sw/source/ui/wrtsh/wrtsh1.cxx b/sw/source/ui/wrtsh/wrtsh1.cxx index e23fd4d2d2c6..8b974bda7715 100644 --- a/sw/source/ui/wrtsh/wrtsh1.cxx +++ b/sw/source/ui/wrtsh/wrtsh1.cxx @@ -824,7 +824,7 @@ void SwWrtShell::ConnectObj( svt::EmbeddedObjectRef& xObj, const SwRect &rPrt, // Insert hard page break; // Selections will be overwritten -void SwWrtShell::InsertPageBreak(const OUString *pPageDesc, sal_uInt16 nPgNum ) +void SwWrtShell::InsertPageBreak(const OUString *pPageDesc, ::boost::optional<sal_uInt16> oPgNum ) { ResetCursorStack(); if( CanInsert() ) @@ -846,7 +846,7 @@ void SwWrtShell::InsertPageBreak(const OUString *pPageDesc, sal_uInt16 nPgNum ) if( pDesc ) { SwFmtPageDesc aDesc( pDesc ); - aDesc.SetNumOffset( nPgNum ); + aDesc.SetNumOffset( oPgNum ); SetAttr( aDesc ); } else |