/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #include #include #include #include DBG_NAME( Hatch ) // -------------- // - ImplHatch - // -------------- ImplHatch::ImplHatch() : mnRefCount ( 1 ), maColor ( COL_BLACK ), meStyle ( HATCH_SINGLE ), mnDistance ( 1 ), mnAngle ( 0 ) { } // ----------------------------------------------------------------------- ImplHatch::ImplHatch( const ImplHatch& rImplHatch ) : mnRefCount ( 1 ), maColor ( rImplHatch.maColor ), meStyle ( rImplHatch.meStyle ), mnDistance ( rImplHatch.mnDistance ), mnAngle ( rImplHatch.mnAngle ) { } // --------- // - Hatch - // --------- Hatch::Hatch() { DBG_CTOR( Hatch, NULL ); mpImplHatch = new ImplHatch; } // ----------------------------------------------------------------------- Hatch::Hatch( const Hatch& rHatch ) { DBG_CTOR( Hatch, NULL ); DBG_CHKOBJ( &rHatch, Hatch, NULL ); mpImplHatch = rHatch.mpImplHatch; mpImplHatch->mnRefCount++; } // ----------------------------------------------------------------------- Hatch::Hatch( HatchStyle eStyle, const Color& rColor, long nDistance, sal_uInt16 nAngle10 ) { DBG_CTOR( Hatch, NULL ); mpImplHatch = new ImplHatch; mpImplHatch->maColor = rColor; mpImplHatch->meStyle = eStyle; mpImplHatch->mnDistance = nDistance; mpImplHatch->mnAngle = nAngle10; } // ----------------------------------------------------------------------- Hatch::~Hatch() { DBG_DTOR( Hatch, NULL ); if( !( --mpImplHatch->mnRefCount ) ) delete mpImplHatch; } // ----------------------------------------------------------------------- Hatch& Hatch::operator=( const Hatch& rHatch ) { DBG_CHKTHIS( Hatch, NULL ); DBG_CHKOBJ( &rHatch, Hatch, NULL ); rHatch.mpImplHatch->mnRefCount++; if( !( --mpImplHatch->mnRefCount ) ) delete mpImplHatch; mpImplHatch = rHatch.mpImplHatch; return *this; } // ----------------------------------------------------------------------- sal_Bool Hatch::operator==( const Hatch& rHatch ) const { DBG_CHKTHIS( Hatch, NULL ); DBG_CHKOBJ( &rHatch, Hatch, NULL ); return( mpImplHatch == rHatch.mpImplHatch || ( mpImplHatch->maColor == rHatch.mpImplHatch->maColor && mpImplHatch->meStyle == rHatch.mpImplHatch->meStyle && mpImplHatch->mnDistance == rHatch.mpImplHatch->mnDistance && mpImplHatch->mnAngle == rHatch.mpImplHatch->mnAngle ) ); } // ----------------------------------------------------------------------- void Hatch::ImplMakeUnique() { if( mpImplHatch->mnRefCount != 1 ) { if( mpImplHatch->mnRefCount ) mpImplHatch->mnRefCount--; mpImplHatch = new ImplHatch( *mpImplHatch ); } } // ----------------------------------------------------------------------- void Hatch::SetColor( const Color& rColor ) { DBG_CHKTHIS( Hatch, NULL ); ImplMakeUnique(); mpImplHatch->maColor = rColor; } // ----------------------------------------------------------------------- void Hatch::SetDistance( long nDistance ) { DBG_CHKTHIS( Hatch, NULL ); ImplMakeUnique(); mpImplHatch->mnDistance = nDistance; } // ----------------------------------------------------------------------- void Hatch::SetAngle( sal_uInt16 nAngle10 ) { DBG_CHKTHIS( Hatch, NULL ); ImplMakeUnique(); mpImplHatch->mnAngle = nAngle10; } // ----------------------------------------------------------------------- SvStream& operator>>( SvStream& rIStm, ImplHatch& rImplHatch ) { VersionCompat aCompat( rIStm, STREAM_READ ); sal_uInt16 nTmp16; sal_Int32 nTmp32(0); rIStm >> nTmp16; rImplHatch.meStyle = (HatchStyle) nTmp16; //#fdo39428 SvStream no longer supports operator>>(long&) rIStm >> rImplHatch.maColor >> nTmp32 >> rImplHatch.mnAngle; rImplHatch.mnDistance = nTmp32; return rIStm; } // ----------------------------------------------------------------------- SvStream& operator<<( SvStream& rOStm, const ImplHatch& rImplHatch ) { VersionCompat aCompat( rOStm, STREAM_WRITE, 1 ); rOStm << (sal_uInt16) rImplHatch.meStyle << rImplHatch.maColor; //#fdo39428 SvStream no longer supports operator<<(long) rOStm << sal::static_int_cast(rImplHatch.mnDistance) << rImplHatch.mnAngle; return rOStm; } // ----------------------------------------------------------------------- SvStream& operator>>( SvStream& rIStm, Hatch& rHatch ) { rHatch.ImplMakeUnique(); return( rIStm >> *rHatch.mpImplHatch ); } // ----------------------------------------------------------------------- SvStream& operator<<( SvStream& rOStm, const Hatch& rHatch ) { return( rOStm << *rHatch.mpImplHatch ); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */