1 // Copyright (C) 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4 **********************************************************************
5 * Copyright (c) 2004-2016, International Business Machines
6 * Corporation and others.  All Rights Reserved.
7 **********************************************************************
8 * Author: Alan Liu
9 * Created: April 26, 2004
10 * Since: ICU 3.0
11 **********************************************************************
12 */
13 #ifndef __MEASUREUNIT_H__
14 #define __MEASUREUNIT_H__
15 
16 #include "unicode/utypes.h"
17 
18 #if !UCONFIG_NO_FORMATTING
19 
20 #include "unicode/unistr.h"
21 
22 /**
23  * \file
24  * \brief C++ API: A unit for measuring a quantity.
25  */
26 
27 U_NAMESPACE_BEGIN
28 
29 class StringEnumeration;
30 
31 /**
32  * A unit such as length, mass, volume, currency, etc.  A unit is
33  * coupled with a numeric amount to produce a Measure.
34  *
35  * @author Alan Liu
36  * @stable ICU 3.0
37  */
38 class U_I18N_API MeasureUnit: public UObject {
39  public:
40 
41     /**
42      * Default constructor.
43      * @stable ICU 3.0
44      */
MeasureUnit()45     MeasureUnit() : fTypeId(0), fSubTypeId(0) {
46         fCurrency[0] = 0;
47     }
48 
49     /**
50      * Copy constructor.
51      * @stable ICU 3.0
52      */
53     MeasureUnit(const MeasureUnit &other);
54 
55     /**
56      * Assignment operator.
57      * @stable ICU 3.0
58      */
59     MeasureUnit &operator=(const MeasureUnit &other);
60 
61     /**
62      * Returns a polymorphic clone of this object.  The result will
63      * have the same class as returned by getDynamicClassID().
64      * @stable ICU 3.0
65      */
66     virtual UObject* clone() const;
67 
68     /**
69      * Destructor
70      * @stable ICU 3.0
71      */
72     virtual ~MeasureUnit();
73 
74     /**
75      * Equality operator.  Return true if this object is equal
76      * to the given object.
77      * @stable ICU 3.0
78      */
79     virtual UBool operator==(const UObject& other) const;
80 
81     /**
82      * Inequality operator.  Return true if this object is not equal
83      * to the given object.
84      * @stable ICU 53
85      */
86     UBool operator!=(const UObject& other) const {
87         return !(*this == other);
88     }
89 
90     /**
91      * Get the type.
92      * @stable ICU 53
93      */
94     const char *getType() const;
95 
96     /**
97      * Get the sub type.
98      * @stable ICU 53
99      */
100     const char *getSubtype() const;
101 
102     /**
103      * getAvailable gets all of the available units.
104      * If there are too many units to fit into destCapacity then the
105      * error code is set to U_BUFFER_OVERFLOW_ERROR.
106      *
107      * @param destArray destination buffer.
108      * @param destCapacity number of MeasureUnit instances available at dest.
109      * @param errorCode ICU error code.
110      * @return number of available units.
111      * @stable ICU 53
112      */
113     static int32_t getAvailable(
114             MeasureUnit *destArray,
115             int32_t destCapacity,
116             UErrorCode &errorCode);
117 
118     /**
119      * getAvailable gets all of the available units for a specific type.
120      * If there are too many units to fit into destCapacity then the
121      * error code is set to U_BUFFER_OVERFLOW_ERROR.
122      *
123      * @param type the type
124      * @param destArray destination buffer.
125      * @param destCapacity number of MeasureUnit instances available at dest.
126      * @param errorCode ICU error code.
127      * @return number of available units for type.
128      * @stable ICU 53
129      */
130     static int32_t getAvailable(
131             const char *type,
132             MeasureUnit *destArray,
133             int32_t destCapacity,
134             UErrorCode &errorCode);
135 
136     /**
137      * getAvailableTypes gets all of the available types. Caller owns the
138      * returned StringEnumeration and must delete it when finished using it.
139      *
140      * @param errorCode ICU error code.
141      * @return the types.
142      * @stable ICU 53
143      */
144     static StringEnumeration* getAvailableTypes(UErrorCode &errorCode);
145 
146     /**
147      * Return the class ID for this class. This is useful only for comparing to
148      * a return value from getDynamicClassID(). For example:
149      * <pre>
150      * .   Base* polymorphic_pointer = createPolymorphicObject();
151      * .   if (polymorphic_pointer->getDynamicClassID() ==
152      * .       erived::getStaticClassID()) ...
153      * </pre>
154      * @return          The class ID for all objects of this class.
155      * @stable ICU 53
156      */
157     static UClassID U_EXPORT2 getStaticClassID(void);
158 
159     /**
160      * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
161      * method is to implement a simple version of RTTI, since not all C++
162      * compilers support genuine RTTI. Polymorphic operator==() and clone()
163      * methods call this method.
164      *
165      * @return          The class ID for this object. All objects of a
166      *                  given class have the same class ID.  Objects of
167      *                  other classes have different class IDs.
168      * @stable ICU 53
169      */
170     virtual UClassID getDynamicClassID(void) const;
171 
172 #ifndef U_HIDE_INTERNAL_API
173     /**
174      * ICU use only.
175      * Returns associated array index for this measure unit. Only valid for
176      * non-currency measure units.
177      * @internal
178      */
179     int32_t getIndex() const;
180 
181     /**
182      * ICU use only.
183      * Returns maximum value from getIndex plus 1.
184      * @internal
185      */
186     static int32_t getIndexCount();
187 
188     /**
189      * ICU use only.
190      * @return the unit.getIndex() of the unit which has this unit.getType() and unit.getSubtype(),
191      *         or a negative value if there is no such unit
192      * @internal
193      */
194     static int32_t internalGetIndexForTypeAndSubtype(const char *type, const char *subtype);
195 
196     /**
197      * ICU use only.
198      * @internal
199      */
200     static MeasureUnit *resolveUnitPerUnit(
201             const MeasureUnit &unit, const MeasureUnit &perUnit);
202 #endif /* U_HIDE_INTERNAL_API */
203 
204 // All code between the "Start generated createXXX methods" comment and
205 // the "End generated createXXX methods" comment is auto generated code
206 // and must not be edited manually. For instructions on how to correctly
207 // update this code, refer to:
208 // http://site.icu-project.org/design/formatting/measureformat/updating-measure-unit
209 //
210 // Start generated createXXX methods
211 
212     /**
213      * Returns unit of acceleration: g-force.
214      * Caller owns returned value and must free it.
215      * @param status ICU error code.
216      * @stable ICU 53
217      */
218     static MeasureUnit *createGForce(UErrorCode &status);
219 
220     /**
221      * Returns unit of acceleration: meter-per-second-squared.
222      * Caller owns returned value and must free it.
223      * @param status ICU error code.
224      * @stable ICU 54
225      */
226     static MeasureUnit *createMeterPerSecondSquared(UErrorCode &status);
227 
228     /**
229      * Returns unit of angle: arc-minute.
230      * Caller owns returned value and must free it.
231      * @param status ICU error code.
232      * @stable ICU 53
233      */
234     static MeasureUnit *createArcMinute(UErrorCode &status);
235 
236     /**
237      * Returns unit of angle: arc-second.
238      * Caller owns returned value and must free it.
239      * @param status ICU error code.
240      * @stable ICU 53
241      */
242     static MeasureUnit *createArcSecond(UErrorCode &status);
243 
244     /**
245      * Returns unit of angle: degree.
246      * Caller owns returned value and must free it.
247      * @param status ICU error code.
248      * @stable ICU 53
249      */
250     static MeasureUnit *createDegree(UErrorCode &status);
251 
252     /**
253      * Returns unit of angle: radian.
254      * Caller owns returned value and must free it.
255      * @param status ICU error code.
256      * @stable ICU 54
257      */
258     static MeasureUnit *createRadian(UErrorCode &status);
259 
260     /**
261      * Returns unit of angle: revolution.
262      * Caller owns returned value and must free it.
263      * @param status ICU error code.
264      * @stable ICU 56
265      */
266     static MeasureUnit *createRevolutionAngle(UErrorCode &status);
267 
268     /**
269      * Returns unit of area: acre.
270      * Caller owns returned value and must free it.
271      * @param status ICU error code.
272      * @stable ICU 53
273      */
274     static MeasureUnit *createAcre(UErrorCode &status);
275 
276     /**
277      * Returns unit of area: hectare.
278      * Caller owns returned value and must free it.
279      * @param status ICU error code.
280      * @stable ICU 53
281      */
282     static MeasureUnit *createHectare(UErrorCode &status);
283 
284     /**
285      * Returns unit of area: square-centimeter.
286      * Caller owns returned value and must free it.
287      * @param status ICU error code.
288      * @stable ICU 54
289      */
290     static MeasureUnit *createSquareCentimeter(UErrorCode &status);
291 
292     /**
293      * Returns unit of area: square-foot.
294      * Caller owns returned value and must free it.
295      * @param status ICU error code.
296      * @stable ICU 53
297      */
298     static MeasureUnit *createSquareFoot(UErrorCode &status);
299 
300     /**
301      * Returns unit of area: square-inch.
302      * Caller owns returned value and must free it.
303      * @param status ICU error code.
304      * @stable ICU 54
305      */
306     static MeasureUnit *createSquareInch(UErrorCode &status);
307 
308     /**
309      * Returns unit of area: square-kilometer.
310      * Caller owns returned value and must free it.
311      * @param status ICU error code.
312      * @stable ICU 53
313      */
314     static MeasureUnit *createSquareKilometer(UErrorCode &status);
315 
316     /**
317      * Returns unit of area: square-meter.
318      * Caller owns returned value and must free it.
319      * @param status ICU error code.
320      * @stable ICU 53
321      */
322     static MeasureUnit *createSquareMeter(UErrorCode &status);
323 
324     /**
325      * Returns unit of area: square-mile.
326      * Caller owns returned value and must free it.
327      * @param status ICU error code.
328      * @stable ICU 53
329      */
330     static MeasureUnit *createSquareMile(UErrorCode &status);
331 
332     /**
333      * Returns unit of area: square-yard.
334      * Caller owns returned value and must free it.
335      * @param status ICU error code.
336      * @stable ICU 54
337      */
338     static MeasureUnit *createSquareYard(UErrorCode &status);
339 
340     /**
341      * Returns unit of concentr: karat.
342      * Caller owns returned value and must free it.
343      * @param status ICU error code.
344      * @stable ICU 54
345      */
346     static MeasureUnit *createKarat(UErrorCode &status);
347 
348 #ifndef U_HIDE_DRAFT_API
349     /**
350      * Returns unit of concentr: milligram-per-deciliter.
351      * Caller owns returned value and must free it.
352      * @param status ICU error code.
353      * @draft ICU 57
354      */
355     static MeasureUnit *createMilligramPerDeciliter(UErrorCode &status);
356 #endif  /* U_HIDE_DRAFT_API */
357 
358 #ifndef U_HIDE_DRAFT_API
359     /**
360      * Returns unit of concentr: millimole-per-liter.
361      * Caller owns returned value and must free it.
362      * @param status ICU error code.
363      * @draft ICU 57
364      */
365     static MeasureUnit *createMillimolePerLiter(UErrorCode &status);
366 #endif  /* U_HIDE_DRAFT_API */
367 
368 #ifndef U_HIDE_DRAFT_API
369     /**
370      * Returns unit of concentr: part-per-million.
371      * Caller owns returned value and must free it.
372      * @param status ICU error code.
373      * @draft ICU 57
374      */
375     static MeasureUnit *createPartPerMillion(UErrorCode &status);
376 #endif  /* U_HIDE_DRAFT_API */
377 
378     /**
379      * Returns unit of consumption: liter-per-100kilometers.
380      * Caller owns returned value and must free it.
381      * @param status ICU error code.
382      * @stable ICU 56
383      */
384     static MeasureUnit *createLiterPer100Kilometers(UErrorCode &status);
385 
386     /**
387      * Returns unit of consumption: liter-per-kilometer.
388      * Caller owns returned value and must free it.
389      * @param status ICU error code.
390      * @stable ICU 54
391      */
392     static MeasureUnit *createLiterPerKilometer(UErrorCode &status);
393 
394     /**
395      * Returns unit of consumption: mile-per-gallon.
396      * Caller owns returned value and must free it.
397      * @param status ICU error code.
398      * @stable ICU 54
399      */
400     static MeasureUnit *createMilePerGallon(UErrorCode &status);
401 
402 #ifndef U_HIDE_DRAFT_API
403     /**
404      * Returns unit of consumption: mile-per-gallon-imperial.
405      * Caller owns returned value and must free it.
406      * @param status ICU error code.
407      * @draft ICU 57
408      */
409     static MeasureUnit *createMilePerGallonImperial(UErrorCode &status);
410 #endif  /* U_HIDE_DRAFT_API */
411 
412 #ifndef U_HIDE_DRAFT_API
413     /**
414      * Returns unit of coordinate: east.
415      * Caller owns returned value and must free it.
416      * @param status ICU error code.
417      * @draft ICU 58
418      */
419     static MeasureUnit *createEast(UErrorCode &status);
420 #endif  /* U_HIDE_DRAFT_API */
421 
422 #ifndef U_HIDE_DRAFT_API
423     /**
424      * Returns unit of coordinate: north.
425      * Caller owns returned value and must free it.
426      * @param status ICU error code.
427      * @draft ICU 58
428      */
429     static MeasureUnit *createNorth(UErrorCode &status);
430 #endif  /* U_HIDE_DRAFT_API */
431 
432 #ifndef U_HIDE_DRAFT_API
433     /**
434      * Returns unit of coordinate: south.
435      * Caller owns returned value and must free it.
436      * @param status ICU error code.
437      * @draft ICU 58
438      */
439     static MeasureUnit *createSouth(UErrorCode &status);
440 #endif  /* U_HIDE_DRAFT_API */
441 
442 #ifndef U_HIDE_DRAFT_API
443     /**
444      * Returns unit of coordinate: west.
445      * Caller owns returned value and must free it.
446      * @param status ICU error code.
447      * @draft ICU 58
448      */
449     static MeasureUnit *createWest(UErrorCode &status);
450 #endif  /* U_HIDE_DRAFT_API */
451 
452     /**
453      * Returns unit of digital: bit.
454      * Caller owns returned value and must free it.
455      * @param status ICU error code.
456      * @stable ICU 54
457      */
458     static MeasureUnit *createBit(UErrorCode &status);
459 
460     /**
461      * Returns unit of digital: byte.
462      * Caller owns returned value and must free it.
463      * @param status ICU error code.
464      * @stable ICU 54
465      */
466     static MeasureUnit *createByte(UErrorCode &status);
467 
468     /**
469      * Returns unit of digital: gigabit.
470      * Caller owns returned value and must free it.
471      * @param status ICU error code.
472      * @stable ICU 54
473      */
474     static MeasureUnit *createGigabit(UErrorCode &status);
475 
476     /**
477      * Returns unit of digital: gigabyte.
478      * Caller owns returned value and must free it.
479      * @param status ICU error code.
480      * @stable ICU 54
481      */
482     static MeasureUnit *createGigabyte(UErrorCode &status);
483 
484     /**
485      * Returns unit of digital: kilobit.
486      * Caller owns returned value and must free it.
487      * @param status ICU error code.
488      * @stable ICU 54
489      */
490     static MeasureUnit *createKilobit(UErrorCode &status);
491 
492     /**
493      * Returns unit of digital: kilobyte.
494      * Caller owns returned value and must free it.
495      * @param status ICU error code.
496      * @stable ICU 54
497      */
498     static MeasureUnit *createKilobyte(UErrorCode &status);
499 
500     /**
501      * Returns unit of digital: megabit.
502      * Caller owns returned value and must free it.
503      * @param status ICU error code.
504      * @stable ICU 54
505      */
506     static MeasureUnit *createMegabit(UErrorCode &status);
507 
508     /**
509      * Returns unit of digital: megabyte.
510      * Caller owns returned value and must free it.
511      * @param status ICU error code.
512      * @stable ICU 54
513      */
514     static MeasureUnit *createMegabyte(UErrorCode &status);
515 
516     /**
517      * Returns unit of digital: terabit.
518      * Caller owns returned value and must free it.
519      * @param status ICU error code.
520      * @stable ICU 54
521      */
522     static MeasureUnit *createTerabit(UErrorCode &status);
523 
524     /**
525      * Returns unit of digital: terabyte.
526      * Caller owns returned value and must free it.
527      * @param status ICU error code.
528      * @stable ICU 54
529      */
530     static MeasureUnit *createTerabyte(UErrorCode &status);
531 
532     /**
533      * Returns unit of duration: century.
534      * Caller owns returned value and must free it.
535      * @param status ICU error code.
536      * @stable ICU 56
537      */
538     static MeasureUnit *createCentury(UErrorCode &status);
539 
540     /**
541      * Returns unit of duration: day.
542      * Caller owns returned value and must free it.
543      * @param status ICU error code.
544      * @stable ICU 53
545      */
546     static MeasureUnit *createDay(UErrorCode &status);
547 
548     /**
549      * Returns unit of duration: hour.
550      * Caller owns returned value and must free it.
551      * @param status ICU error code.
552      * @stable ICU 53
553      */
554     static MeasureUnit *createHour(UErrorCode &status);
555 
556     /**
557      * Returns unit of duration: microsecond.
558      * Caller owns returned value and must free it.
559      * @param status ICU error code.
560      * @stable ICU 54
561      */
562     static MeasureUnit *createMicrosecond(UErrorCode &status);
563 
564     /**
565      * Returns unit of duration: millisecond.
566      * Caller owns returned value and must free it.
567      * @param status ICU error code.
568      * @stable ICU 53
569      */
570     static MeasureUnit *createMillisecond(UErrorCode &status);
571 
572     /**
573      * Returns unit of duration: minute.
574      * Caller owns returned value and must free it.
575      * @param status ICU error code.
576      * @stable ICU 53
577      */
578     static MeasureUnit *createMinute(UErrorCode &status);
579 
580     /**
581      * Returns unit of duration: month.
582      * Caller owns returned value and must free it.
583      * @param status ICU error code.
584      * @stable ICU 53
585      */
586     static MeasureUnit *createMonth(UErrorCode &status);
587 
588     /**
589      * Returns unit of duration: nanosecond.
590      * Caller owns returned value and must free it.
591      * @param status ICU error code.
592      * @stable ICU 54
593      */
594     static MeasureUnit *createNanosecond(UErrorCode &status);
595 
596     /**
597      * Returns unit of duration: second.
598      * Caller owns returned value and must free it.
599      * @param status ICU error code.
600      * @stable ICU 53
601      */
602     static MeasureUnit *createSecond(UErrorCode &status);
603 
604     /**
605      * Returns unit of duration: week.
606      * Caller owns returned value and must free it.
607      * @param status ICU error code.
608      * @stable ICU 53
609      */
610     static MeasureUnit *createWeek(UErrorCode &status);
611 
612     /**
613      * Returns unit of duration: year.
614      * Caller owns returned value and must free it.
615      * @param status ICU error code.
616      * @stable ICU 53
617      */
618     static MeasureUnit *createYear(UErrorCode &status);
619 
620     /**
621      * Returns unit of electric: ampere.
622      * Caller owns returned value and must free it.
623      * @param status ICU error code.
624      * @stable ICU 54
625      */
626     static MeasureUnit *createAmpere(UErrorCode &status);
627 
628     /**
629      * Returns unit of electric: milliampere.
630      * Caller owns returned value and must free it.
631      * @param status ICU error code.
632      * @stable ICU 54
633      */
634     static MeasureUnit *createMilliampere(UErrorCode &status);
635 
636     /**
637      * Returns unit of electric: ohm.
638      * Caller owns returned value and must free it.
639      * @param status ICU error code.
640      * @stable ICU 54
641      */
642     static MeasureUnit *createOhm(UErrorCode &status);
643 
644     /**
645      * Returns unit of electric: volt.
646      * Caller owns returned value and must free it.
647      * @param status ICU error code.
648      * @stable ICU 54
649      */
650     static MeasureUnit *createVolt(UErrorCode &status);
651 
652     /**
653      * Returns unit of energy: calorie.
654      * Caller owns returned value and must free it.
655      * @param status ICU error code.
656      * @stable ICU 54
657      */
658     static MeasureUnit *createCalorie(UErrorCode &status);
659 
660     /**
661      * Returns unit of energy: foodcalorie.
662      * Caller owns returned value and must free it.
663      * @param status ICU error code.
664      * @stable ICU 54
665      */
666     static MeasureUnit *createFoodcalorie(UErrorCode &status);
667 
668     /**
669      * Returns unit of energy: joule.
670      * Caller owns returned value and must free it.
671      * @param status ICU error code.
672      * @stable ICU 54
673      */
674     static MeasureUnit *createJoule(UErrorCode &status);
675 
676     /**
677      * Returns unit of energy: kilocalorie.
678      * Caller owns returned value and must free it.
679      * @param status ICU error code.
680      * @stable ICU 54
681      */
682     static MeasureUnit *createKilocalorie(UErrorCode &status);
683 
684     /**
685      * Returns unit of energy: kilojoule.
686      * Caller owns returned value and must free it.
687      * @param status ICU error code.
688      * @stable ICU 54
689      */
690     static MeasureUnit *createKilojoule(UErrorCode &status);
691 
692     /**
693      * Returns unit of energy: kilowatt-hour.
694      * Caller owns returned value and must free it.
695      * @param status ICU error code.
696      * @stable ICU 54
697      */
698     static MeasureUnit *createKilowattHour(UErrorCode &status);
699 
700     /**
701      * Returns unit of frequency: gigahertz.
702      * Caller owns returned value and must free it.
703      * @param status ICU error code.
704      * @stable ICU 54
705      */
706     static MeasureUnit *createGigahertz(UErrorCode &status);
707 
708     /**
709      * Returns unit of frequency: hertz.
710      * Caller owns returned value and must free it.
711      * @param status ICU error code.
712      * @stable ICU 54
713      */
714     static MeasureUnit *createHertz(UErrorCode &status);
715 
716     /**
717      * Returns unit of frequency: kilohertz.
718      * Caller owns returned value and must free it.
719      * @param status ICU error code.
720      * @stable ICU 54
721      */
722     static MeasureUnit *createKilohertz(UErrorCode &status);
723 
724     /**
725      * Returns unit of frequency: megahertz.
726      * Caller owns returned value and must free it.
727      * @param status ICU error code.
728      * @stable ICU 54
729      */
730     static MeasureUnit *createMegahertz(UErrorCode &status);
731 
732     /**
733      * Returns unit of length: astronomical-unit.
734      * Caller owns returned value and must free it.
735      * @param status ICU error code.
736      * @stable ICU 54
737      */
738     static MeasureUnit *createAstronomicalUnit(UErrorCode &status);
739 
740     /**
741      * Returns unit of length: centimeter.
742      * Caller owns returned value and must free it.
743      * @param status ICU error code.
744      * @stable ICU 53
745      */
746     static MeasureUnit *createCentimeter(UErrorCode &status);
747 
748     /**
749      * Returns unit of length: decimeter.
750      * Caller owns returned value and must free it.
751      * @param status ICU error code.
752      * @stable ICU 54
753      */
754     static MeasureUnit *createDecimeter(UErrorCode &status);
755 
756     /**
757      * Returns unit of length: fathom.
758      * Caller owns returned value and must free it.
759      * @param status ICU error code.
760      * @stable ICU 54
761      */
762     static MeasureUnit *createFathom(UErrorCode &status);
763 
764     /**
765      * Returns unit of length: foot.
766      * Caller owns returned value and must free it.
767      * @param status ICU error code.
768      * @stable ICU 53
769      */
770     static MeasureUnit *createFoot(UErrorCode &status);
771 
772     /**
773      * Returns unit of length: furlong.
774      * Caller owns returned value and must free it.
775      * @param status ICU error code.
776      * @stable ICU 54
777      */
778     static MeasureUnit *createFurlong(UErrorCode &status);
779 
780     /**
781      * Returns unit of length: inch.
782      * Caller owns returned value and must free it.
783      * @param status ICU error code.
784      * @stable ICU 53
785      */
786     static MeasureUnit *createInch(UErrorCode &status);
787 
788     /**
789      * Returns unit of length: kilometer.
790      * Caller owns returned value and must free it.
791      * @param status ICU error code.
792      * @stable ICU 53
793      */
794     static MeasureUnit *createKilometer(UErrorCode &status);
795 
796     /**
797      * Returns unit of length: light-year.
798      * Caller owns returned value and must free it.
799      * @param status ICU error code.
800      * @stable ICU 53
801      */
802     static MeasureUnit *createLightYear(UErrorCode &status);
803 
804     /**
805      * Returns unit of length: meter.
806      * Caller owns returned value and must free it.
807      * @param status ICU error code.
808      * @stable ICU 53
809      */
810     static MeasureUnit *createMeter(UErrorCode &status);
811 
812     /**
813      * Returns unit of length: micrometer.
814      * Caller owns returned value and must free it.
815      * @param status ICU error code.
816      * @stable ICU 54
817      */
818     static MeasureUnit *createMicrometer(UErrorCode &status);
819 
820     /**
821      * Returns unit of length: mile.
822      * Caller owns returned value and must free it.
823      * @param status ICU error code.
824      * @stable ICU 53
825      */
826     static MeasureUnit *createMile(UErrorCode &status);
827 
828     /**
829      * Returns unit of length: mile-scandinavian.
830      * Caller owns returned value and must free it.
831      * @param status ICU error code.
832      * @stable ICU 56
833      */
834     static MeasureUnit *createMileScandinavian(UErrorCode &status);
835 
836     /**
837      * Returns unit of length: millimeter.
838      * Caller owns returned value and must free it.
839      * @param status ICU error code.
840      * @stable ICU 53
841      */
842     static MeasureUnit *createMillimeter(UErrorCode &status);
843 
844     /**
845      * Returns unit of length: nanometer.
846      * Caller owns returned value and must free it.
847      * @param status ICU error code.
848      * @stable ICU 54
849      */
850     static MeasureUnit *createNanometer(UErrorCode &status);
851 
852     /**
853      * Returns unit of length: nautical-mile.
854      * Caller owns returned value and must free it.
855      * @param status ICU error code.
856      * @stable ICU 54
857      */
858     static MeasureUnit *createNauticalMile(UErrorCode &status);
859 
860     /**
861      * Returns unit of length: parsec.
862      * Caller owns returned value and must free it.
863      * @param status ICU error code.
864      * @stable ICU 54
865      */
866     static MeasureUnit *createParsec(UErrorCode &status);
867 
868     /**
869      * Returns unit of length: picometer.
870      * Caller owns returned value and must free it.
871      * @param status ICU error code.
872      * @stable ICU 53
873      */
874     static MeasureUnit *createPicometer(UErrorCode &status);
875 
876     /**
877      * Returns unit of length: yard.
878      * Caller owns returned value and must free it.
879      * @param status ICU error code.
880      * @stable ICU 53
881      */
882     static MeasureUnit *createYard(UErrorCode &status);
883 
884     /**
885      * Returns unit of light: lux.
886      * Caller owns returned value and must free it.
887      * @param status ICU error code.
888      * @stable ICU 54
889      */
890     static MeasureUnit *createLux(UErrorCode &status);
891 
892     /**
893      * Returns unit of mass: carat.
894      * Caller owns returned value and must free it.
895      * @param status ICU error code.
896      * @stable ICU 54
897      */
898     static MeasureUnit *createCarat(UErrorCode &status);
899 
900     /**
901      * Returns unit of mass: gram.
902      * Caller owns returned value and must free it.
903      * @param status ICU error code.
904      * @stable ICU 53
905      */
906     static MeasureUnit *createGram(UErrorCode &status);
907 
908     /**
909      * Returns unit of mass: kilogram.
910      * Caller owns returned value and must free it.
911      * @param status ICU error code.
912      * @stable ICU 53
913      */
914     static MeasureUnit *createKilogram(UErrorCode &status);
915 
916     /**
917      * Returns unit of mass: metric-ton.
918      * Caller owns returned value and must free it.
919      * @param status ICU error code.
920      * @stable ICU 54
921      */
922     static MeasureUnit *createMetricTon(UErrorCode &status);
923 
924     /**
925      * Returns unit of mass: microgram.
926      * Caller owns returned value and must free it.
927      * @param status ICU error code.
928      * @stable ICU 54
929      */
930     static MeasureUnit *createMicrogram(UErrorCode &status);
931 
932     /**
933      * Returns unit of mass: milligram.
934      * Caller owns returned value and must free it.
935      * @param status ICU error code.
936      * @stable ICU 54
937      */
938     static MeasureUnit *createMilligram(UErrorCode &status);
939 
940     /**
941      * Returns unit of mass: ounce.
942      * Caller owns returned value and must free it.
943      * @param status ICU error code.
944      * @stable ICU 53
945      */
946     static MeasureUnit *createOunce(UErrorCode &status);
947 
948     /**
949      * Returns unit of mass: ounce-troy.
950      * Caller owns returned value and must free it.
951      * @param status ICU error code.
952      * @stable ICU 54
953      */
954     static MeasureUnit *createOunceTroy(UErrorCode &status);
955 
956     /**
957      * Returns unit of mass: pound.
958      * Caller owns returned value and must free it.
959      * @param status ICU error code.
960      * @stable ICU 53
961      */
962     static MeasureUnit *createPound(UErrorCode &status);
963 
964     /**
965      * Returns unit of mass: stone.
966      * Caller owns returned value and must free it.
967      * @param status ICU error code.
968      * @stable ICU 54
969      */
970     static MeasureUnit *createStone(UErrorCode &status);
971 
972     /**
973      * Returns unit of mass: ton.
974      * Caller owns returned value and must free it.
975      * @param status ICU error code.
976      * @stable ICU 54
977      */
978     static MeasureUnit *createTon(UErrorCode &status);
979 
980     /**
981      * Returns unit of power: gigawatt.
982      * Caller owns returned value and must free it.
983      * @param status ICU error code.
984      * @stable ICU 54
985      */
986     static MeasureUnit *createGigawatt(UErrorCode &status);
987 
988     /**
989      * Returns unit of power: horsepower.
990      * Caller owns returned value and must free it.
991      * @param status ICU error code.
992      * @stable ICU 53
993      */
994     static MeasureUnit *createHorsepower(UErrorCode &status);
995 
996     /**
997      * Returns unit of power: kilowatt.
998      * Caller owns returned value and must free it.
999      * @param status ICU error code.
1000      * @stable ICU 53
1001      */
1002     static MeasureUnit *createKilowatt(UErrorCode &status);
1003 
1004     /**
1005      * Returns unit of power: megawatt.
1006      * Caller owns returned value and must free it.
1007      * @param status ICU error code.
1008      * @stable ICU 54
1009      */
1010     static MeasureUnit *createMegawatt(UErrorCode &status);
1011 
1012     /**
1013      * Returns unit of power: milliwatt.
1014      * Caller owns returned value and must free it.
1015      * @param status ICU error code.
1016      * @stable ICU 54
1017      */
1018     static MeasureUnit *createMilliwatt(UErrorCode &status);
1019 
1020     /**
1021      * Returns unit of power: watt.
1022      * Caller owns returned value and must free it.
1023      * @param status ICU error code.
1024      * @stable ICU 53
1025      */
1026     static MeasureUnit *createWatt(UErrorCode &status);
1027 
1028     /**
1029      * Returns unit of pressure: hectopascal.
1030      * Caller owns returned value and must free it.
1031      * @param status ICU error code.
1032      * @stable ICU 53
1033      */
1034     static MeasureUnit *createHectopascal(UErrorCode &status);
1035 
1036     /**
1037      * Returns unit of pressure: inch-hg.
1038      * Caller owns returned value and must free it.
1039      * @param status ICU error code.
1040      * @stable ICU 53
1041      */
1042     static MeasureUnit *createInchHg(UErrorCode &status);
1043 
1044     /**
1045      * Returns unit of pressure: millibar.
1046      * Caller owns returned value and must free it.
1047      * @param status ICU error code.
1048      * @stable ICU 53
1049      */
1050     static MeasureUnit *createMillibar(UErrorCode &status);
1051 
1052     /**
1053      * Returns unit of pressure: millimeter-of-mercury.
1054      * Caller owns returned value and must free it.
1055      * @param status ICU error code.
1056      * @stable ICU 54
1057      */
1058     static MeasureUnit *createMillimeterOfMercury(UErrorCode &status);
1059 
1060     /**
1061      * Returns unit of pressure: pound-per-square-inch.
1062      * Caller owns returned value and must free it.
1063      * @param status ICU error code.
1064      * @stable ICU 54
1065      */
1066     static MeasureUnit *createPoundPerSquareInch(UErrorCode &status);
1067 
1068     /**
1069      * Returns unit of speed: kilometer-per-hour.
1070      * Caller owns returned value and must free it.
1071      * @param status ICU error code.
1072      * @stable ICU 53
1073      */
1074     static MeasureUnit *createKilometerPerHour(UErrorCode &status);
1075 
1076     /**
1077      * Returns unit of speed: knot.
1078      * Caller owns returned value and must free it.
1079      * @param status ICU error code.
1080      * @stable ICU 56
1081      */
1082     static MeasureUnit *createKnot(UErrorCode &status);
1083 
1084     /**
1085      * Returns unit of speed: meter-per-second.
1086      * Caller owns returned value and must free it.
1087      * @param status ICU error code.
1088      * @stable ICU 53
1089      */
1090     static MeasureUnit *createMeterPerSecond(UErrorCode &status);
1091 
1092     /**
1093      * Returns unit of speed: mile-per-hour.
1094      * Caller owns returned value and must free it.
1095      * @param status ICU error code.
1096      * @stable ICU 53
1097      */
1098     static MeasureUnit *createMilePerHour(UErrorCode &status);
1099 
1100     /**
1101      * Returns unit of temperature: celsius.
1102      * Caller owns returned value and must free it.
1103      * @param status ICU error code.
1104      * @stable ICU 53
1105      */
1106     static MeasureUnit *createCelsius(UErrorCode &status);
1107 
1108     /**
1109      * Returns unit of temperature: fahrenheit.
1110      * Caller owns returned value and must free it.
1111      * @param status ICU error code.
1112      * @stable ICU 53
1113      */
1114     static MeasureUnit *createFahrenheit(UErrorCode &status);
1115 
1116     /**
1117      * Returns unit of temperature: generic.
1118      * Caller owns returned value and must free it.
1119      * @param status ICU error code.
1120      * @stable ICU 56
1121      */
1122     static MeasureUnit *createGenericTemperature(UErrorCode &status);
1123 
1124     /**
1125      * Returns unit of temperature: kelvin.
1126      * Caller owns returned value and must free it.
1127      * @param status ICU error code.
1128      * @stable ICU 54
1129      */
1130     static MeasureUnit *createKelvin(UErrorCode &status);
1131 
1132     /**
1133      * Returns unit of volume: acre-foot.
1134      * Caller owns returned value and must free it.
1135      * @param status ICU error code.
1136      * @stable ICU 54
1137      */
1138     static MeasureUnit *createAcreFoot(UErrorCode &status);
1139 
1140     /**
1141      * Returns unit of volume: bushel.
1142      * Caller owns returned value and must free it.
1143      * @param status ICU error code.
1144      * @stable ICU 54
1145      */
1146     static MeasureUnit *createBushel(UErrorCode &status);
1147 
1148     /**
1149      * Returns unit of volume: centiliter.
1150      * Caller owns returned value and must free it.
1151      * @param status ICU error code.
1152      * @stable ICU 54
1153      */
1154     static MeasureUnit *createCentiliter(UErrorCode &status);
1155 
1156     /**
1157      * Returns unit of volume: cubic-centimeter.
1158      * Caller owns returned value and must free it.
1159      * @param status ICU error code.
1160      * @stable ICU 54
1161      */
1162     static MeasureUnit *createCubicCentimeter(UErrorCode &status);
1163 
1164     /**
1165      * Returns unit of volume: cubic-foot.
1166      * Caller owns returned value and must free it.
1167      * @param status ICU error code.
1168      * @stable ICU 54
1169      */
1170     static MeasureUnit *createCubicFoot(UErrorCode &status);
1171 
1172     /**
1173      * Returns unit of volume: cubic-inch.
1174      * Caller owns returned value and must free it.
1175      * @param status ICU error code.
1176      * @stable ICU 54
1177      */
1178     static MeasureUnit *createCubicInch(UErrorCode &status);
1179 
1180     /**
1181      * Returns unit of volume: cubic-kilometer.
1182      * Caller owns returned value and must free it.
1183      * @param status ICU error code.
1184      * @stable ICU 53
1185      */
1186     static MeasureUnit *createCubicKilometer(UErrorCode &status);
1187 
1188     /**
1189      * Returns unit of volume: cubic-meter.
1190      * Caller owns returned value and must free it.
1191      * @param status ICU error code.
1192      * @stable ICU 54
1193      */
1194     static MeasureUnit *createCubicMeter(UErrorCode &status);
1195 
1196     /**
1197      * Returns unit of volume: cubic-mile.
1198      * Caller owns returned value and must free it.
1199      * @param status ICU error code.
1200      * @stable ICU 53
1201      */
1202     static MeasureUnit *createCubicMile(UErrorCode &status);
1203 
1204     /**
1205      * Returns unit of volume: cubic-yard.
1206      * Caller owns returned value and must free it.
1207      * @param status ICU error code.
1208      * @stable ICU 54
1209      */
1210     static MeasureUnit *createCubicYard(UErrorCode &status);
1211 
1212     /**
1213      * Returns unit of volume: cup.
1214      * Caller owns returned value and must free it.
1215      * @param status ICU error code.
1216      * @stable ICU 54
1217      */
1218     static MeasureUnit *createCup(UErrorCode &status);
1219 
1220     /**
1221      * Returns unit of volume: cup-metric.
1222      * Caller owns returned value and must free it.
1223      * @param status ICU error code.
1224      * @stable ICU 56
1225      */
1226     static MeasureUnit *createCupMetric(UErrorCode &status);
1227 
1228     /**
1229      * Returns unit of volume: deciliter.
1230      * Caller owns returned value and must free it.
1231      * @param status ICU error code.
1232      * @stable ICU 54
1233      */
1234     static MeasureUnit *createDeciliter(UErrorCode &status);
1235 
1236     /**
1237      * Returns unit of volume: fluid-ounce.
1238      * Caller owns returned value and must free it.
1239      * @param status ICU error code.
1240      * @stable ICU 54
1241      */
1242     static MeasureUnit *createFluidOunce(UErrorCode &status);
1243 
1244     /**
1245      * Returns unit of volume: gallon.
1246      * Caller owns returned value and must free it.
1247      * @param status ICU error code.
1248      * @stable ICU 54
1249      */
1250     static MeasureUnit *createGallon(UErrorCode &status);
1251 
1252 #ifndef U_HIDE_DRAFT_API
1253     /**
1254      * Returns unit of volume: gallon-imperial.
1255      * Caller owns returned value and must free it.
1256      * @param status ICU error code.
1257      * @draft ICU 57
1258      */
1259     static MeasureUnit *createGallonImperial(UErrorCode &status);
1260 #endif  /* U_HIDE_DRAFT_API */
1261 
1262     /**
1263      * Returns unit of volume: hectoliter.
1264      * Caller owns returned value and must free it.
1265      * @param status ICU error code.
1266      * @stable ICU 54
1267      */
1268     static MeasureUnit *createHectoliter(UErrorCode &status);
1269 
1270     /**
1271      * Returns unit of volume: liter.
1272      * Caller owns returned value and must free it.
1273      * @param status ICU error code.
1274      * @stable ICU 53
1275      */
1276     static MeasureUnit *createLiter(UErrorCode &status);
1277 
1278     /**
1279      * Returns unit of volume: megaliter.
1280      * Caller owns returned value and must free it.
1281      * @param status ICU error code.
1282      * @stable ICU 54
1283      */
1284     static MeasureUnit *createMegaliter(UErrorCode &status);
1285 
1286     /**
1287      * Returns unit of volume: milliliter.
1288      * Caller owns returned value and must free it.
1289      * @param status ICU error code.
1290      * @stable ICU 54
1291      */
1292     static MeasureUnit *createMilliliter(UErrorCode &status);
1293 
1294     /**
1295      * Returns unit of volume: pint.
1296      * Caller owns returned value and must free it.
1297      * @param status ICU error code.
1298      * @stable ICU 54
1299      */
1300     static MeasureUnit *createPint(UErrorCode &status);
1301 
1302     /**
1303      * Returns unit of volume: pint-metric.
1304      * Caller owns returned value and must free it.
1305      * @param status ICU error code.
1306      * @stable ICU 56
1307      */
1308     static MeasureUnit *createPintMetric(UErrorCode &status);
1309 
1310     /**
1311      * Returns unit of volume: quart.
1312      * Caller owns returned value and must free it.
1313      * @param status ICU error code.
1314      * @stable ICU 54
1315      */
1316     static MeasureUnit *createQuart(UErrorCode &status);
1317 
1318     /**
1319      * Returns unit of volume: tablespoon.
1320      * Caller owns returned value and must free it.
1321      * @param status ICU error code.
1322      * @stable ICU 54
1323      */
1324     static MeasureUnit *createTablespoon(UErrorCode &status);
1325 
1326     /**
1327      * Returns unit of volume: teaspoon.
1328      * Caller owns returned value and must free it.
1329      * @param status ICU error code.
1330      * @stable ICU 54
1331      */
1332     static MeasureUnit *createTeaspoon(UErrorCode &status);
1333 
1334 
1335 // End generated createXXX methods
1336 
1337  protected:
1338 
1339 #ifndef U_HIDE_INTERNAL_API
1340     /**
1341      * For ICU use only.
1342      * @internal
1343      */
1344     void initTime(const char *timeId);
1345 
1346     /**
1347      * For ICU use only.
1348      * @internal
1349      */
1350     void initCurrency(const char *isoCurrency);
1351 
1352 #endif  /* U_HIDE_INTERNAL_API */
1353 
1354 private:
1355     int32_t fTypeId;
1356     int32_t fSubTypeId;
1357     char fCurrency[4];
1358 
MeasureUnit(int32_t typeId,int32_t subTypeId)1359     MeasureUnit(int32_t typeId, int32_t subTypeId) : fTypeId(typeId), fSubTypeId(subTypeId) {
1360         fCurrency[0] = 0;
1361     }
1362     void setTo(int32_t typeId, int32_t subTypeId);
1363     int32_t getOffset() const;
1364     static MeasureUnit *create(int typeId, int subTypeId, UErrorCode &status);
1365 };
1366 
1367 U_NAMESPACE_END
1368 
1369 #endif // !UNCONFIG_NO_FORMATTING
1370 #endif // __MEASUREUNIT_H__
1371