OpenFPGA/libs/libopenfpgautil/src/openfpga_tokenizer.cpp

168 lines
4.8 KiB
C++

/************************************************************************
* Member functions for StringToken class
***********************************************************************/
#include <cstring>
/* Headers from vtrutil library */
#include "openfpga_tokenizer.h"
#include "vtr_assert.h"
/* namespace openfpga begins */
namespace openfpga {
/************************************************************************
* Constructors
***********************************************************************/
StringToken::StringToken(const std::string& data) { set_data(data); }
/************************************************************************
* Public Accessors
***********************************************************************/
/* Get the data string */
std::string StringToken::data() const { return data_; }
/* Split the string using a given delim */
std::vector<std::string> StringToken::split(const std::string& delims) const {
/* Return vector */
std::vector<std::string> ret;
/* Get a writable char array */
char* tmp = new char[data_.size() + 1];
std::copy(data_.begin(), data_.end(), tmp);
tmp[data_.size()] = '\0';
/* Split using strtok */
char* result = std::strtok(tmp, delims.c_str());
while (NULL != result) {
std::string result_str(result);
/* Store the token */
ret.push_back(result_str);
/* Got to next */
result = std::strtok(NULL, delims.c_str());
}
/* Free the tmp */
delete[] tmp;
return ret;
}
/* Split the string using a given delim */
std::vector<std::string> StringToken::split(const char& delim) const {
/* Create delims */
std::string delims(1, delim);
return split(delims);
}
/* Split the string using a given delim */
std::vector<std::string> StringToken::split(const char* delim) const {
/* Create delims */
std::string delims(delim);
return split(delims);
}
/* Split the string using a given delim */
std::vector<std::string> StringToken::split(
const std::vector<char>& delims) const {
/* Create delims */
std::string delims_str;
for (const auto& delim : delims) {
delims_str.push_back(delim);
}
return split(delims_str);
}
/* Split the string */
std::vector<std::string> StringToken::split() {
/* Add a default delim */
if (true == delims_.empty()) {
add_default_delim();
}
/* Create delims */
std::string delims;
for (const auto& delim : delims_) {
delims.push_back(delim);
}
return split(delims);
}
std::vector<size_t> StringToken::find_positions(const char& delim) const {
std::vector<size_t> anchors;
size_t found = data_.find(delim);
while (std::string::npos != found) {
anchors.push_back(found);
found = data_.find(delim, found + 1);
}
return anchors;
}
std::vector<std::string> StringToken::split_by_chunks(
const char& chunk_delim, const bool& split_odd_chunk) const {
size_t chunk_idx_mod = 0;
if (split_odd_chunk) {
chunk_idx_mod = 1;
}
std::vector<std::string> tokens;
/* There are pairs of quotes, identify the chunk which should be split*/
std::vector<std::string> token_chunks = split(chunk_delim);
for (size_t ichunk = 0; ichunk < token_chunks.size(); ichunk++) {
/* Chunk with even index (including the first) is always out of two quote ->
* Split! Chunk with odd index is always between two quotes -> Do not split!
*/
if (ichunk % 2 == chunk_idx_mod) {
StringToken chunk_tokenizer(token_chunks[ichunk]);
for (std::string curr_token : chunk_tokenizer.split()) {
tokens.push_back(curr_token);
}
} else {
tokens.push_back(token_chunks[ichunk]);
}
}
return tokens;
}
/************************************************************************
* Public Mutators
***********************************************************************/
void StringToken::set_data(const std::string& data) {
data_ = data;
return;
}
/* Add a delima to the list */
void StringToken::add_delim(const char& delim) { delims_.push_back(delim); }
/* Remove the string repeated at the beginning of string */
void StringToken::ltrim(const std::string& sensitive_word) {
size_t start = data_.find_first_not_of(sensitive_word);
data_ = (start == std::string::npos) ? "" : data_.substr(start);
return;
}
/* Remove the string repeated at the end of string */
void StringToken::rtrim(const std::string& sensitive_word) {
size_t end = data_.find_last_not_of(sensitive_word);
data_ = (end == std::string::npos) ? "" : data_.substr(0, end + 1);
return;
}
void StringToken::trim() {
rtrim(" ");
ltrim(" ");
return;
}
/************************************************************************
* Internal Mutators
***********************************************************************/
void StringToken::add_default_delim() {
VTR_ASSERT_SAFE(true == delims_.empty());
delims_.push_back(' ');
return;
}
} // namespace openfpga