]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/i18n/currfmt.cpp
ICU-491.11.2.tar.gz
[apple/icu.git] / icuSources / i18n / currfmt.cpp
index 42471c01856a76a06ff2a076c7dd326d196af189..d3de2ab633d64fc39331bcb696407df03559e68a 100644 (file)
@@ -1,6 +1,6 @@
 /*
 **********************************************************************
-* Copyright (c) 2004, International Business Machines
+* Copyright (c) 2004-2012 International Business Machines
 * Corporation and others.  All Rights Reserved.
 **********************************************************************
 * Author: Alan Liu
@@ -8,22 +8,27 @@
 * Since: ICU 3.0
 **********************************************************************
 */
+#include <typeinfo>  // for 'typeid' to work
+
 #include "unicode/utypes.h"
 
 #if !UCONFIG_NO_FORMATTING
 
 #include "currfmt.h"
 #include "unicode/numfmt.h"
+#include "unicode/curramt.h"
 
 U_NAMESPACE_BEGIN
 
 CurrencyFormat::CurrencyFormat(const Locale& locale, UErrorCode& ec) :
-    fmt(NULL) {
+    fmt(NULL)
+{
     fmt = NumberFormat::createCurrencyInstance(locale, ec);
 }
 
 CurrencyFormat::CurrencyFormat(const CurrencyFormat& other) :
-    MeasureFormat(other), fmt(NULL) {
+    MeasureFormat(other), fmt(NULL)
+{
     fmt = (NumberFormat*) other.fmt->clone();
 }
 
@@ -35,7 +40,7 @@ UBool CurrencyFormat::operator==(const Format& other) const {
     if (this == &other) {
         return TRUE;
     }
-    if (other.getDynamicClassID() != CurrencyFormat::getStaticClassID()) {
+    if (typeid(*this) != typeid(other)) {
         return FALSE;
     }
     const CurrencyFormat* c = (const CurrencyFormat*) &other;
@@ -49,26 +54,19 @@ Format* CurrencyFormat::clone() const {
 UnicodeString& CurrencyFormat::format(const Formattable& obj,
                                       UnicodeString& appendTo,
                                       FieldPosition& pos,
-                                      UErrorCode& ec) const {
+                                      UErrorCode& ec) const
+{
     return fmt->format(obj, appendTo, pos, ec);
 }
 
-UnicodeString& CurrencyFormat::format(const Formattable& obj,
-                                      UnicodeString& appendTo,
-                                      UErrorCode& ec) const {
-    return MeasureFormat::format(obj, appendTo, ec);
-}
-
 void CurrencyFormat::parseObject(const UnicodeString& source,
                                  Formattable& result,
-                                 ParsePosition& pos) const {
-    fmt->parseCurrency(source, result, pos);
-}
-
-void CurrencyFormat::parseObject(const UnicodeString& source,
-                                 Formattable& result,
-                                 UErrorCode& ec) const {
-    MeasureFormat::parseObject(source, result, ec);
+                                 ParsePosition& pos) const
+{
+    CurrencyAmount* currAmt = fmt->parseCurrency(source, pos);
+    if (currAmt != NULL) {
+        result.adoptObject(currAmt);
+    }
 }
 
 UOBJECT_DEFINE_RTTI_IMPLEMENTATION(CurrencyFormat)