// Copyright (C) XFX Team // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // // * Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above copyright // notice, this list of conditions and the following disclaimer in the // documentation and/or other materials provided with the distribution. // * Neither the name of the copyright holder nor the names of any // contributors may be used to endorse or promote products derived from // this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE // POSSIBILITY OF SUCH DAMAGE. #include #include #include #include #include #include namespace System { unsigned long long rawNaND = 0x7ff8000000000000ULL; unsigned long long rawPosInfD = 0x7ff0000000000000ULL; unsigned long long rawNegInfD = 0xfff0000000000000ULL; const double Double::Epsilon = 4.94066e-324; const double Double::MaxValue = 1.79769e+308; const double Double::MinValue = -1.79769e+308; const double Double::NaN = *(double *)&rawNaND; const double Double::PositiveInfinity = *(double *)&rawPosInfD; const double Double::NegativeInfinity = *(double *)&rawNegInfD; Double::Double(const Double &obj) : value(obj.value) { } Double::Double(const double &obj) : value(obj) { } int Double::CompareTo(const Double other) const { if (value > other.value) return 1; if (value < other.value) return -1; return 0; } bool Double::Equals(const Double other) const { return (*this == other); } int Double::GetHashCode() const { return (int)value; } int Double::GetType() const { return 14; } bool Double::TryParse(const String& str, out double* result) { sassert(!String::IsNullOrEmpty(str), String::Format("str; %s", FrameworkResources::ArgumentNull_Generic)); sassert(result, String::Format("result; %s", FrameworkResources::ArgumentNull_Generic)); *result = 0; char sign = 0; char *sp = const_cast((const char *)str.ToString()); if (*sp == '+' || *sp == '-') sign = *sp++; if (stricmp(sp, "inf") == 0) { if (!sign || sign == '+') *result = PositiveInfinity; else *result = NegativeInfinity; } else if (stricmp(sp, "nan") == 0) *result = NaN; else /* valid number */ *result = atof(sp); return true; } const String& Double::ToString() const { return String::Format("%g", value); } const String& Double::ToString(const double value) { return String::Format("%g", value); } Double::operator double() const { return value; } bool Double::operator !=(const Double& right) const { return (value != right.value); } bool Double::operator ==(const Double& right) const { return (value == right.value); } }