From 1faa928214210f00d781e2f25f6b2a010fcc91fe Mon Sep 17 00:00:00 2001 From: John Sundell Date: Mon, 27 Aug 2018 18:32:22 +0200 Subject: [PATCH] Correctly highlight subscript declarations MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This patch fixes syntax highlighting when declaring a subscript: ``` struct MyStruct { subscript(key: Key) -> Value? { … } } ``` --- Sources/Splash/Grammar/SwiftGrammar.swift | 8 +++- Tests/SplashTests/Core/TestCaseVerifier.swift | 6 ++- .../SplashTests/Tests/DeclarationTests.swift | 40 ++++++++++++++++++- 3 files changed, 51 insertions(+), 3 deletions(-) diff --git a/Sources/Splash/Grammar/SwiftGrammar.swift b/Sources/Splash/Grammar/SwiftGrammar.swift index 891084a..72b84f9 100644 --- a/Sources/Splash/Grammar/SwiftGrammar.swift +++ b/Sources/Splash/Grammar/SwiftGrammar.swift @@ -47,7 +47,7 @@ private extension SwiftGrammar { "super", "self", "set", "true", "false", "nil", "override", "where", "_", "default", "break", "#selector", "required", "willSet", "didSet", - "lazy" + "lazy", "subscript" ] struct PreprocessingRule: SyntaxRule { @@ -162,6 +162,12 @@ private extension SwiftGrammar { return false } + // Subscripting is a bit of an edge case, since it's the only keyword + // that looks like a function call, so we need to handle it explicitly + guard segment.tokens.current != "subscript" else { + return false + } + if let previousToken = segment.tokens.previous { guard !keywordsToAvoid.contains(previousToken) else { return false diff --git a/Tests/SplashTests/Core/TestCaseVerifier.swift b/Tests/SplashTests/Core/TestCaseVerifier.swift index ca6ee1f..32ff345 100644 --- a/Tests/SplashTests/Core/TestCaseVerifier.swift +++ b/Tests/SplashTests/Core/TestCaseVerifier.swift @@ -22,7 +22,11 @@ struct TestCaseVerifier { } guard testNames.contains(name) else { - XCTFail("Test case \(Case.self) does not include test \(name) on Linux") + XCTFail(""" + Test case \(Case.self) does not include test \(name) on Linux. + Please add it to the test case's 'allTests' array. + """) + return false } } diff --git a/Tests/SplashTests/Tests/DeclarationTests.swift b/Tests/SplashTests/Tests/DeclarationTests.swift index 63a5b23..27fe459 100644 --- a/Tests/SplashTests/Tests/DeclarationTests.swift +++ b/Tests/SplashTests/Tests/DeclarationTests.swift @@ -424,6 +424,43 @@ final class DeclarationTests: SyntaxHighlighterTestCase { ]) } + func testSubscriptDeclaration() { + let components = highlighter.highlight(""" + extension Collection { + subscript(key: Key) -> Value? { return nil } + } + """) + + XCTAssertEqual(components, [ + .token("extension", .keyword), + .whitespace(" "), + .token("Collection", .type), + .whitespace(" "), + .plainText("{"), + .whitespace("\n "), + .token("subscript", .keyword), + .plainText("(key:"), + .whitespace(" "), + .token("Key", .type), + .plainText(")"), + .whitespace(" "), + .plainText("->"), + .whitespace(" "), + .token("Value", .type), + .plainText("?"), + .whitespace(" "), + .plainText("{"), + .whitespace(" "), + .token("return", .keyword), + .whitespace(" "), + .token("nil", .keyword), + .whitespace(" "), + .plainText("}"), + .whitespace("\n"), + .plainText("}") + ]) + } + func testAllTestsRunOnLinux() { XCTAssertTrue(TestCaseVerifier.verifyLinuxTests((type(of: self)).allTests)) } @@ -449,7 +486,8 @@ extension DeclarationTests { ("testLazyPropertyDeclaration", testLazyPropertyDeclaration), ("testGenericPropertyDeclaration", testGenericPropertyDeclaration), ("testPropertyDeclarationWithWillSet", testPropertyDeclarationWithWillSet), - ("testPropertyDeclarationWithDidSet", testPropertyDeclarationWithDidSet) + ("testPropertyDeclarationWithDidSet", testPropertyDeclarationWithDidSet), + ("testSubscriptDeclaration", testSubscriptDeclaration) ] } }