root/OpenSceneGraph/trunk/src/osg/Math.cpp @ 13041

Revision 13041, 3.4 kB (checked in by robert, 2 years ago)

Ran script to remove trailing spaces and tabs

  • Property svn:eol-style set to native
Line 
1/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2006 Robert Osfield
2 *
3 * This library is open source and may be redistributed and/or modified under
4 * the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
5 * (at your option) any later version.  The full license is in LICENSE file
6 * included with this distribution, and on the openscenegraph.org website.
7 *
8 * This library is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11 * OpenSceneGraph Public License for more details.
12*/
13
14#include <osg/Math>
15
16#include <string.h>
17
18
19double osg::asciiToDouble(const char* str)
20{
21    const char* ptr = str;
22
23    // check if could be a hex number.
24    if (strncmp(ptr,"0x",2)==0)
25    {
26
27        double value = 0.0;
28
29        // skip over leading 0x, and then go through rest of string
30        // checking to make sure all values are 0...9 or a..f.
31        ptr+=2;
32        while (
33               *ptr!=0 &&
34               ((*ptr>='0' && *ptr<='9') ||
35                (*ptr>='a' && *ptr<='f') ||
36                (*ptr>='A' && *ptr<='F'))
37              )
38        {
39            if (*ptr>='0' && *ptr<='9') value = value*16.0 + double(*ptr-'0');
40            else if (*ptr>='a' && *ptr<='f') value = value*16.0 + double(*ptr-'a'+10);
41            else if (*ptr>='A' && *ptr<='F') value = value*16.0 + double(*ptr-'A'+10);
42            ++ptr;
43        }
44
45        // OSG_NOTICE<<"Read "<<str<<" result = "<<value<<std::endl;
46        return value;
47    }
48
49    ptr = str;
50
51    bool    hadDecimal[2];
52    double  value[2];
53    double  sign[2];
54    double  decimalMultiplier[2];
55
56    hadDecimal[0] = hadDecimal[1] = false;
57    sign[0] = sign[1] = 1.0;
58    value[0] = value[1] = 0.0;
59    decimalMultiplier[0] = decimalMultiplier[1] = 0.1;
60    int pos = 0;
61
62    // compute mantissa and exponent parts
63    while (*ptr!=0 && pos<2)
64    {
65        if (*ptr=='+')
66        {
67            sign[pos] = 1.0;
68        }
69        else if (*ptr=='-')
70        {
71            sign[pos] = -1.0;
72        }
73        else if (*ptr>='0' && *ptr<='9')
74        {
75            if (!hadDecimal[pos])
76            {
77                value[pos] = value[pos]*10.0 + double(*ptr-'0');
78            }
79            else
80            {
81                value[pos] = value[pos] + decimalMultiplier[pos] * double(*ptr-'0');
82                decimalMultiplier[pos] *= 0.1;
83            }
84        }
85        else if (*ptr=='.')
86        {
87            hadDecimal[pos] = true;
88        }
89        else if (*ptr=='e' || *ptr=='E')
90        {
91            if (pos==1) break;
92
93            pos = 1;
94        }
95        else
96        {
97            break;
98        }
99        ++ptr;
100    }
101
102    if (pos==0)
103    {
104        // OSG_NOTICE<<"Read "<<str<<" result = "<<value[0]*sign[0]<<std::endl;
105        return value[0]*sign[0];
106    }
107    else
108    {
109        double mantissa = value[0]*sign[0];
110        double exponent = value[1]*sign[1];
111        //OSG_NOTICE<<"Read "<<str<<" mantissa = "<<mantissa<<" exponent="<<exponent<<" result = "<<mantissa*pow(10.0,exponent)<<std::endl;
112        return mantissa*pow(10.0,exponent);
113    }
114}
115
116double osg::findAsciiToDouble(const char* str)
117{
118   const char* ptr = str;
119   double value = 0.0;
120
121   while(*ptr != 0) {
122
123       if(*ptr>='0' && *ptr<='9') {
124           value = asciiToDouble(ptr);
125           return value;
126       }
127
128       ++ptr;
129   }
130
131   return 0.0;
132}
Note: See TracBrowser for help on using the browser.