]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/i18n/unicode/measunit.h
ICU-59180.0.1.tar.gz
[apple/icu.git] / icuSources / i18n / unicode / measunit.h
index 3e3046cb37bc4c0fa8927fa616666e2d803a386b..e32b8ef86925c13bf12e00860b3e6fb7cc21d360 100644 (file)
@@ -1,6 +1,8 @@
+// © 2016 and later: Unicode, Inc. and others.
+// License & terms of use: http://www.unicode.org/copyright.html
 /*
 **********************************************************************
-* Copyright (c) 2004-2014, International Business Machines
+* Copyright (c) 2004-2016, International Business Machines
 * Corporation and others.  All Rights Reserved.
 **********************************************************************
 * Author: Alan Liu
@@ -22,6 +24,7 @@
  * \brief C++ API: A unit for measuring a quantity.
  */
  
+#if U_SHOW_CPLUSPLUS_API
 U_NAMESPACE_BEGIN
 
 class StringEnumeration;
@@ -46,13 +49,13 @@ class U_I18N_API MeasureUnit: public UObject {
     
     /**
      * Copy constructor.
-     * @draft ICU 53
+     * @stable ICU 3.0
      */
     MeasureUnit(const MeasureUnit &other);
         
     /**
      * Assignment operator.
-     * @draft ICU 53
+     * @stable ICU 3.0
      */
     MeasureUnit &operator=(const MeasureUnit &other);
 
@@ -76,11 +79,10 @@ class U_I18N_API MeasureUnit: public UObject {
      */
     virtual UBool operator==(const UObject& other) const;
 
-#ifndef U_HIDE_DRAFT_API
     /**
      * Inequality operator.  Return true if this object is not equal
      * to the given object.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     UBool operator!=(const UObject& other) const {
         return !(*this == other);
@@ -88,13 +90,13 @@ class U_I18N_API MeasureUnit: public UObject {
 
     /**
      * Get the type.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     const char *getType() const;
 
     /**
      * Get the sub type.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     const char *getSubtype() const;
 
@@ -107,7 +109,7 @@ class U_I18N_API MeasureUnit: public UObject {
      * @param destCapacity number of MeasureUnit instances available at dest.
      * @param errorCode ICU error code.
      * @return number of available units.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static int32_t getAvailable(
             MeasureUnit *destArray,
@@ -124,7 +126,7 @@ class U_I18N_API MeasureUnit: public UObject {
      * @param destCapacity number of MeasureUnit instances available at dest.
      * @param errorCode ICU error code.
      * @return number of available units for type.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static int32_t getAvailable(
             const char *type,
@@ -138,10 +140,9 @@ class U_I18N_API MeasureUnit: public UObject {
      *
      * @param errorCode ICU error code.
      * @return the types.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static StringEnumeration* getAvailableTypes(UErrorCode &errorCode);
-#endif /* U_HIDE_DRAFT_API */
 
     /**
      * Return the class ID for this class. This is useful only for comparing to
@@ -152,7 +153,7 @@ class U_I18N_API MeasureUnit: public UObject {
      * .       erived::getStaticClassID()) ...
      * </pre>
      * @return          The class ID for all objects of this class.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static UClassID U_EXPORT2 getStaticClassID(void);
 
@@ -165,7 +166,7 @@ class U_I18N_API MeasureUnit: public UObject {
      * @return          The class ID for this object. All objects of a
      *                  given class have the same class ID.  Objects of
      *                  other classes have different class IDs.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     virtual UClassID getDynamicClassID(void) const;
 
@@ -184,400 +185,1123 @@ class U_I18N_API MeasureUnit: public UObject {
      * @internal
      */
     static int32_t getIndexCount();
+
+    /**
+     * ICU use only.
+     * @return the unit.getIndex() of the unit which has this unit.getType() and unit.getSubtype(),
+     *         or a negative value if there is no such unit
+     * @internal
+     */
+    static int32_t internalGetIndexForTypeAndSubtype(const char *type, const char *subtype);
+
+    /**
+     * ICU use only.
+     * @internal
+     */
+    static MeasureUnit *resolveUnitPerUnit(
+            const MeasureUnit &unit, const MeasureUnit &perUnit);
 #endif /* U_HIDE_INTERNAL_API */
 
+// All code between the "Start generated createXXX methods" comment and
+// the "End generated createXXX methods" comment is auto generated code
+// and must not be edited manually. For instructions on how to correctly
+// update this code, refer to:
+// http://site.icu-project.org/design/formatting/measureformat/updating-measure-unit
+//
 // Start generated createXXX methods
 
-#ifndef U_HIDE_DRAFT_API
     /**
-     * Creates a unit of acceleration: g-force.
+     * Returns unit of acceleration: g-force.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createGForce(UErrorCode &status);
 
     /**
-     * Creates a unit of angle: arc-minute.
+     * Returns unit of acceleration: meter-per-second-squared.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMeterPerSecondSquared(UErrorCode &status);
+
+    /**
+     * Returns unit of angle: arc-minute.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createArcMinute(UErrorCode &status);
 
     /**
-     * Creates a unit of angle: arc-second.
+     * Returns unit of angle: arc-second.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createArcSecond(UErrorCode &status);
 
     /**
-     * Creates a unit of angle: degree.
+     * Returns unit of angle: degree.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createDegree(UErrorCode &status);
 
     /**
-     * Creates a unit of area: acre.
+     * Returns unit of angle: radian.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createRadian(UErrorCode &status);
+
+    /**
+     * Returns unit of angle: revolution.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createRevolutionAngle(UErrorCode &status);
+
+    /**
+     * Returns unit of area: acre.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createAcre(UErrorCode &status);
 
     /**
-     * Creates a unit of area: hectare.
+     * Returns unit of area: hectare.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createHectare(UErrorCode &status);
 
     /**
-     * Creates a unit of area: square-foot.
+     * Returns unit of area: square-centimeter.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createSquareCentimeter(UErrorCode &status);
+
+    /**
+     * Returns unit of area: square-foot.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createSquareFoot(UErrorCode &status);
 
     /**
-     * Creates a unit of area: square-kilometer.
+     * Returns unit of area: square-inch.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createSquareInch(UErrorCode &status);
+
+    /**
+     * Returns unit of area: square-kilometer.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createSquareKilometer(UErrorCode &status);
 
     /**
-     * Creates a unit of area: square-meter.
+     * Returns unit of area: square-meter.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createSquareMeter(UErrorCode &status);
 
     /**
-     * Creates a unit of area: square-mile.
+     * Returns unit of area: square-mile.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createSquareMile(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: day.
+     * Returns unit of area: square-yard.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createSquareYard(UErrorCode &status);
+
+    /**
+     * Returns unit of concentr: karat.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKarat(UErrorCode &status);
+
+    /**
+     * Returns unit of concentr: milligram-per-deciliter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 57
+     */
+    static MeasureUnit *createMilligramPerDeciliter(UErrorCode &status);
+
+    /**
+     * Returns unit of concentr: millimole-per-liter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 57
+     */
+    static MeasureUnit *createMillimolePerLiter(UErrorCode &status);
+
+    /**
+     * Returns unit of concentr: part-per-million.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 57
+     */
+    static MeasureUnit *createPartPerMillion(UErrorCode &status);
+
+    /**
+     * Returns unit of consumption: liter-per-100kilometers.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createLiterPer100Kilometers(UErrorCode &status);
+
+    /**
+     * Returns unit of consumption: liter-per-kilometer.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createLiterPerKilometer(UErrorCode &status);
+
+    /**
+     * Returns unit of consumption: mile-per-gallon.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMilePerGallon(UErrorCode &status);
+
+    /**
+     * Returns unit of consumption: mile-per-gallon-imperial.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 57
+     */
+    static MeasureUnit *createMilePerGallonImperial(UErrorCode &status);
+
+    /*
+     * The following were draft ICU 58, but have been withdrawn:
+     * static MeasureUnit *createEast(UErrorCode &status);
+     * static MeasureUnit *createNorth(UErrorCode &status);
+     * static MeasureUnit *createSouth(UErrorCode &status);
+     * static MeasureUnit *createWest(UErrorCode &status);
+     */
+
+    /**
+     * Returns unit of digital: bit.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createBit(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: byte.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createByte(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: gigabit.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createGigabit(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: gigabyte.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createGigabyte(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: kilobit.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKilobit(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: kilobyte.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKilobyte(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: megabit.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMegabit(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: megabyte.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMegabyte(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: terabit.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createTerabit(UErrorCode &status);
+
+    /**
+     * Returns unit of digital: terabyte.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createTerabyte(UErrorCode &status);
+
+    /**
+     * Returns unit of duration: century.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createCentury(UErrorCode &status);
+
+    /**
+     * Returns unit of duration: day.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createDay(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: hour.
+     * Returns unit of duration: hour.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createHour(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: millisecond.
+     * Returns unit of duration: microsecond.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMicrosecond(UErrorCode &status);
+
+    /**
+     * Returns unit of duration: millisecond.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMillisecond(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: minute.
+     * Returns unit of duration: minute.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMinute(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: month.
+     * Returns unit of duration: month.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMonth(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: second.
+     * Returns unit of duration: nanosecond.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createNanosecond(UErrorCode &status);
+
+    /**
+     * Returns unit of duration: second.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createSecond(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: week.
+     * Returns unit of duration: week.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createWeek(UErrorCode &status);
 
     /**
-     * Creates a unit of duration: year.
+     * Returns unit of duration: year.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createYear(UErrorCode &status);
 
     /**
-     * Creates a unit of length: centimeter.
+     * Returns unit of electric: ampere.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createAmpere(UErrorCode &status);
+
+    /**
+     * Returns unit of electric: milliampere.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMilliampere(UErrorCode &status);
+
+    /**
+     * Returns unit of electric: ohm.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createOhm(UErrorCode &status);
+
+    /**
+     * Returns unit of electric: volt.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createVolt(UErrorCode &status);
+
+    /**
+     * Returns unit of energy: calorie.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCalorie(UErrorCode &status);
+
+    /**
+     * Returns unit of energy: foodcalorie.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createFoodcalorie(UErrorCode &status);
+
+    /**
+     * Returns unit of energy: joule.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createJoule(UErrorCode &status);
+
+    /**
+     * Returns unit of energy: kilocalorie.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKilocalorie(UErrorCode &status);
+
+    /**
+     * Returns unit of energy: kilojoule.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKilojoule(UErrorCode &status);
+
+    /**
+     * Returns unit of energy: kilowatt-hour.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKilowattHour(UErrorCode &status);
+
+    /**
+     * Returns unit of frequency: gigahertz.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createGigahertz(UErrorCode &status);
+
+    /**
+     * Returns unit of frequency: hertz.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createHertz(UErrorCode &status);
+
+    /**
+     * Returns unit of frequency: kilohertz.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKilohertz(UErrorCode &status);
+
+    /**
+     * Returns unit of frequency: megahertz.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMegahertz(UErrorCode &status);
+
+    /**
+     * Returns unit of length: astronomical-unit.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createAstronomicalUnit(UErrorCode &status);
+
+    /**
+     * Returns unit of length: centimeter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createCentimeter(UErrorCode &status);
 
     /**
-     * Creates a unit of length: foot.
+     * Returns unit of length: decimeter.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createDecimeter(UErrorCode &status);
+
+    /**
+     * Returns unit of length: fathom.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createFathom(UErrorCode &status);
+
+    /**
+     * Returns unit of length: foot.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createFoot(UErrorCode &status);
 
     /**
-     * Creates a unit of length: inch.
+     * Returns unit of length: furlong.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createFurlong(UErrorCode &status);
+
+    /**
+     * Returns unit of length: inch.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createInch(UErrorCode &status);
 
     /**
-     * Creates a unit of length: kilometer.
+     * Returns unit of length: kilometer.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createKilometer(UErrorCode &status);
 
     /**
-     * Creates a unit of length: light-year.
+     * Returns unit of length: light-year.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createLightYear(UErrorCode &status);
 
     /**
-     * Creates a unit of length: meter.
+     * Returns unit of length: meter.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMeter(UErrorCode &status);
 
     /**
-     * Creates a unit of length: mile.
+     * Returns unit of length: micrometer.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMicrometer(UErrorCode &status);
+
+    /**
+     * Returns unit of length: mile.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createMile(UErrorCode &status);
 
     /**
-     * Creates a unit of length: millimeter.
+     * Returns unit of length: mile-scandinavian.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createMileScandinavian(UErrorCode &status);
+
+    /**
+     * Returns unit of length: millimeter.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMillimeter(UErrorCode &status);
 
     /**
-     * Creates a unit of length: picometer.
+     * Returns unit of length: nanometer.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createNanometer(UErrorCode &status);
+
+    /**
+     * Returns unit of length: nautical-mile.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createNauticalMile(UErrorCode &status);
+
+    /**
+     * Returns unit of length: parsec.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createParsec(UErrorCode &status);
+
+    /**
+     * Returns unit of length: picometer.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createPicometer(UErrorCode &status);
 
+#ifndef U_HIDE_DRAFT_API
+    /**
+     * Returns unit of length: point.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @draft ICU 59
+     */
+    static MeasureUnit *createPoint(UErrorCode &status);
+#endif  /* U_HIDE_DRAFT_API */
+
     /**
-     * Creates a unit of length: yard.
+     * Returns unit of length: yard.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createYard(UErrorCode &status);
 
     /**
-     * Creates a unit of mass: gram.
+     * Returns unit of light: lux.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createLux(UErrorCode &status);
+
+    /**
+     * Returns unit of mass: carat.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCarat(UErrorCode &status);
+
+    /**
+     * Returns unit of mass: gram.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createGram(UErrorCode &status);
 
     /**
-     * Creates a unit of mass: kilogram.
+     * Returns unit of mass: kilogram.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createKilogram(UErrorCode &status);
 
     /**
-     * Creates a unit of mass: ounce.
+     * Returns unit of mass: metric-ton.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMetricTon(UErrorCode &status);
+
+    /**
+     * Returns unit of mass: microgram.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMicrogram(UErrorCode &status);
+
+    /**
+     * Returns unit of mass: milligram.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMilligram(UErrorCode &status);
+
+    /**
+     * Returns unit of mass: ounce.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createOunce(UErrorCode &status);
 
     /**
-     * Creates a unit of mass: pound.
+     * Returns unit of mass: ounce-troy.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createOunceTroy(UErrorCode &status);
+
+    /**
+     * Returns unit of mass: pound.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createPound(UErrorCode &status);
 
     /**
-     * Creates a unit of mass: stone. (for now, Apple-specific addition)
+     * Returns unit of mass: stone.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @internal
+     * @stable ICU 54
      */
     static MeasureUnit *createStone(UErrorCode &status);
 
     /**
-     * Creates a unit of power: horsepower.
+     * Returns unit of mass: ton.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createTon(UErrorCode &status);
+
+    /**
+     * Returns unit of power: gigawatt.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createGigawatt(UErrorCode &status);
+
+    /**
+     * Returns unit of power: horsepower.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createHorsepower(UErrorCode &status);
 
     /**
-     * Creates a unit of power: kilowatt.
+     * Returns unit of power: kilowatt.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createKilowatt(UErrorCode &status);
 
     /**
-     * Creates a unit of power: watt.
+     * Returns unit of power: megawatt.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMegawatt(UErrorCode &status);
+
+    /**
+     * Returns unit of power: milliwatt.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMilliwatt(UErrorCode &status);
+
+    /**
+     * Returns unit of power: watt.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createWatt(UErrorCode &status);
 
     /**
-     * Creates a unit of pressure: hectopascal.
+     * Returns unit of pressure: hectopascal.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createHectopascal(UErrorCode &status);
 
     /**
-     * Creates a unit of pressure: inch-hg.
+     * Returns unit of pressure: inch-hg.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createInchHg(UErrorCode &status);
 
     /**
-     * Creates a unit of pressure: millibar.
+     * Returns unit of pressure: millibar.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMillibar(UErrorCode &status);
 
     /**
-     * Creates a unit of speed: kilometer-per-hour.
+     * Returns unit of pressure: millimeter-of-mercury.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMillimeterOfMercury(UErrorCode &status);
+
+    /**
+     * Returns unit of pressure: pound-per-square-inch.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createPoundPerSquareInch(UErrorCode &status);
+
+    /**
+     * Returns unit of speed: kilometer-per-hour.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createKilometerPerHour(UErrorCode &status);
 
     /**
-     * Creates a unit of speed: meter-per-second.
+     * Returns unit of speed: knot.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createKnot(UErrorCode &status);
+
+    /**
+     * Returns unit of speed: meter-per-second.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMeterPerSecond(UErrorCode &status);
 
     /**
-     * Creates a unit of speed: mile-per-hour.
+     * Returns unit of speed: mile-per-hour.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createMilePerHour(UErrorCode &status);
 
     /**
-     * Creates a unit of temperature: celsius.
+     * Returns unit of temperature: celsius.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createCelsius(UErrorCode &status);
 
     /**
-     * Creates a unit of temperature: fahrenheit.
+     * Returns unit of temperature: fahrenheit.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 53
      */
     static MeasureUnit *createFahrenheit(UErrorCode &status);
 
     /**
-     * Creates a unit of volume: cubic-kilometer.
+     * Returns unit of temperature: generic.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createGenericTemperature(UErrorCode &status);
+
+    /**
+     * Returns unit of temperature: kelvin.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createKelvin(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: acre-foot.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createAcreFoot(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: bushel.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createBushel(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: centiliter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCentiliter(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: cubic-centimeter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCubicCentimeter(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: cubic-foot.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCubicFoot(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: cubic-inch.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCubicInch(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: cubic-kilometer.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createCubicKilometer(UErrorCode &status);
 
     /**
-     * Creates a unit of volume: cubic-mile.
+     * Returns unit of volume: cubic-meter.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCubicMeter(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: cubic-mile.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createCubicMile(UErrorCode &status);
 
     /**
-     * Creates a unit of volume: liter.
+     * Returns unit of volume: cubic-yard.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCubicYard(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: cup.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createCup(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: cup-metric.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createCupMetric(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: deciliter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createDeciliter(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: fluid-ounce.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createFluidOunce(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: gallon.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @draft ICU 53
+     * @stable ICU 54
+     */
+    static MeasureUnit *createGallon(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: gallon-imperial.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 57
+     */
+    static MeasureUnit *createGallonImperial(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: hectoliter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createHectoliter(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: liter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 53
      */
     static MeasureUnit *createLiter(UErrorCode &status);
 
     /**
-     * Creates a unit of energy: as listed. (for now, Apple-specific addition)
+     * Returns unit of volume: megaliter.
      * Caller owns returned value and must free it.
      * @param status ICU error code.
-     * @internal
+     * @stable ICU 54
      */
-    static MeasureUnit *createCalorie(UErrorCode &status);
-    static MeasureUnit *createFoodcalorie(UErrorCode &status);
-    static MeasureUnit *createJoule(UErrorCode &status);
-    static MeasureUnit *createKilocalorie(UErrorCode &status);
-    static MeasureUnit *createKilojoule(UErrorCode &status);
+    static MeasureUnit *createMegaliter(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: milliliter.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createMilliliter(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: pint.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createPint(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: pint-metric.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 56
+     */
+    static MeasureUnit *createPintMetric(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: quart.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createQuart(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: tablespoon.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createTablespoon(UErrorCode &status);
+
+    /**
+     * Returns unit of volume: teaspoon.
+     * Caller owns returned value and must free it.
+     * @param status ICU error code.
+     * @stable ICU 54
+     */
+    static MeasureUnit *createTeaspoon(UErrorCode &status);
+
 
-#endif /* U_HIDE_DRAFT_API */
+// End generated createXXX methods
 
  protected:
 
@@ -594,7 +1318,7 @@ class U_I18N_API MeasureUnit: public UObject {
      */
     void initCurrency(const char *isoCurrency);
 
-#endif
+#endif  /* U_HIDE_INTERNAL_API */
 
 private:
     int32_t fTypeId;
@@ -610,6 +1334,7 @@ private:
 };
 
 U_NAMESPACE_END
+#endif // U_SHOW_CPLUSPLUS_API
 
 #endif // !UNCONFIG_NO_FORMATTING
 #endif // __MEASUREUNIT_H__