1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_comphelper.hxx"
26*b1cdbd2cSJim Jagielski #include <comphelper/numbers.hxx>
27*b1cdbd2cSJim Jagielski #include <osl/diagnose.h>
28*b1cdbd2cSJim Jagielski #include <com/sun/star/util/NumberFormat.hpp>
29*b1cdbd2cSJim Jagielski #include <com/sun/star/util/XNumberFormatTypes.hpp>
30*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/XPropertySet.hpp>
31*b1cdbd2cSJim Jagielski #include <com/sun/star/lang/Locale.hpp>
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski //.........................................................................
34*b1cdbd2cSJim Jagielski namespace comphelper
35*b1cdbd2cSJim Jagielski {
36*b1cdbd2cSJim Jagielski //.........................................................................
37*b1cdbd2cSJim Jagielski 
38*b1cdbd2cSJim Jagielski namespace starbeans	= ::com::sun::star::beans;
39*b1cdbd2cSJim Jagielski namespace starlang	= ::com::sun::star::lang;
40*b1cdbd2cSJim Jagielski 
41*b1cdbd2cSJim Jagielski //------------------------------------------------------------------------------
getNumberFormatType(const staruno::Reference<starutil::XNumberFormats> & xFormats,sal_Int32 nKey)42*b1cdbd2cSJim Jagielski sal_Int16 getNumberFormatType(const staruno::Reference<starutil::XNumberFormats>& xFormats, sal_Int32 nKey)
43*b1cdbd2cSJim Jagielski {
44*b1cdbd2cSJim Jagielski 	sal_Int16 nReturn(starutil::NumberFormat::UNDEFINED);
45*b1cdbd2cSJim Jagielski 	if (xFormats.is())
46*b1cdbd2cSJim Jagielski 	{
47*b1cdbd2cSJim Jagielski 		try
48*b1cdbd2cSJim Jagielski 		{
49*b1cdbd2cSJim Jagielski 			staruno::Reference<starbeans::XPropertySet> xFormat(xFormats->getByKey(nKey));
50*b1cdbd2cSJim Jagielski 			if (xFormat.is())
51*b1cdbd2cSJim Jagielski 				xFormat->getPropertyValue(rtl::OUString::createFromAscii("Type")) >>= nReturn;
52*b1cdbd2cSJim Jagielski 		}
53*b1cdbd2cSJim Jagielski 		catch(...)
54*b1cdbd2cSJim Jagielski 		{
55*b1cdbd2cSJim Jagielski 			OSL_TRACE("getNumberFormatType : invalid key! (maybe created with another formatter ?)");
56*b1cdbd2cSJim Jagielski 		}
57*b1cdbd2cSJim Jagielski 	}
58*b1cdbd2cSJim Jagielski 	return nReturn;
59*b1cdbd2cSJim Jagielski }
60*b1cdbd2cSJim Jagielski 
61*b1cdbd2cSJim Jagielski //------------------------------------------------------------------------------
getNumberFormatType(const staruno::Reference<starutil::XNumberFormatter> & xFormatter,sal_Int32 nKey)62*b1cdbd2cSJim Jagielski sal_Int16 getNumberFormatType(const staruno::Reference<starutil::XNumberFormatter>& xFormatter, sal_Int32 nKey)
63*b1cdbd2cSJim Jagielski {
64*b1cdbd2cSJim Jagielski 	OSL_ENSURE(xFormatter.is(), "getNumberFormatType : the formatter isn't valid !");
65*b1cdbd2cSJim Jagielski 	staruno::Reference<starutil::XNumberFormatsSupplier> xSupplier( xFormatter->getNumberFormatsSupplier());
66*b1cdbd2cSJim Jagielski 	OSL_ENSURE(xSupplier.is(), "getNumberFormatType : the formatter doesn't implement a supplier !");
67*b1cdbd2cSJim Jagielski 	staruno::Reference<starutil::XNumberFormats> xFormats( xSupplier->getNumberFormats());
68*b1cdbd2cSJim Jagielski 	return getNumberFormatType(xFormats, nKey);
69*b1cdbd2cSJim Jagielski }
70*b1cdbd2cSJim Jagielski 
71*b1cdbd2cSJim Jagielski //------------------------------------------------------------------------------
getNumberFormatDecimals(const staruno::Reference<starutil::XNumberFormats> & xFormats,sal_Int32 nKey)72*b1cdbd2cSJim Jagielski staruno::Any getNumberFormatDecimals(const staruno::Reference<starutil::XNumberFormats>& xFormats, sal_Int32 nKey)
73*b1cdbd2cSJim Jagielski {
74*b1cdbd2cSJim Jagielski 	if (xFormats.is())
75*b1cdbd2cSJim Jagielski 	{
76*b1cdbd2cSJim Jagielski 		try
77*b1cdbd2cSJim Jagielski 		{
78*b1cdbd2cSJim Jagielski 			staruno::Reference<starbeans::XPropertySet> xFormat( xFormats->getByKey(nKey));
79*b1cdbd2cSJim Jagielski 			if (xFormat.is())
80*b1cdbd2cSJim Jagielski 			{
81*b1cdbd2cSJim Jagielski 				static ::rtl::OUString PROPERTY_DECIMALS = ::rtl::OUString::createFromAscii("Decimals");
82*b1cdbd2cSJim Jagielski 				return xFormat->getPropertyValue(PROPERTY_DECIMALS);
83*b1cdbd2cSJim Jagielski 			}
84*b1cdbd2cSJim Jagielski 		}
85*b1cdbd2cSJim Jagielski 		catch(...)
86*b1cdbd2cSJim Jagielski 		{
87*b1cdbd2cSJim Jagielski 			OSL_TRACE("getNumberFormatDecimals : invalid key! (may be created with another formatter ?)");
88*b1cdbd2cSJim Jagielski 		}
89*b1cdbd2cSJim Jagielski 	}
90*b1cdbd2cSJim Jagielski 	return staruno::makeAny((sal_Int16)0);
91*b1cdbd2cSJim Jagielski }
92*b1cdbd2cSJim Jagielski 
93*b1cdbd2cSJim Jagielski 
94*b1cdbd2cSJim Jagielski //------------------------------------------------------------------------------
getStandardFormat(const staruno::Reference<starutil::XNumberFormatter> & xFormatter,sal_Int16 nType,const starlang::Locale & _rLocale)95*b1cdbd2cSJim Jagielski sal_Int32 getStandardFormat(
96*b1cdbd2cSJim Jagielski 		const staruno::Reference<starutil::XNumberFormatter>& xFormatter,
97*b1cdbd2cSJim Jagielski 		sal_Int16 nType,
98*b1cdbd2cSJim Jagielski 		const starlang::Locale& _rLocale)
99*b1cdbd2cSJim Jagielski {
100*b1cdbd2cSJim Jagielski 	staruno::Reference<starutil::XNumberFormatsSupplier> xSupplier( xFormatter.is() ? xFormatter->getNumberFormatsSupplier() : staruno::Reference<starutil::XNumberFormatsSupplier>(NULL));
101*b1cdbd2cSJim Jagielski 	staruno::Reference<starutil::XNumberFormats> xFormats( xSupplier.is() ? xSupplier->getNumberFormats() : staruno::Reference<starutil::XNumberFormats>(NULL));
102*b1cdbd2cSJim Jagielski 	staruno::Reference<starutil::XNumberFormatTypes> xTypes(xFormats, staruno::UNO_QUERY);
103*b1cdbd2cSJim Jagielski 	OSL_ENSURE(xTypes.is(), "getStandardFormat : no format types !");
104*b1cdbd2cSJim Jagielski 
105*b1cdbd2cSJim Jagielski 	return xTypes.is() ? xTypes->getStandardFormat(nType, _rLocale) : 0;
106*b1cdbd2cSJim Jagielski }
107*b1cdbd2cSJim Jagielski 
108*b1cdbd2cSJim Jagielski //------------------------------------------------------------------------------
109*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno;
110*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::util;
111*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::beans;
112*b1cdbd2cSJim Jagielski 
113*b1cdbd2cSJim Jagielski //------------------------------------------------------------------------------
getNumberFormatProperty(const Reference<XNumberFormatter> & _rxFormatter,sal_Int32 _nKey,const rtl::OUString & _rPropertyName)114*b1cdbd2cSJim Jagielski Any getNumberFormatProperty( const Reference< XNumberFormatter >& _rxFormatter, sal_Int32 _nKey, const rtl::OUString& _rPropertyName )
115*b1cdbd2cSJim Jagielski {
116*b1cdbd2cSJim Jagielski 	Any aReturn;
117*b1cdbd2cSJim Jagielski 
118*b1cdbd2cSJim Jagielski 	OSL_ENSURE( _rxFormatter.is() && !_rPropertyName.isEmpty(), "getNumberFormatProperty: invalid arguments!" );
119*b1cdbd2cSJim Jagielski 	try
120*b1cdbd2cSJim Jagielski 	{
121*b1cdbd2cSJim Jagielski 		Reference< XNumberFormatsSupplier > xSupplier;
122*b1cdbd2cSJim Jagielski 		Reference< XNumberFormats > xFormats;
123*b1cdbd2cSJim Jagielski 		Reference< XPropertySet > xFormatProperties;
124*b1cdbd2cSJim Jagielski 
125*b1cdbd2cSJim Jagielski 		if ( _rxFormatter.is() )
126*b1cdbd2cSJim Jagielski 			xSupplier = _rxFormatter->getNumberFormatsSupplier();
127*b1cdbd2cSJim Jagielski 		if ( xSupplier.is() )
128*b1cdbd2cSJim Jagielski 			xFormats = xSupplier->getNumberFormats();
129*b1cdbd2cSJim Jagielski 		if ( xFormats.is() )
130*b1cdbd2cSJim Jagielski 			xFormatProperties = xFormats->getByKey( _nKey );
131*b1cdbd2cSJim Jagielski 
132*b1cdbd2cSJim Jagielski 		if ( xFormatProperties.is() )
133*b1cdbd2cSJim Jagielski 			aReturn = xFormatProperties->getPropertyValue( _rPropertyName );
134*b1cdbd2cSJim Jagielski 	}
135*b1cdbd2cSJim Jagielski 	catch( const Exception& )
136*b1cdbd2cSJim Jagielski 	{
137*b1cdbd2cSJim Jagielski 		OSL_ENSURE( sal_False, "::getNumberFormatProperty: caught an exception (did you create the key with another formatter?)!" );
138*b1cdbd2cSJim Jagielski 	}
139*b1cdbd2cSJim Jagielski 
140*b1cdbd2cSJim Jagielski 	return aReturn;
141*b1cdbd2cSJim Jagielski }
142*b1cdbd2cSJim Jagielski 
143*b1cdbd2cSJim Jagielski //.........................................................................
144*b1cdbd2cSJim Jagielski }	// namespace comphelper
145*b1cdbd2cSJim Jagielski //.........................................................................
146*b1cdbd2cSJim Jagielski 
147