diff --git a/peglib.h b/peglib.h index 49f7232..f61c08f 100644 --- a/peglib.h +++ b/peglib.h @@ -469,8 +469,8 @@ inline constexpr unsigned int operator "" _(const char* s, size_t) { struct SemanticValues : protected std::vector { // Input text - const char* path; - const char* ss; + const char* path = nullptr; + const char* ss = nullptr; // Matched string const char* c_str() const { return s_; } @@ -493,10 +493,10 @@ struct SemanticValues : protected std::vector } // Choice count - size_t choice_count() const { return choice_count_; } + size_t choice_count() const { return choice_count_; } // Choice number (0 based index) - size_t choice() const { return choice_; } + size_t choice() const { return choice_; } // Tokens std::vector> tokens; @@ -516,8 +516,6 @@ struct SemanticValues : protected std::vector return this->transform(beg, end, [](const any& v) { return any_cast(v); }); } - SemanticValues() : s_(nullptr), n_(0), choice_count_(0), choice_(0) {} - using std::vector::iterator; using std::vector::const_iterator; using std::vector::size; @@ -547,10 +545,10 @@ private: friend class PrioritizedChoice; friend class Holder; - const char* s_; - size_t n_; - size_t choice_count_; - size_t choice_; + const char* s_ = nullptr; + size_t n_ = 0; + size_t choice_count_ = 0; + size_t choice_ = 0; std::string name_; template @@ -618,8 +616,7 @@ class Action { public: Action() = default; - - Action(const Action& rhs) : fn_(rhs.fn_) {} + Action(const Action& rhs) = default; template ::value && !std::is_same::value, std::nullptr_t>::type = nullptr> Action(F fn) : fn_(make_adaptor(fn, &F::operator())) {} @@ -798,20 +795,20 @@ public: const char* s; const size_t l; - const char* error_pos; - const char* message_pos; + const char* error_pos = nullptr; + const char* message_pos = nullptr; std::string message; // TODO: should be `int`. std::vector> value_stack; - size_t value_stack_size; + size_t value_stack_size = 0; std::vector>> args_stack; - size_t nest_level; + size_t nest_level = 0; - bool in_token; + bool in_token = false; std::shared_ptr whitespaceOpe; - bool in_whitespace; + bool in_whitespace = false; std::shared_ptr wordOpe; @@ -838,13 +835,7 @@ public: : path(a_path) , s(a_s) , l(a_l) - , error_pos(nullptr) - , message_pos(nullptr) - , value_stack_size(0) - , nest_level(0) - , in_token(false) , whitespaceOpe(a_whitespaceOpe) - , in_whitespace(false) , wordOpe(a_wordOpe) , def_count(a_def_count) , enablePackratParsing(a_enablePackratParsing) @@ -2000,42 +1991,17 @@ public: }; Definition() - : ignoreSemanticValue(false) - , enablePackratParsing(false) - , is_macro(false) - , holder_(std::make_shared(this)) - , is_token_(false) {} + : holder_(std::make_shared(this)) {} Definition(const Definition& rhs) : name(rhs.name) - , ignoreSemanticValue(false) - , enablePackratParsing(false) - , is_macro(false) , holder_(rhs.holder_) - , is_token_(false) - { - holder_->outer_ = this; - } - - Definition(Definition&& rhs) - : name(std::move(rhs.name)) - , ignoreSemanticValue(rhs.ignoreSemanticValue) - , whitespaceOpe(rhs.whitespaceOpe) - , wordOpe(rhs.wordOpe) - , enablePackratParsing(rhs.enablePackratParsing) - , is_macro(rhs.is_macro) - , holder_(std::move(rhs.holder_)) - , is_token_(rhs.is_token_) { holder_->outer_ = this; } Definition(const std::shared_ptr& ope) - : ignoreSemanticValue(false) - , enablePackratParsing(false) - , is_macro(false) - , holder_(std::make_shared(this)) - , is_token_(false) + : holder_(std::make_shared(this)) { *this <= ope; } @@ -2135,16 +2101,16 @@ public: } std::string name; - size_t id; + size_t id = 0; Action action; std::function enter; std::function leave; std::function error_message; - bool ignoreSemanticValue; + bool ignoreSemanticValue = false; std::shared_ptr whitespaceOpe; std::shared_ptr wordOpe; - bool enablePackratParsing; - bool is_macro; + bool enablePackratParsing = false; + bool is_macro = false; std::vector params; Tracer tracer; @@ -2176,7 +2142,7 @@ private: std::shared_ptr holder_; mutable std::once_flag is_token_init_; - mutable bool is_token_; + mutable bool is_token_ = false; }; /*