1/**************************************************************
2 *
3 * Licensed to the Apache Software Foundation (ASF) under one
4 * or more contributor license agreements.  See the NOTICE file
5 * distributed with this work for additional information
6 * regarding copyright ownership.  The ASF licenses this file
7 * to you under the Apache License, Version 2.0 (the
8 * "License"); you may not use this file except in compliance
9 * with the License.  You may obtain a copy of the License at
10 *
11 *   http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing,
14 * software distributed under the License is distributed on an
15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16 * KIND, either express or implied.  See the License for the
17 * specific language governing permissions and limitations
18 * under the License.
19 *
20 *************************************************************/
21
22
23
24#ifndef __com_sun_star_i18n_NumberFormatIndex_idl__
25#define __com_sun_star_i18n_NumberFormatIndex_idl__
26
27//=============================================================================
28
29module com { module sun { module star { module i18n {
30
31//=============================================================================
32
33//! Do NOT insert any new values!
34//! Locale data number format creation must match these values!
35//! Number formatter internals must match these values!
36
37/**
38	Number format indices to be passed as the index argument to
39    <member>XNumberFormatCode::getFormatCode()</member>
40    or
41    <member scope="::com::sun::star::util">XNumberFormatTypes::getFormatIndex()</member>.
42
43    <p> Each locale can support up to about 5000 arbitrary format
44    codes. But for backward compatibility reasons, each locale
45    <b>MUST</b> support some predefined format codes. These predefined
46    format codes are accessed through indices as the following, and
47    the locale data format code definitions in
48    i18npool\source\localedata\data\*.xml <b>MUST</b> have matching
49    entries in the form <br/>
50
51    <code>&lt;FormatElement formatindex="0"&gt;</code> <br/>
52
53    (see also <member>FormatElement::formatIndex</member>).
54
55    The index values are also used to define the <code>enum
56    NfIndexTableOffset</code> in file svtools/inc/zforlist.hxx </p>
57
58    <p> Note: This index has <b>nothing</b> to do with the index key
59    used internally by the number formatter. </p> <br/>
60
61    <p> Date formats may have a comment of DIN/EN/ISO, meaning
62        <ul>
63            <li> DIN 5008 (Deutsche Industrie Norm) </li>
64            <li> EN 28601 (European Norm) </li>
65            <li> ISO 8601 (International Standards Organisation) </li>
66        </ul>
67    </p>
68
69    <p> Some names of date format constants indicate a special
70    behavior of those formats in StarOffice 5.2 or older. Those are:
71
72    <dl>
73    <dt> <a name="SYSTEM"> DATE_SYSTEM_... </a> </dt>
74        <dd> On Windows platforms these formats were entirely
75        retrieved from the system's Regional Settings. OpenOffice.org
76        / StarOffice 6 don't use those Windows settings anymore in
77        order to provide the same functionality and document layout on
78        every platform. Like all other formats these formats are now
79        defined in the i18n framework locale data files under
80        i18npool\source\localedata\data\*.xml </dd>
81
82    <dt> <a name="SYS"> DATE_SYS_... </a> </dt>
83        <dd> On Windows platforms these formats used separators and
84        YMD order retrieved from the Regional Settings, but appearance
85        of short/long days/months/years was defined by the
86        application. </dd>
87
88    <dt> <a name="DEF"> DATE_DEF_... </a> </dt>
89        <dd> The format code was hard defined, only the date separator
90        was taken from the Windows Regional Settings, but not the YMD
91        order. </dd>
92
93    </dl>
94    </p>
95 */
96published constants NumberFormatIndex
97{
98	/// Start of simple numerical formats (first format)
99	const short NUMBER_START				= 0;
100	/// The "General" standard format
101	const short NUMBER_STANDARD				= NUMBER_START;
102	/// 0           <br/>Integer number
103	const short NUMBER_INT					= NUMBER_START+1;
104	/// 0.00        <br/>Decimal number with 2 decimals
105	const short NUMBER_DEC2 				= NUMBER_START+2;
106	/// #,##0       <br/>Integer number with group separator
107	const short NUMBER_1000INT				= NUMBER_START+3;
108	/// #,##0.00    <br/>Decimal number with group separator
109	const short NUMBER_1000DEC2				= NUMBER_START+4;
110	/// #,##0.00    <br/> In SO5/Win this format was retrieved from the Regional Settings
111	const short NUMBER_SYSTEM				= NUMBER_START+5;
112    /// End of simple numerical formats (last format)
113	const short NUMBER_END					= NUMBER_SYSTEM ;
114
115
116	/// Start of Scientific formats (first format)
117	const short SCIENTIFIC_START			= NUMBER_END+1;
118	/// 0.00E+000   <br/>Number in scientific notation with exponent in 3 digit placeholders
119	const short SCIENTIFIC_000E000			= SCIENTIFIC_START;
120	/// 0.00E+00    <br/>Number in scientific notation with exponent in 2 digit placeholders
121	const short SCIENTIFIC_000E00			= SCIENTIFIC_START+1;
122	/// End of Scientific formats (last format)
123	const short SCIENTIFIC_END				= SCIENTIFIC_000E00;
124
125
126	/// Start of Percent formats (first format)
127	const short PERCENT_START				= SCIENTIFIC_END+1;
128	/// 0%          <br/>Percentage format, rounded to integer
129	const short PERCENT_INT					= PERCENT_START;
130	/// 0.00%       <br/>Percentage format, rounded to 2 decimals
131	const short PERCENT_DEC2				= PERCENT_START+1;
132	/// End of Percent formats (last format)
133	const short PERCENT_END					= PERCENT_DEC2;
134
135
136	/// Start of Fraction formats (first format)
137	const short FRACTION_START				= PERCENT_END+1;
138	/// # ?/?       <br/>Number with decimal in fraction in 1 digit placeholder
139	const short FRACTION_1					= FRACTION_START;
140	/// # ??/??     <br/>Number with decimal in fraction in 2 digit placeholders
141	const short FRACTION_2					= FRACTION_START+1;
142	/// End of Fraction formats (last format)
143	const short FRACTION_END				= FRACTION_2;
144
145
146	/// Start of Currency formats (first format)
147	const short CURRENCY_START				= FRACTION_END+1;
148	/// #,##0 DM    <br/>Integer currency format with group separator
149	const short CURRENCY_1000INT			= CURRENCY_START;
150	/// #,##0.00 DM <br/>Decimal currency format with group separator
151	const short CURRENCY_1000DEC2			= CURRENCY_START+1;
152	/// #,##0 DM    <br/>Integer currency format with negative in red
153	const short CURRENCY_1000INT_RED		= CURRENCY_START+2;
154	/// #,##0.00 DM <br/>Decimal currency format with negative in red
155	const short CURRENCY_1000DEC2_RED		= CURRENCY_START+3;
156	/// #,##0.00 DEM <br/>Currency in ISO-4217 abbreviation format
157	const short CURRENCY_1000DEC2_CCC		= CURRENCY_START+4;
158	/// #,##0.-- DM <br/>Currency format with dash representing 0 in decimals
159	const short CURRENCY_1000DEC2_DASHED	= CURRENCY_START+5;
160	/// End of Currency formats (last format)
161	const short CURRENCY_END				= CURRENCY_1000DEC2_DASHED;
162
163
164	/// Start of Date formats (first format)
165	const short DATE_START					= CURRENCY_END+1;
166	/// 08.10.97        <br/> see also DATE_SYSTEM_... <a href="#SYSTEM">explanation</a>
167    const short DATE_SYSTEM_SHORT			= DATE_START;
168    /// Wednesday, 8. October 1997  <br/> see also DATE_SYSTEM_... <a href="#SYSTEM">explanation</a>
169	const short DATE_SYSTEM_LONG			= DATE_START+1;
170	/// 08.10.97        <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
171	const short DATE_SYS_DDMMYY   			= DATE_START+2;
172	/** 08.10.1997      <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
173        <br/><b>Note:</b> When editing already existing date data this
174        format is forced in order to always edit the full century.  */
175	const short DATE_SYS_DDMMYYYY 			= DATE_START+3;
176	/// 8. Oct 97       <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
177	const short DATE_SYS_DMMMYY   			= DATE_START+4;
178	/// 8. Oct 1997     <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
179	const short DATE_SYS_DMMMYYYY 			= DATE_START+5;
180	/// 8. Oct. 1997    <br/> DIN/EN
181	const short DATE_DIN_DMMMYYYY 			= DATE_START+6;
182	/// 8. October 1997 <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
183	const short DATE_SYS_DMMMMYYYY			= DATE_START+7;
184	/// 8. October 1997 <br/> DIN/EN
185	const short DATE_DIN_DMMMMYYYY			= DATE_START+8;
186	/// Wed, 8. Oct 97  <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
187	const short DATE_SYS_NNDMMMYY 			= DATE_START+9;
188	/// Wed 08.Oct 97   <br/> see also DATE_DEF_... <a href="#DEF">explanation</a>
189	const short DATE_DEF_NNDDMMMYY			= DATE_START+10;
190	/// Wed, 8. October 1997    <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
191	const short DATE_SYS_NNDMMMMYYYY		= DATE_START+11;
192	/// Wednesday, 8. October 1997
193	const short DATE_SYS_NNNNDMMMMYYYY		= DATE_START+12;
194	/// 10-08           <br/> DIN/EN
195	const short DATE_DIN_MMDD				= DATE_START+13;
196	/// 97-10-08        <br/> DIN/EN/ISO
197	const short DATE_DIN_YYMMDD				= DATE_START+14;
198	/// 1997-10-08      <br/> DIN/EN/ISO
199	const short DATE_DIN_YYYYMMDD			= DATE_START+15;
200	/// 10.97           <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
201	const short DATE_SYS_MMYY				= DATE_START+16;
202	/// 08.Oct          <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
203	const short DATE_SYS_DDMMM				= DATE_START+17;
204	/// October
205	const short DATE_MMMM					= DATE_START+18;
206	/// 4th quarter 97
207	const short DATE_QQJJ					= DATE_START+19;
208	/// week of year
209	const short DATE_WW						= DATE_START+20;
210	/// End of Date formats (last format)
211	const short DATE_END					= DATE_WW;
212
213
214	/// Start of Time formats (first format)
215	const short TIME_START					= DATE_END+1;
216	/// HH:MM           <br/>Time format with hour and minute
217	const short TIME_HHMM					= TIME_START;
218	/// HH:MM:SS        <br/>Time format with hour, minute and second
219	const short TIME_HHMMSS					= TIME_START+1;
220	/// HH:MM AM/PM     <br/>Time format with hour, minute and morning/afternoon notation
221	const short TIME_HHMMAMPM				= TIME_START+2;
222	/// HH:MM:SS AM/PM  <br/>Time format with hour, minute, second and morning/afternoon notation
223	const short TIME_HHMMSSAMPM				= TIME_START+3;
224	/// [HH]:MM:SS      <br/>Time format with amount of hours
225	const short TIME_HH_MMSS				= TIME_START+4;
226	/// MM:SS,00        <br/>Time format with second in fraction
227	const short TIME_MMSS00					= TIME_START+5;
228	/// [HH]:MM:SS,00   <br/>Time format with amount of hours and seconds with fraction
229	const short TIME_HH_MMSS00				= TIME_START+6;
230	/// End of Time formats (last format)
231	const short TIME_END					= TIME_HH_MMSS00;
232
233
234	/// Start of DateTime formats (first format)
235	const short DATETIME_START				= TIME_END + 1;
236	/// 08.10.97 01:23 Date/time format
237	const short DATETIME_SYSTEM_SHORT_HHMM	= DATETIME_START;
238	/** 08.10.1997 01:23:45 Date/time format with second
239        <br/><b>Note:</b> When editing already existing date/time data this
240        format is forced in order to always edit the full century.  */
241	const short DATETIME_SYS_DDMMYYYY_HHMMSS= DATETIME_START+1;
242	/// End of DateTime formats (last format)
243	const short DATETIME_END				= DATETIME_SYS_DDMMYYYY_HHMMSS;
244
245
246	/**
247		BOOLEAN format
248
249		@ATTENTION
250			<b>Not</b> defined in locale data, but generated by the number
251	 		formatter. If you want to access this format you <b>MUST</b>
252			do it via <member scope="com::sun::star::util">XNumberFormatTypes::getFormatIndex()</member>
253			instead of <member>XNumberFormatCode::getFormatCode()</member>.
254	*/
255	const short BOOLEAN						= DATETIME_END+1;
256
257	/**
258		Text format
259
260		@ATTENTION
261			<b>Not</b> defined in locale data, but generated by the number
262	 		formatter. If you want to access this format you <b>MUST</b>
263			do it via <member scope="com::sun::star::util">XNumberFormatTypes::getFormatIndex()</member>
264			instead of <member>XNumberFormatCode::getFormatCode()</member>
265    */
266	const short TEXT						= BOOLEAN+1;
267
268	/// count of built-in format codes.
269	const short INDEX_TABLE_ENTRIES			= TEXT+1;
270};
271
272
273//=============================================================================
274}; }; }; };
275#endif
276
277