summaryrefslogtreecommitdiffstats
path: root/offapi/com/sun/star/i18n/NumberFormatIndex.idl
blob: 93e39cc8af8e6c53e4fc8c970272c1687b383dcd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   Licensed to the Apache Software Foundation (ASF) under one or more
 *   contributor license agreements. See the NOTICE file distributed
 *   with this work for additional information regarding copyright
 *   ownership. The ASF licenses this file to you under the Apache
 *   License, Version 2.0 (the "License"); you may not use this file
 *   except in compliance with the License. You may obtain a copy of
 *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
 */


module com { module sun { module star { module i18n {


//! Do NOT insert any new values!
//! Locale data number format creation must match these values!
//! Number formatter internals must match these values!

/**
    Number format indices to be passed as the index argument to
    XNumberFormatCode::getFormatCode()
    or
    ::com::sun::star::util::XNumberFormatTypes::getFormatIndex().

    <p> Each locale can support up to about 5000 arbitrary format
    codes. But for backward compatibility reasons, each locale
    <b>MUST</b> support some predefined format codes. These predefined
    format codes are accessed through indices as the following, and
    the locale data format code definitions in
    i18npool/source/localedata/data/\*.xml <b>MUST</b> have matching
    entries in the form <br/>

    <code>&lt;FormatElement formatindex="0"&gt;</code> <br/>

    (see also FormatElement::formatIndex()).

    The index values are also used to define the <code>enum
    NfIndexTableOffset</code> in file svtools/inc/zforlist.hxx </p>

    <p> Note: This index has <b>nothing</b> to do with the index key
    used internally by the number formatter. </p> <br/>

    <p> Date formats may have a comment of DIN/EN/ISO, meaning
        <ul>
            <li> DIN 5008 (Deutsches Institut f&uuml;r Normung, formerly Deutsche Industrie-Norm) </li>
            <li> EN 28601 (European Norm) </li>
            <li> ISO 8601 (International Standards Organization) </li>
        </ul>
    </p>

    <p> Some names of date format constants indicate a special
    behavior of those formats in StarOffice 5.2 or older. Those are:

    <dl>
    <dt> <a name="SYSTEM"> DATE_SYSTEM_... </a> </dt>
        <dd> On Windows platforms these formats were entirely
        retrieved from the system's Regional Settings. OpenOffice.org
        / StarOffice 6 don't use those Windows settings anymore in
        order to provide the same functionality and document layout on
        every platform. Like all other formats these formats are now
        defined in the i18n framework locale data files under
        i18npool/source/localedata/data/\*.xml </dd>

    <dt> <a name="SYS"> DATE_SYS_... </a> </dt>
        <dd> On Windows platforms these formats used separators and
        YMD order retrieved from the Regional Settings, but appearance
        of short/long days/months/years was defined by the
        application. </dd>

    <dt> <a name="DEF"> DATE_DEF_... </a> </dt>
        <dd> The format code was hard defined, only the date separator
        was taken from the Windows Regional Settings, but not the YMD
        order. </dd>

    </dl>
    </p>
 */
published constants NumberFormatIndex
{
    /// Start of simple numerical formats (first format)
    const short NUMBER_START                = 0;
    /// The "General" standard format <br/> formatindex="0"
    const short NUMBER_STANDARD             = NUMBER_START;
    /// 0           <br/>Integer number <br/> formatindex="1"
    const short NUMBER_INT                  = NUMBER_START+1;
    /// 0.00        <br/>Decimal number with 2 decimals <br/> formatindex="2"
    const short NUMBER_DEC2                 = NUMBER_START+2;
    /// #,##0       <br/>Integer number with group separator <br/> formatindex="3"
    const short NUMBER_1000INT              = NUMBER_START+3;
    /// #,##0.00    <br/>Decimal number with group separator <br/> formatindex="4"
    const short NUMBER_1000DEC2             = NUMBER_START+4;
    /// #,##0.00    <br/> In SO5/Win this format was retrieved from the Regional Settings <br/> formatindex="5"
    const short NUMBER_SYSTEM               = NUMBER_START+5;
    /// End of simple numerical formats (last format)
    const short NUMBER_END                  = NUMBER_SYSTEM ;


    /// Start of Scientific formats (first format)
    const short SCIENTIFIC_START            = NUMBER_END+1;
    /// 0.00E+000   <br/>Number in scientific notation with exponent in 3 digit placeholders <br/> formatindex="6"
    const short SCIENTIFIC_000E000          = SCIENTIFIC_START;
    /// 0.00E+00    <br/>Number in scientific notation with exponent in 2 digit placeholders <br/> formatindex="7"
    const short SCIENTIFIC_000E00           = SCIENTIFIC_START+1;
    /// End of Scientific formats (last format)
    const short SCIENTIFIC_END              = SCIENTIFIC_000E00;


    /// Start of Percent formats (first format)
    const short PERCENT_START               = SCIENTIFIC_END+1;
    /// 0%          <br/>Percentage format, rounded to integer <br/> formatindex="8"
    const short PERCENT_INT                 = PERCENT_START;
    /// 0.00%       <br/>Percentage format, rounded to 2 decimals <br/> formatindex="9"
    const short PERCENT_DEC2                = PERCENT_START+1;
    /// End of Percent formats (last format)
    const short PERCENT_END                 = PERCENT_DEC2;


    /// Start of Fraction formats (first format)
    const short FRACTION_START              = PERCENT_END+1;
    /// # ?/?       <br/>Number with decimal in fraction in 1 digit placeholder <br/> formatindex="10"
    const short FRACTION_1                  = FRACTION_START;
    /// # ??/??     <br/>Number with decimal in fraction in 2 digit placeholders <br/> formatindex="11"
    const short FRACTION_2                  = FRACTION_START+1;
    /// End of Fraction formats (last format)
    const short FRACTION_END                = FRACTION_2;


    /// Start of Currency formats (first format)
    const short CURRENCY_START              = FRACTION_END+1;
    /// #,##0 DM    <br/>Integer currency format with group separator <br/> formatindex="12"
    const short CURRENCY_1000INT            = CURRENCY_START;
    /// #,##0.00 DM <br/>Decimal currency format with group separator <br/> formatindex="13"
    const short CURRENCY_1000DEC2           = CURRENCY_START+1;
    /// #,##0 DM    <br/>Integer currency format with negative in red <br/> formatindex="14"
    const short CURRENCY_1000INT_RED        = CURRENCY_START+2;
    /// #,##0.00 DM <br/>Decimal currency format with negative in red <br/> formatindex="15"
    const short CURRENCY_1000DEC2_RED       = CURRENCY_START+3;
    /// #,##0.00 DEM <br/>Currency in ISO-4217 abbreviation format <br/> formatindex="16"
    const short CURRENCY_1000DEC2_CCC       = CURRENCY_START+4;
    /// #,##0.-- DM <br/>Currency format with dash representing 0 in decimals <br/> formatindex="17"
    const short CURRENCY_1000DEC2_DASHED    = CURRENCY_START+5;
    /// End of Currency formats (last format)
    const short CURRENCY_END                = CURRENCY_1000DEC2_DASHED;


    /// Start of Date formats (first format)
    const short DATE_START                  = CURRENCY_END+1;
    /// 08.10.97        <br/> see also DATE_SYSTEM_... <a href="#SYSTEM">explanation</a> <br/> formatindex="18"
    const short DATE_SYSTEM_SHORT           = DATE_START;
    /** Wednesday, 8. October 1997  <br/> see also DATE_SYSTEM_... <a href="#SYSTEM">explanation</a>
         <br/> formatindex="19" */
    const short DATE_SYSTEM_LONG            = DATE_START+1;
    /// 08.10.97        <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="20"
    const short DATE_SYS_DDMMYY             = DATE_START+2;
    /** 08.10.1997      <br/> see also DATE_SYS_... <a href="#SYS">explanation</a>
        <br/><b>Note:</b> When editing already existing date data this
        format is forced in order to always edit the full century.
        <br/> formatindex="21" */
    const short DATE_SYS_DDMMYYYY           = DATE_START+3;
    /// 8. Oct 97       <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="22"
    const short DATE_SYS_DMMMYY             = DATE_START+4;
    /// 8. Oct 1997     <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="23"
    const short DATE_SYS_DMMMYYYY           = DATE_START+5;
    /// 8. Oct. 1997    <br/> DIN/EN <br/> formatindex="24"
    const short DATE_DIN_DMMMYYYY           = DATE_START+6;
    /// 8. October 1997 <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="25"
    const short DATE_SYS_DMMMMYYYY          = DATE_START+7;
    /// 8. October 1997 <br/> DIN/EN <br/> formatindex="26"
    const short DATE_DIN_DMMMMYYYY          = DATE_START+8;
    /// Wed, 8. Oct 97  <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="27"
    const short DATE_SYS_NNDMMMYY           = DATE_START+9;
    /// Wed 08.Oct 97   <br/> see also DATE_DEF_... <a href="#DEF">explanation</a> <br/> formatindex="28"
    const short DATE_DEF_NNDDMMMYY          = DATE_START+10;
    /// Wed, 8. October 1997    <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="29"
    const short DATE_SYS_NNDMMMMYYYY        = DATE_START+11;
    /// Wednesday, 8. October 1997 <br/> formatindex="30"
    const short DATE_SYS_NNNNDMMMMYYYY      = DATE_START+12;
    /// 10-08           <br/> DIN/EN <br/> formatindex="31"
    const short DATE_DIN_MMDD               = DATE_START+13;
    /// 97-10-08        <br/> DIN/EN <br/> formatindex="32"
    const short DATE_DIN_YYMMDD             = DATE_START+14;
    /// 1997-10-08      <br/> DIN/EN/ISO <br/> formatindex="33"
    const short DATE_DIN_YYYYMMDD           = DATE_START+15;
    /// 10.97           <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="34"
    const short DATE_SYS_MMYY               = DATE_START+16;
    /// 08.Oct          <br/> see also DATE_SYS_... <a href="#SYS">explanation</a> <br/> formatindex="35"
    const short DATE_SYS_DDMMM              = DATE_START+17;
    /// October         <br/> formatindex="36"
    const short DATE_MMMM                   = DATE_START+18;
    /// 4th quarter 97  <br/> formatindex="37"
    const short DATE_QQJJ                   = DATE_START+19;
    /// week of year    <br/> formatindex="38"
    const short DATE_WW                     = DATE_START+20;
    /// End of Date formats (last format)
    const short DATE_END                    = DATE_WW;


    /// Start of Time formats (first format)
    const short TIME_START                  = DATE_END+1;
    /// HH:MM           <br/>Time format with hour and minute <br/> formatindex="39"
    const short TIME_HHMM                   = TIME_START;
    /// HH:MM:SS        <br/>Time format with hour, minute and second <br/> formatindex="40"
    const short TIME_HHMMSS                 = TIME_START+1;
    /// HH:MM AM/PM     <br/>Time format with hour, minute and morning/afternoon notation <br/> formatindex="41"
    const short TIME_HHMMAMPM               = TIME_START+2;
    /// HH:MM:SS AM/PM  <br/>Time format with hour, minute, second and morning/afternoon notation <br/> formatindex="42"
    const short TIME_HHMMSSAMPM             = TIME_START+3;
    /// [HH]:MM:SS      <br/>Time format with amount of hours <br/> formatindex="43"
    const short TIME_HH_MMSS                = TIME_START+4;
    /// MM:SS,00        <br/>Time format with second in fraction <br/> formatindex="44"
    const short TIME_MMSS00                 = TIME_START+5;
    /// [HH]:MM:SS,00   <br/>Time format with amount of hours and seconds with fraction <br/> formatindex="45"
    const short TIME_HH_MMSS00              = TIME_START+6;
    /// End of Time formats (last format)
    const short TIME_END                    = TIME_HH_MMSS00;


    /// Start of DateTime formats (first format)
    const short DATETIME_START              = TIME_END + 1;
    /// 08.10.97 01:23 Date/time format <br/> formatindex="46"
    const short DATETIME_SYSTEM_SHORT_HHMM  = DATETIME_START;
    /** 08.10.1997 01:23:45 Date/time format with second
        <br/><b>Note:</b> When editing already existing date/time data this
        format is forced in order to always edit the full century.
        <br/> formatindex="47" */
    const short DATETIME_SYS_DDMMYYYY_HHMMSS= DATETIME_START+1;
    /// End of DateTime formats (last format)
    const short DATETIME_END                = DATETIME_SYS_DDMMYYYY_HHMMSS;


    /**
        BOOLEAN format

        @attention
            <b>Not</b> defined in locale data, but generated by the number
             formatter. If you want to access this format you <b>MUST</b>
            do it via com::sun::star::util::XNumberFormatTypes::getFormatIndex()
            instead of XNumberFormatCode::getFormatCode().
            <br/> reserved formatindex="48"
    */
    const short BOOLEAN                     = DATETIME_END+1;

    /**
        Text format

        @attention
            <b>Not</b> defined in locale data, but generated by the number
             formatter. If you want to access this format you <b>MUST</b>
            do it via com::sun::star::util::XNumberFormatTypes::getFormatIndex()
            instead of XNumberFormatCode::getFormatCode()
            <br/> reserved formatindex="49"
    */
    const short TEXT                        = BOOLEAN+1;

    /// count of built-in format codes.
    const short INDEX_TABLE_ENTRIES         = TEXT+1;
};


}; }; }; };

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */