Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
M
Mirai
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Packages
Packages
List
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issues
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
MyCard
Mirai
Commits
346aecd6
Commit
346aecd6
authored
May 09, 2020
by
Him188
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Enable progressiveMode
parent
613ab883
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
55 additions
and
18 deletions
+55
-18
mirai-core-qqandroid/build.gradle.kts
mirai-core-qqandroid/build.gradle.kts
+1
-0
mirai-core/build.gradle.kts
mirai-core/build.gradle.kts
+1
-0
mirai-core/src/commonMain/kotlin/net.mamoe.mirai/event/MessageSubscribersBuilder.kt
...kotlin/net.mamoe.mirai/event/MessageSubscribersBuilder.kt
+53
-18
No files found.
mirai-core-qqandroid/build.gradle.kts
View file @
346aecd6
...
@@ -40,6 +40,7 @@ kotlin {
...
@@ -40,6 +40,7 @@ kotlin {
all
{
all
{
languageSettings
.
enableLanguageFeature
(
"InlineClasses"
)
languageSettings
.
enableLanguageFeature
(
"InlineClasses"
)
languageSettings
.
useExperimentalAnnotation
(
"kotlin.Experimental"
)
languageSettings
.
useExperimentalAnnotation
(
"kotlin.Experimental"
)
languageSettings
.
progressiveMode
=
true
dependencies
{
dependencies
{
api
(
project
(
":mirai-core"
))
api
(
project
(
":mirai-core"
))
...
...
mirai-core/build.gradle.kts
View file @
346aecd6
...
@@ -41,6 +41,7 @@ kotlin {
...
@@ -41,6 +41,7 @@ kotlin {
all
{
all
{
languageSettings
.
enableLanguageFeature
(
"InlineClasses"
)
languageSettings
.
enableLanguageFeature
(
"InlineClasses"
)
languageSettings
.
useExperimentalAnnotation
(
"kotlin.Experimental"
)
languageSettings
.
useExperimentalAnnotation
(
"kotlin.Experimental"
)
languageSettings
.
progressiveMode
=
true
}
}
commonMain
{
commonMain
{
...
...
mirai-core/src/commonMain/kotlin/net.mamoe.mirai/event/MessageSubscribersBuilder.kt
View file @
346aecd6
...
@@ -97,12 +97,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -97,12 +97,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
/** 启动这个监听器, 在满足条件时回复原消息 */
/** 启动这个监听器, 在满足条件时回复原消息 */
@MessageDsl
@MessageDsl
open
infix
fun
ListeningFilter
.
reply
(
toReply
:
String
):
Ret
=
content
(
filter
)
{
reply
(
toReply
);
stub
}
open
infix
fun
ListeningFilter
.
reply
(
toReply
:
String
):
Ret
=
content
(
filter
)
{
reply
(
toReply
);
this
@MessageSubscribersBuilder
.
stub
}
/** 启动这个监听器, 在满足条件时回复原消息 */
/** 启动这个监听器, 在满足条件时回复原消息 */
@MessageDsl
@MessageDsl
open
infix
fun
ListeningFilter
.
reply
(
message
:
Message
):
Ret
=
content
(
filter
)
{
reply
(
message
);
stub
}
open
infix
fun
ListeningFilter
.
reply
(
message
:
Message
):
Ret
=
content
(
filter
)
{
reply
(
message
);
this
@MessageSubscribersBuilder
.
stub
}
/** 启动这个监听器, 在满足条件时回复原消息 */
/** 启动这个监听器, 在满足条件时回复原消息 */
@JvmName
(
"reply3"
)
@JvmName
(
"reply3"
)
...
@@ -117,22 +119,22 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -117,22 +119,22 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
/** 启动这个监听器, 在满足条件时回复原消息 */
/** 启动这个监听器, 在满足条件时回复原消息 */
@MessageDsl
@MessageDsl
open
infix
fun
ListeningFilter
.
reply
(
replier
:
(
@MessageDsl
suspend
M
.(
String
)
->
Any
?)):
Ret
=
open
infix
fun
ListeningFilter
.
reply
(
replier
:
(
@MessageDsl
suspend
M
.(
String
)
->
Any
?)):
Ret
=
content
(
filter
)
{
executeAndReply
(
this
,
replier
)
}
content
(
filter
)
{
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
,
replier
)
}
/** 启动这个监听器, 在满足条件时引用回复原消息 */
/** 启动这个监听器, 在满足条件时引用回复原消息 */
@MessageDsl
@MessageDsl
open
infix
fun
ListeningFilter
.
quoteReply
(
toReply
:
String
):
Ret
=
open
infix
fun
ListeningFilter
.
quoteReply
(
toReply
:
String
):
Ret
=
content
(
filter
)
{
quoteReply
(
toReply
);
stub
}
content
(
filter
)
{
quoteReply
(
toReply
);
this
@MessageSubscribersBuilder
.
stub
}
/** 启动这个监听器, 在满足条件时引用回复原消息 */
/** 启动这个监听器, 在满足条件时引用回复原消息 */
@MessageDsl
@MessageDsl
open
infix
fun
ListeningFilter
.
quoteReply
(
toReply
:
Message
):
Ret
=
open
infix
fun
ListeningFilter
.
quoteReply
(
toReply
:
Message
):
Ret
=
content
(
filter
)
{
quoteReply
(
toReply
);
stub
}
content
(
filter
)
{
quoteReply
(
toReply
);
this
@MessageSubscribersBuilder
.
stub
}
/** 启动这个监听器, 在满足条件时执行 [replier] 并引用回复原消息 */
/** 启动这个监听器, 在满足条件时执行 [replier] 并引用回复原消息 */
@MessageDsl
@MessageDsl
open
infix
fun
ListeningFilter
.
quoteReply
(
replier
:
(
@MessageDsl
suspend
M
.(
String
)
->
Any
?)):
Ret
=
open
infix
fun
ListeningFilter
.
quoteReply
(
replier
:
(
@MessageDsl
suspend
M
.(
String
)
->
Any
?)):
Ret
=
content
(
filter
)
{
executeAndQuoteReply
(
this
,
replier
)
}
content
(
filter
)
{
this
@MessageSubscribersBuilder
.
executeAndQuoteReply
(
this
,
replier
)
}
/** 无任何触发条件, 每次收到消息都执行 [onEvent] */
/** 无任何触发条件, 每次收到消息都执行 [onEvent] */
@MessageDsl
@MessageDsl
...
@@ -158,7 +160,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -158,7 +160,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
@JvmSynthetic
@JvmSynthetic
@JvmName
(
"findingExtension"
)
@JvmName
(
"findingExtension"
)
infix
fun
Regex
.
finding
(
block
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
R
):
Ret
=
infix
fun
Regex
.
finding
(
block
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
R
):
Ret
=
always
{
content
->
this
@
finding
.
find
(
content
)
?.
let
{
block
(
this
,
it
)
}
?:
stub
}
always
{
content
->
this
@
finding
.
find
(
content
)
?.
let
{
block
(
this
,
it
)
}
?:
this
@MessageSubscribersBuilder
.
stub
}
/**
/**
* [消息内容][Message.contentToString] `==` [equals]
* [消息内容][Message.contentToString] `==` [equals]
...
@@ -313,7 +315,12 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -313,7 +315,12 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
/** 如果 [mapper] 返回值非空, 就执行 [onEvent] */
/** 如果 [mapper] 返回值非空, 就执行 [onEvent] */
@MessageDsl
@MessageDsl
open
fun
<
N
:
Any
>
mapping
(
mapper
:
M
.(
String
)
->
N
?,
onEvent
:
@MessageDsl
suspend
M
.(
N
)
->
R
):
Ret
=
open
fun
<
N
:
Any
>
mapping
(
mapper
:
M
.(
String
)
->
N
?,
onEvent
:
@MessageDsl
suspend
M
.(
N
)
->
R
):
Ret
=
always
{
onEvent
.
invoke
(
this
,
mapper
(
this
,
message
.
contentToString
())
?:
return
@
always
stub
)
}
always
{
onEvent
.
invoke
(
this
,
mapper
(
this
,
message
.
contentToString
())
?:
return
@
always
this
@MessageSubscribersBuilder
.
stub
)
}
/** 如果 [filter] 返回 `true` */
/** 如果 [filter] 返回 `true` */
@MessageDsl
@MessageDsl
...
@@ -327,7 +334,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -327,7 +334,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
/** [消息内容][Message.contentToString]可由正则表达式匹配([Regex.matchEntire]), 就执行 `onEvent` */
/** [消息内容][Message.contentToString]可由正则表达式匹配([Regex.matchEntire]), 就执行 `onEvent` */
@MessageDsl
@MessageDsl
fun
matching
(
regex
:
Regex
,
onEvent
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Unit
):
Ret
=
fun
matching
(
regex
:
Regex
,
onEvent
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Unit
):
Ret
=
always
{
executeAndReply
(
this
)
{
onEvent
.
invoke
(
this
,
regex
.
matchEntire
(
it
)
?:
return
@
always
stub
)
}
}
always
{
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
)
{
onEvent
.
invoke
(
this
,
regex
.
matchEntire
(
it
)
?:
return
@
always
this
@MessageSubscribersBuilder
.
stub
)
}
}
/** [消息内容][Message.contentToString]可由正则表达式查找([Regex.find]) */
/** [消息内容][Message.contentToString]可由正则表达式查找([Regex.find]) */
@MessageDsl
@MessageDsl
...
@@ -336,13 +350,20 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -336,13 +350,20 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
/** [消息内容][Message.contentToString]可由正则表达式查找([Regex.find]), 就执行 `onEvent` */
/** [消息内容][Message.contentToString]可由正则表达式查找([Regex.find]), 就执行 `onEvent` */
@MessageDsl
@MessageDsl
fun
finding
(
regex
:
Regex
,
onEvent
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Unit
):
Ret
=
fun
finding
(
regex
:
Regex
,
onEvent
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Unit
):
Ret
=
always
{
executeAndReply
(
this
)
{
onEvent
.
invoke
(
this
,
regex
.
find
(
it
)
?:
return
@
always
stub
)
}
}
always
{
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
)
{
onEvent
.
invoke
(
this
,
regex
.
find
(
it
)
?:
return
@
always
this
@MessageSubscribersBuilder
.
stub
)
}
}
/** [消息内容][Message.contentToString]包含 [this] 则回复 [reply] */
/** [消息内容][Message.contentToString]包含 [this] 则回复 [reply] */
@MessageDsl
@MessageDsl
open
infix
fun
String
.
containsReply
(
reply
:
String
):
Ret
=
open
infix
fun
String
.
containsReply
(
reply
:
String
):
Ret
=
content
({
this
@
containsReply
in
it
},
{
reply
(
reply
);
stub
})
content
({
this
@
containsReply
in
it
},
{
reply
(
reply
);
this
@MessageSubscribersBuilder
.
stub
})
/**
/**
* [消息内容][Message.contentToString]包含 [this] 则执行 [replier] 并将其返回值回复给发信对象.
* [消息内容][Message.contentToString]包含 [this] 则执行 [replier] 并将其返回值回复给发信对象.
...
@@ -353,7 +374,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -353,7 +374,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
*/
*/
@MessageDsl
@MessageDsl
open
infix
fun
String
.
containsReply
(
replier
:
@MessageDsl
suspend
M
.(
String
)
->
Any
?):
Ret
=
open
infix
fun
String
.
containsReply
(
replier
:
@MessageDsl
suspend
M
.(
String
)
->
Any
?):
Ret
=
content
({
this
@
containsReply
in
it
},
{
executeAndReply
(
this
,
replier
)
})
content
({
this
@
containsReply
in
it
},
{
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
,
replier
)
})
/**
/**
* [消息内容][Message.contentToString]可由正则表达式匹配([Regex.matchEntire]), 则执行 [replier] 并将其返回值回复给发信对象.
* [消息内容][Message.contentToString]可由正则表达式匹配([Regex.matchEntire]), 则执行 [replier] 并将其返回值回复给发信对象.
...
@@ -364,7 +385,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -364,7 +385,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
*/
*/
@MessageDsl
@MessageDsl
open
infix
fun
Regex
.
matchingReply
(
replier
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Any
?):
Ret
=
open
infix
fun
Regex
.
matchingReply
(
replier
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Any
?):
Ret
=
always
{
executeAndReply
(
this
)
{
replier
.
invoke
(
this
,
matchEntire
(
it
)
?:
return
@
always
stub
)
}
}
always
{
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
)
{
replier
.
invoke
(
this
,
matchEntire
(
it
)
?:
return
@
always
this
@MessageSubscribersBuilder
.
stub
)
}
}
/**
/**
* [消息内容][Message.contentToString]可由正则表达式查找([Regex.find]), 则执行 [replier] 并将其返回值回复给发信对象.
* [消息内容][Message.contentToString]可由正则表达式查找([Regex.find]), 则执行 [replier] 并将其返回值回复给发信对象.
...
@@ -375,7 +403,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -375,7 +403,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
*/
*/
@MessageDsl
@MessageDsl
open
infix
fun
Regex
.
findingReply
(
replier
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Any
?):
Ret
=
open
infix
fun
Regex
.
findingReply
(
replier
:
@MessageDsl
suspend
M
.(
MatchResult
)
->
Any
?):
Ret
=
always
{
executeAndReply
(
this
)
{
replier
.
invoke
(
this
,
this
@
findingReply
.
find
(
it
)
?:
return
@
always
stub
)
}
}
always
{
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
)
{
replier
.
invoke
(
this
,
this
@
findingReply
.
find
(
it
)
?:
return
@
always
this
@MessageSubscribersBuilder
.
stub
)
}
}
/**
/**
...
@@ -386,7 +421,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -386,7 +421,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
open
infix
fun
String
.
endsWithReply
(
replier
:
@MessageDsl
suspend
M
.(
String
)
->
Any
?):
Ret
{
open
infix
fun
String
.
endsWithReply
(
replier
:
@MessageDsl
suspend
M
.(
String
)
->
Any
?):
Ret
{
val
toCheck
=
this
.
trimEnd
()
val
toCheck
=
this
.
trimEnd
()
return
content
({
it
.
trim
().
endsWith
(
toCheck
)
},
{
return
content
({
it
.
trim
().
endsWith
(
toCheck
)
},
{
executeAndReply
(
this
)
{
replier
(
this
,
it
.
trim
().
removeSuffix
(
toCheck
))
}
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
)
{
replier
(
this
,
it
.
trim
().
removeSuffix
(
toCheck
))
}
})
})
}
}
...
@@ -394,14 +429,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -394,14 +429,14 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
@MessageDsl
@MessageDsl
open
infix
fun
String
.
reply
(
reply
:
String
):
Ret
{
open
infix
fun
String
.
reply
(
reply
:
String
):
Ret
{
val
toCheck
=
this
.
trim
()
val
toCheck
=
this
.
trim
()
return
content
({
it
.
trim
()
==
toCheck
},
{
reply
(
reply
);
stub
})
return
content
({
it
.
trim
()
==
toCheck
},
{
reply
(
reply
);
this
@MessageSubscribersBuilder
.
stub
})
}
}
/** 当发送的消息内容为 [this] 就回复 [reply] */
/** 当发送的消息内容为 [this] 就回复 [reply] */
@MessageDsl
@MessageDsl
open
infix
fun
String
.
reply
(
reply
:
Message
):
Ret
{
open
infix
fun
String
.
reply
(
reply
:
Message
):
Ret
{
val
toCheck
=
this
.
trim
()
val
toCheck
=
this
.
trim
()
return
content
({
it
.
trim
()
==
toCheck
},
{
reply
(
reply
);
stub
})
return
content
({
it
.
trim
()
==
toCheck
},
{
reply
(
reply
);
this
@MessageSubscribersBuilder
.
stub
})
}
}
/** 当发送的消息内容为 [this] 就执行并回复 [replier] 的返回值 */
/** 当发送的消息内容为 [this] 就执行并回复 [replier] 的返回值 */
...
@@ -410,7 +445,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
...
@@ -410,7 +445,7 @@ open class MessageSubscribersBuilder<M : MessageEvent, out Ret, R : RR, RR>(
val
toCheck
=
this
.
trim
()
val
toCheck
=
this
.
trim
()
return
content
({
it
.
trim
()
==
toCheck
},
{
return
content
({
it
.
trim
()
==
toCheck
},
{
@Suppress
(
"DSL_SCOPE_VIOLATION_WARNING"
)
@Suppress
(
"DSL_SCOPE_VIOLATION_WARNING"
)
executeAndReply
(
this
)
{
replier
(
this
,
it
.
trim
())
}
this
@MessageSubscribersBuilder
.
executeAndReply
(
this
)
{
replier
(
this
,
it
.
trim
())
}
})
})
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment