Merge "BigInteger class implementation" into tizen
[platform/framework/native/appfw.git] / src / base / FBaseInteger.cpp
index 83027a1..49d0276 100644 (file)
@@ -26,6 +26,7 @@
 #include <FBaseResult.h>
 #include <FBaseCharacter.h>
 #include <FBaseSysLog.h>
+#include "FBase_NumberUtil.h"
 
 namespace Tizen { namespace Base
 {
@@ -84,53 +85,11 @@ Integer::Equals(const Object& obj) const
 result
 Integer::Decode(const String& s, int& ret)
 {
-       SysTryReturn(NID_BASE, s.GetLength() >= 1, E_NUM_FORMAT, E_NUM_FORMAT,
-               "[%s] The length of s MUST be greater than 0.", GetErrorMessage(E_NUM_FORMAT));
-
-       int radix = 0;
-       int startIndex = 0;
-       int minLength = 2;
-       wchar_t* pEnd = null;
-       String str(s);
-
-       if (s[0] == L'-' || s[0] == L'+')
-       {
-               startIndex = 1;
-               minLength = 3;
-       }
-
-       // Find radix
-       if (s[startIndex] == L'#')
-       {
-               radix = Character::RADIX_HEXADECIMAL;
-
-               // Remove '#'
-               str.Remove(startIndex, 1);
-       }
-       else if (s[startIndex] == L'0' && (s.GetLength() >= minLength))
-       {
-               if (s[startIndex + 1] == L'x' || s[startIndex + 1] == L'X')
-               {
-                       radix = Character::RADIX_HEXADECIMAL;
-               }
-               else
-               {
-                       radix = Character::RADIX_OCTAL;
-               }
-       }
-       else
-       {
-               radix = Character::RADIX_DECIMAL;
-       }
-
-       errno = 0;
-       ret = wcstol(str.GetPointer(), &pEnd, radix);
-       SysTryReturn(NID_BASE, (pEnd[0] == 0), E_NUM_FORMAT, E_NUM_FORMAT,
-               "[%s] Integer decode failed. Scan stopped at (%ls).", GetErrorMessage(E_NUM_FORMAT), pEnd);
-       SysTryReturn(NID_BASE, !((ret == LONG_MAX || ret == LONG_MIN) && (errno != 0)), E_NUM_FORMAT, E_NUM_FORMAT,
-               "[%s] Decoded value cannot fit into an Integer.", GetErrorMessage(E_NUM_FORMAT));
-
-       return E_SUCCESS;
+       long value;
+       result r = _NumberUtil::Decode(s, value);
+       SysTryReturnResult(NID_BASE, r == E_SUCCESS, r, "Propagating.");
+       ret = static_cast< int >(value);
+       return r;
 }
 
 int
@@ -148,34 +107,16 @@ Integer::GetHashCode(int val)
 result
 Integer::Parse(const String& s, int& ret)
 {
-       int len = s.GetLength();
-       SysTryReturn(NID_BASE, (len > 0 && len < 12), E_NUM_FORMAT, E_NUM_FORMAT,
-               "[%s] The length of s(%ls) MUST be greater than 0 and less than 12.",
-               GetErrorMessage(E_NUM_FORMAT), s.GetPointer());
-
        return Parse(s, Character::RADIX_DECIMAL, ret);
 }
 
 result
 Integer::Parse(const String& s, int radix, int& ret)
 {
-       SysTryReturn(NID_BASE, ((radix == Character::RADIX_BINARY) || (radix == Character::RADIX_OCTAL) ||
-               (radix == Character::RADIX_DECIMAL) || (radix == Character::RADIX_HEXADECIMAL)), E_OUT_OF_RANGE, E_OUT_OF_RANGE,
-               "[%s] The radix(%d) MUST be one of 2, 8, 10 and 16.", GetErrorMessage(E_OUT_OF_RANGE), radix);
-
-       int len = s.GetLength();
-       SysTryReturn(NID_BASE, (len > 0), E_NUM_FORMAT, E_NUM_FORMAT, "[%s] The length of s MUST be greater than 0.",
-               GetErrorMessage(E_NUM_FORMAT));
-
-       errno = 0;
-       wchar_t* pEnd = null;
-       int tmpRet = wcstol(s.GetPointer(), &pEnd, radix);
-       SysTryReturn(NID_BASE, (pEnd[0] == 0), E_NUM_FORMAT, E_NUM_FORMAT,
-               "[%s] Integer parse failed. Scan stopped at (%ls).", GetErrorMessage(E_NUM_FORMAT), pEnd);
-       SysTryReturn(NID_BASE, !((tmpRet == LONG_MAX || tmpRet == LONG_MIN) && (errno != 0)), E_NUM_FORMAT, E_NUM_FORMAT,
-               "[%s] Parsed value cannot fit into an Integer.", GetErrorMessage(E_NUM_FORMAT));
-
-       ret = tmpRet;
+       long value;
+       result r = _NumberUtil::Parse(s, radix, value);
+       SysTryReturnResult(NID_BASE, r == E_SUCCESS, r, "Propagating.");
+       ret = static_cast< int >(value);
        return E_SUCCESS;
 }
 
@@ -185,6 +126,12 @@ Integer::ToChar(void) const
        return static_cast< char >(value);
 }
 
+int8_t
+Integer::ToInt8(void) const
+{
+       return static_cast< int8_t >(value);
+}
+
 short
 Integer::ToShort(void) const
 {