4#include "facilities/Util.h"
6#ifdef DEFECT_NO_STRINGSTREAM
23 const std::string& closeDel ) {
24 unsigned opLen = openDel.size();
25 unsigned clLen = closeDel.size();
28 int envStart = toExpand->find( openDel.c_str() );
29 while ( envStart != -1 )
31 int envEnd = toExpand->find( closeDel.c_str() );
34 int afterBracket = envStart + opLen;
36 if ( !( ( envStart == -1 ) || ( envEnd == -1 ) ) )
38 std::string envVariable = toExpand->substr( afterBracket, ( envEnd - afterBracket ) );
39 const char* path = getenv( envVariable.c_str() );
42 toExpand->replace( envStart, ( envEnd + clLen ), path );
43 if ( nSuccess > -1 ) nSuccess++;
47 std::cerr <<
"Util::expandEnvVar unable to translate " << envVariable << std::endl;
48 throw Untranslatable( envVariable );
51 envStart = toExpand->find( openDel.c_str() );
64 static char outCharPtr[20];
66#ifdef DEFECT_NO_STRINGSTREAM
69 std::ostrstream locStream( a, 100 );
71 std::ostringstream locStream;
75#ifdef DEFECT_NO_STRINGSTREAM
76 locStream << std::ends;
78 outStr = locStream.str();
79 strcpy( outCharPtr, outStr.c_str() );
95#ifdef DEFECT_NO_STRINGSTREAM
96 std::istrstream locStream( inStr.c_str() );
98 std::istringstream locStream( inStr );
101 if ( !locStream ) {
return 0; }
108 int nItem = sscanf( inStr.c_str(),
"%lg %1s", &val, junk );
109 if ( nItem != 1 ) {
throw WrongType( inStr,
"double" ); }
116 int nItem = sscanf( inStr.c_str(),
"%d %1s", &val, junk );
117 if ( nItem != 1 ) {
throw WrongType( inStr,
"int" ); }
122 std::vector<std::string>& tokens,
bool clear ) {
123 if ( clear ) tokens.clear();
125 std::string::size_type j;
126 while ( ( j = input.find_first_of( delimiters ) ) != std::string::npos )
128 if ( j != 0 ) tokens.push_back( input.substr( 0, j ) );
129 input = input.substr( j + 1 );
131 tokens.push_back( input );
132 if ( tokens.back() ==
"" ) tokens.pop_back();
136 std::map<std::string, std::string>& tokens,
137 const std::string& pairDelimiter,
bool clear ) {
138 if ( clear ) tokens.clear();
140 std::vector<std::string> strvec;
142 unsigned advance = pairDelimiter.size();
144 std::vector<std::string>::const_iterator input_itr = strvec.begin();
145 while ( input_itr != strvec.end() )
147 std::string current = *input_itr++;
148 std::string::size_type j = current.find( pairDelimiter );
149 std::string
key = current.substr( 0, j );
150 std::string value = current.substr( j + advance );
156 std::vector<std::string> names;
158 return *( names.end() - 1 );
162 static const char blank =
' ';
163 static const char LF = 0xA;
164 static const char FF = 0xC;
165 static const char CR = 0xD;
167 unsigned orig = toTrim->size();
168 unsigned last = orig - 1;
170 unsigned nTrimmed = 0;
174 char lastChar = ( *toTrim )[last];
184 default: notDone =
false;
break;
187 if ( nTrimmed ) toTrim->resize( orig - nTrimmed );
*************DOUBLE PRECISION m_pi *DOUBLE PRECISION m_HvecTau2 DOUBLE PRECISION m_HvClone2 DOUBLE PRECISION m_gamma1 DOUBLE PRECISION m_gamma2 DOUBLE PRECISION m_thet1 DOUBLE PRECISION m_thet2 INTEGER m_IFPHOT *COMMON c_Taupair $ !Spin Polarimeter vector first Tau $ !Spin Polarimeter vector second Tau $ !Clone Spin Polarimeter vector first Tau $ !Clone Spin Polarimeter vector second Tau $ !Random Euler angle for cloning st tau $ !Random Euler angle for cloning st tau $ !Random Euler angle for cloning st tau $ !Random Euler angle for cloning nd tau $ !Random Euler angle for cloning nd tau $ !Random Euler angle for cloning nd tau $ !phi of HvecTau1 $ !theta of HvecTau1 $ !phi of HvecTau2 $ !theta of HvecTau2 $ !super key
static double stringToDouble(const std::string &InStr)
static int expandEnvVar(std::string *toExpand, const std::string &openDel=std::string("$("), const std::string &closeDel=std::string(")"))
static void stringTokenize(std::string input, const std::string &delimiters, std::vector< std::string > &tokens, bool clear=true)
static int atoi(const std::string &InStr)
converts an std::string to an integer
static std::string basename(const std::string &path)
static int stringToInt(const std::string &InStr)
static void keyValueTokenize(std::string input, const std::string &delimiters, std::map< std::string, std::string > &tokenMap, const std::string &pairDelimiter=std::string("="), bool clear=true)
static const char * itoa(int val, std::string &outStr)
static unsigned trimTrailing(std::string *toTrim)
Exception class used when converting from string to numeric type.