/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include #include #include #include #include #include #include #include using namespace ::com::sun::star; TYPEINIT1_FACTORY( SvxPageItem, SfxPoolItem , new SvxPageItem(0)); // Konstruktor SvxPageItem::SvxPageItem( const sal_uInt16 nId ) : SfxPoolItem( nId ), eNumType ( SVX_ARABIC ), bLandscape ( false ), eUse ( SVX_PAGE_ALL ) { } // Copy-Konstruktor SvxPageItem::SvxPageItem( const SvxPageItem& rItem ) : SfxPoolItem( rItem ) { eNumType = rItem.eNumType; bLandscape = rItem.bLandscape; eUse = rItem.eUse; } // Clonen SfxPoolItem* SvxPageItem::Clone( SfxItemPool * ) const { return new SvxPageItem( *this ); } // Abfrage auf Gleichheit bool SvxPageItem::operator==( const SfxPoolItem& rAttr ) const { DBG_ASSERT( SfxPoolItem::operator==(rAttr), "unequal types" ); const SvxPageItem& rItem = static_cast(rAttr); return ( eNumType == rItem.eNumType && bLandscape == rItem.bLandscape && eUse == rItem.eUse ); } inline OUString GetUsageText( const sal_uInt16 eU ) { switch( eU & 0x000f ) { case SVX_PAGE_LEFT : return SVX_RESSTR(RID_SVXITEMS_PAGE_USAGE_LEFT); case SVX_PAGE_RIGHT : return SVX_RESSTR(RID_SVXITEMS_PAGE_USAGE_RIGHT); case SVX_PAGE_ALL : return SVX_RESSTR(RID_SVXITEMS_PAGE_USAGE_ALL); case SVX_PAGE_MIRROR: return SVX_RESSTR(RID_SVXITEMS_PAGE_USAGE_MIRROR); default: return OUString(); } } bool SvxPageItem::GetPresentation ( SfxItemPresentation ePres, SfxMapUnit /*eCoreUnit*/, SfxMapUnit /*ePresUnit*/, OUString& rText, const IntlWrapper * ) const { rText.clear(); OUString cpDelimTmp = OUString(cpDelim); switch ( ePres ) { case SFX_ITEM_PRESENTATION_NAMELESS: { if ( !aDescName.isEmpty() ) { rText = aDescName + cpDelimTmp; } DBG_ASSERT( eNumType <= SVX_NUMBER_NONE, "enum overflow" ); rText += SVX_RESSTR(RID_SVXITEMS_PAGE_NUM_BEGIN + eNumType) + cpDelimTmp; if ( bLandscape ) rText += SVX_RESSTR(RID_SVXITEMS_PAGE_LAND_TRUE); else rText += SVX_RESSTR(RID_SVXITEMS_PAGE_LAND_FALSE); OUString aUsageText = GetUsageText( eUse ); if (!aUsageText.isEmpty()) { rText += cpDelimTmp + aUsageText; } return true; } case SFX_ITEM_PRESENTATION_COMPLETE: { rText += SVX_RESSTR(RID_SVXITEMS_PAGE_COMPLETE); if ( !aDescName.isEmpty() ) { rText += aDescName + cpDelimTmp; } DBG_ASSERT( eNumType <= SVX_NUMBER_NONE, "enum overflow" ); rText += SVX_RESSTR(RID_SVXITEMS_PAGE_NUM_BEGIN + eNumType) + cpDelimTmp; if ( bLandscape ) rText += SVX_RESSTR(RID_SVXITEMS_PAGE_LAND_TRUE); else rText += SVX_RESSTR(RID_SVXITEMS_PAGE_LAND_FALSE); OUString aUsageText = GetUsageText( eUse ); if (!aUsageText.isEmpty()) { rText += cpDelimTmp + aUsageText; } return true; } default: ;//prevent warning } return false; } bool SvxPageItem::QueryValue( uno::Any& rVal, sal_uInt8 nMemberId ) const { // sal_Bool bConvert = 0!=(nMemberId&CONVERT_TWIPS); nMemberId &= ~CONVERT_TWIPS; switch( nMemberId ) { case MID_PAGE_NUMTYPE: { //! die Konstanten sind nicht mehr in den IDLs ?!? rVal <<= (sal_Int16)( eNumType ); } break; case MID_PAGE_ORIENTATION: //Landscape= sal_True rVal = Bool2Any(bLandscape); break; case MID_PAGE_LAYOUT : { style::PageStyleLayout eRet; switch(eUse & 0x0f) { case SVX_PAGE_LEFT : eRet = style::PageStyleLayout_LEFT; break; case SVX_PAGE_RIGHT : eRet = style::PageStyleLayout_RIGHT; break; case SVX_PAGE_ALL : eRet = style::PageStyleLayout_ALL; break; case SVX_PAGE_MIRROR: eRet = style::PageStyleLayout_MIRRORED; break; default: OSL_FAIL("was fuer ein Layout ist das?"); return false; } rVal <<= eRet; } break; } return true; } bool SvxPageItem::PutValue( const uno::Any& rVal, sal_uInt8 nMemberId ) { switch( nMemberId ) { case MID_PAGE_NUMTYPE: { sal_Int32 nValue = 0; if(!(rVal >>= nValue)) return false; eNumType = (SvxNumType)nValue; } break; case MID_PAGE_ORIENTATION: bLandscape = Any2Bool(rVal); break; case MID_PAGE_LAYOUT : { style::PageStyleLayout eLayout; if(!(rVal >>= eLayout)) { sal_Int32 nValue = 0; if(!(rVal >>= nValue)) return false; eLayout = (style::PageStyleLayout)nValue; } eUse &= 0xfff0; switch( eLayout ) { case style::PageStyleLayout_LEFT : eUse |= SVX_PAGE_LEFT ; break; case style::PageStyleLayout_RIGHT : eUse |= SVX_PAGE_RIGHT; break; case style::PageStyleLayout_ALL : eUse |= SVX_PAGE_ALL ; break; case style::PageStyleLayout_MIRRORED: eUse |= SVX_PAGE_MIRROR;break; default: ;//prevent warning } } break; } return true; } SfxPoolItem* SvxPageItem::Create( SvStream& rStream, sal_uInt16 ) const { sal_uInt8 eType; bool bLand; sal_uInt16 nUse; // UNICODE: rStream >> sStr; OUString sStr = rStream.ReadUniOrByteString( rStream.GetStreamCharSet() ); rStream.ReadUChar( eType ); rStream.ReadCharAsBool( bLand ); rStream.ReadUInt16( nUse ); SvxPageItem* pPage = new SvxPageItem( Which() ); pPage->SetDescName( sStr ); pPage->SetNumType( (SvxNumType)eType ); pPage->SetLandscape( bLand ); pPage->SetPageUsage( nUse ); return pPage; } SvStream& SvxPageItem::Store( SvStream &rStrm, sal_uInt16 /*nItemVersion*/ ) const { // UNICODE: rStrm << aDescName; rStrm.WriteUniOrByteString(aDescName, rStrm.GetStreamCharSet()); rStrm.WriteUChar( eNumType ).WriteUChar( bLandscape ).WriteUInt16( eUse ); return rStrm; } // HeaderFooterSet SvxSetItem::SvxSetItem( const sal_uInt16 nId, const SfxItemSet& rSet ) : SfxSetItem( nId, rSet ) { } SvxSetItem::SvxSetItem( const SvxSetItem& rItem ) : SfxSetItem( rItem ) { } SvxSetItem::SvxSetItem( const sal_uInt16 nId, SfxItemSet* _pSet ) : SfxSetItem( nId, _pSet ) { } SfxPoolItem* SvxSetItem::Clone( SfxItemPool * ) const { return new SvxSetItem(*this); } bool SvxSetItem::GetPresentation ( SfxItemPresentation /*ePres*/, SfxMapUnit /*eCoreUnit*/, SfxMapUnit /*ePresUnit*/, OUString& rText, const IntlWrapper * ) const { rText.clear(); return false; } SfxPoolItem* SvxSetItem::Create(SvStream &rStrm, sal_uInt16 /*nVersion*/) const { SfxItemSet* _pSet = new SfxItemSet( *GetItemSet().GetPool(), GetItemSet().GetRanges() ); _pSet->Load( rStrm ); return new SvxSetItem( Which(), *_pSet ); } SvStream& SvxSetItem::Store(SvStream &rStrm, sal_uInt16 nItemVersion) const { GetItemSet().Store( rStrm, nItemVersion ); return rStrm; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */