mirror of
https://github.com/red0124/ssp.git
synced 2025-01-23 04:55:20 +01:00
minor refactoring
This commit is contained in:
parent
5cd458e2bc
commit
a1ca012203
@ -10,7 +10,6 @@
|
||||
#include <vector>
|
||||
|
||||
// TODO rule of 5-3-1
|
||||
// TODO threads
|
||||
namespace ss {
|
||||
|
||||
template <typename... Matchers>
|
||||
@ -261,7 +260,6 @@ private:
|
||||
bool crlf;
|
||||
|
||||
bool escaped_eol(size_t size) {
|
||||
if constexpr (setup<Matchers...>::escape::enabled) {
|
||||
const char* curr;
|
||||
for (curr = next_line_buffer_ + size - 1;
|
||||
curr >= next_line_buffer_ &&
|
||||
@ -271,15 +269,10 @@ private:
|
||||
return (next_line_buffer_ - curr + size) % 2 == 0;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool unterminated_quote() {
|
||||
if constexpr (ss::setup<Matchers...>::quote::enabled) {
|
||||
if (next_line_converter_.unterminated_quote()) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -347,20 +340,24 @@ private:
|
||||
|
||||
size_t size = remove_eol(next_line_buffer_, ssize);
|
||||
|
||||
if constexpr (setup<Matchers...>::escape::enabled) {
|
||||
while (escaped_eol(size)) {
|
||||
if (!append_line(file, next_line_buffer_, size)) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
next_line_converter_.split(next_line_buffer_, delim_);
|
||||
|
||||
if constexpr (setup<Matchers...>::quote::enabled) {
|
||||
while (unterminated_quote()) {
|
||||
if (!append_line(file, next_line_buffer_, size)) {
|
||||
return false;
|
||||
}
|
||||
next_line_converter_.resplit(next_line_buffer_, size);
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -169,14 +169,6 @@ private:
|
||||
}
|
||||
}
|
||||
|
||||
void shift_if_escaped(line_ptr_type& curr) {
|
||||
if constexpr (escape::enabled) {
|
||||
if (escape::match(*curr)) {
|
||||
shift_and_jump_escape();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template <typename Delim>
|
||||
std::tuple<size_t, bool> match_delimiter(line_ptr_type begin,
|
||||
const Delim& delim) {
|
||||
@ -207,12 +199,14 @@ private:
|
||||
////////////////
|
||||
|
||||
void shift_and_set_current() {
|
||||
if (escaped_ > 0) {
|
||||
if constexpr (!is_const_line) {
|
||||
if (escaped_ > 0) {
|
||||
std::copy_n(curr_ + escaped_, end_ - curr_, curr_);
|
||||
}
|
||||
}
|
||||
curr_ = end_ - escaped_;
|
||||
return;
|
||||
}
|
||||
}
|
||||
curr_ = end_;
|
||||
}
|
||||
|
||||
void shift_and_push() {
|
||||
@ -220,11 +214,21 @@ private:
|
||||
split_input_.emplace_back(begin_, curr_);
|
||||
}
|
||||
|
||||
void shift_if_escaped(line_ptr_type& curr) {
|
||||
if constexpr (escape::enabled) {
|
||||
if (escape::match(*curr)) {
|
||||
shift_and_jump_escape();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void shift_and_jump_escape() {
|
||||
shift_and_set_current();
|
||||
++end_;
|
||||
if constexpr (!is_const_line) {
|
||||
++escaped_;
|
||||
}
|
||||
++end_;
|
||||
}
|
||||
|
||||
void shift_push_and_start_next(size_t n) {
|
||||
shift_and_push();
|
||||
@ -381,7 +385,7 @@ private:
|
||||
size_t escaped_{0};
|
||||
split_input split_input_;
|
||||
|
||||
template <typename ...>
|
||||
template <typename...>
|
||||
friend class converter;
|
||||
};
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user