Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add generators #9

Draft
wants to merge 54 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
4f965cb
setup config file
glcraft Jan 23, 2023
4b0f729
remove glap option deps from programs
glcraft Jan 23, 2023
1967ec2
options check if std library available
glcraft Jan 23, 2023
afd5506
convert_to: impl gcc way for fallback
glcraft Nov 28, 2022
2959371
add console style
glcraft Nov 28, 2022
f325814
add print
glcraft Nov 28, 2022
072ac53
move help in generators
glcraft Nov 28, 2022
1deed38
update help to work with the new model
glcraft Nov 28, 2022
0282ace
remove extra newline
glcraft Nov 28, 2022
9898848
Add ability to get help of command from program
glcraft Nov 28, 2022
cc786ba
update example
glcraft Nov 28, 2022
5a8f896
rename help concepts
glcraft Nov 30, 2022
28754c6
update example
glcraft Nov 28, 2022
636ab28
initialize new target
glcraft Nov 29, 2022
8f03197
update example
glcraft Nov 30, 2022
c9f6032
rename longname => name
glcraft Nov 30, 2022
e13dbe5
codepoint_to_utf8 now inline
glcraft Nov 30, 2022
2cace2e
add missing header
glcraft Nov 30, 2022
c2c47c0
add gitignore test lua
glcraft Dec 1, 2022
eca4f8f
correct name param
Dec 1, 2022
d905894
update gitignore
glcraft Dec 2, 2022
5f372d9
add config import in base
glcraft Jan 23, 2023
d7f528c
add module and std module in config
glcraft Jan 23, 2023
ef7ff32
add missing endif
glcraft Jan 23, 2023
ad9cba9
add config in glap module
glcraft Jan 23, 2023
7099fbd
fix fmt import
glcraft Jan 23, 2023
ab4d674
add missing character
glcraft Jan 23, 2023
5042a42
fix help header
glcraft Jan 23, 2023
7f708cf
move help in generators
glcraft Nov 28, 2022
b3415e7
update help to work with the new model
glcraft Nov 28, 2022
fdf4382
Add ability to get help of command from program
glcraft Nov 28, 2022
c2c2ca3
rename help concepts
glcraft Nov 30, 2022
e5083fc
rename longname => name
glcraft Nov 30, 2022
740fb51
add missing namespace
glcraft Jan 22, 2023
f76f0a6
remove preproc
glcraft Jan 22, 2023
94b7a7f
add missing fonction on windows
glcraft Jan 22, 2023
5ebce4f
use cout instead of print
glcraft Jan 22, 2023
be89d87
remove print from glap fmt
glcraft Jan 22, 2023
3f0324d
config.h in buildir/include/glap
glcraft Jan 23, 2023
4abd171
remove sample from git
glcraft Jan 23, 2023
6ca2292
add config.h in core base
glcraft Jan 23, 2023
1a8a77f
glap module : config in glap folder
glcraft Jan 23, 2023
f6a47cd
fix wrong duplication code
glcraft Jan 25, 2023
8511a28
add mmg rule
glcraft Jan 27, 2023
47ca2a1
improve mmg rule
glcraft Jan 27, 2023
ad7b0e1
embed rule in a function
glcraft Jan 28, 2023
35d56fd
manage lua files
glcraft Jan 29, 2023
ed554fd
WIP depend glap conf
glcraft Jan 29, 2023
735a569
move mmg rule into its target
glcraft Jan 29, 2023
f901886
remove mmg from glap xmake includes
glcraft Jan 29, 2023
b26443e
add xmake repo for test
glcraft Jan 29, 2023
a36d423
git ignore install folder
glcraft Jan 29, 2023
bc0beb4
glap add config in header files
glcraft Jan 29, 2023
1af8a59
Update HELP doc file
Feb 14, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -589,4 +589,8 @@ healthchecksdb

builddir-release
build
.xmake
.xmake
test.lua

make_my_glap/sample.h
install/
4 changes: 4 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
[submodule "test_mmg/test-xmake-repo"]
path = test_mmg/test-xmake-repo
url = https://github.com/glcraft/xmake-repo.git
branch = mmg-test
2,658 changes: 2,658 additions & 0 deletions _doxygen.conf_

Large diffs are not rendered by default.

8 changes: 4 additions & 4 deletions docs/HELP.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Help text generator

It is currently in development, not usable.
It is still in development, usable but not yet documented.

## Utils

Expand All @@ -15,19 +15,19 @@ struct FullDescription;
## Program description class
```cpp
/// In namespace glap::help::model
template<StringLiteral Name, IsDescription Desc, class ...Commands>
template<StringLiteral Name, HasDescription Desc, class ...Commands>
struct Program;
```
## Command description class
```cpp
/// In namespace glap::help::model
template<StringLiteral Name, IsDescription Desc, class ...Params>
template<StringLiteral Name, HasDescription Desc, class ...Params>
struct Command;
```
## Argument description class
```cpp
/// In namespace glap::help::model
template<StringLiteral Name, IsDescription Desc>
template<StringLiteral Name, HasDescription Desc>
struct Argument;
```
## Help generator class
Expand Down
4 changes: 2 additions & 2 deletions docs/UTILS.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,9 @@

```cpp
/// In namespace glap
template <StringLiteral LongName, auto ShortName = discard>
template <StringLiteral Name, auto ShortName = discard>
struct Names {
static constexpr std::string_view longname = LongName;
static constexpr std::string_view name = Name;
static constexpr std::optional<char32_t> shortname = impl::optional_value<char32_t, ShortName>;
};
```
Expand Down
2 changes: 2 additions & 0 deletions include/glap/core/base.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
#pragma once

#include <glap/config.h>

#ifndef GLAP_EXPORT
#define GLAP_EXPORT
#endif
12 changes: 8 additions & 4 deletions include/glap/core/convertible_to.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,15 @@ GLAP_EXPORT namespace glap
{
namespace impl {
#if defined(__cpp_lib_concepts) && __cpp_lib_concepts >= 201806L
template <typename T, typename U>
concept convertible_to = std::convertible_to<T, U>;
template <typename From, typename To>
concept convertible_to = std::convertible_to<From, To>;
#else
template <typename T, typename U>
concept convertible_to = std::is_convertible_v<U, T>;
template <class From, class To>
concept convertible_to =
std::is_convertible_v<From, To> &&
requires {
static_cast<To>(std::declval<From>());
};
#endif
}
}
2 changes: 1 addition & 1 deletion include/glap/core/utf8.h
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ GLAP_EXPORT namespace glap::utils::uni {
}
return codepoint;
}
[[nodiscard]] constexpr std::string codepoint_to_utf8(char32_t codepoint) noexcept {
[[nodiscard]] inline std::string codepoint_to_utf8(char32_t codepoint) noexcept {
std::string utf8;
if (codepoint <= 0x7F) {
utf8.push_back(static_cast<char>(codepoint));
Expand Down
8 changes: 4 additions & 4 deletions include/glap/core/utils.h
Original file line number Diff line number Diff line change
Expand Up @@ -88,13 +88,13 @@ namespace glap::impl {
}

GLAP_EXPORT namespace glap {
template <StringLiteral LongName, auto ShortName = discard>
template <StringLiteral Name, auto ShortName = discard>
struct Names {
static constexpr std::string_view longname = LongName;
static constexpr std::string_view name = Name;
static constexpr std::optional<char32_t> shortname = impl::optional_value<char32_t, ShortName>;
};
template <typename T>
concept HasLongName = std::same_as<std::remove_cvref_t<decltype(T::longname)>, std::string_view>;
concept HasLongName = std::same_as<std::remove_cvref_t<decltype(T::name)>, std::string_view>;
template <typename T>
concept HasNames = HasLongName<T>
&& std::same_as<std::remove_cvref_t<decltype(T::shortname)>, std::optional<char32_t>>;
Expand All @@ -117,7 +117,7 @@ namespace glap::impl
template <HasNames Arg1, HasNames Arg2, class ...ArgN>
struct NameChecker<Arg1, Arg2, ArgN...>
{
static constexpr bool has_duplicate_longname = Arg1::longname == Arg2::longname || NameChecker<Arg1, ArgN...>::has_duplicate_longname || NameChecker<Arg2, ArgN...>::has_duplicate_longname;
static constexpr bool has_duplicate_longname = Arg1::name == Arg2::name || NameChecker<Arg1, ArgN...>::has_duplicate_longname || NameChecker<Arg2, ArgN...>::has_duplicate_longname;
static constexpr bool has_duplicate_shortname = (Arg1::shortname.has_value() && Arg2::shortname.has_value() && Arg1::shortname.value() == Arg2::shortname.value()) || NameChecker<Arg1, ArgN...>::has_duplicate_shortname || NameChecker<Arg2, ArgN...>::has_duplicate_shortname;
};
template <typename Arg1, typename Arg2, class ...ArgN>
Expand Down
52 changes: 52 additions & 0 deletions include/glap/generators/help.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
#pragma once

#ifndef GLAP_MODULE
#include "../core/base.h"
#include "../core/discard.h"
#include "../core/utils.h"
#include <concepts>
#include <optional>
#include <string_view>
#include <type_traits>
namespace glap::generators {
namespace help {
inline constexpr std::string_view INPUTS_NAME = "INPUTS";
inline constexpr int PADDING = 4;
template <class T>
concept HasDescription = std::same_as<std::remove_cvref_t<decltype(T::short_description)>, std::string_view>;
template <class T>
concept HasFullDescription = HasDescription<T>
&& std::same_as<std::remove_cvref_t<decltype(T::long_description)>, std::string_view>;
template <class T>
concept IsInputs = (T::name == INPUTS_NAME);

template<StringLiteral Short>
struct Description {
static constexpr std::string_view short_description = Short;
};
template<StringLiteral Short, StringLiteral Long>
struct FullDescription : Description<Short> {
static constexpr std::string_view long_description = Long;
};

template<StringLiteral Name, HasDescription Desc>
struct Argument : Desc {
static constexpr std::string_view name = Name;
};
template<StringLiteral Name, HasDescription Desc, class ...Params>
struct Command : Desc {
static constexpr auto name = Name;
};
template<StringLiteral Name, HasDescription Desc, class ...Commands>
struct Program : Desc
{};
}
template<class FromHelp, class FromParser>
struct Help
{};

template<class FromHelp, class FromParser>
inline constexpr auto get_help = Help<FromHelp, FromParser>{};
}
#include "impl/help.inl"
#endif
Original file line number Diff line number Diff line change
@@ -1,34 +1,34 @@
#pragma once

#ifndef GLAP_MODULE
#include "core/utf8.h"
#include "core/discard.h"
#include "core/utils.h"
#include "help.h"
#include "../../core/utf8.h"
#include "../../core/discard.h"
#include "../../core/utils.h"
#include "../../core/fmt.h"
#include "../help.h"

#include "model.h"
#include "parser.h"
#include "../../model.h"
#include <concepts>
#include <cstddef>
#include <algorithm>
#endif

namespace glap {
namespace glap::generators {
namespace impl {
template <class P, class H>
concept IsHelpInputsCompatible = requires { P::type == glap::model::ArgumentType::Input; } && help::IsInputs<H>;
template <class FromParser, class ...Others>
struct FindByName
{};
template <class FromParser, class T, class ...Others>
requires (HasLongName<FromParser> && FromParser::longname == T::name) || IsHelpInputsCompatible<FromParser, T>
requires (HasLongName<FromParser> && FromParser::name == T::name) || IsHelpInputsCompatible<FromParser, T>
struct FindByName<FromParser, T, Others...>
{
public:
using type = T;
};
template <class Named, class T, class ...Others>
requires ((!HasLongName<Named> || Named::longname != T::name) && !IsHelpInputsCompatible<Named, T>)
struct FindByName<Named, T, Others...> : FindByName<Named, Others...>
struct FindByName<Named, T, Others...> : FindByName<Named, Others...>
{};
template <class FromParser>
struct FindByName<FromParser>
Expand All @@ -42,7 +42,7 @@ namespace glap {
([&max, separator_length]() {
size_t len = 0;
if constexpr (HasNames<FromParser>) {
len = FromParser::longname.length();
len = FromParser::name.length();
if constexpr (HasShortName<FromParser>) {
len += 1 + separator_length;
}
Expand Down Expand Up @@ -72,7 +72,7 @@ namespace glap {
}
template <class OutputIt, bool FullDescription = false>
OutputIt description(OutputIt it) const noexcept {
if constexpr(help::IsFullDescription<FromHelp>)
if constexpr(help::HasFullDescription<FromHelp>)
return glap::format_to(it, "{}\n\n{}", FromHelp::short_description, FromHelp::long_description);
else
return glap::format_to(it, "{}", FromHelp::short_description);
Expand All @@ -85,19 +85,22 @@ namespace glap {
return it;
}
};
template<help::IsDescription FromHelp, HasLongName FromParser>
template<help::HasDescription FromHelp, class FromParser>
requires (HasLongName<FromParser> || requires { FromParser::name; })
struct BasicHelp<FromHelp, FromParser>
{
template <class OutputIt, bool Fullname = false>
OutputIt name(OutputIt it) const noexcept {
if constexpr(Fullname && HasShortName<FromParser>)
return glap::format_to(it, "{}, {}", glap::utils::uni::codepoint_to_utf8(FromParser::shortname.value()), FromParser::longname);
else
return glap::format_to(it, "{}", FromParser::longname);
return glap::format_to(it, "{}, {}", glap::utils::uni::codepoint_to_utf8(FromParser::shortname.value()), FromParser::name);
else if constexpr(requires { FromParser::name; })
return glap::format_to(it, "{}", FromParser::name);
else
return glap::format_to(it, "{}", FromParser::name);
}
template <class OutputIt, bool FullDescription = false>
OutputIt description(OutputIt it) const noexcept {
if constexpr(help::IsFullDescription<FromHelp>)
if constexpr(FullDescription && help::HasFullDescription<FromHelp>)
return glap::format_to(it, "{}\n\n{}", FromHelp::short_description, FromHelp::long_description);
else
return glap::format_to(it, "{}", FromHelp::short_description);
Expand All @@ -116,9 +119,9 @@ namespace glap {
template <class OutputIt, bool Fullname = false>
OutputIt name(OutputIt it) const noexcept {
if constexpr(Fullname && HasNames<FromParser> && FromParser::shortname.has_value())
return glap::format_to(it, "{}, {}", glap::utils::uni::codepoint_to_utf8(FromParser::shortname.value()), FromParser::longname);
return glap::format_to(it, "{}, {}", glap::utils::uni::codepoint_to_utf8(FromParser::shortname.value()), FromParser::name);
else
return glap::format_to(it, "{}", FromParser::longname);
return glap::format_to(it, "{}", FromParser::name);
}
template <class OutputIt, bool FullDescription = false>
OutputIt description(OutputIt it) const noexcept {
Expand All @@ -135,21 +138,22 @@ namespace glap {
static constexpr auto basic_help = BasicHelp<FromHelp, FromParser>{};
}

template<StringLiteral NameHelp, help::IsDescription Desc, class ...CommandsHelp, StringLiteral NameParser, DefaultCommand def_cmd, class... CommandsParser>
struct Help<help::model::Program<NameHelp, Desc, CommandsHelp...>, Parser<NameParser, def_cmd, CommandsParser...>> {
using ProgramHelp = help::model::Program<NameHelp, Desc, CommandsHelp...>;
using ProgramParser = Parser<NameParser, def_cmd, CommandsParser...>;

[[nodiscard]] constexpr std::string operator()() const noexcept {
template<StringLiteral NameHelp, help::HasDescription Desc, class ...CommandsHelp, StringLiteral NameParser, model::DefaultCommand def_cmd, class... CommandsParser>
struct Help<help::Program<NameHelp, Desc, CommandsHelp...>, model::Program<NameParser, def_cmd, CommandsParser...>> {
using ProgramHelp = help::Program<NameHelp, Desc, CommandsHelp...>;
using ProgramParser = model::Program<NameParser, def_cmd, CommandsParser...>;
[[nodiscard]] std::string operator()() const noexcept {
std::string result;
result.reserve(1024);
this->operator()(std::back_inserter(result));
return result;
}
template <class OutputIt>
constexpr OutputIt operator()(OutputIt it) const noexcept {
it = this_basic_help.template identity<OutputIt, false, false>(it);
it = glap::format_to(it, "\n\n");
it = glap::format_to(it, "Command{}:\n", sizeof...(CommandsParser) > 1 ? "s" : "");
it = glap::format_to(it, "Command{}:", sizeof...(CommandsParser) > 1 ? "s" : "");
// constexpr auto max_cmd_name_length = impl::max_length<CommandsParser...>(2)+2;
([&] {
constexpr auto cmd_basic_help = impl::basic_help<typename impl::FindByName<CommandsParser, CommandsHelp...>::type, CommandsParser>;
Expand All @@ -164,12 +168,13 @@ namespace glap {
static constexpr auto this_basic_help = impl::basic_help<ProgramHelp, ProgramParser>;
};

template<StringLiteral Name, help::IsDescription Desc, class ...ParamsHelp, class CommandNames, model::IsArgument... ParamsParser>
struct Help<help::model::Command<Name, Desc, ParamsHelp...>, model::Command<CommandNames, ParamsParser...>> {
using CommandHelp = help::model::Command<Name, Desc, ParamsHelp...>;
template<StringLiteral Name, help::HasDescription Desc, class ...ParamsHelp, class CommandNames, model::IsArgument... ParamsParser>
struct Help<help::Command<Name, Desc, ParamsHelp...>, model::Command<CommandNames, ParamsParser...>> {
using CommandHelp = help::Command<Name, Desc, ParamsHelp...>;
using CommandParser = model::Command<CommandNames, ParamsParser...>;
[[nodiscard]] constexpr std::string operator()() const noexcept {
[[nodiscard]] std::string operator()() const noexcept {
std::string result;
result.reserve(1024);
this->operator()(std::back_inserter(result));
return result;
}
Expand All @@ -185,7 +190,7 @@ namespace glap {
if constexpr(model::IsArgumentTyped<ParamsParser, model::ArgumentType::Parameter>) {
it = glap::format_to(it, " [--");
it = param_basic_help.template name<OutputIt>(it);
it = glap::format_to(it, " VALUE]");
it = glap::format_to(it, "=VALUE]");
} else if constexpr(model::IsArgumentTyped<ParamsParser, model::ArgumentType::Flag>) {
it = glap::format_to(it, " [--");
it = param_basic_help.template name<OutputIt>(it);
Expand All @@ -196,7 +201,7 @@ namespace glap {
}(), ...);
it = glap::format_to(it, "\n\n");
}
it = glap::format_to(it, "Argument{}:\n", sizeof...(ParamsParser) > 1 ? "s" : "");
it = glap::format_to(it, "Argument{}:", sizeof...(ParamsParser) > 1 ? "s" : "");
([&] {
constexpr auto param_basic_help = impl::basic_help<typename impl::FindByName<ParamsParser, ParamsHelp...>::type, ParamsParser>;
constexpr auto spacing = param_name_max_length - impl::max_length<ParamsParser>(2);
Expand All @@ -209,4 +214,7 @@ namespace glap {
static constexpr auto param_name_max_length = impl::max_length<ParamsParser...>(2)+help::PADDING;
static constexpr auto this_basic_help = impl::basic_help<CommandHelp, CommandParser>;
};
template<StringLiteral NameHelp, help::HasDescription Desc, class ...CommandsHelp, class CommandNames, model::IsArgument... ParamsParser>
struct Help<help::Program<NameHelp, Desc, CommandsHelp...>, model::Command<CommandNames, ParamsParser...>> : Help<typename impl::FindByName<CommandNames, CommandsHelp...>::type, model::Command<CommandNames, ParamsParser...>>
{};
}
Loading