Line data Source code
1 : /* 2 : * ALMA - Atacama Large Millimeter Array 3 : * (c) European Southern Observatory, 2002 4 : * (c) Associated Universities Inc., 2002 5 : * Copyright by ESO (in the framework of the ALMA collaboration), 6 : * Copyright by AUI (in the framework of the ALMA collaboration), 7 : * All rights reserved. 8 : * 9 : * This library is free software; you can redistribute it and/or 10 : * modify it under the terms of the GNU Lesser General Public 11 : * License as published by the Free software Foundation; either 12 : * version 2.1 of the License, or (at your option) any later version. 13 : * 14 : * This library is distributed in the hope that it will be useful, 15 : * but WITHOUT ANY WARRANTY, without even the implied warranty of 16 : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 17 : * Lesser General Public License for more details. 18 : * 19 : * You should have received a copy of the GNU Lesser General Public 20 : * License along with this library; if not, write to the Free Software 21 : * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 22 : * MA 02111-1307 USA 23 : * 24 : * File Double.cpp 25 : */ 26 : 27 : #include <alma/ASDM/DoubleWrapper.h> 28 : #include <alma/ASDM/NumberFormatException.h> 29 : 30 : #include <sstream> 31 : 32 : #include <iostream> 33 : using namespace std; 34 : 35 : namespace asdm { 36 : 37 : const double Double::MAX_VALUE = 1.7976931348623157e+308; 38 : const double Double::MIN_VALUE = 4.9e-324; 39 : 40 13220442 : double Double::parseDouble(const string &s) { 41 13220442 : istringstream in; 42 13220442 : in.str(s); 43 : double x; 44 13220442 : in >> x; 45 13220442 : if (in.rdstate() == istream::failbit) 46 0 : throw NumberFormatException (s); 47 13220442 : return x; 48 13220442 : } 49 : 50 185058 : string Double::toString(double x) { 51 185058 : ostringstream out; 52 185058 : out.width(30); 53 185058 : out.precision(20); 54 185058 : out << x; 55 185058 : string s = out.str(); 56 185058 : int i = 0; 57 3680306 : while (i < 30 && s.at(i) == ' ') 58 3495248 : ++i; 59 370116 : return s.substr(i,s.length() - i); 60 185058 : } 61 : 62 : } // End namespace.