diff --git a/nonebot/adapters/satori/message.py b/nonebot/adapters/satori/message.py
index 44d8bc3..65c4396 100644
--- a/nonebot/adapters/satori/message.py
+++ b/nonebot/adapters/satori/message.py
@@ -9,7 +9,7 @@
from nonebot.adapters import Message as BaseMessage
from nonebot.adapters import MessageSegment as BaseMessageSegment
-from .element import Element, parse, escape, param_case
+from .element import Element, escape, param_case
@dataclass
@@ -735,6 +735,15 @@ class Message(BaseMessage[MessageSegment]):
def get_segment_class(cls) -> Type[MessageSegment]:
return MessageSegment
+ def __init__(
+ self,
+ message: Union[str, None, Iterable[MessageSegment], MessageSegment] = None,
+ ):
+ if isinstance(message, str):
+ super().__init__(MessageSegment.raw(message))
+ else:
+ super().__init__(message)
+
@override
def __add__(self, other: Union[str, MessageSegment, Iterable[MessageSegment]]) -> "Message":
result = self.copy()
@@ -749,7 +758,7 @@ def __radd__(self, other: Union[str, MessageSegment, Iterable[MessageSegment]])
@staticmethod
@override
def _construct(msg: str) -> Iterable[MessageSegment]:
- yield from Message.from_satori_element(parse(msg))
+ yield Text(msg)
@classmethod
def from_satori_element(cls, elements: List[Element]) -> "Message":
diff --git a/pyproject.toml b/pyproject.toml
index 4900ca7..3fa342f 100644
--- a/pyproject.toml
+++ b/pyproject.toml
@@ -1,6 +1,6 @@
[project]
name = "nonebot-adapter-satori"
-version = "0.11.2"
+version = "0.11.3"
description = "Satori Protocol Adapter for Nonebot2"
authors = [
{name = "RF-Tar-Railt",email = "rf_tar_railt@qq.com"},
diff --git a/tests/test_message.py b/tests/test_message.py
index dcfc779..61b7929 100644
--- a/tests/test_message.py
+++ b/tests/test_message.py
@@ -21,6 +21,9 @@ def test_message():
parse("")
)[0].data == {"id": "265", "name": "[辣眼睛]", "platform": "chronocat"}
+ test_message1 = MessageSegment(type="chronocat:face", data={"id": 12}) + "\n" + "Hello Yoshi"
+ assert str(test_message1) == '\nHello Yoshi'
+
@pytest.mark.asyncio
async def test_message_rich_expr():