-
-
Notifications
You must be signed in to change notification settings - Fork 45
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
[Feature] 通用的 help 解决方案 #192
Comments
try this @help.register("foo", auto=True) # default: True
@listen(GroupMessage)
async def bar(...):
"""
qwertyuiop
Usage:
blablabla
Example:
blablabla
"""
...
@help.register("foo", auto=False)
@help.description("...")
@listen(GroupMessage)
async def bar(...):
... |
the behaviour between help.register and help.description is like click.command and click.option |
也许需要约定一个协议类 class HelpInfo(TypedDict):
...
@runtime_checkable
class HelpProvider(Protocol):
def help_info(self) -> HelpInfo: ... 消息链匹配器(base-parser, twilight, alc-dispatcher, commander, etc.)应提供可能的"help_info"接口,否则help_generator或视作为普通的消息事件监听 |
顺带一提,HelpInfo或许会被扬掉 |
help = HelpRecoder()
# or help = HelpRecoder.current(), that record as one global recorder
@help.record("name1") # title
@help.usage("foo") # short,or sub-title
@help.description("foo bar") # long
@help.example("baz qux")
@listen(...)
async def _(...):
...
@help.record("name2", auto_gen=True) # default to False;auto_gen will try to call the HelpProvider to provider possible help info with higher priority
@help.usage("foo1") # using it when provider missing "usage"
@listen(...)
@decorate(DetectPrefix("#")) # if it is HelpProvider, it may generate info like "#<...>"
asycn def _(...):
... |
可以去掉usage, 塞进record里 即 |
使用场景
通过一个统一的方式注册help菜单,然后通过特定的格式输出
你想要的解决方案
例如使用类似:
大概就是这样的实现(?
当然只是举个例子,实际应该不会这么草率
The text was updated successfully, but these errors were encountered: