1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2000, 2010 Oracle and/or its affiliates.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * This file is part of OpenOffice.org.
11 * OpenOffice.org is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU Lesser General Public License version 3
13 * only, as published by the Free Software Foundation.
15 * OpenOffice.org is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License version 3 for more details
19 * (a copy is included in the LICENSE file that accompanied this code).
21 * You should have received a copy of the GNU Lesser General Public License
22 * version 3 along with OpenOffice.org. If not, see
23 * <http://www.openoffice.org/license.html>
24 * for a copy of the LGPLv3 License.
26 ************************************************************************/
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_comphelper.hxx"
30 #include <comphelper/numbers.hxx>
31 #include <osl/diagnose.h>
32 #include <com/sun/star/util/NumberFormat.hpp>
33 #include <com/sun/star/util/XNumberFormatTypes.hpp>
34 #include <com/sun/star/beans/XPropertySet.hpp>
35 #include <com/sun/star/lang/Locale.hpp>
37 //.........................................................................
40 //.........................................................................
42 namespace starbeans
= ::com::sun::star::beans
;
43 namespace starlang
= ::com::sun::star::lang
;
45 //------------------------------------------------------------------------------
46 sal_Int16
getNumberFormatType(const staruno::Reference
<starutil::XNumberFormats
>& xFormats
, sal_Int32 nKey
)
48 sal_Int16
nReturn(starutil::NumberFormat::UNDEFINED
);
53 staruno::Reference
<starbeans::XPropertySet
> xFormat(xFormats
->getByKey(nKey
));
55 xFormat
->getPropertyValue(rtl::OUString::createFromAscii("Type")) >>= nReturn
;
59 OSL_TRACE("getNumberFormatType : invalid key! (maybe created with another formatter ?)");
65 //------------------------------------------------------------------------------
66 sal_Int16
getNumberFormatType(const staruno::Reference
<starutil::XNumberFormatter
>& xFormatter
, sal_Int32 nKey
)
68 OSL_ENSURE(xFormatter
.is(), "getNumberFormatType : the formatter isn't valid !");
69 staruno::Reference
<starutil::XNumberFormatsSupplier
> xSupplier( xFormatter
->getNumberFormatsSupplier());
70 OSL_ENSURE(xSupplier
.is(), "getNumberFormatType : the formatter doesn't implement a supplier !");
71 staruno::Reference
<starutil::XNumberFormats
> xFormats( xSupplier
->getNumberFormats());
72 return getNumberFormatType(xFormats
, nKey
);
75 //------------------------------------------------------------------------------
76 staruno::Any
getNumberFormatDecimals(const staruno::Reference
<starutil::XNumberFormats
>& xFormats
, sal_Int32 nKey
)
82 staruno::Reference
<starbeans::XPropertySet
> xFormat( xFormats
->getByKey(nKey
));
85 static ::rtl::OUString PROPERTY_DECIMALS
= ::rtl::OUString::createFromAscii("Decimals");
86 return xFormat
->getPropertyValue(PROPERTY_DECIMALS
);
91 OSL_TRACE("getNumberFormatDecimals : invalid key! (may be created with another formatter ?)");
94 return staruno::makeAny((sal_Int16
)0);
98 //------------------------------------------------------------------------------
99 sal_Int32
getStandardFormat(
100 const staruno::Reference
<starutil::XNumberFormatter
>& xFormatter
,
102 const starlang::Locale
& _rLocale
)
104 staruno::Reference
<starutil::XNumberFormatsSupplier
> xSupplier( xFormatter
.is() ? xFormatter
->getNumberFormatsSupplier() : staruno::Reference
<starutil::XNumberFormatsSupplier
>(NULL
));
105 staruno::Reference
<starutil::XNumberFormats
> xFormats( xSupplier
.is() ? xSupplier
->getNumberFormats() : staruno::Reference
<starutil::XNumberFormats
>(NULL
));
106 staruno::Reference
<starutil::XNumberFormatTypes
> xTypes(xFormats
, staruno::UNO_QUERY
);
107 OSL_ENSURE(xTypes
.is(), "getStandardFormat : no format types !");
109 return xTypes
.is() ? xTypes
->getStandardFormat(nType
, _rLocale
) : 0;
112 //------------------------------------------------------------------------------
113 using namespace ::com::sun::star::uno
;
114 using namespace ::com::sun::star::util
;
115 using namespace ::com::sun::star::beans
;
117 //------------------------------------------------------------------------------
118 Any
getNumberFormatProperty( const Reference
< XNumberFormatter
>& _rxFormatter
, sal_Int32 _nKey
, const rtl::OUString
& _rPropertyName
)
122 OSL_ENSURE( _rxFormatter
.is() && _rPropertyName
.getLength(), "getNumberFormatProperty: invalid arguments!" );
125 Reference
< XNumberFormatsSupplier
> xSupplier
;
126 Reference
< XNumberFormats
> xFormats
;
127 Reference
< XPropertySet
> xFormatProperties
;
129 if ( _rxFormatter
.is() )
130 xSupplier
= _rxFormatter
->getNumberFormatsSupplier();
131 if ( xSupplier
.is() )
132 xFormats
= xSupplier
->getNumberFormats();
134 xFormatProperties
= xFormats
->getByKey( _nKey
);
136 if ( xFormatProperties
.is() )
137 aReturn
= xFormatProperties
->getPropertyValue( _rPropertyName
);
139 catch( const Exception
& )
141 OSL_ENSURE( sal_False
, "::getNumberFormatProperty: caught an exception (did you create the key with another formatter?)!" );
147 //.........................................................................
148 } // namespace comphelper
149 //.........................................................................