diff options
Diffstat (limited to 'svl/source/numbers/numuno.cxx')
-rw-r--r-- | svl/source/numbers/numuno.cxx | 170 |
1 files changed, 170 insertions, 0 deletions
diff --git a/svl/source/numbers/numuno.cxx b/svl/source/numbers/numuno.cxx new file mode 100644 index 000000000000..3cc90998e2dc --- /dev/null +++ b/svl/source/numbers/numuno.cxx @@ -0,0 +1,170 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2008 by Sun Microsystems, Inc. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * $RCSfile: numuno.cxx,v $ + * $Revision: 1.9 $ + * + * 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 + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +// MARKER(update_precomp.py): autogen include statement, do not remove +#include "precompiled_svl.hxx" +#ifndef GCC +#endif + +#define _ZFORLIST_DECLARE_TABLE + +#include <tools/color.hxx> +#include <tools/debug.hxx> +#include <vos/mutex.hxx> +#include <osl/mutex.hxx> +#include <rtl/uuid.h> + +#include "numuno.hxx" +#include "numfmuno.hxx" +#include <svl/zforlist.hxx> + +using namespace com::sun::star; + +//------------------------------------------------------------------------ + +class SvNumFmtSuppl_Impl +{ +public: + SvNumberFormatter* pFormatter; + mutable ::comphelper::SharedMutex aMutex; + + SvNumFmtSuppl_Impl(SvNumberFormatter* p) : + pFormatter(p) {} +}; + +//------------------------------------------------------------------------ + +// Default-ctor fuer getReflection +SvNumberFormatsSupplierObj::SvNumberFormatsSupplierObj() +{ + pImpl = new SvNumFmtSuppl_Impl(NULL); +} + +SvNumberFormatsSupplierObj::SvNumberFormatsSupplierObj(SvNumberFormatter* pForm) +{ + pImpl = new SvNumFmtSuppl_Impl(pForm); +} + +SvNumberFormatsSupplierObj::~SvNumberFormatsSupplierObj() +{ + delete pImpl; +} + +::comphelper::SharedMutex& SvNumberFormatsSupplierObj::getSharedMutex() const +{ + return pImpl->aMutex; +} + +SvNumberFormatter* SvNumberFormatsSupplierObj::GetNumberFormatter() const +{ + return pImpl->pFormatter; +} + +void SvNumberFormatsSupplierObj::SetNumberFormatter(SvNumberFormatter* pNew) +{ + // der alte Numberformatter ist ungueltig geworden, nicht mehr darauf zugreifen! + pImpl->pFormatter = pNew; +} + +void SvNumberFormatsSupplierObj::NumberFormatDeleted(sal_uInt32) +{ + // Basis-Implementierung tut nix... +} + +void SvNumberFormatsSupplierObj::SettingsChanged() +{ + // Basis-Implementierung tut nix... +} + +// XNumberFormatsSupplier + +uno::Reference<beans::XPropertySet> SAL_CALL SvNumberFormatsSupplierObj::getNumberFormatSettings() + throw(uno::RuntimeException) +{ + ::osl::MutexGuard aGuard( pImpl->aMutex ); + + return new SvNumberFormatSettingsObj( *this, pImpl->aMutex ); +} + +uno::Reference<util::XNumberFormats> SAL_CALL SvNumberFormatsSupplierObj::getNumberFormats() + throw(uno::RuntimeException) +{ + ::osl::MutexGuard aGuard( pImpl->aMutex ); + + return new SvNumberFormatsObj( *this, pImpl->aMutex ); +} + +// XUnoTunnel + +sal_Int64 SAL_CALL SvNumberFormatsSupplierObj::getSomething( + const uno::Sequence<sal_Int8 >& rId ) throw(uno::RuntimeException) +{ + if ( rId.getLength() == 16 && + 0 == rtl_compareMemory( getUnoTunnelId().getConstArray(), + rId.getConstArray(), 16 ) ) + { + return sal::static_int_cast<sal_Int64>(reinterpret_cast<sal_IntPtr>(this)); + } + return 0; +} + +// static +const uno::Sequence<sal_Int8>& SvNumberFormatsSupplierObj::getUnoTunnelId() +{ + static uno::Sequence<sal_Int8> * pSeq = 0; + if( !pSeq ) + { + osl::Guard< osl::Mutex > aGuard( osl::Mutex::getGlobalMutex() ); + if( !pSeq ) + { + static uno::Sequence< sal_Int8 > aSeq( 16 ); + rtl_createUuid( (sal_uInt8*)aSeq.getArray(), 0, sal_True ); + pSeq = &aSeq; + } + } + return *pSeq; +} + +// static +SvNumberFormatsSupplierObj* SvNumberFormatsSupplierObj::getImplementation( + const uno::Reference<util::XNumberFormatsSupplier> xObj ) +{ + SvNumberFormatsSupplierObj* pRet = NULL; + uno::Reference<lang::XUnoTunnel> xUT( xObj, uno::UNO_QUERY ); + if (xUT.is()) + pRet = reinterpret_cast<SvNumberFormatsSupplierObj*>(sal::static_int_cast<sal_IntPtr>(xUT->getSomething( getUnoTunnelId() ))); + return pRet; +} + + +//------------------------------------------------------------------------ + + + |