Mantid
Loading...
Searching...
No Matches
Strings.h
Go to the documentation of this file.
1// Mantid Repository : https://github.com/mantidproject/mantid
2//
3// Copyright © 2007 ISIS Rutherford Appleton Laboratory UKRI,
4// NScD Oak Ridge National Laboratory, European Spallation Source,
5// Institut Laue - Langevin & CSNS, Institute of High Energy Physics, CAS
6// SPDX - License - Identifier: GPL - 3.0 +
7#pragma once
8
9//----------------------------------------------------------------------
10// Includes
11//----------------------------------------------------------------------
12#include "MantidKernel/DllConfig.h"
15#include "MantidKernel/System.h"
16
17#ifndef Q_MOC_RUN
18#include <boost/lexical_cast.hpp>
19#endif
20#include <iosfwd>
21#include <map>
22#include <set>
23#include <sstream>
24#include <string>
25#include <vector>
26
27namespace Mantid {
28namespace Kernel {
29
33namespace Strings {
34
35//------------------------------------------------------------------------------------------------
52template <typename ITERATOR_TYPE>
53DLLExport std::string simpleJoin(ITERATOR_TYPE begin, ITERATOR_TYPE end, const std::string &separator) {
54 std::ostringstream output;
55 ITERATOR_TYPE it;
56 for (it = begin; it != end;) {
57 output << *it;
58 it++;
59 if (it != end)
60 output << separator;
61 }
62 return output.str();
63}
64
65//------------------------------------------------------------------------------------------------
82template <typename ITERATOR_TYPE>
83DLLExport std::string
84join(ITERATOR_TYPE begin, ITERATOR_TYPE end, const std::string &separator,
85 typename std::enable_if<!(std::is_same<typename std::iterator_traits<ITERATOR_TYPE>::iterator_category,
86 std::random_access_iterator_tag>::value)>::type * = nullptr) {
87 return simpleJoin(begin, end, separator);
88}
89
90//------------------------------------------------------------------------------------------------
109template <typename ITERATOR_TYPE>
110DLLExport std::string
111join(ITERATOR_TYPE begin, ITERATOR_TYPE end, const std::string &separator,
112 typename std::enable_if<(std::is_same<typename std::iterator_traits<ITERATOR_TYPE>::iterator_category,
113 std::random_access_iterator_tag>::value)>::type * = nullptr) {
114
115 // Get max number of threads
116 int nmaxThreads = static_cast<int>(PARALLEL_GET_MAX_THREADS);
117
118 // Define minimum size for using threading
119 int min_size = 500 * nmaxThreads;
120
121 // Get the distance between begining and end
122 int dist = static_cast<int>(std::distance(begin, end));
123
124 if (dist < min_size) {
125
126 // If the input array is small, use the simpler function to avoid
127 // unnecessary overhead from generating the parallel section
128 return simpleJoin(begin, end, separator);
129
130 } else {
131
132 // Allocate vector space
133 std::vector<std::string> output(nmaxThreads);
134 size_t stream_size = 0;
135
136 // Actual number of threads in the current region
137 int nThreads = 1;
138#pragma omp parallel reduction(+ : stream_size)
139 {
140 nThreads = static_cast<int>(PARALLEL_NUMBER_OF_THREADS);
141 int idThread = static_cast<int>(PARALLEL_THREAD_NUMBER);
142
143 // Initialise ostringstream
144 std::ostringstream thread_stream;
145
146/* To make sure the loop is done in the right order, we use schedule(static).
147
148 From the OpenMP documentation:
149 "When schedule(static, chunk_size) is specified, iterations are divided into
150 chunks of size chunk_size, and the chunks are assigned to the threads in the
151 team in a round-robin fashion **in the order of the thread number**."
152
153 "When no chunk_size is specified, the iteration space is divided into chunks
154 that are approximately equal in size, and at most one chunk is distributed
155 to each thread."
156*/
157#pragma omp for schedule(static)
158 for (int i = 0; i < dist; i++) {
159 thread_stream << separator << *(begin + i);
160 }
161 output[idThread] = thread_stream.str();
162 stream_size += output[idThread].length();
163 }
164
165 // Reserve space in memory for output string
166 std::string master_string = output[0].erase(0, separator.length());
167 master_string.reserve(stream_size - separator.length());
168
169 // Concatenate the contributions from the remaning threads
170 // cppcheck-suppress knownConditionTrueFalse
171 for (int i = 1; i < nThreads; i++) {
172 master_string += output[i];
173 }
174
175 return master_string;
176 }
177}
178
179//------------------------------------------------------------------------------------------------
196template <typename ITERATOR_TYPE>
197DLLExport std::string joinCompress(ITERATOR_TYPE begin, ITERATOR_TYPE end, const std::string &separator = ",",
198 const std::string &listSeparator = "-") {
199
200 if (begin == end) {
201 return "";
202 }
203 std::stringstream result;
204
205 ITERATOR_TYPE i = begin;
206 // Always include the first value
207 result << *begin;
208 // move on to the next value
209 ITERATOR_TYPE previousValue = i;
210 ++i;
211
212 std::string currentSeparator = separator;
213 for (; i != end; ++i) {
214 // if it is one higher than the last value
215 if (*i == (*previousValue + 1)) {
216 currentSeparator = listSeparator;
217 } else {
218 if (currentSeparator == listSeparator) {
219 // add the last value that was the end of the list
220 result << currentSeparator;
221 result << *previousValue;
222 currentSeparator = separator;
223 }
224 // add the current value
225 result << currentSeparator;
226 result << *i;
227 }
228 previousValue = i;
229 }
230 // if we have got to the end and part of a list output the last value
231 if (currentSeparator == listSeparator) {
232 result << currentSeparator;
233 result << *previousValue;
234 }
235 return result.str();
236}
238MANTID_KERNEL_DLL std::string shorten(const std::string &input, const size_t max_length);
239
241MANTID_KERNEL_DLL std::string replace(const std::string &input, const std::string &find_what,
242 const std::string &replace_with);
243
245MANTID_KERNEL_DLL std::string replaceAll(std::string const &input, char const to_replace, char const substitute);
246
249MANTID_KERNEL_DLL std::string replaceAll(const std::string &input, const std::string &charStr,
250 const std::string &substitute);
251
253MANTID_KERNEL_DLL std::string toLower(const std::string &input);
254
256MANTID_KERNEL_DLL std::string toUpper(const std::string &input);
257
259MANTID_KERNEL_DLL bool endsWith(std::string const &str, std::string const &suffix);
260
262MANTID_KERNEL_DLL int confirmStr(const std::string &S, const std::string &fullPhrase);
264MANTID_KERNEL_DLL int extractWord(std::string &Line, const std::string &Word, const int cnt = 4);
266MANTID_KERNEL_DLL int endsWithInt(const std::string &word);
267
269MANTID_KERNEL_DLL std::string removeSpace(const std::string &CLine);
271MANTID_KERNEL_DLL std::string fullBlock(const std::string &A);
273MANTID_KERNEL_DLL std::string strip(const std::string &A);
275MANTID_KERNEL_DLL void stripInPlace(std::string &A);
277MANTID_KERNEL_DLL void stripComment(std::string &A);
279MANTID_KERNEL_DLL int isEmpty(const std::string &A);
281MANTID_KERNEL_DLL bool skipLine(const std::string &line);
284MANTID_KERNEL_DLL std::string getLine(std::istream &fh);
287MANTID_KERNEL_DLL void getLine(std::istream &fh, std::string &Line);
289MANTID_KERNEL_DLL std::string peekLine(std::istream &fh);
291MANTID_KERNEL_DLL int getPartLine(std::istream &fh, std::string &Out, std::string &Excess, const int spc = 256);
292
294template <typename T> int convPartNum(const std::string &A, T &out);
295
297template <typename T> int convert(const std::string &A, T &out);
299template <typename T> int convert(const char *A, T &out);
300
302template <typename T> std::string toString(const T &value);
303
305template <typename T> std::string toString(const std::vector<T> &value);
306
308template <typename T> std::string toString(const std::set<T> &value);
309
310template <typename T> int setValues(const std::string &Line, const std::vector<int> &Index, std::vector<T> &Out);
311
313template <typename T> int sectPartNum(std::string &A, T &out);
314
316template <typename T> int section(std::string &A, T &out);
318template <typename T> int section(char *cA, T &out);
319
321template <typename T> int sectionMCNPX(std::string &A, T &out);
322
324MANTID_KERNEL_DLL void writeMCNPX(const std::string &Line, std::ostream &OX);
325
327MANTID_KERNEL_DLL std::vector<std::string> StrParts(const std::string &Ln);
328
330MANTID_KERNEL_DLL std::map<std::string, std::string>
331splitToKeyValues(const std::string &input, const std::string &keyValSep = "=", const std::string &listSep = ",");
332
334template <template <typename T, typename A> class V, typename T, typename A>
335int writeFile(const std::string &Fname, const T &step, const V<T, A> &Y);
336template <template <typename T, typename A> class V, typename T, typename A>
337int writeFile(const std::string &Fname, const V<T, A> &X, const V<T, A> &Y);
338template <template <typename T, typename A> class V, typename T, typename A>
339int writeFile(const std::string &Fname, const V<T, A> &X, const V<T, A> &Y, const V<T, A> &Err);
340
342float getVAXnum(const float A);
343
345MANTID_KERNEL_DLL void readToEndOfLine(std::istream &in, bool ConsumeEOL);
347MANTID_KERNEL_DLL std::string getWord(std::istream &in, bool consumeEOL);
350MANTID_KERNEL_DLL size_t split_path(const std::string &path, std::vector<std::string> &path_components);
351
353MANTID_KERNEL_DLL std::string loadFile(const std::string &filename);
354
356MANTID_KERNEL_DLL int isMember(const std::vector<std::string> &group, const std::string &candidate);
357
360MANTID_KERNEL_DLL std::vector<int> parseRange(const std::string &str, const std::string &elemSep = ",",
361 const std::string &rangeSep = "-");
362
365template <typename Integer> std::vector<std::vector<Integer>> parseGroups(const std::string &str) {
366 std::vector<std::vector<Integer>> groups;
367
368 // Local helper functions.
369 auto translateAdd = [&groups](const std::string &str) {
370 const auto tokens = Kernel::StringTokenizer(
372 std::vector<Integer> currentGroup;
373 currentGroup.reserve(tokens.count());
374 std::transform(tokens.cbegin(), tokens.cend(), std::back_inserter(currentGroup),
375 [](const auto &t) { return boost::lexical_cast<Integer>(t); });
376 groups.emplace_back(std::move(currentGroup));
377 };
378
379 auto translateSumRange = [&groups](const std::string &str) {
380 // add a group with the numbers in the range
381 const auto tokens = Kernel::StringTokenizer(
383 if (tokens.count() != 2)
384 throw std::runtime_error("Malformed range (-) operation.");
385 Integer first = boost::lexical_cast<Integer>(tokens[0]);
386 Integer last = boost::lexical_cast<Integer>(tokens[1]);
387 if (first > last)
388 std::swap(first, last);
389 // add all the numbers in the range to the output group
390 std::vector<Integer> group;
391 group.reserve(last - first + 1);
392 for (Integer i = first; i <= last; ++i)
393 group.emplace_back(i);
394 if (!group.empty())
395 groups.emplace_back(std::move(group));
396 };
397
398 auto translateRange = [&groups](const std::string &str) {
399 // add a group per number
400 const auto tokens = Kernel::StringTokenizer(
402 if (tokens.count() != 2)
403 throw std::runtime_error("Malformed range (:) operation.");
404 Integer first = boost::lexical_cast<Integer>(tokens[0]);
405 Integer last = boost::lexical_cast<Integer>(tokens[1]);
406 if (first > last)
407 std::swap(first, last);
408 // add all the numbers in the range to separate output groups
409 for (Integer i = first; i <= last; ++i) {
410 groups.emplace_back(1, i);
411 }
412 };
413
414 try {
415 // split into comma separated groups, each group potentially containing
416 // an operation (+-:) that produces even more groups.
418 for (const auto &token : tokens) {
419 // Look for the various operators in the string. If one is found then
420 // do the necessary translation into groupings.
421 if (token.find('+') != std::string::npos) {
422 translateAdd(token);
423 } else if (token.find('-') != std::string::npos) {
424 translateSumRange(token);
425 } else if (token.find(':') != std::string::npos) {
426 translateRange(token);
427 } else if (!token.empty()) {
428 // contains a single number, just add it as a new group
429 groups.emplace_back(1, boost::lexical_cast<Integer>(token));
430 }
431 }
432 } catch (boost::bad_lexical_cast &) {
433 throw std::runtime_error("Cannot parse numbers from string: '" + str + "'");
434 }
435
436 return groups;
437}
438
444MANTID_KERNEL_DLL std::string randomString(const size_t len);
445
447MANTID_KERNEL_DLL std::istream &extractToEOL(std::istream &is, std::string &str);
448
456MANTID_KERNEL_DLL std::string strmakef(char const *const fmt, ...);
457
458} // NAMESPACE Strings
459
460} // NAMESPACE Kernel
461
462} // NAMESPACE Mantid
double value
The value of the point.
Definition FitMW.cpp:51
#define PARALLEL_THREAD_NUMBER
#define PARALLEL_NUMBER_OF_THREADS
#define PARALLEL_GET_MAX_THREADS
#define DLLExport
Definitions of the DLLImport compiler directives for MSVC.
Definition System.h:37
Impliments a line.
Definition Line.h:43
@ 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
Definition Strings.cpp:429
MANTID_KERNEL_DLL std::string removeSpace(const std::string &CLine)
strip all spaces
Definition Strings.cpp:322
MANTID_KERNEL_DLL std::string toLower(const std::string &input)
Converts string to all lowercase.
Definition Strings.cpp:129
MANTID_KERNEL_DLL std::istream & extractToEOL(std::istream &is, std::string &str)
Extract a line from input stream, discarding any EOL characters encountered.
Definition Strings.cpp:1167
MANTID_KERNEL_DLL std::string strmakef(char const *const fmt,...)
This is the constructor that std::string needed to have.
Definition Strings.cpp:1205
int sectPartNum(std::string &A, T &out)
Convert and cut a string.
Definition Strings.cpp:558
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...
Definition Strings.cpp:1001
MANTID_KERNEL_DLL int confirmStr(const std::string &S, const std::string &fullPhrase)
determine if a character group exists in a string
Definition Strings.cpp:261
float getVAXnum(const float A)
Convert a VAX number to x86 little eindien.
Definition Strings.cpp:522
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,...
Definition Strings.h:197
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.
Definition Strings.cpp:1101
MANTID_KERNEL_DLL std::string shorten(const std::string &input, const size_t max_length)
Converts long strings into "start ... end".
Definition Strings.cpp:52
int convPartNum(const std::string &A, T &out)
Takes a character string and evaluates the first [typename T] object.
Definition Strings.cpp:670
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
Definition Strings.cpp:1080
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,...
Definition Strings.h:84
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.
Definition Strings.cpp:72
int section(std::string &A, T &out)
Convert and cut a string.
Definition Strings.cpp:604
MANTID_KERNEL_DLL std::string peekLine(std::istream &fh)
Peek at a line without extracting it from the stream.
Definition Strings.cpp:366
std::vector< std::vector< Integer > > parseGroups(const std::string &str)
Parses unsigned integer groups, e.g.
Definition Strings.h:365
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.
Definition Strings.cpp:90
MANTID_KERNEL_DLL std::string fullBlock(const std::string &A)
strip pre/post spaces
Definition Strings.cpp:411
MANTID_KERNEL_DLL bool skipLine(const std::string &line)
Determines if a string starts with a #.
Definition Strings.cpp:439
int sectionMCNPX(std::string &A, T &out)
Convert and cut a string for MCNPX.
Definition Strings.cpp:634
MANTID_KERNEL_DLL std::string loadFile(const std::string &filename)
Loads the entire contents of a text file into a string.
Definition Strings.cpp:26
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.
Definition Strings.cpp:137
MANTID_KERNEL_DLL bool endsWith(std::string const &str, std::string const &suffix)
Checks if string ends with a suffix.
Definition Strings.cpp:145
MANTID_KERNEL_DLL int endsWithInt(const std::string &word)
Get an int from the end of a word.
Definition Strings.cpp:232
MANTID_KERNEL_DLL void writeMCNPX(const std::string &Line, std::ostream &OX)
Write file in standard MCNPX input form.
Definition Strings.cpp:452
MANTID_KERNEL_DLL std::string getLine(std::istream &fh)
Get a line and strip comments Use only for a single call.
Definition Strings.cpp:341
MANTID_KERNEL_DLL void stripComment(std::string &A)
strip trailling comments
Definition Strings.cpp:392
MANTID_KERNEL_DLL int extractWord(std::string &Line, const std::string &Word, const int cnt=4)
Get a word from a string.
Definition Strings.cpp:208
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.
Definition Strings.cpp:500
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.
Definition Strings.cpp:875
MANTID_KERNEL_DLL int isEmpty(const std::string &A)
Determines if a string is only spaces.
Definition Strings.cpp:381
int writeFile(const std::string &Fname, const T &step, const V< T, A > &Y)
Write a set of containers to a file.
Definition Strings.cpp:794
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,...
Definition Strings.h:53
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
Definition Strings.cpp:284
std::string toString(const T &value)
Convert values to strings.
Helper class which provides the Collimation Length for SANS instruments.