This commit is contained in:
codeboss 2024-10-01 17:48:20 +08:00
parent 0de21ee189
commit 435d01dde7
3 changed files with 62 additions and 29 deletions

View File

@ -33,6 +33,12 @@ bool __FloatArgvImpl::optional() const {
return optional_value;
}
QString args_parse::FloatKeyValue::placeHolder() const {
if(optional())
return QString("[--%1 <%2>]").arg(bindKey(), bindKey());
return QString("--%1 <%2>").arg(bindKey(), bindKey());
}
int FloatKeyValue::matchLenth() const {
return 2;
}
@ -45,7 +51,12 @@ bool FloatKeyValue::parse(const QList<QString> args, int start) {
return args_t == bindKey();
}
IndexParam::IndexParam(const QString& means) : __ArgvPackImpls(means, ParamType::IndexParam) { }
IndexParam::IndexParam(const QString& place_v, const QString& means)
: __ArgvPackImpls(means, ParamType::IndexParam), _place_holder(place_v) { }
QString args_parse::IndexParam::placeHolder() const {
return QString("<%1>").arg(_place_holder);
}
int IndexParam::matchLenth() const {
return 1;
@ -64,6 +75,12 @@ FloatOption::FloatOption(const QString& key, const QString& means, bool opt)
setValue(u8"0");
}
QString args_parse::FloatOption::placeHolder() const {
if(optional())
return QString("[--%1]").arg(bindKey());
return QString("--%1").arg(bindKey());
}
int FloatOption::matchLenth() const {
return 1;
}

View File

@ -22,9 +22,19 @@ namespace args_parse {
class IArgvPack {
public:
virtual ~IArgvPack() = default;
/**
* .
*
* \return
*/
virtual ParamType paramType() const = 0;
/**
* @brief .
*
* \return
*/
virtual QString means() const = 0;
virtual QString placeHolder() const = 0;
virtual QString value() const = 0;
/**
* @brief .
@ -80,6 +90,7 @@ namespace args_parse {
explicit FloatKeyValue(const QString& key, const QString &means, bool optional = false);
virtual ~FloatKeyValue() = default;
virtual QString placeHolder() const override;
virtual int matchLenth() const override;
bool parse(const QList<QString> args, int start) override;
};
@ -93,6 +104,7 @@ namespace args_parse {
explicit FloatOption(const QString& key, const QString& means, bool optional = false);
virtual ~FloatOption() = default;
virtual QString placeHolder() const override;
virtual int matchLenth() const override;
bool parse(const QList<QString> args, int start) override;
};
@ -101,11 +113,15 @@ namespace args_parse {
* .
*/
class ARGSPARSER_EXPORT IndexParam : public __ArgvPackImpls {
private:
QString _place_holder;
public:
explicit IndexParam(const QString &means);
explicit IndexParam(const QString & place_v, const QString &means);
virtual ~IndexParam() = default;
// 通过 __ArgvPackImpls 继承
virtual QString placeHolder() const override;
int matchLenth() const override;
bool parse(const QList<QString> args, int start) override;
};

View File

@ -30,12 +30,12 @@ int main(int argc, char* argv[]) {
args_parse::ArgsParser args_parser;
QList<std::shared_ptr<args_parse::IArgvPack>> args_mode;
args_mode << std::make_shared<args_parse::IndexParam>(u8"³ÌÐòÃû³Æ");
args_mode << std::make_shared<args_parse::IndexParam>(u8"nsc", u8"³ÌÐòÃû³Æ");
args_mode << std::make_shared<args_parse::FloatOption>(u8"--help", u8"帮助");
args_parser.loadMode(0x000Au, args_mode);
args_mode.clear();
args_mode << std::make_shared<args_parse::IndexParam>(u8"³ÌÐòÃû³Æ");
args_mode << std::make_shared<args_parse::IndexParam>(u8"nsc", u8"³ÌÐòÃû³Æ");
args_mode << std::make_shared<args_parse::FloatKeyValue>(u8"--path", u8"源代码目录");
args_mode << std::make_shared<args_parse::FloatKeyValue>(u8"--dest", u8"生成目录");
args_mode << std::make_shared<args_parse::FloatOption>(u8"--html", u8"生成html文件格式取代AST", true);