Skip to content

Commit

Permalink
🐛 fix missing update when reject or pause (fix #394)
Browse files Browse the repository at this point in the history
  • Loading branch information
yanyongyu committed May 30, 2021
1 parent 57cf8e9 commit 45e1126
Showing 1 changed file with 56 additions and 37 deletions.
93 changes: 56 additions & 37 deletions nonebot/matcher.py
Original file line number Diff line number Diff line change
Expand Up @@ -166,20 +166,25 @@ def __str__(self) -> str:
return repr(self)

@classmethod
def new(cls,
type_: str = "",
rule: Optional[Rule] = None,
permission: Optional[Permission] = None,
handlers: Optional[Union[List[T_Handler], List[Handler],
List[Union[T_Handler, Handler]]]] = None,
temp: bool = False,
priority: int = 1,
block: bool = False,
*,
module: Optional[ModuleType] = None,
default_state: Optional[T_State] = None,
default_state_factory: Optional[T_StateFactory] = None,
expire_time: Optional[datetime] = None) -> Type["Matcher"]:
def new(
cls,
type_: str = "",
rule: Optional[Rule] = None,
permission: Optional[Permission] = None,
handlers: Optional[Union[List[T_Handler], List[Handler],
List[Union[T_Handler, Handler]]]] = None,
temp: bool = False,
priority: int = 1,
block: bool = False,
*,
module: Optional[ModuleType] = None,
expire_time: Optional[datetime] = None,
default_state: Optional[T_State] = None,
default_state_factory: Optional[T_StateFactory] = None,
default_parser: Optional[T_ArgsParser] = None,
default_type_updater: Optional[T_TypeUpdater] = None,
default_permission_updater: Optional[T_PermissionUpdater] = None
) -> Type["Matcher"]:
"""
:说明:
Expand Down Expand Up @@ -237,7 +242,13 @@ def new(cls,
default_state or {},
"_default_state_factory":
staticmethod(default_state_factory)
if default_state_factory else None
if default_state_factory else None,
"_default_parser":
default_parser,
"_default_type_updater":
default_type_updater,
"_default_permission_updater":
default_permission_updater
})

matchers[priority].append(NewMatcher)
Expand Down Expand Up @@ -586,17 +597,21 @@ async def run(self, bot: "Bot", event: "Event", state: T_State):
else:
permission = USER(event.get_session_id(), perm=self.permission)

Matcher.new(type_,
Rule(),
permission,
self.handlers,
temp=True,
priority=0,
block=True,
module=self.module,
default_state=self.state,
expire_time=datetime.now() +
bot.config.session_expire_timeout)
Matcher.new(
type_,
Rule(),
permission,
self.handlers,
temp=True,
priority=0,
block=True,
module=self.module,
expire_time=datetime.now() + bot.config.session_expire_timeout,
default_state=self.state,
default_parser=self.__class__._default_parser,
default_type_updater=self.__class__._default_type_updater,
default_permission_updater=self.__class__.
_default_permission_updater)
except PausedException:
updater = self.__class__._default_type_updater
if updater:
Expand All @@ -610,17 +625,21 @@ async def run(self, bot: "Bot", event: "Event", state: T_State):
else:
permission = USER(event.get_session_id(), perm=self.permission)

Matcher.new(type_,
Rule(),
permission,
self.handlers,
temp=True,
priority=0,
block=True,
module=self.module,
default_state=self.state,
expire_time=datetime.now() +
bot.config.session_expire_timeout)
Matcher.new(
type_,
Rule(),
permission,
self.handlers,
temp=True,
priority=0,
block=True,
module=self.module,
expire_time=datetime.now() + bot.config.session_expire_timeout,
default_state=self.state,
default_parser=self.__class__._default_parser,
default_type_updater=self.__class__._default_type_updater,
default_permission_updater=self.__class__.
_default_permission_updater)
except FinishedException:
pass
except StopPropagation:
Expand Down

0 comments on commit 45e1126

Please sign in to comment.