From 699a6f1b18d7832f775106fce6cced0cf0b037d9 Mon Sep 17 00:00:00 2001 From: klaus triendl Date: Mon, 29 Jan 2024 20:41:11 +0200 Subject: [PATCH] Amended merging upstream/master into subcommand Amended #c66b20247858 --- include/clara.hpp | 10 +++++----- single_include/clara.hpp | 10 +++++----- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/include/clara.hpp b/include/clara.hpp index c78bf09..09e0c7b 100644 --- a/include/clara.hpp +++ b/include/clara.hpp @@ -116,7 +116,9 @@ namespace detail { void loadBuffer() { m_tokenBuffer.resize( 0 ); - // Note: not skiping empty strings + // Note: not skipping empty strings + while (it != itEnd && it->empty()) + ++it; if( it != itEnd ) { auto const &next = *it; @@ -979,9 +981,6 @@ namespace detail { } } - struct ParserInfo { - ParserBase const* parser = nullptr; - }; const size_t totalParsers = m_options.size() + m_args.size(); assert( totalParsers < 512 ); // ParserInfo parseInfos[totalParsers]; // <-- this is what we really want to do @@ -1007,7 +1006,8 @@ namespace detail { while( result.value().remainingTokens() ) { bool tokenParsed = false; - for (auto& parser : parsers) { + for (size_t i = 0; i < totalParsers; ++i) { + ParserBase const* parser = parsers[i]; if( parser->canParse() ) { result = parser->internalParse(exeName, result.value().remainingTokens()); if (!result) diff --git a/single_include/clara.hpp b/single_include/clara.hpp index 84eb21f..3e69b7a 100644 --- a/single_include/clara.hpp +++ b/single_include/clara.hpp @@ -456,7 +456,9 @@ namespace detail { void loadBuffer() { m_tokenBuffer.resize( 0 ); - // Note: not skiping empty strings + // Note: not skipping empty strings + while (it != itEnd && it->empty()) + ++it; if( it != itEnd ) { auto const &next = *it; @@ -1319,9 +1321,6 @@ namespace detail { } } - struct ParserInfo { - ParserBase const* parser = nullptr; - }; const size_t totalParsers = m_options.size() + m_args.size(); assert( totalParsers < 512 ); // ParserInfo parseInfos[totalParsers]; // <-- this is what we really want to do @@ -1347,7 +1346,8 @@ namespace detail { while( result.value().remainingTokens() ) { bool tokenParsed = false; - for (auto& parser : parsers) { + for (size_t i = 0; i < totalParsers; ++i) { + ParserBase const* parser = parsers[i]; if( parser->canParse() ) { result = parser->internalParse(exeName, result.value().remainingTokens()); if (!result)