12#include "MantidKernel/DllConfig.h"
18#include <boost/lexical_cast.hpp>
53template <
typename ITERATOR_TYPE>
54DLLExport std::string
simpleJoin(ITERATOR_TYPE begin, ITERATOR_TYPE end,
const std::string &separator) {
55 std::ostringstream output;
57 for (it = begin; it != end;) {
83template <
typename ITERATOR_TYPE>
85join(ITERATOR_TYPE begin, ITERATOR_TYPE end,
const std::string &separator,
86 typename std::enable_if<!(std::is_same<
typename std::iterator_traits<ITERATOR_TYPE>::iterator_category,
87 std::random_access_iterator_tag>
::value)>::type * =
nullptr) {
110template <
typename ITERATOR_TYPE>
112join(ITERATOR_TYPE begin, ITERATOR_TYPE end,
const std::string &separator,
113 typename std::enable_if<(std::is_same<
typename std::iterator_traits<ITERATOR_TYPE>::iterator_category,
114 std::random_access_iterator_tag>
::value)>::type * =
nullptr) {
120 int min_size = 500 * nmaxThreads;
123 int dist =
static_cast<int>(std::distance(begin, end));
125 if (dist < min_size) {
134 std::vector<std::string> output(nmaxThreads);
135 size_t stream_size = 0;
139#pragma omp parallel reduction(+ : stream_size)
145 std::ostringstream thread_stream;
158#pragma omp for schedule(static)
159 for (
int i = 0; i < dist; i++) {
160 thread_stream << separator << *(begin + i);
162 output[idThread] = thread_stream.str();
163 stream_size += output[idThread].length();
167 std::string master_string = output[0].erase(0, separator.length());
168 master_string.reserve(stream_size - separator.length());
172 for (
int i = 1; i < nThreads; i++) {
173 master_string += output[i];
176 return master_string;
197template <
typename ITERATOR_TYPE>
199 const std::string &listSeparator =
"-") {
204 std::stringstream result;
206 ITERATOR_TYPE i = begin;
210 ITERATOR_TYPE previousValue = i;
213 std::string currentSeparator = separator;
214 for (; i != end; ++i) {
216 if (*i == (*previousValue + 1)) {
217 currentSeparator = listSeparator;
219 if (currentSeparator == listSeparator) {
221 result << currentSeparator;
222 result << *previousValue;
223 currentSeparator = separator;
226 result << currentSeparator;
232 if (currentSeparator == listSeparator) {
233 result << currentSeparator;
234 result << *previousValue;
239MANTID_KERNEL_DLL std::string
shorten(
const std::string &input,
const size_t max_length);
242MANTID_KERNEL_DLL std::string
replace(
const std::string &input,
const std::string &find_what,
243 const std::string &replace_with);
246MANTID_KERNEL_DLL std::string
replaceAll(std::string
const &input,
char const to_replace,
char const substitute);
250MANTID_KERNEL_DLL std::string
replaceAll(
const std::string &input,
const std::string &charStr,
251 const std::string &substitute);
254MANTID_KERNEL_DLL std::string
toLower(
const std::string &input);
257MANTID_KERNEL_DLL std::string
toUpper(
const std::string &input);
260MANTID_KERNEL_DLL
bool endsWith(std::string
const &str, std::string
const &suffix);
263MANTID_KERNEL_DLL
int confirmStr(
const std::string &S,
const std::string &fullPhrase);
265MANTID_KERNEL_DLL
int extractWord(std::string &
Line,
const std::string &Word,
const int cnt = 4);
267MANTID_KERNEL_DLL
int endsWithInt(
const std::string &word);
270MANTID_KERNEL_DLL std::string
removeSpace(
const std::string &CLine);
272MANTID_KERNEL_DLL std::string
fullBlock(
const std::string &A);
274MANTID_KERNEL_DLL std::string strip(
const std::string &A);
280MANTID_KERNEL_DLL
int isEmpty(
const std::string &A);
282MANTID_KERNEL_DLL
bool skipLine(
const std::string &line);
285MANTID_KERNEL_DLL std::string
getLine(std::istream &fh);
288MANTID_KERNEL_DLL
void getLine(std::istream &fh, std::string &
Line);
290MANTID_KERNEL_DLL std::string
peekLine(std::istream &fh);
292MANTID_KERNEL_DLL
int getPartLine(std::istream &fh, std::string &Out, std::string &Excess,
const int spc = 256);
295template <
typename T>
int convPartNum(
const std::string &A, T &out);
298template <
typename T>
int convert(
const std::string &A, T &out);
300template <
typename T>
int convert(
const char *A, T &out);
306template <
typename T> std::string
toString(
const std::vector<T> &
value);
309template <
typename T> std::string
toString(
const std::set<T> &
value);
311template <
typename T>
int setValues(
const std::string &
Line,
const std::vector<int> &Index, std::vector<T> &Out);
314template <
typename T>
int sectPartNum(std::string &A, T &out);
317template <
typename T>
int section(std::string &A, T &out);
319template <
typename T>
int section(
char *cA, T &out);
322template <
typename T>
int sectionMCNPX(std::string &A, T &out);
325MANTID_KERNEL_DLL
void writeMCNPX(
const std::string &
Line, std::ostream &OX);
328MANTID_KERNEL_DLL std::vector<std::string>
StrParts(
const std::string &Ln);
331MANTID_KERNEL_DLL std::map<std::string, std::string>
332splitToKeyValues(
const std::string &input,
const std::string &keyValSep =
"=",
const std::string &listSep =
",");
335template <
template <
typename T,
typename A>
class V,
typename T,
typename A>
336int writeFile(
const std::string &Fname,
const T &step,
const V<T, A> &
Y);
337template <
template <
typename T,
typename A>
class V,
typename T,
typename A>
338int writeFile(
const std::string &Fname,
const V<T, A> &
X,
const V<T, A> &
Y);
339template <
template <
typename T,
typename A>
class V,
typename T,
typename A>
340int writeFile(
const std::string &Fname,
const V<T, A> &
X,
const V<T, A> &
Y,
const V<T, A> &Err);
346MANTID_KERNEL_DLL
void readToEndOfLine(std::istream &in,
bool ConsumeEOL);
348MANTID_KERNEL_DLL std::string getWord(std::istream &in,
bool consumeEOL);
351MANTID_KERNEL_DLL
size_t split_path(
const std::string &path, std::vector<std::string> &path_components);
354MANTID_KERNEL_DLL std::string
loadFile(
const std::string &filename);
357MANTID_KERNEL_DLL
int isMember(
const std::vector<std::string> &
group,
const std::string &candidate);
361MANTID_KERNEL_DLL std::vector<int>
parseRange(
const std::string &str,
const std::string &elemSep =
",",
362 const std::string &rangeSep =
"-");
366template <
typename Integer> std::vector<std::vector<Integer>>
parseGroups(
const std::string &str) {
367 std::vector<std::vector<Integer>> groups;
370 auto translateAdd = [&groups](
const std::string &str) {
373 std::vector<Integer> currentGroup;
374 currentGroup.reserve(tokens.count());
375 std::transform(tokens.cbegin(), tokens.cend(), std::back_inserter(currentGroup),
376 [](
const auto &t) { return boost::lexical_cast<Integer>(t); });
377 groups.emplace_back(std::move(currentGroup));
380 auto translateSumRange = [&groups](
const std::string &str) {
384 if (tokens.count() != 2)
385 throw std::runtime_error(
"Malformed range (-) operation.");
386 Integer first = boost::lexical_cast<Integer>(tokens[0]);
387 Integer last = boost::lexical_cast<Integer>(tokens[1]);
389 std::swap(first, last);
391 std::vector<Integer>
group;
392 group.reserve(last - first + 1);
393 for (Integer i = first; i <= last; ++i)
394 group.emplace_back(i);
396 groups.emplace_back(std::move(
group));
399 auto translateRange = [&groups](
const std::string &str) {
403 if (tokens.count() != 2)
404 throw std::runtime_error(
"Malformed range (:) operation.");
405 Integer first = boost::lexical_cast<Integer>(tokens[0]);
406 Integer last = boost::lexical_cast<Integer>(tokens[1]);
408 std::swap(first, last);
410 for (Integer i = first; i <= last; ++i) {
411 groups.emplace_back(1, i);
419 for (
const auto &token : tokens) {
422 if (token.find(
'+') != std::string::npos) {
424 }
else if (token.find(
'-') != std::string::npos) {
425 translateSumRange(token);
426 }
else if (token.find(
':') != std::string::npos) {
427 translateRange(token);
428 }
else if (!token.empty()) {
430 groups.emplace_back(1, boost::lexical_cast<Integer>(token));
433 }
catch (boost::bad_lexical_cast &) {
434 throw std::runtime_error(
"Cannot parse numbers from string: '" + str +
"'");
445MANTID_KERNEL_DLL std::string randomString(
const size_t len);
448MANTID_KERNEL_DLL std::istream &
extractToEOL(std::istream &is, std::string &str);
457MANTID_KERNEL_DLL std::string strmakef(
char const *
const fmt, ...);
double value
The value of the point.
#define PARALLEL_THREAD_NUMBER
#define PARALLEL_NUMBER_OF_THREADS
#define PARALLEL_GET_MAX_THREADS
#define DLLExport
Definitions of the DLLImport compiler directives for MSVC.
@ TOK_IGNORE_EMPTY
ignore empty tokens
@ TOK_TRIM
remove leading and trailing whitespace from tokens
Holds support functions for strings.
MANTID_KERNEL_DLL void stripInPlace(std::string &A)
strip pre/post spaces
MANTID_KERNEL_DLL std::string removeSpace(const std::string &CLine)
strip all spaces
MANTID_KERNEL_DLL std::string toLower(const std::string &input)
Converts string to all lowercase.
MANTID_KERNEL_DLL std::istream & extractToEOL(std::istream &is, std::string &str)
Extract a line from input stream, discarding any EOL characters encountered.
int sectPartNum(std::string &A, T &out)
Convert and cut a string.
MANTID_KERNEL_DLL size_t split_path(const std::string &path, std::vector< std::string > &path_components)
function parses a path, found in input string "path" and returns vector of the folders contributed in...
MANTID_KERNEL_DLL int confirmStr(const std::string &S, const std::string &fullPhrase)
determine if a character group exists in a string
float getVAXnum(const float A)
Convert a VAX number to x86 little eindien.
DLLExport std::string joinCompress(ITERATOR_TYPE begin, ITERATOR_TYPE end, const std::string &separator=",", const std::string &listSeparator="-")
Join a set or vector of (something that turns into a string) together into one string,...
MANTID_KERNEL_DLL std::vector< int > parseRange(const std::string &str, const std::string &elemSep=",", const std::string &rangeSep="-")
Parses a number range, e.g.
MANTID_KERNEL_DLL std::string shorten(const std::string &input, const size_t max_length)
Converts long strings into "start ... end".
int convPartNum(const std::string &A, T &out)
Takes a character string and evaluates the first [typename T] object.
MANTID_KERNEL_DLL int isMember(const std::vector< std::string > &group, const std::string &candidate)
checks if the candidate is the member of the group
DLLExport std::string join(ITERATOR_TYPE begin, ITERATOR_TYPE end, const std::string &separator, typename std::enable_if<!(std::is_same< typename std::iterator_traits< ITERATOR_TYPE >::iterator_category, std::random_access_iterator_tag >::value)>::type *=nullptr)
Join a set or vector of (something that turns into a string) together into one string,...
MANTID_KERNEL_DLL std::string replace(const std::string &input, const std::string &find_what, const std::string &replace_with)
Return a string with all matching occurence-strings.
int section(std::string &A, T &out)
Convert and cut a string.
MANTID_KERNEL_DLL std::string peekLine(std::istream &fh)
Peek at a line without extracting it from the stream.
std::vector< std::vector< Integer > > parseGroups(const std::string &str)
Parses unsigned integer groups, e.g.
MANTID_KERNEL_DLL std::string replaceAll(std::string const &input, char const to_replace, char const substitute)
Return a string with all occurrences of indicated character replaced by the new character.
MANTID_KERNEL_DLL std::string fullBlock(const std::string &A)
strip pre/post spaces
MANTID_KERNEL_DLL bool skipLine(const std::string &line)
Determines if a string starts with a #.
int sectionMCNPX(std::string &A, T &out)
Convert and cut a string for MCNPX.
MANTID_KERNEL_DLL std::string loadFile(const std::string &filename)
Loads the entire contents of a text file into a string.
MANTID_KERNEL_DLL std::vector< std::string > StrParts(std::string, const boost::regex &)
Split a line into component parts.
MANTID_KERNEL_DLL std::string toUpper(const std::string &input)
Converts string to all uppercase.
MANTID_KERNEL_DLL bool endsWith(std::string const &str, std::string const &suffix)
Checks if string ends with a suffix.
MANTID_KERNEL_DLL int endsWithInt(const std::string &word)
Get an int from the end of a word.
MANTID_KERNEL_DLL void writeMCNPX(const std::string &Line, std::ostream &OX)
Write file in standard MCNPX input form.
MANTID_KERNEL_DLL std::string getLine(std::istream &fh)
Get a line and strip comments Use only for a single call.
MANTID_KERNEL_DLL void stripComment(std::string &A)
strip trailling comments
MANTID_KERNEL_DLL int extractWord(std::string &Line, const std::string &Word, const int cnt=4)
Get a word from a string.
MANTID_KERNEL_DLL std::map< std::string, std::string > splitToKeyValues(const std::string &input, const std::string &keyValSep="=", const std::string &listSep=",")
Splits a string into key value pairs.
int setValues(const std::string &Line, const std::vector< int > &Index, std::vector< T > &Out)
Call to read in various values in position x1,x2,x3 from the line.
MANTID_KERNEL_DLL int isEmpty(const std::string &A)
Determines if a string is only spaces.
int writeFile(const std::string &Fname, const T &step, const V< T, A > &Y)
Write a set of containers to a file.
DLLExport std::string simpleJoin(ITERATOR_TYPE begin, ITERATOR_TYPE end, const std::string &separator)
Join a set or vector of (something that turns into a string) together into one string,...
MANTID_KERNEL_DLL int getPartLine(std::istream &fh, std::string &Out, std::string &Excess, const int spc=256)
get a part of a long line
std::string toString(const T &value)
Convert values to strings.
Helper class which provides the Collimation Length for SANS instruments.