scuffed-code/icu4c/source/i18n/unicode/measunit.h
Travis Keep 0a42d4959f ICU-10640 Add C++ MeasureFormat API.
X-SVN-Rev: 35069
2014-02-04 00:29:17 +00:00

333 lines
9.6 KiB
C++

/*
**********************************************************************
* Copyright (c) 2004-2014, International Business Machines
* Corporation and others. All Rights Reserved.
**********************************************************************
* Author: Alan Liu
* Created: April 26, 2004
* Since: ICU 3.0
**********************************************************************
*/
#ifndef __MEASUREUNIT_H__
#define __MEASUREUNIT_H__
#include "unicode/utypes.h"
#include "unicode/unistr.h"
/**
* \file
* \brief C++ API: A unit for measuring a quantity.
*/
U_NAMESPACE_BEGIN
class StringEnumeration;
/**
* A unit such as length, mass, volume, currency, etc. A unit is
* coupled with a numeric amount to produce a Measure.
*
* @author Alan Liu
* @stable ICU 3.0
*/
class U_I18N_API MeasureUnit: public UObject {
public:
/**
* Default constructor.
* @stable ICU 3.0
*/
MeasureUnit() : fTypeId(0), fSubTypeId(0) {
fCurrency[0] = 0;
}
/**
* Copy constructor.
* @draft ICU 53
*/
MeasureUnit(const MeasureUnit &other);
/**
* Assignment operator.
* @draft ICU 53.
*/
MeasureUnit &operator=(const MeasureUnit &other);
/**
* Returns a polymorphic clone of this object. The result will
* have the same class as returned by getDynamicClassID().
* @stable ICU 3.0
*/
virtual UObject* clone() const;
/**
* Destructor
* @stable ICU 3.0
*/
virtual ~MeasureUnit();
/**
* Equality operator. Return true if this object is equal
* to the given object.
* @stable ICU 3.0
*/
virtual UBool operator==(const UObject& other) const;
/**
* Inequality operator. Return true if this object is not equal
* to the given object.
* @draft ICU 53
*/
UBool operator!=(const UObject& other) const {
return !(*this == other);
}
/**
* Get the type.
* @draft ICU 53
*/
const char *getType() const;
/**
* Get the sub type.
* @draft ICU 53
*/
const char *getSubtype() const;
/**
* getAvailable gets all of the available units.
* If there are too many units to fit into destCapacity then the
* error code is set to U_BUFFER_OVERFLOW_ERROR.
*
* @param destArray destination buffer.
* @param destCapacity number of MeasureUnit instances available at dest.
* @param errorCode ICU error code.
* @return number of available units.
* @draft ICU 53
*/
static int32_t getAvailable(
MeasureUnit *destArray,
int32_t destCapacity,
UErrorCode &errorCode);
/**
* getAvailable gets all of the available units for a specific type.
* If there are too many units to fit into destCapacity then the
* error code is set to U_BUFFER_OVERFLOW_ERROR.
*
* @param type the type
* @param destArray destination buffer.
* @param destCapacity number of MeasureUnit instances available at dest.
* @param errorCode ICU error code.
* @return number of available units for type.
* @draft ICU 53
*/
static int32_t getAvailable(
const char *type,
MeasureUnit *destArray,
int32_t destCapacity,
UErrorCode &errorCode);
/**
* getAvailableTypes gets all of the available types. Caller owns the
* returned StringEnumeration and must delete it when finished using it.
*
* @param errorCode ICU error code.
* @return the types.
* @draft ICU 53
*/
static StringEnumeration* getAvailableTypes(UErrorCode &errorCode);
#ifndef U_HIDE_INTERNAL_API
/**
* ICU use only.
* Returns associated array index for this measure unit. Only valid for
* non-currency measure units.
* @internal
*/
int32_t getIndex() const;
/**
* ICU use only.
* Returns maximum value from getIndex plus 1.
* @internal
*/
static int32_t getIndexCount();
#endif /* U_HIDE_INTERNAL_API */
// Start generated createXXX methods
/** Constant for unit of acceleration: g-force */
static MeasureUnit *createGForce(UErrorCode &status);
/** Constant for unit of angle: arc-minute */
static MeasureUnit *createArcMinute(UErrorCode &status);
/** Constant for unit of angle: arc-second */
static MeasureUnit *createArcSecond(UErrorCode &status);
/** Constant for unit of angle: degree */
static MeasureUnit *createDegree(UErrorCode &status);
/** Constant for unit of area: acre */
static MeasureUnit *createAcre(UErrorCode &status);
/** Constant for unit of area: hectare */
static MeasureUnit *createHectare(UErrorCode &status);
/** Constant for unit of area: square-foot */
static MeasureUnit *createSquareFoot(UErrorCode &status);
/** Constant for unit of area: square-kilometer */
static MeasureUnit *createSquareKilometer(UErrorCode &status);
/** Constant for unit of area: square-meter */
static MeasureUnit *createSquareMeter(UErrorCode &status);
/** Constant for unit of area: square-mile */
static MeasureUnit *createSquareMile(UErrorCode &status);
/** Constant for unit of duration: day */
static MeasureUnit *createDay(UErrorCode &status);
/** Constant for unit of duration: hour */
static MeasureUnit *createHour(UErrorCode &status);
/** Constant for unit of duration: millisecond */
static MeasureUnit *createMillisecond(UErrorCode &status);
/** Constant for unit of duration: minute */
static MeasureUnit *createMinute(UErrorCode &status);
/** Constant for unit of duration: month */
static MeasureUnit *createMonth(UErrorCode &status);
/** Constant for unit of duration: second */
static MeasureUnit *createSecond(UErrorCode &status);
/** Constant for unit of duration: week */
static MeasureUnit *createWeek(UErrorCode &status);
/** Constant for unit of duration: year */
static MeasureUnit *createYear(UErrorCode &status);
/** Constant for unit of length: centimeter */
static MeasureUnit *createCentimeter(UErrorCode &status);
/** Constant for unit of length: foot */
static MeasureUnit *createFoot(UErrorCode &status);
/** Constant for unit of length: inch */
static MeasureUnit *createInch(UErrorCode &status);
/** Constant for unit of length: kilometer */
static MeasureUnit *createKilometer(UErrorCode &status);
/** Constant for unit of length: light-year */
static MeasureUnit *createLightYear(UErrorCode &status);
/** Constant for unit of length: meter */
static MeasureUnit *createMeter(UErrorCode &status);
/** Constant for unit of length: mile */
static MeasureUnit *createMile(UErrorCode &status);
/** Constant for unit of length: millimeter */
static MeasureUnit *createMillimeter(UErrorCode &status);
/** Constant for unit of length: picometer */
static MeasureUnit *createPicometer(UErrorCode &status);
/** Constant for unit of length: yard */
static MeasureUnit *createYard(UErrorCode &status);
/** Constant for unit of mass: gram */
static MeasureUnit *createGram(UErrorCode &status);
/** Constant for unit of mass: kilogram */
static MeasureUnit *createKilogram(UErrorCode &status);
/** Constant for unit of mass: ounce */
static MeasureUnit *createOunce(UErrorCode &status);
/** Constant for unit of mass: pound */
static MeasureUnit *createPound(UErrorCode &status);
/** Constant for unit of power: horsepower */
static MeasureUnit *createHorsepower(UErrorCode &status);
/** Constant for unit of power: kilowatt */
static MeasureUnit *createKilowatt(UErrorCode &status);
/** Constant for unit of power: watt */
static MeasureUnit *createWatt(UErrorCode &status);
/** Constant for unit of pressure: hectopascal */
static MeasureUnit *createHectopascal(UErrorCode &status);
/** Constant for unit of pressure: inch-hg */
static MeasureUnit *createInchHg(UErrorCode &status);
/** Constant for unit of pressure: millibar */
static MeasureUnit *createMillibar(UErrorCode &status);
/** Constant for unit of speed: kilometer-per-hour */
static MeasureUnit *createKilometerPerHour(UErrorCode &status);
/** Constant for unit of speed: meter-per-second */
static MeasureUnit *createMeterPerSecond(UErrorCode &status);
/** Constant for unit of speed: mile-per-hour */
static MeasureUnit *createMilePerHour(UErrorCode &status);
/** Constant for unit of temperature: celsius */
static MeasureUnit *createCelsius(UErrorCode &status);
/** Constant for unit of temperature: fahrenheit */
static MeasureUnit *createFahrenheit(UErrorCode &status);
/** Constant for unit of volume: cubic-kilometer */
static MeasureUnit *createCubicKilometer(UErrorCode &status);
/** Constant for unit of volume: cubic-mile */
static MeasureUnit *createCubicMile(UErrorCode &status);
/** Constant for unit of volume: liter */
static MeasureUnit *createLiter(UErrorCode &status);
protected:
#ifndef U_HIDE_INTERNAL_API
/**
* For ICU use only.
* @internal
*/
void initTime(const char *timeId);
/**
* For ICU use only.
* @internal
*/
void initCurrency(const char *isoCurrency);
#endif
private:
int32_t fTypeId;
int32_t fSubTypeId;
char fCurrency[4];
MeasureUnit(int32_t typeId, int32_t subTypeId) : fTypeId(typeId), fSubTypeId(subTypeId) {
fCurrency[0] = 0;
}
void setTo(int32_t typeId, int32_t subTypeId);
int32_t getOffset() const;
static MeasureUnit *create(int typeId, int subTypeId, UErrorCode &status);
};
U_NAMESPACE_END
#endif // __MEASUREUNIT_H__