diff options
author | Ilnur Khuziev <ilnur.khuziev@yandex.ru> | 2022-02-10 16:46:13 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:46:13 +0300 |
commit | 736dcd8ca259457a136f2f9f9168c44643914323 (patch) | |
tree | ddd46a036d68bfa83aa11b892f31243ea6b068a1 /library/cpp/getopt/small | |
parent | 9bf2fa2b060c9881d3135c2208c624a1dd546ecc (diff) | |
download | ydb-736dcd8ca259457a136f2f9f9168c44643914323.tar.gz |
Restoring authorship annotation for Ilnur Khuziev <ilnur.khuziev@yandex.ru>. Commit 1 of 2.
Diffstat (limited to 'library/cpp/getopt/small')
-rw-r--r-- | library/cpp/getopt/small/last_getopt.h | 68 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_easy_setup.cpp | 22 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_easy_setup.h | 24 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_handlers.h | 28 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_opt.cpp | 60 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_opt.h | 146 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_opts.cpp | 182 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_opts.h | 112 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_parse_result.cpp | 68 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_parse_result.h | 80 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_parser.cpp | 162 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_parser.h | 80 | ||||
-rw-r--r-- | library/cpp/getopt/small/last_getopt_support.h | 10 | ||||
-rw-r--r-- | library/cpp/getopt/small/opt.h | 2 | ||||
-rw-r--r-- | library/cpp/getopt/small/ya.make | 10 |
15 files changed, 527 insertions, 527 deletions
diff --git a/library/cpp/getopt/small/last_getopt.h b/library/cpp/getopt/small/last_getopt.h index 07687bc914..e0479cc433 100644 --- a/library/cpp/getopt/small/last_getopt.h +++ b/library/cpp/getopt/small/last_getopt.h @@ -1,38 +1,38 @@ #pragma once -#include "last_getopt_opts.h" -#include "last_getopt_easy_setup.h" -#include "last_getopt_parse_result.h" - +#include "last_getopt_opts.h" +#include "last_getopt_easy_setup.h" +#include "last_getopt_parse_result.h" + #include <util/generic/function.h> #include <util/string/split.h> -/// see some documentation in -/// https://wiki.yandex-team.ru/development/poisk/arcadia/util/lastgetopt/ +/// see some documentation in +/// https://wiki.yandex-team.ru/development/poisk/arcadia/util/lastgetopt/ /// https://wiki.yandex-team.ru/development/poisk/arcadia/library/getopt/ -/// see examples in library/cpp/getopt/last_getopt_demo - -//TODO: in most cases this include is unnecessary, but needed THandlerFunctor1<TpFunc, TpArg>::HandleOpt -#include "last_getopt_parser.h" +/// see examples in library/cpp/getopt/last_getopt_demo +//TODO: in most cases this include is unnecessary, but needed THandlerFunctor1<TpFunc, TpArg>::HandleOpt +#include "last_getopt_parser.h" + namespace NLastGetopt { - /// Handler to split option value by delimiter into a target container and allow ranges. + /// Handler to split option value by delimiter into a target container and allow ranges. template <class Container> struct TOptRangeSplitHandler: public IOptHandler { - public: - using TContainer = Container; - using TValue = typename TContainer::value_type; + public: + using TContainer = Container; + using TValue = typename TContainer::value_type; - explicit TOptRangeSplitHandler(TContainer* target, const char elementsDelim, const char rangesDelim) - : Target(target) - , ElementsDelim(elementsDelim) + explicit TOptRangeSplitHandler(TContainer* target, const char elementsDelim, const char rangesDelim) + : Target(target) + , ElementsDelim(elementsDelim) , RangesDelim(rangesDelim) { } void HandleOpt(const TOptsParser* parser) override { - const TStringBuf curval(parser->CurValOrDef()); - if (curval.IsInited()) { + const TStringBuf curval(parser->CurValOrDef()); + if (curval.IsInited()) { StringSplitter(curval).Split(ElementsDelim).Consume([&](const TStringBuf& val) { TStringBuf mutableValue = val; @@ -47,39 +47,39 @@ namespace NLastGetopt { Target->insert(Target->end(), first); } }); - } + } } private: TContainer* Target; - char ElementsDelim; - char RangesDelim; + char ElementsDelim; + char RangesDelim; }; template <class Container> struct TOptSplitHandler: public IOptHandler { - public: - using TContainer = Container; - using TValue = typename TContainer::value_type; + public: + using TContainer = Container; + using TValue = typename TContainer::value_type; - explicit TOptSplitHandler(TContainer* target, const char delim) - : Target(target) + explicit TOptSplitHandler(TContainer* target, const char delim) + : Target(target) , Delim(delim) { } void HandleOpt(const TOptsParser* parser) override { - const TStringBuf curval(parser->CurValOrDef()); - if (curval.IsInited()) { + const TStringBuf curval(parser->CurValOrDef()); + if (curval.IsInited()) { StringSplitter(curval).Split(Delim).Consume([&](const TStringBuf& val) { Target->insert(Target->end(), NPrivate::OptFromString<TValue>(val, parser->CurOpt())); }); - } + } } - private: - TContainer* Target; - char Delim; + private: + TContainer* Target; + char Delim; }; template <class TpFunc> @@ -129,4 +129,4 @@ namespace NLastGetopt { } -} +} diff --git a/library/cpp/getopt/small/last_getopt_easy_setup.cpp b/library/cpp/getopt/small/last_getopt_easy_setup.cpp index c87dedf95e..dea45dbb83 100644 --- a/library/cpp/getopt/small/last_getopt_easy_setup.cpp +++ b/library/cpp/getopt/small/last_getopt_easy_setup.cpp @@ -1,12 +1,12 @@ -#include "last_getopt_easy_setup.h" - -namespace NLastGetopt { +#include "last_getopt_easy_setup.h" + +namespace NLastGetopt { TEasySetup::TEasySetup(const TStringBuf& optstring) : TOpts(optstring) { AddHelpOption(); } - + TOpt& TEasySetup::AdjustParam(const char* longName, const char* help, const char* argName, bool required) { Y_ASSERT(longName); TOpt& o = AddLongOption(longName); @@ -23,25 +23,25 @@ namespace NLastGetopt { } return o; } - + TEasySetup& TEasySetup::operator()(char shortName, const char* longName, const char* help, bool required) { AdjustParam(longName, help, nullptr, required).AddShortName(shortName); return *this; - } + } TEasySetup& TEasySetup::operator()(char shortName, const char* longName, const char* argName, const char* help, bool required) { AdjustParam(longName, help, argName, required).AddShortName(shortName); return *this; - } + } TEasySetup& TEasySetup::operator()(const char* longName, const char* help, bool required) { AdjustParam(longName, help, nullptr, required); return *this; - } - + } + TEasySetup& TEasySetup::operator()(const char* longName, const char* argName, const char* help, bool required) { AdjustParam(longName, help, argName, required); return *this; } - -} + +} diff --git a/library/cpp/getopt/small/last_getopt_easy_setup.h b/library/cpp/getopt/small/last_getopt_easy_setup.h index 60dddda225..8baa889a87 100644 --- a/library/cpp/getopt/small/last_getopt_easy_setup.h +++ b/library/cpp/getopt/small/last_getopt_easy_setup.h @@ -1,8 +1,8 @@ -#pragma once - -#include "last_getopt_opts.h" - -namespace NLastGetopt { +#pragma once + +#include "last_getopt_opts.h" + +namespace NLastGetopt { /** * Wrapper for TOpts class to make the life a bit easier. * Usual usage: @@ -21,25 +21,25 @@ namespace NLastGetopt { TEasySetup(const TStringBuf& optstring = TStringBuf()); TEasySetup& operator()(char shortName, const char* longName, const char* help, bool required = false); TEasySetup& operator()(char shortName, const char* longName, const char* argName, const char* help, bool required = false); - + template <class TpFunc> TEasySetup& operator()(char shortName, const char* longName, TpFunc handler, const char* help, bool required = false) { AdjustParam(longName, help, nullptr, handler, required).AddShortName(shortName); return *this; } - + TEasySetup& operator()(const char* longName, const char* help, bool required = false); TEasySetup& operator()(const char* longName, const char* argName, const char* help, bool required = false); - + template <class TpFunc> TEasySetup& operator()(const char* longName, TpFunc handler, const char* help, bool required = false) { AdjustParam(longName, help, nullptr, handler, required); return *this; } - + private: TOpt& AdjustParam(const char* longName, const char* help, const char* argName, bool required); - + template <class TpFunc> TOpt& AdjustParam(const char* longName, const char* help, const char* argName, TpFunc handler, bool required) { TOpt& o = AdjustParam(longName, help, argName, required); @@ -47,5 +47,5 @@ namespace NLastGetopt { return o; } }; - -} + +} diff --git a/library/cpp/getopt/small/last_getopt_handlers.h b/library/cpp/getopt/small/last_getopt_handlers.h index d35456ef34..db6e21ded3 100644 --- a/library/cpp/getopt/small/last_getopt_handlers.h +++ b/library/cpp/getopt/small/last_getopt_handlers.h @@ -1,19 +1,19 @@ -#pragma once - -#include "last_getopt_support.h" - -#include <util/string/split.h> +#pragma once + +#include "last_getopt_support.h" + +#include <util/string/split.h> #include <util/system/compiler.h> - -namespace NLastGetopt { - /// Handler to split option value by delimiter into a target container. + +namespace NLastGetopt { + /// Handler to split option value by delimiter into a target container. template <class Container> - struct TOptSplitHandler; - - /// Handler to split option value by delimiter into a target container and allow ranges. + struct TOptSplitHandler; + + /// Handler to split option value by delimiter into a target container and allow ranges. template <class Container> - struct TOptRangeSplitHandler; - + struct TOptRangeSplitHandler; + /// Handler to parse key-value pairs (default delimiter is '=') and apply user-supplied handler to each pair template <class TpFunc> struct TOptKVHandler; @@ -21,4 +21,4 @@ namespace NLastGetopt { [[noreturn]] void PrintUsageAndExit(const TOptsParser* parser); [[noreturn]] void PrintVersionAndExit(const TOptsParser* parser); [[noreturn]] void PrintShortVersionAndExit(const TString& appName); -} +} diff --git a/library/cpp/getopt/small/last_getopt_opt.cpp b/library/cpp/getopt/small/last_getopt_opt.cpp index 9a99437f4b..7f63053afe 100644 --- a/library/cpp/getopt/small/last_getopt_opt.cpp +++ b/library/cpp/getopt/small/last_getopt_opt.cpp @@ -1,16 +1,16 @@ -#include "last_getopt_opt.h" - -#include <util/stream/format.h> -#include <util/string/escape.h> -#include <util/generic/ylimits.h> -#include <util/generic/utility.h> -#include <util/generic/algorithm.h> -#include <ctype.h> - -namespace NLastGetopt { +#include "last_getopt_opt.h" + +#include <util/stream/format.h> +#include <util/string/escape.h> +#include <util/generic/ylimits.h> +#include <util/generic/utility.h> +#include <util/generic/algorithm.h> +#include <ctype.h> + +namespace NLastGetopt { static const TStringBuf ExcludedShortNameChars = "= -\t\n"; static const TStringBuf ExcludedLongNameChars = "= \t\n"; - + bool TOpt::NameIs(const TString& name) const { for (const auto& next : LongNames_) { if (next == name) @@ -18,7 +18,7 @@ namespace NLastGetopt { } return false; } - + bool TOpt::CharIs(char c) const { for (auto next : Chars_) { if (next == c) @@ -26,31 +26,31 @@ namespace NLastGetopt { } return false; } - + char TOpt::GetChar() const { ; if (Chars_.empty()) ythrow TConfException() << "no char for option " << this->ToShortString(); return Chars_.at(0); - } - + } + char TOpt::GetCharOr0() const { if (Chars_.empty()) return 0; return GetChar(); - } - + } + TString TOpt::GetName() const { ; if (LongNames_.empty()) ythrow TConfException() << "no name for option " << this->ToShortString(); return LongNames_.at(0); } - + bool TOpt::IsAllowedShortName(unsigned char c) { return isprint(c) && TStringBuf::npos == ExcludedShortNameChars.find(c); } - + TOpt& TOpt::AddShortName(unsigned char c) { ; if (!IsAllowedShortName(c)) @@ -58,7 +58,7 @@ namespace NLastGetopt { Chars_.push_back(c); return *this; } - + bool TOpt::IsAllowedLongName(const TString& name, unsigned char* out) { for (size_t i = 0; i != name.size(); ++i) { const unsigned char c = name[i]; @@ -67,10 +67,10 @@ namespace NLastGetopt { *out = c; return false; } - } + } return true; - } - + } + TOpt& TOpt::AddLongName(const TString& name) { ; unsigned char c = 0; @@ -80,13 +80,13 @@ namespace NLastGetopt { LongNames_.push_back(name); return *this; } - + namespace NPrivate { TString OptToString(char c); - + TString OptToString(const TString& longOption); } - + TString TOpt::ToShortString() const { ; if (!LongNames_.empty()) @@ -95,13 +95,13 @@ namespace NLastGetopt { return NPrivate::OptToString(Chars_.front()); return "?"; } - + void TOpt::FireHandlers(const TOptsParser* parser) const { for (const auto& handler : Handlers_) { handler->HandleOpt(parser); } - } - + } + TOpt& TOpt::IfPresentDisableCompletionFor(const TOpt& opt) { if (opt.GetLongNames()) { IfPresentDisableCompletionFor(opt.GetName()); @@ -110,4 +110,4 @@ namespace NLastGetopt { } return *this; } -} +} diff --git a/library/cpp/getopt/small/last_getopt_opt.h b/library/cpp/getopt/small/last_getopt_opt.h index a8dd5adca9..3a39357365 100644 --- a/library/cpp/getopt/small/last_getopt_opt.h +++ b/library/cpp/getopt/small/last_getopt_opt.h @@ -1,25 +1,25 @@ -#pragma once - +#pragma once + #include "completer.h" -#include "last_getopt_handlers.h" - -#include <util/string/split.h> -#include <util/generic/ptr.h> +#include "last_getopt_handlers.h" + +#include <util/string/split.h> +#include <util/generic/ptr.h> #include <util/generic/string.h> -#include <util/generic/maybe.h> -#include <util/generic/vector.h> +#include <util/generic/maybe.h> +#include <util/generic/vector.h> #include <util/string/cast.h> - -#include <stdarg.h> - -namespace NLastGetopt { + +#include <stdarg.h> + +namespace NLastGetopt { enum EHasArg { NO_ARGUMENT, REQUIRED_ARGUMENT, OPTIONAL_ARGUMENT, DEFAULT_HAS_ARG = REQUIRED_ARGUMENT }; - + /** * NLastGetopt::TOpt is a storage of data about exactly one program option. * The data is: parse politics and help information. @@ -44,25 +44,25 @@ namespace NLastGetopt { public: typedef TVector<char> TShortNames; typedef TVector<TString> TLongNames; - + protected: TShortNames Chars_; TLongNames LongNames_; - + private: typedef TMaybe<TString> TdOptVal; typedef TVector<TSimpleSharedPtr<IOptHandler>> TOptHandlers; - + public: bool Hidden_ = false; // is visible in help TString ArgTitle_; // the name of argument in help output TString Help_; // the help string TString CompletionHelp_; // the help string that's used in completion script, a shorter version of Help_ TString CompletionArgHelp_; // the description of argument in completion script - + EHasArg HasArg_ = DEFAULT_HAS_ARG; // the argument parsing politics bool Required_ = false; // option existence politics - + bool AllowMultipleCompletion_ = false; // let the completer know that this option can occur more than once bool DisableCompletionForOptions_ = false; @@ -78,48 +78,48 @@ namespace NLastGetopt { TdOptVal OptionalValue_; TdOptVal DefaultValue_; TOptHandlers Handlers_; - + public: /** * Checks if given char can be a short name * @param c char to check */ static bool IsAllowedShortName(unsigned char c); - + /** * Checks if given string can be a long name * @param name string to check * @param c if given, the first bad charecter will be saved in c */ static bool IsAllowedLongName(const TString& name, unsigned char* c = nullptr); - + /** * @return one of the expected representations of the option. * If the option has short names, will return "-<char>" * Otherwise will return "--<long name>" */ TString ToShortString() const; - + /** * check if given string is one of the long names * * @param name string to check */ bool NameIs(const TString& name) const; - + /** * check if given char is one of the short names * * @param c char to check */ bool CharIs(char c) const; - + /** * If string has long names - will return one of them * Otherwise will throw */ TString GetName() const; - + /** * adds short alias for the option * @@ -128,14 +128,14 @@ namespace NLastGetopt { * @return self */ TOpt& AddShortName(unsigned char c); - + /** * return all short names of the option */ const TShortNames& GetShortNames() const { return Chars_; } - + /** * adds long alias for the option * @@ -144,31 +144,31 @@ namespace NLastGetopt { * @return self */ TOpt& AddLongName(const TString& name); - + /** * return all long names of the option */ const TLongNames& GetLongNames() const { return LongNames_; } - + /** * @return one of short names of the opt. If there is no short names exception is raised. */ char GetChar() const; - + /** * @return one of short names of the opt. If there is no short names '\0' returned. */ char GetCharOr0() const; - + /** * @returns argument parsing politics */ const EHasArg& GetHasArg() const { return HasArg_; } - + /** * sets argument parsing politics * @@ -181,14 +181,14 @@ namespace NLastGetopt { HasArg_ = hasArg; return *this; } - + /** * @returns argument title */ TString GetArgTitle() const { return ArgTitle_; } - + /** * sets argument parsing politics into REQUIRED_ARGUMENT * @@ -199,7 +199,7 @@ namespace NLastGetopt { ArgTitle_ = title; return HasArg(REQUIRED_ARGUMENT); } - + /** * sets argument parsing politics into NO_ARGUMENT * @@ -208,7 +208,7 @@ namespace NLastGetopt { TOpt& NoArgument() { return HasArg(NO_ARGUMENT); } - + /** * sets argument parsing politics into OPTIONAL_ARGUMENT * for details see NLastGetopt::TOpt @@ -220,7 +220,7 @@ namespace NLastGetopt { ArgTitle_ = title; return HasArg(OPTIONAL_ARGUMENT); } - + /** * sets argument parsing politics into OPTIONAL_ARGUMENT * sets the <optional value> into given @@ -235,14 +235,14 @@ namespace NLastGetopt { OptionalValue_ = val; return OptionalArgument(title); } - + /** * checks if "argument parsing politics" is OPTIONAL_ARGUMENT and the <optional value> is set. */ bool HasOptionalValue() const { return OPTIONAL_ARGUMENT == HasArg_ && OptionalValue_; } - + /** * @return optional value * throws exception if optional value wasn't set @@ -250,7 +250,7 @@ namespace NLastGetopt { const TString& GetOptionalValue() const { return *OptionalValue_; } - + /** * sets <default value> * @return self @@ -260,14 +260,14 @@ namespace NLastGetopt { DefaultValue_ = ToString(val); return *this; } - + /** * checks if default value is set. */ bool HasDefaultValue() const { return DefaultValue_.Defined(); } - + /** * @return default value * throws exception if <default value> wasn't set @@ -275,7 +275,7 @@ namespace NLastGetopt { const TString& GetDefaultValue() const { return *DefaultValue_; } - + /** * sets the option to be required * @return self @@ -284,7 +284,7 @@ namespace NLastGetopt { Required_ = true; return *this; } - + /** * sets the option to be optional * @return self @@ -293,14 +293,14 @@ namespace NLastGetopt { Required_ = false; return *this; } - + /** * @return true if the option is required */ bool IsRequired() const { return Required_; } - + /** * sets the option to be hidden (invisible in help) * @return self @@ -309,14 +309,14 @@ namespace NLastGetopt { Hidden_ = true; return *this; } - + /** * @return true if the option is hidden */ bool IsHidden() const { return Hidden_; } - + /** * sets the <user value> * @return self @@ -326,14 +326,14 @@ namespace NLastGetopt { UserValue_ = userval; return *this; } - + /** * @return user value */ const void* UserValue() const { return UserValue_; } - + /** * Set help string that appears with `--help`. Unless `CompletionHelp` is given, this message will also be used * in completion script. In this case, don't make it too long, don't start it with a capital letter and don't @@ -371,14 +371,14 @@ namespace NLastGetopt { Help_ = help; return *this; } - + /** * Get help string. */ const TString& GetHelp() const { return Help_; } - + /** * Set help string that appears when argument completer lists available options. * @@ -546,19 +546,19 @@ namespace NLastGetopt { * Run handlers for this option. */ void FireHandlers(const TOptsParser* parser) const; - + private: TOpt& HandlerImpl(IOptHandler* handler) { Handlers_.push_back(handler); return *this; } - + public: template <typename TpFunc> TOpt& Handler0(TpFunc func) { // functor taking no parameters return HandlerImpl(new NPrivate::THandlerFunctor0<TpFunc>(func)); } - + template <typename TpFunc> TOpt& Handler1(TpFunc func) { // functor taking one parameter return HandlerImpl(new NPrivate::THandlerFunctor1<TpFunc>(func)); @@ -575,35 +575,35 @@ namespace NLastGetopt { TOpt& Handler1T2(const TpArg2& def, TpFunc func) { return HandlerImpl(new NPrivate::THandlerFunctor1<TpFunc, TpArg>(func, def)); } - + TOpt& Handler(void (*f)()) { return Handler0(f); } TOpt& Handler(void (*f)(const TOptsParser*)) { return Handler1(f); } - + TOpt& Handler(TAutoPtr<IOptHandler> handler) { return HandlerImpl(handler.Release()); } - + template <typename T> // T extends IOptHandler TOpt& Handler(TAutoPtr<T> handler) { return HandlerImpl(handler.Release()); } - + // Stores FromString<T>(arg) in *target // T maybe anything with FromString<T>(const TStringBuf&) defined template <typename TpVal, typename T> TOpt& StoreResultT(T* target) { return Handler1T<TpVal>(NPrivate::TStoreResultFunctor<T, TpVal>(target)); } - + template <typename T> TOpt& StoreResult(T* target) { return StoreResultT<T>(target); } - + // Uses TMaybe<T> to store FromString<T>(arg) template <typename T> TOpt& StoreResult(TMaybe<T>* target) { @@ -614,12 +614,12 @@ namespace NLastGetopt { TOpt& StoreResultT(T* target, const TpDef& def) { return Handler1T<TpVal>(def, NPrivate::TStoreResultFunctor<T, TpVal>(target)); } - + template <typename T, typename TpDef> TOpt& StoreResult(T* target, const TpDef& def) { return StoreResultT<T>(target, def); } - + template <typename T> TOpt& StoreResultDef(T* target) { DefaultValue_ = ToString(*target); @@ -636,7 +636,7 @@ namespace NLastGetopt { TOpt& SetFlag(bool* target) { return DefaultValue("0").StoreResult(target, true); } - + // Similar to store_true in Python's argparse TOpt& StoreTrue(bool* target) { return NoArgument().SetFlag(target); @@ -646,12 +646,12 @@ namespace NLastGetopt { TOpt& StoreMappedResultT(T* target, const TpFunc& func) { return Handler1T<TpVal>(NPrivate::TStoreMappedResultFunctor<T, TpFunc, TpVal>(target, func)); } - + template <typename T, typename TpFunc> TOpt& StoreMappedResult(T* target, const TpFunc& func) { return StoreMappedResultT<T>(target, func); } - + // Stores given value in *target if the option is present. // TValue must be a copyable type, constructible from TParam. // T must be a copyable type, assignable from TValue. @@ -659,25 +659,25 @@ namespace NLastGetopt { TOpt& StoreValueT(T* target, const TParam& value) { return Handler1(NPrivate::TStoreValueFunctor<T, TValue>(target, value)); } - + // save value as target type template <typename T, typename TParam> TOpt& StoreValue(T* target, const TParam& value) { return StoreValueT<T>(target, value); } - + // save value as its original type (2nd template parameter) template <typename T, typename TValue> TOpt& StoreValue2(T* target, const TValue& value) { return StoreValueT<TValue>(target, value); } - + // Appends FromString<T>(arg) to *target for each argument template <typename T> TOpt& AppendTo(TVector<T>* target) { return Handler1T<T>([target](auto&& value) { target->push_back(std::move(value)); }); } - + // Appends FromString<T>(arg) to *target for each argument template <typename T> TOpt& InsertTo(THashSet<T>* target) { @@ -694,7 +694,7 @@ namespace NLastGetopt { TOpt& SplitHandler(Container* target, const char delim) { return Handler(new NLastGetopt::TOptSplitHandler<Container>(target, delim)); } - + template <class Container> TOpt& RangeSplitHandler(Container* target, const char elementsDelim, const char rangesDelim) { return Handler(new NLastGetopt::TOptRangeSplitHandler<Container>(target, elementsDelim, rangesDelim)); @@ -705,7 +705,7 @@ namespace NLastGetopt { return Handler(new NLastGetopt::TOptKVHandler<TpFunc>(func, kvdelim)); } }; - + /** * NLastGetopt::TFreeArgSpec is a storage of data about free argument. * The data is help information and (maybe) linked named argument. @@ -722,7 +722,7 @@ namespace NLastGetopt { , Optional_(optional) { } - + TString Title_; TString Help_; TString CompletionArgHelp_; diff --git a/library/cpp/getopt/small/last_getopt_opts.cpp b/library/cpp/getopt/small/last_getopt_opts.cpp index 03c432849f..7122bba10a 100644 --- a/library/cpp/getopt/small/last_getopt_opts.cpp +++ b/library/cpp/getopt/small/last_getopt_opts.cpp @@ -1,36 +1,36 @@ #include "completer_command.h" -#include "last_getopt_opts.h" +#include "last_getopt_opts.h" #include "wrap.h" #include "last_getopt_parser.h" - + #include <library/cpp/colorizer/colors.h> -#include <util/stream/format.h> +#include <util/stream/format.h> #include <util/charset/utf8.h> -#include <stdlib.h> - -namespace NLastGetoptPrivate { +#include <stdlib.h> + +namespace NLastGetoptPrivate { TString& VersionString() { static TString data; - return data; - } + return data; + } TString& ShortVersionString() { static TString data; return data; } } - + namespace NLastGetopt { static const TStringBuf SPad = " "; - + void PrintVersionAndExit(const TOptsParser*) { - Cout << (NLastGetoptPrivate::VersionString() ? NLastGetoptPrivate::VersionString() : "program version: not linked with library/cpp/getopt") << Endl; + Cout << (NLastGetoptPrivate::VersionString() ? NLastGetoptPrivate::VersionString() : "program version: not linked with library/cpp/getopt") << Endl; exit(NLastGetoptPrivate::VersionString().empty()); } - + void PrintShortVersionAndExit(const TString& appName) { - Cout << appName << " version " << (NLastGetoptPrivate::ShortVersionString() ? NLastGetoptPrivate::ShortVersionString() : "not linked with library/cpp/getopt") << Endl; + Cout << appName << " version " << (NLastGetoptPrivate::ShortVersionString() ? NLastGetoptPrivate::ShortVersionString() : "not linked with library/cpp/getopt") << Endl; exit(NLastGetoptPrivate::ShortVersionString().empty()); } @@ -44,24 +44,24 @@ namespace NLastGetopt { } return str; } - + namespace NPrivate { TString OptToString(char c) { TStringStream ss; ss << "-" << c; return ss.Str(); } - + TString OptToString(const TString& longOption) { TStringStream ss; ss << "--" << longOption; return ss.Str(); } - + TString OptToString(const TOpt* opt) { return opt->ToShortString(); } - } + } TOpts::TOpts(const TStringBuf& optstring) : ArgPermutation_(DEFAULT_ARG_PERMUTATION) @@ -76,8 +76,8 @@ namespace NLastGetopt { AddCharOptions(optstring); } AddVersionOption(0); - } - + } + void TOpts::AddCharOptions(const TStringBuf& optstring) { size_t p = 0; if (optstring[p] == '+') { @@ -102,8 +102,8 @@ namespace NLastGetopt { } AddCharOption(c, ha); } - } - + } + const TOpt* TOpts::FindLongOption(const TStringBuf& name) const { for (const auto& Opt : Opts_) { const TOpt* opt = Opt.Get(); @@ -111,8 +111,8 @@ namespace NLastGetopt { return opt; } return nullptr; - } - + } + TOpt* TOpts::FindLongOption(const TStringBuf& name) { for (auto& Opt : Opts_) { TOpt* opt = Opt.Get(); @@ -120,8 +120,8 @@ namespace NLastGetopt { return opt; } return nullptr; - } - + } + const TOpt* TOpts::FindCharOption(char c) const { for (const auto& Opt : Opts_) { const TOpt* opt = Opt.Get(); @@ -129,45 +129,45 @@ namespace NLastGetopt { return opt; } return nullptr; - } - + } + TOpt* TOpts::FindCharOption(char c) { for (auto& Opt : Opts_) { TOpt* opt = Opt.Get(); if (IsIn(opt->GetShortNames(), c)) return opt; - } + } return nullptr; - } - + } + const TOpt& TOpts::GetCharOption(char c) const { const TOpt* option = FindCharOption(c); if (!option) ythrow TException() << "unknown char option '" << c << "'"; return *option; - } - + } + TOpt& TOpts::GetCharOption(char c) { TOpt* option = FindCharOption(c); if (!option) ythrow TException() << "unknown char option '" << c << "'"; return *option; - } - + } + const TOpt& TOpts::GetLongOption(const TStringBuf& name) const { const TOpt* option = FindLongOption(name); if (!option) ythrow TException() << "unknown option " << name; return *option; - } - + } + TOpt& TOpts::GetLongOption(const TStringBuf& name) { TOpt* option = FindLongOption(name); if (!option) ythrow TException() << "unknown option " << name; return *option; - } - + } + bool TOpts::HasAnyShortOption() const { for (const auto& Opt : Opts_) { const TOpt* opt = Opt.Get(); @@ -175,8 +175,8 @@ namespace NLastGetopt { return true; } return false; - } - + } + bool TOpts::HasAnyLongOption() const { for (const auto& Opt : Opts_) { TOpt* opt = Opt.Get(); @@ -184,8 +184,8 @@ namespace NLastGetopt { return true; } return false; - } - + } + void TOpts::Validate() const { for (TOptsVector::const_iterator i = Opts_.begin(); i != Opts_.end(); ++i) { TOpt* opt = i->Get(); @@ -198,7 +198,7 @@ namespace NLastGetopt { << NPrivate::OptToString(c) << " is defined more than once"; } - } + } const TOpt::TLongNames& longNames = opt->GetLongNames(); for (const auto& longName : longNames) { for (TOptsVector::const_iterator j = i + 1; j != Opts_.end(); ++j) { @@ -208,22 +208,22 @@ namespace NLastGetopt { << NPrivate::OptToString(longName) << " is defined more than once"; } - } - } + } + } if (FreeArgsMax_ < FreeArgsMin_) { ythrow TConfException() << "FreeArgsMax must be >= FreeArgsMin"; } if (!FreeArgSpecs_.empty() && FreeArgSpecs_.rbegin()->first >= FreeArgsMax_) { ythrow TConfException() << "Described args count is greater than FreeArgsMax. Either increase FreeArgsMax or remove unreachable descriptions"; } - } + } TOpt& TOpts::AddOption(const TOpt& option) { if (option.GetShortNames().empty() && option.GetLongNames().empty()) ythrow TConfException() << "bad option: no chars, no long names"; Opts_.push_back(new TOpt(option)); return *Opts_.back(); - } + } TOpt& TOpts::AddCompletionOption(TString command, TString longName) { if (TOpt* o = FindLongOption(longName)) { @@ -257,28 +257,28 @@ namespace NLastGetopt { if (it == Opts_.end()) ythrow TException() << "unknown option"; return it - Opts_.begin(); - } - + } + TStringBuf TOpts::GetFreeArgTitle(size_t pos) const { if (FreeArgSpecs_.contains(pos)) { return FreeArgSpecs_.at(pos).GetTitle(DefaultFreeArgTitle_); } return DefaultFreeArgTitle_; } - + void TOpts::SetFreeArgTitle(size_t pos, const TString& title, const TString& help, bool optional) { FreeArgSpecs_[pos] = TFreeArgSpec(title, help, optional); - } - + } + TFreeArgSpec& TOpts::GetFreeArgSpec(size_t pos) { return FreeArgSpecs_[pos]; - } - + } + static TString FormatOption(const TOpt* option, const NColorizer::TColors& colors) { TStringStream result; const TOpt::TShortNames& shorts = option->GetShortNames(); const TOpt::TLongNames& longs = option->GetLongNames(); - + const size_t nopts = shorts.size() + longs.size(); const bool multiple = 1 < nopts; if (multiple) @@ -286,7 +286,7 @@ namespace NLastGetopt { for (size_t i = 0; i < nopts; ++i) { if (multiple && 0 != i) result << '|'; - + if (i < shorts.size()) // short result << colors.GreenColor() << '-' << shorts[i] << colors.OldColor(); else @@ -294,11 +294,11 @@ namespace NLastGetopt { } if (multiple) result << '}'; - + static const TString metavarDef("VAL"); const TString& title = option->GetArgTitle(); const TString& metavar = title.empty() ? metavarDef : title; - + if (option->GetHasArg() == OPTIONAL_ARGUMENT) { result << " [" << metavar; if (option->HasOptionalValue()) @@ -306,12 +306,12 @@ namespace NLastGetopt { result << ']'; } else if (option->GetHasArg() == REQUIRED_ARGUMENT) result << ' ' << metavar; - else + else Y_ASSERT(option->GetHasArg() == NO_ARGUMENT); - + return result.Str(); - } - + } + void TOpts::PrintCmdLine(const TStringBuf& program, IOutputStream& os, const NColorizer::TColors& colors) const { os << colors.BoldColor() << "Usage" << colors.OldColor() << ": "; if (CustomUsage) { @@ -322,12 +322,12 @@ namespace NLastGetopt { if (CustomCmdLineDescr) { os << CustomCmdLineDescr << Endl; return; - } + } os << "[OPTIONS]"; - + ui32 numDescribedFlags = FreeArgSpecs_.empty() ? 0 : FreeArgSpecs_.rbegin()->first + 1; ui32 numArgsToShow = Max(FreeArgsMin_, FreeArgsMax_ == UNLIMITED_ARGS ? numDescribedFlags : FreeArgsMax_); - + for (ui32 i = 0, nonOptionalFlagsPrinted = 0; i < numArgsToShow; ++i) { bool isOptional = nonOptionalFlagsPrinted >= FreeArgsMin_ || FreeArgSpecs_.Value(i, TFreeArgSpec()).Optional_; @@ -350,26 +350,26 @@ namespace NLastGetopt { os << Endl; } - + void TOpts::PrintUsage(const TStringBuf& program, IOutputStream& osIn, const NColorizer::TColors& colors) const { TStringStream os; - + if (!Title.empty()) os << Title << "\n\n"; - + PrintCmdLine(program, os, colors); - + TVector<TString> leftColumn(Opts_.size()); TVector<size_t> leftColumnSizes(leftColumn.size()); const size_t kMaxLeftWidth = 25; size_t leftWidth = 0; size_t requiredOptionsCount = 0; NColorizer::TColors disabledColors(false); - - for (size_t i = 0; i < Opts_.size(); i++) { - const TOpt* opt = Opts_[i].Get(); - if (opt->IsHidden()) - continue; + + for (size_t i = 0; i < Opts_.size(); i++) { + const TOpt* opt = Opts_[i].Get(); + if (opt->IsHidden()) + continue; leftColumn[i] = FormatOption(opt, colors); size_t leftColumnSize = leftColumn[i].size(); if (colors.IsTTY()) { @@ -382,7 +382,7 @@ namespace NLastGetopt { if (opt->IsRequired()) requiredOptionsCount++; } - + const TString leftPadding(leftWidth, ' '); for (size_t sectionId = 0; sectionId <= 1; sectionId++) { @@ -400,7 +400,7 @@ namespace NLastGetopt { else os << Endl << colors.BoldColor() << "Optional parameters" << colors.OldColor() << ":" << Endl; // optional options would be a tautology } - + for (size_t i = 0; i < Opts_.size(); i++) { const TOpt* opt = Opts_[i].Get(); @@ -415,8 +415,8 @@ namespace NLastGetopt { os << SPad << leftColumn[i] << ' '; if (leftColumnSizes[i] < leftWidth) os << TStringBuf(leftPadding.data(), leftWidth - leftColumnSizes[i]); - } - + } + TStringBuf help = opt->GetHelp(); while (help && isspace(help.back())) { help.Chop(1); @@ -452,8 +452,8 @@ namespace NLastGetopt { if (helpHasParagraphs) { os << Endl; } - } - } + } + } PrintFreeArgsDesc(os, colors); @@ -464,8 +464,8 @@ namespace NLastGetopt { } osIn << os.Str(); - } - + } + void TOpts::PrintUsage(const TStringBuf& program, IOutputStream& os) const { PrintUsage(program, os, NColorizer::AutoColors(os)); } @@ -473,19 +473,19 @@ namespace NLastGetopt { void TOpts::PrintFreeArgsDesc(IOutputStream& os, const NColorizer::TColors& colors) const { if (0 == FreeArgsMax_) return; - + size_t leftFreeWidth = 0; for (size_t i = 0; i < FreeArgSpecs_.size(); ++i) { leftFreeWidth = Max(leftFreeWidth, GetFreeArgTitle(i).size()); } - + if (!TrailingArgSpec_.IsDefault()) { leftFreeWidth = Max(leftFreeWidth, TrailingArgSpec_.GetTitle(DefaultFreeArgTitle_).size()); } - + leftFreeWidth = Min(leftFreeWidth, size_t(30)); os << Endl << colors.BoldColor() << "Free args" << colors.OldColor() << ":"; - + os << " min: " << colors.GreenColor() << FreeArgsMin_ << colors.OldColor() << ","; os << " max: " << colors.GreenColor(); if (FreeArgsMax_ != UNLIMITED_ARGS) { @@ -494,20 +494,20 @@ namespace NLastGetopt { os << "unlimited"; } os << colors.OldColor() << Endl; - + const size_t limit = FreeArgSpecs_.empty() ? 0 : FreeArgSpecs_.rbegin()->first; for (size_t i = 0; i <= limit; ++i) { if (!FreeArgSpecs_.contains(i)) { continue; } - + if (auto help = FreeArgSpecs_.at(i).GetHelp()) { auto title = GetFreeArgTitle(i); os << SPad << colors.GreenColor() << RightPad(title, leftFreeWidth, ' ') << colors.OldColor() << SPad << help << Endl; } } - + if (FreeArgsMax_ == UNLIMITED_ARGS) { auto title = TrailingArgSpec_.GetTitle(DefaultFreeArgTitle_); if (auto help = TrailingArgSpec_.GetHelp()) { @@ -515,5 +515,5 @@ namespace NLastGetopt { << SPad << help << Endl; } } - } -} + } +} diff --git a/library/cpp/getopt/small/last_getopt_opts.h b/library/cpp/getopt/small/last_getopt_opts.h index 825b99c871..be6978ed4d 100644 --- a/library/cpp/getopt/small/last_getopt_opts.h +++ b/library/cpp/getopt/small/last_getopt_opts.h @@ -1,19 +1,19 @@ -#pragma once - -#include "last_getopt_opt.h" - +#pragma once + +#include "last_getopt_opt.h" + #include <library/cpp/colorizer/fwd.h> -#include <util/generic/map.h> - -namespace NLastGetopt { +#include <util/generic/map.h> + +namespace NLastGetopt { enum EArgPermutation { REQUIRE_ORDER, PERMUTE, RETURN_IN_ORDER, DEFAULT_ARG_PERMUTATION = PERMUTE }; - + /** * NLastGetopt::TOpts is a storage of program options' parse rules. * It contains information about all options, free args, some parsing options @@ -37,36 +37,36 @@ namespace NLastGetopt { class TOpts { friend class TOptsParseResult; friend class TOptsParser; - + public: static constexpr const ui32 UNLIMITED_ARGS = Max<ui32>(); typedef TVector<TSimpleSharedPtr<TOpt>> TOptsVector; TOptsVector Opts_; // infomation about named (short and long) options TVector<std::function<void(TStringBuf)>> ArgBindings_; - + EArgPermutation ArgPermutation_ = DEFAULT_ARG_PERMUTATION; // determines how to parse positions of named and free options. See information below. bool AllowSingleDashForLong_ = false; // bool AllowPlusForLong_ = false; // using '+' instead '--' for long options - + //Allows unknwon options: bool AllowUnknownCharOptions_ = false; bool AllowUnknownLongOptions_ = false; - + ui32 Wrap_ = 80; private: ui32 FreeArgsMin_; // minimal number of free args ui32 FreeArgsMax_; // maximal number of free args - + TMap<ui32, TFreeArgSpec> FreeArgSpecs_; // mapping [free arg position] -> [free arg specification] TFreeArgSpec TrailingArgSpec_; // spec for the trailing argument (when arguments are unlimited) TString DefaultFreeArgTitle_ = "ARG"; // title that's used for free args without a title - + TString Title; // title of the help string TString CustomCmdLineDescr; // user defined help string TString CustomUsage; // user defined usage string - + TVector<std::pair<TString, TString>> Sections; // additional help entries to print after usage public: @@ -74,7 +74,7 @@ namespace NLastGetopt { * Constructs TOpts from string as in getopt(3) */ TOpts(const TStringBuf& optstring = TStringBuf()); - + /** * Constructs TOpts from string as in getopt(3) and * additionally adds help option (for '?') and svn-verstion option (for 'V') @@ -85,7 +85,7 @@ namespace NLastGetopt { opts.AddVersionOption(); return opts; } - + /** * Checks correctness of options' descriptions. * Throws TConfException if validation failed. @@ -94,35 +94,35 @@ namespace NLastGetopt { * -compability of settings, that responsable for freeArgs parsing */ void Validate() const; - + /** * Search for the option with given long name * @param name long name for search * @return ptr on result (nullptr if not found) */ const TOpt* FindLongOption(const TStringBuf& name) const; - + /** * Search for the option with given short name * @param c short name for search * @return ptr on result (nullptr if not found) */ const TOpt* FindCharOption(char c) const; - + /** * Search for the option with given long name * @param name long name for search * @return ptr on result (nullptr if not found) */ TOpt* FindLongOption(const TStringBuf& name); - + /** * Search for the option with given short name * @param c short name for search * @return ptr on result (nullptr if not found) */ TOpt* FindCharOption(char c); - + /** * Search for the option with given name * @param name name for search @@ -155,7 +155,7 @@ namespace NLastGetopt { void SetTitle(const TString& title) { Title = title; } - + /** * @return true if there is an option with given long name * @@ -164,7 +164,7 @@ namespace NLastGetopt { bool HasLongOption(const TString& name) const { return FindLongOption(name) != nullptr; } - + /** * @return true if there is an option with given short name * @@ -173,35 +173,35 @@ namespace NLastGetopt { bool HasCharOption(char c) const { return FindCharOption(c) != nullptr; } - + /** * Search for the option with given long name * @param name long name for search * @return ref on result (throw exception if not found) */ const TOpt& GetLongOption(const TStringBuf& name) const; - + /** * Search for the option with given long name * @param name long name for search * @return ref on result (throw exception if not found) */ TOpt& GetLongOption(const TStringBuf& name); - + /** * Search for the option with given short name * @param c short name for search * @return ref on result (throw exception if not found) */ const TOpt& GetCharOption(char c) const; - + /** * Search for the option with given short name * @param c short name for search * @return ref on result (throw exception if not found) */ TOpt& GetCharOption(char c); - + /** * Search for the option with given name * @param name name for search @@ -231,19 +231,19 @@ namespace NLastGetopt { * @return true if short options exist */ bool HasAnyShortOption() const; - + /** * @return true if long options exist */ bool HasAnyLongOption() const; - + /** * Creates new [option description (TOpt)] as a copy of given one * @param option source * @return reference for created option */ TOpt& AddOption(const TOpt& option); - + /** * Creates new free argument handling * @param name name of free arg to show in help @@ -266,7 +266,7 @@ namespace NLastGetopt { * @param optstring source */ void AddCharOptions(const TStringBuf& optstring); - + /** * Creates new [option description (TOpt)] with given short name and given help string * @@ -277,7 +277,7 @@ namespace NLastGetopt { TOpt& AddCharOption(char c, const TString& help = "") { return AddCharOption(c, DEFAULT_HAS_ARG, help); } - + /** * Creates new [option description (TOpt)] with given short name and given help string * @@ -292,7 +292,7 @@ namespace NLastGetopt { option.HasArg(hasArg); return AddOption(option); } - + /** * Creates new [option description (TOpt)] with given long name and given help string * @@ -303,7 +303,7 @@ namespace NLastGetopt { TOpt& AddLongOption(const TString& name, const TString& help = "") { return AddLongOption(0, name, help); } - + /** * Creates new [option description (TOpt)] with given long and short names and given help string * @@ -320,7 +320,7 @@ namespace NLastGetopt { option.Help(help); return AddOption(option); } - + /** * Creates new [option description (TOpt)] for help printing, * adds appropriate handler for it @@ -338,8 +338,8 @@ namespace NLastGetopt { .HasArg(NO_ARGUMENT) .IfPresentDisableCompletion() .Handler(&PrintUsageAndExit); - } - + } + /** * Creates new [option description (TOpt)] for svn-revision printing, * adds appropriate handler for it. @@ -357,8 +357,8 @@ namespace NLastGetopt { .HasArg(NO_ARGUMENT) .IfPresentDisableCompletion() .Handler(&PrintVersionAndExit); - } - + } + /** * Creates new option for generating completion shell scripts. * @@ -379,8 +379,8 @@ namespace NLastGetopt { AddCharOption(c); return const_cast<TOpt&>(GetCharOption(c)); } - } - + } + /** * Indicate that some options can't appear together. * @@ -405,7 +405,7 @@ namespace NLastGetopt { * @param opt pointer of option to search */ size_t IndexOf(const TOpt* opt) const; - + /** * Replace help string with given * @@ -414,7 +414,7 @@ namespace NLastGetopt { void SetCmdLineDescr(const TString& descr) { CustomCmdLineDescr = descr; } - + /** * Replace usage string with given * @@ -448,7 +448,7 @@ namespace NLastGetopt { void SetFreeArgsMin(size_t min) { FreeArgsMin_ = ui32(min); } - + /** * Get current minimal number of free args @@ -466,7 +466,7 @@ namespace NLastGetopt { FreeArgsMax_ = ui32(max); FreeArgsMax_ = Max<ui32>(FreeArgsMax_, ArgBindings_.size()); } - + /** * Get current maximal number of free args */ @@ -490,7 +490,7 @@ namespace NLastGetopt { FreeArgsMin_ = ui32(count); FreeArgsMax_ = ui32(count); } - + /** * Set minimal and maximal number of free args * @@ -501,7 +501,7 @@ namespace NLastGetopt { FreeArgsMin_ = ui32(min); FreeArgsMax_ = ui32(max); } - + /** * Set title and help string of free argument * @@ -512,7 +512,7 @@ namespace NLastGetopt { * does not affect actual flags parsing */ void SetFreeArgTitle(size_t pos, const TString& title, const TString& help = TString(), bool optional = false); - + /** * Get free argument's spec for further modification. */ @@ -555,7 +555,7 @@ namespace NLastGetopt { TrailingArgSpec_.Help(std::move(help)); } /// @} - + /** * Get spec for the trailing argument. * @@ -578,7 +578,7 @@ namespace NLastGetopt { void SetAllowSingleDashForLong(bool value) { AllowSingleDashForLong_ = value; } - + /** * Wrap help text at this number of characters. 0 to disable wrapping. */ @@ -613,7 +613,7 @@ namespace NLastGetopt { } return ret; } - + private: /** * @return argument title of a free argument @@ -621,7 +621,7 @@ namespace NLastGetopt { * @param pos position of the argument */ TStringBuf GetFreeArgTitle(size_t pos) const; - + /** * Print usage helper * @@ -630,7 +630,7 @@ namespace NLastGetopt { * @param colors colorizer */ void PrintCmdLine(const TStringBuf& program, IOutputStream& os, const NColorizer::TColors& colors) const; - + /** * Print usage helper * @@ -639,5 +639,5 @@ namespace NLastGetopt { */ void PrintFreeArgsDesc(IOutputStream& os, const NColorizer::TColors& colors) const; }; - + } diff --git a/library/cpp/getopt/small/last_getopt_parse_result.cpp b/library/cpp/getopt/small/last_getopt_parse_result.cpp index f4b5607a90..423e035bc5 100644 --- a/library/cpp/getopt/small/last_getopt_parse_result.cpp +++ b/library/cpp/getopt/small/last_getopt_parse_result.cpp @@ -1,6 +1,6 @@ -#include "last_getopt_parse_result.h" - -namespace NLastGetopt { +#include "last_getopt_parse_result.h" + +namespace NLastGetopt { const TOptParseResult* TOptsParseResult::FindParseResult(const TdVec& vec, const TOpt* opt) { for (const auto& r : vec) { if (r.OptPtr() == opt) @@ -8,35 +8,35 @@ namespace NLastGetopt { } return nullptr; } - + const TOptParseResult* TOptsParseResult::FindOptParseResult(const TOpt* opt, bool includeDefault) const { const TOptParseResult* r = FindParseResult(Opts_, opt); if (nullptr == r && includeDefault) r = FindParseResult(OptsDef_, opt); return r; - } - + } + const TOptParseResult* TOptsParseResult::FindLongOptParseResult(const TString& name, bool includeDefault) const { return FindOptParseResult(&Parser_->Opts_->GetLongOption(name), includeDefault); } - + const TOptParseResult* TOptsParseResult::FindCharOptParseResult(char c, bool includeDefault) const { return FindOptParseResult(&Parser_->Opts_->GetCharOption(c), includeDefault); } - + bool TOptsParseResult::Has(const TOpt* opt, bool includeDefault) const { Y_ASSERT(opt); return FindOptParseResult(opt, includeDefault) != nullptr; } - + bool TOptsParseResult::Has(const TString& name, bool includeDefault) const { return FindLongOptParseResult(name, includeDefault) != nullptr; } - + bool TOptsParseResult::Has(char c, bool includeDefault) const { return FindCharOptParseResult(c, includeDefault) != nullptr; } - + const char* TOptsParseResult::Get(const TOpt* opt, bool includeDefault) const { Y_ASSERT(opt); const TOptParseResult* r = FindOptParseResult(opt, includeDefault); @@ -52,7 +52,7 @@ namespace NLastGetopt { return r->Back(); } } - + const char* TOptsParseResult::GetOrElse(const TOpt* opt, const char* defaultValue) const { Y_ASSERT(opt); const TOptParseResult* r = FindOptParseResult(opt); @@ -60,29 +60,29 @@ namespace NLastGetopt { return defaultValue; } else { return r->Back(); - } - } - + } + } + const char* TOptsParseResult::Get(const TString& name, bool includeDefault) const { return Get(&Parser_->Opts_->GetLongOption(name), includeDefault); - } - + } + const char* TOptsParseResult::Get(char c, bool includeDefault) const { return Get(&Parser_->Opts_->GetCharOption(c), includeDefault); } - + const char* TOptsParseResult::GetOrElse(const TString& name, const char* defaultValue) const { if (!Has(name)) return defaultValue; return Get(name); } - + const char* TOptsParseResult::GetOrElse(char c, const char* defaultValue) const { if (!Has(c)) return defaultValue; return Get(c); } - + TOptParseResult& TOptsParseResult::OptParseResult() { const TOpt* opt = Parser_->CurOpt(); Y_ASSERT(opt); @@ -94,11 +94,11 @@ namespace NLastGetopt { opts.push_back(TOptParseResult(opt)); return opts.back(); } - + TString TOptsParseResult::GetProgramName() const { return Parser_->ProgramName_; } - + void TOptsParseResult::PrintUsage(IOutputStream& os) const { Parser_->Opts_->PrintUsage(Parser_->ProgramName_, os); } @@ -106,7 +106,7 @@ namespace NLastGetopt { size_t TOptsParseResult::GetFreeArgsPos() const { return Parser_->Pos_; } - + TVector<TString> TOptsParseResult::GetFreeArgs() const { TVector<TString> v; for (size_t i = GetFreeArgsPos(); i < Parser_->Argc_; ++i) { @@ -114,11 +114,11 @@ namespace NLastGetopt { } return v; } - + size_t TOptsParseResult::GetFreeArgCount() const { return Parser_->Argc_ - GetFreeArgsPos(); - } - + } + void TOptsParseResult::Init(const TOpts* options, int argc, const char** argv) { try { Parser_.Reset(new TOptsParser(options, argc, argv)); @@ -138,9 +138,9 @@ namespace NLastGetopt { } } catch (...) { HandleError(); - } - } - + } + } + void TOptsParseResult::HandleError() const { Cerr << CurrentExceptionMessage() << Endl; if (Parser_.Get()) { // parser initializing can fail (and we get here, see Init) @@ -149,12 +149,12 @@ namespace NLastGetopt { } else { PrintUsage(); } - } + } exit(1); - } - + } + void TOptsParseResultException::HandleError() const { throw; } - -} + +} diff --git a/library/cpp/getopt/small/last_getopt_parse_result.h b/library/cpp/getopt/small/last_getopt_parse_result.h index 1ab6f598c9..e55a1a1eec 100644 --- a/library/cpp/getopt/small/last_getopt_parse_result.h +++ b/library/cpp/getopt/small/last_getopt_parse_result.h @@ -1,9 +1,9 @@ -#pragma once - -#include "last_getopt_opts.h" +#pragma once + +#include "last_getopt_opts.h" #include "last_getopt_parser.h" - -namespace NLastGetopt { + +namespace NLastGetopt { /** * NLastGetopt::TOptParseResult contains all arguments for exactly one TOpt, * that have been fetched during parsing @@ -13,13 +13,13 @@ namespace NLastGetopt { class TOptParseResult { public: typedef TVector<const char*> TValues; - + public: TOptParseResult(const TOpt* opt = nullptr) : Opt_(opt) { } - + public: const TOpt& Opt() const { return *Opt_; @@ -49,7 +49,7 @@ namespace NLastGetopt { const char* Back(const char* def = nullptr) const { return Empty() ? DefVal(def) : Values().back(); } - + private: const TOpt* Opt_; TValues Values_; @@ -67,16 +67,16 @@ namespace NLastGetopt { class TOptsParseResult { private: THolder<TOptsParser> Parser_; //The instance of parser. - + // XXX: make argc, argv typedef TVector<TOptParseResult> TdVec; - + TdVec Opts_; //Parsing result for all options, that have been explicitly defined in argc/argv TdVec OptsDef_; //Parsing result for options, that have been defined by default values only - + private: TOptParseResult& OptParseResult(); - + /** * Searchs for object in given container * @@ -86,15 +86,15 @@ namespace NLastGetopt { * @retunr ptr on corresponding TOptParseResult */ static const TOptParseResult* FindParseResult(const TdVec& vec, const TOpt* opt); - + protected: /** * Performs parsing of comand line arguments. */ void Init(const TOpts* options, int argc, const char** argv); - + TOptsParseResult() = default; - + public: /** * The action in case of parser failure. @@ -102,7 +102,7 @@ namespace NLastGetopt { * By default prints error string and aborts the program */ virtual void HandleError() const; - + /** * Constructs object by parsing arguments with given rules * @@ -113,7 +113,7 @@ namespace NLastGetopt { TOptsParseResult(const TOpts* options, int argc, const char* argv[]) { Init(options, argc, argv); } - + /** * Constructs object by parsing arguments with given rules * @@ -124,9 +124,9 @@ namespace NLastGetopt { TOptsParseResult(const TOpts* options, int argc, char* argv[]) { Init(options, argc, const_cast<const char**>(argv)); } - + virtual ~TOptsParseResult() = default; - + /** * Search for TOptParseResult that corresponds to given option (TOpt) * @@ -136,7 +136,7 @@ namespace NLastGetopt { * @return ptr on result */ const TOptParseResult* FindOptParseResult(const TOpt* opt, bool includeDefault = false) const; - + /** * Search for TOptParseResult that corresponds to given long name * @@ -146,7 +146,7 @@ namespace NLastGetopt { * @return ptr on result */ const TOptParseResult* FindLongOptParseResult(const TString& name, bool includeDefault = false) const; - + /** * Search for TOptParseResult that corresponds to given short name * @@ -156,12 +156,12 @@ namespace NLastGetopt { * @return ptr on result */ const TOptParseResult* FindCharOptParseResult(char c, bool includeDefault = false) const; - + /** * @return argv[0] */ TString GetProgramName() const; - + /** * Print usage string. */ @@ -171,17 +171,17 @@ namespace NLastGetopt { * @return position in [premuted argv] of the first free argument */ size_t GetFreeArgsPos() const; - + /** * @return number of fetched free arguments */ size_t GetFreeArgCount() const; - + /** * @return all fetched free arguments */ TVector<TString> GetFreeArgs() const; - + /** * @return true if given option exist in results of parsing * @@ -190,7 +190,7 @@ namespace NLastGetopt { * */ bool Has(const TOpt* opt, bool includeDefault = false) const; - + /** * @return nil terminated string on the last fetched argument of givne option * @@ -198,7 +198,7 @@ namespace NLastGetopt { * @param includeDefault search in results obtained from default values */ const char* Get(const TOpt* opt, bool includeDefault = true) const; - + /** * @return nil terminated string on the last fetched argument of givne option * if option haven't been fetched, given defaultValue will be returned @@ -207,7 +207,7 @@ namespace NLastGetopt { * @param defaultValue */ const char* GetOrElse(const TOpt* opt, const char* defaultValue) const; - + /** * @return true if given option exist in results of parsing * @@ -216,7 +216,7 @@ namespace NLastGetopt { * */ bool Has(const TString& name, bool includeDefault = false) const; - + /** * @return nil terminated string on the last fetched argument of givne option * @@ -224,7 +224,7 @@ namespace NLastGetopt { * @param includeDefault search in results obtained from default values */ const char* Get(const TString& name, bool includeDefault = true) const; - + /** * @return nil terminated string on the last fetched argument of givne option * if option haven't been fetched, given defaultValue will be returned @@ -233,7 +233,7 @@ namespace NLastGetopt { * @param defaultValue */ const char* GetOrElse(const TString& name, const char* defaultValue) const; - + /** * @return true if given option exist in results of parsing * @@ -242,7 +242,7 @@ namespace NLastGetopt { * */ bool Has(char name, bool includeDefault = false) const; - + /** * @return nil terminated string on the last fetched argument of givne option * @@ -250,7 +250,7 @@ namespace NLastGetopt { * @param includeDefault search in results obtained from default values */ const char* Get(char name, bool includeDefault = true) const; - + /** * @return nil terminated string on the last fetched argument of givne option * if option haven't been fetched, given defaultValue will be returned @@ -259,7 +259,7 @@ namespace NLastGetopt { * @param defaultValue */ const char* GetOrElse(char name, const char* defaultValue) const; - + /** * for givne option return parsed value of the last fetched argument * if option haven't been fetched, HandleError action is called @@ -277,8 +277,8 @@ namespace NLastGetopt { HandleError(); throw; } - } - + } + /** * for givne option return parsed value of the last fetched argument * if option haven't been fetched, given defaultValue will be returned @@ -296,7 +296,7 @@ namespace NLastGetopt { return defaultValue; } }; - + /** * NLastGetopt::TOptsParseResultException contains result of parsing argc,argv be parser. * @@ -317,5 +317,5 @@ namespace NLastGetopt { protected: TOptsParseResultException() = default; }; - -} + +} diff --git a/library/cpp/getopt/small/last_getopt_parser.cpp b/library/cpp/getopt/small/last_getopt_parser.cpp index 7668b12a03..7c474809ce 100644 --- a/library/cpp/getopt/small/last_getopt_parser.cpp +++ b/library/cpp/getopt/small/last_getopt_parser.cpp @@ -1,23 +1,23 @@ -#include "last_getopt_parser.h" - +#include "last_getopt_parser.h" + #include <library/cpp/colorizer/colors.h> -#include <util/string/escape.h> - -namespace NLastGetopt { +#include <util/string/escape.h> + +namespace NLastGetopt { void TOptsParser::Init(const TOpts* opts, int argc, const char* argv[]) { opts->Validate(); - + Opts_ = opts; - + if (argc < 1) throw TUsageException() << "argv must have at least one argument"; - + Argc_ = argc; Argv_ = argv; - + ProgramName_ = argv[0]; - + Pos_ = 1; Sop_ = 0; CurrentOpt_ = nullptr; @@ -27,11 +27,11 @@ namespace NLastGetopt { OptsSeen_.clear(); OptsDefault_.clear(); } - + void TOptsParser::Init(const TOpts* opts, int argc, char* argv[]) { Init(opts, argc, const_cast<const char**>(argv)); } - + void TOptsParser::Swap(TOptsParser& that) { DoSwap(Opts_, that.Opts_); DoSwap(Argc_, that.Argc_); @@ -46,7 +46,7 @@ namespace NLastGetopt { DoSwap(GotMinusMinus_, that.GotMinusMinus_); DoSwap(OptsSeen_, that.OptsSeen_); } - + bool TOptsParser::Commit(const TOpt* currentOpt, const TStringBuf& currentValue, size_t pos, size_t sop) { Pos_ = pos; Sop_ = sop; @@ -56,62 +56,62 @@ namespace NLastGetopt { OptsSeen_.insert(currentOpt); return true; } - + bool TOptsParser::CommitEndOfOptions(size_t pos) { Pos_ = pos; Sop_ = 0; Y_ASSERT(!CurOpt()); Y_ASSERT(!CurVal()); - + Y_ASSERT(!Stopped_); - + if (Opts_->FreeArgsMin_ == Opts_->FreeArgsMax_ && Argc_ - Pos_ != Opts_->FreeArgsMin_) throw TUsageException() << "required exactly " << Opts_->FreeArgsMin_ << " free args"; else if (Argc_ - Pos_ < Opts_->FreeArgsMin_) throw TUsageException() << "required at least " << Opts_->FreeArgsMin_ << " free args"; else if (Argc_ - Pos_ > Opts_->FreeArgsMax_) throw TUsageException() << "required at most " << Opts_->FreeArgsMax_ << " free args"; - + return false; } - + bool TOptsParser::ParseUnknownShortOptWithinArg(size_t pos, size_t sop) { Y_ASSERT(pos < Argc_); const TStringBuf arg(Argv_[pos]); Y_ASSERT(sop > 0); Y_ASSERT(sop < arg.length()); Y_ASSERT(EIO_NONE != IsOpt(arg)); - + if (!Opts_->AllowUnknownCharOptions_) throw TUsageException() << "unknown option '" << EscapeC(arg[sop]) << "' in '" << arg << "'"; - + TempCurrentOpt_.Reset(new TOpt); TempCurrentOpt_->AddShortName(arg[sop]); - + sop += 1; - + // mimic behavior of Opt: unknown option has arg only if char is last within arg if (sop < arg.length()) { return Commit(TempCurrentOpt_.Get(), nullptr, pos, sop); } - + pos += 1; sop = 0; if (pos == Argc_ || EIO_NONE != IsOpt(Argv_[pos])) { return Commit(TempCurrentOpt_.Get(), nullptr, pos, 0); } - + return Commit(TempCurrentOpt_.Get(), Argv_[pos], pos + 1, 0); - } - + } + bool TOptsParser::ParseShortOptWithinArg(size_t pos, size_t sop) { Y_ASSERT(pos < Argc_); const TStringBuf arg(Argv_[pos]); Y_ASSERT(sop > 0); Y_ASSERT(sop < arg.length()); Y_ASSERT(EIO_NONE != IsOpt(arg)); - + size_t p = sop; char c = arg[p]; const TOpt* opt = Opts_->FindCharOption(c); @@ -126,15 +126,15 @@ namespace NLastGetopt { } return Commit(opt, arg.SubStr(p), pos + 1, 0); } - + bool TOptsParser::ParseShortOptArg(size_t pos) { Y_ASSERT(pos < Argc_); const TStringBuf arg(Argv_[pos]); Y_ASSERT(EIO_NONE != IsOpt(arg)); Y_ASSERT(!arg.StartsWith("--")); return ParseShortOptWithinArg(pos, 1); - } - + } + bool TOptsParser::ParseOptArg(size_t pos) { Y_ASSERT(pos < Argc_); TStringBuf arg(Argv_[pos]); @@ -155,7 +155,7 @@ namespace NLastGetopt { throw TUsageException() << "unknown option '" << optionName << "' in '" << Argv_[pos] << "'"; } - } + } if (arg.IsInited()) { if (option->GetHasArg() == NO_ARGUMENT) throw TUsageException() << "option " << optionName << " must have no arg"; @@ -165,9 +165,9 @@ namespace NLastGetopt { return ParseOptParam(option, pos); } else { return ParseShortOptArg(pos); - } - } - + } + } + bool TOptsParser::ParseOptParam(const TOpt* opt, size_t pos) { Y_ASSERT(opt); if (opt->GetHasArg() == NO_ARGUMENT) { @@ -183,8 +183,8 @@ namespace NLastGetopt { return Commit(opt, arg, pos + 1, 0); } return Commit(opt, nullptr, pos, 0); - } - + } + TOptsParser::EIsOpt TOptsParser::IsOpt(const TStringBuf& arg) const { EIsOpt eio = EIO_NONE; if (1 < arg.length()) { @@ -202,35 +202,35 @@ namespace NLastGetopt { eio = EIO_PLUS; break; } - } + } return eio; - } - + } + static void memrotate(void* ptr, size_t size, size_t shift) { TTempBuf buf(shift); memcpy(buf.Data(), (char*)ptr + size - shift, shift); memmove((char*)ptr + shift, ptr, size - shift); memcpy(ptr, buf.Data(), shift); } - + bool TOptsParser::ParseWithPermutation() { Y_ASSERT(Sop_ == 0); Y_ASSERT(Opts_->ArgPermutation_ == PERMUTE); - + const size_t p0 = Pos_; - + size_t pc = Pos_; - + for (; pc < Argc_ && EIO_NONE == IsOpt(Argv_[pc]); ++pc) { // count non-args } - + if (pc == Argc_) { return CommitEndOfOptions(Pos_); } - + Pos_ = pc; - + bool r = ParseOptArg(Pos_); Y_ASSERT(r); while (Pos_ == pc) { @@ -238,33 +238,33 @@ namespace NLastGetopt { r = ParseShortOptWithinArg(Pos_, Sop_); Y_ASSERT(r); } - + size_t p2 = Pos_; - + Y_ASSERT(p2 - pc >= 1); Y_ASSERT(p2 - pc <= 2); - + memrotate(Argv_ + p0, (p2 - p0) * sizeof(void*), (p2 - pc) * sizeof(void*)); - + bool r2 = ParseOptArg(p0); Y_ASSERT(r2); return r2; } - + bool TOptsParser::DoNext() { Y_ASSERT(Pos_ <= Argc_); - + if (Pos_ == Argc_) return CommitEndOfOptions(Pos_); - + if (GotMinusMinus_ && Opts_->ArgPermutation_ == RETURN_IN_ORDER) { Y_ASSERT(Sop_ == 0); return Commit(nullptr, Argv_[Pos_], Pos_ + 1, 0); } - + if (Sop_ > 0) return ParseShortOptWithinArg(Pos_, Sop_); - + size_t pos = Pos_; const TStringBuf arg(Argv_[pos]); if (EIO_NONE != IsOpt(arg)) { @@ -283,59 +283,59 @@ namespace NLastGetopt { return Commit(nullptr, arg, pos + 1, 0); } else if (Opts_->ArgPermutation_ == REQUIRE_ORDER) { return CommitEndOfOptions(Pos_); - } else { + } else { return ParseWithPermutation(); - } - } - + } + } + bool TOptsParser::Next() { bool r = false; - + if (OptsDefault_.empty()) { CurrentOpt_ = nullptr; TempCurrentOpt_.Destroy(); - + CurrentValue_ = nullptr; - + if (Stopped_) return false; - + TOptsParser copy = *this; - + r = copy.DoNext(); - + Swap(copy); - + if (!r) { Stopped_ = true; // we are done; check for missing options Finish(); } - } - + } + if (!r && !OptsDefault_.empty()) { CurrentOpt_ = OptsDefault_.front(); CurrentValue_ = CurrentOpt_->GetDefaultValue(); OptsDefault_.pop_front(); r = true; } - + if (r) { if (CurOpt()) CurOpt()->FireHandlers(this); } return r; - } - + } + void TOptsParser::Finish() { const TOpts::TOptsVector& optvec = Opts_->Opts_; if (optvec.size() == OptsSeen_.size()) return; - + TVector<TString> missingLong; TVector<char> missingShort; - + TOpts::TOptsVector::const_iterator it; for (it = optvec.begin(); it != optvec.end(); ++it) { const TOpt* opt = (*it).Get(); @@ -343,7 +343,7 @@ namespace NLastGetopt { continue; if (OptsSeen_.contains(opt)) continue; - + if (opt->IsRequired()) { const TOpt::TLongNames& optnames = opt->GetLongNames(); if (!optnames.empty()) @@ -355,18 +355,18 @@ namespace NLastGetopt { } continue; } - + if (opt->HasDefaultValue()) OptsDefault_.push_back(opt); - } - + } + // also indicates subsequent options, if any, haven't been seen actually OptsSeen_.clear(); - + const size_t nmissing = missingLong.size() + missingShort.size(); if (0 == nmissing) return; - + TUsageException usage; usage << "The following option"; usage << ((1 == nmissing) ? " is" : "s are"); @@ -377,11 +377,11 @@ namespace NLastGetopt { usage << " -" << missingShort[i]; throw usage; // don't need lineinfo, just the message } - + void TOptsParser::PrintUsage(IOutputStream& os, const NColorizer::TColors& colors) const { Opts_->PrintUsage(ProgramName(), os, colors); } - + void TOptsParser::PrintUsage(IOutputStream& os) const { PrintUsage(os, NColorizer::AutoColors(os)); } diff --git a/library/cpp/getopt/small/last_getopt_parser.h b/library/cpp/getopt/small/last_getopt_parser.h index 2cf8a6c308..292fb49d11 100644 --- a/library/cpp/getopt/small/last_getopt_parser.h +++ b/library/cpp/getopt/small/last_getopt_parser.h @@ -1,20 +1,20 @@ -#pragma once - -#include "last_getopt_opts.h" - +#pragma once + +#include "last_getopt_opts.h" + #include <library/cpp/colorizer/fwd.h> -#include <util/generic/hash_set.h> -#include <util/generic/list.h> - -namespace NLastGetopt { +#include <util/generic/hash_set.h> +#include <util/generic/list.h> + +namespace NLastGetopt { /** -* NLastGetopt::TOptsParser is an implementation of parsing -* argv/argv into TOptsParseResult by rules of TOpts. -* -* The class allows to make complicated handlers. -* Note, that if PERMUTE mode is on, then data, pointed by argv can be changed. -*/ +* NLastGetopt::TOptsParser is an implementation of parsing +* argv/argv into TOptsParseResult by rules of TOpts. +* +* The class allows to make complicated handlers. +* Note, that if PERMUTE mode is on, then data, pointed by argv can be changed. +*/ class TOptsParser { enum EIsOpt { EIO_NONE, //is not an option name @@ -22,72 +22,72 @@ namespace NLastGetopt { EIO_DDASH, //double-dashed ("--opt") option name EIO_PLUS, //plus prefix ("+opt") option name }; - + public: // TODO: make private const TOpts* Opts_; //rules of parsing - + // argc/argv pair size_t Argc_; const char** Argv_; - + private: //the storage of last unkown options. TODO: can be moved to local-method scope TCopyPtr<TOpt> TempCurrentOpt_; - + public: //storage of argv[0] TString ProgramName_; - + //state of parsing: - + size_t Pos_; // current element withing argv size_t Sop_; // current char within arg bool Stopped_; bool GotMinusMinus_; //true if "--" have been seen in argv - + protected: const TOpt* CurrentOpt_; // ptr on the last meeted option TStringBuf CurrentValue_; // the value of the last met argument (corresponding to CurrentOpt_) - + private: typedef THashSet<const TOpt*> TdOptSet; TdOptSet OptsSeen_; //the set of options that have been met during parsing - + TList<const TOpt*> OptsDefault_; - + private: void Init(const TOpts* options, int argc, const char* argv[]); void Init(const TOpts* options, int argc, char* argv[]); - + bool CommitEndOfOptions(size_t pos); bool Commit(const TOpt* currentOption, const TStringBuf& currentValue, size_t pos, size_t sop); - + bool ParseShortOptArg(size_t pos); bool ParseOptArg(size_t pos); bool ParseOptParam(const TOpt* opt, size_t pos); bool ParseUnknownShortOptWithinArg(size_t pos, size_t sop); bool ParseShortOptWithinArg(size_t pos, size_t sop); bool ParseWithPermutation(); - + bool DoNext(); void Finish(); - + EIsOpt IsOpt(const TStringBuf& arg) const; - + void Swap(TOptsParser& that); - + public: TOptsParser(const TOpts* options, int argc, const char* argv[]) { Init(options, argc, argv); } - + TOptsParser(const TOpts* options, int argc, char* argv[]) { Init(options, argc, argv); } - + /// fetch next argument, false if no more arguments left bool Next(); - + bool Seen(const TOpt* opt) const { return OptsSeen_.contains(opt); } @@ -111,38 +111,38 @@ namespace NLastGetopt { const TOpt* CurOpt() const { return CurrentOpt_; } - + const char* CurVal() const { return CurrentValue_.data(); } - + const TStringBuf& CurValStr() const { return CurrentValue_; } - + TStringBuf CurValOrOpt() const { TStringBuf val(CurValStr()); if (!val.IsInited() && CurOpt()->HasOptionalValue()) val = CurOpt()->GetOptionalValue(); return val; } - + TStringBuf CurValOrDef(bool useDef = true) const { TStringBuf val(CurValOrOpt()); if (!val.IsInited() && useDef && CurOpt()->HasDefaultValue()) val = CurOpt()->GetDefaultValue(); return val; } - + // true if this option was actually specified by the user bool IsExplicit() const { return nullptr == CurrentOpt_ || !OptsSeen_.empty(); } - + bool CurrentIs(const TString& name) const { return CurOpt()->NameIs(name); } - + const TString& ProgramName() const { return ProgramName_; } diff --git a/library/cpp/getopt/small/last_getopt_support.h b/library/cpp/getopt/small/last_getopt_support.h index 17bed3e614..352a8616fb 100644 --- a/library/cpp/getopt/small/last_getopt_support.h +++ b/library/cpp/getopt/small/last_getopt_support.h @@ -136,21 +136,21 @@ namespace NLastGetopt { , Value(value) { } - + void operator()(const TOptsParser*) { *Target = Value; } }; - + TString OptToString(char c); TString OptToString(const TString& longOption); TString OptToString(const TOpt* opt); - + template <typename T> inline T OptFromStringImpl(const TStringBuf& value) { return FromString<T>(value); - } - + } + template <> inline TStringBuf OptFromStringImpl<TStringBuf>(const TStringBuf& value) { return value; diff --git a/library/cpp/getopt/small/opt.h b/library/cpp/getopt/small/opt.h index ecb57439bc..2a04caab29 100644 --- a/library/cpp/getopt/small/opt.h +++ b/library/cpp/getopt/small/opt.h @@ -25,7 +25,7 @@ == non-option forces getopt to return 1 and to place non-option into optarg 2. shortopts begins with '+' :=> REQUIRE_ORDER - GetEnv(_POSIX_OPTION_ORDER) :=> REQUIRE_ORDER + GetEnv(_POSIX_OPTION_ORDER) :=> REQUIRE_ORDER == 1st non-option forces getopt to return EOF 3. default :=> PERMUTE diff --git a/library/cpp/getopt/small/ya.make b/library/cpp/getopt/small/ya.make index 96de0f04b1..a11fc36ab3 100644 --- a/library/cpp/getopt/small/ya.make +++ b/library/cpp/getopt/small/ya.make @@ -12,11 +12,11 @@ SRCS( completion_generator.cpp formatted_output.cpp last_getopt.cpp - last_getopt_easy_setup.cpp - last_getopt_opt.cpp - last_getopt_opts.cpp - last_getopt_parser.cpp - last_getopt_parse_result.cpp + last_getopt_easy_setup.cpp + last_getopt_opt.cpp + last_getopt_opts.cpp + last_getopt_parser.cpp + last_getopt_parse_result.cpp modchooser.cpp opt.cpp opt2.cpp |