diff --git a/selector/src/commonMain/kotlin/li/songe/selector/CommonSelector.kt b/selector/src/commonMain/kotlin/li/songe/selector/CommonSelector.kt index 4fb6e2885..6a82b0c9b 100644 --- a/selector/src/commonMain/kotlin/li/songe/selector/CommonSelector.kt +++ b/selector/src/commonMain/kotlin/li/songe/selector/CommonSelector.kt @@ -11,6 +11,7 @@ class CommonSelector private constructor( ) { val tracks = selector.tracks val trackIndex = selector.trackIndex + val connectKeys = selector.connectKeys fun match(node: T, transform: CommonTransform): T? { return selector.match(node, transform.transform) diff --git a/selector/src/commonMain/kotlin/li/songe/selector/Selector.kt b/selector/src/commonMain/kotlin/li/songe/selector/Selector.kt index 4f494c583..433d150d3 100644 --- a/selector/src/commonMain/kotlin/li/songe/selector/Selector.kt +++ b/selector/src/commonMain/kotlin/li/songe/selector/Selector.kt @@ -23,6 +23,17 @@ class Selector internal constructor(private val propertyWrapper: PropertyWrapper if (i < 0) 0 else i } + val connectKeys by lazy { + var c = propertyWrapper.to + val keys = mutableListOf() + while (c != null) { + c!!.connectSegment.connectExpression + keys.add(c!!.connectSegment.operator.key) + c = c?.to?.to + } + keys.toTypedArray() + } + fun match( node: T, transform: Transform,