File: SeeAlsoInTopicsHeadingChecker.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (56 lines) | stat: -rw-r--r-- 2,297 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2021 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See https://swift.org/LICENSE.txt for license information
 See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

import Foundation
import Markdown

public struct SeeAlsoInTopicsHeadingChecker: Checker {
    public var seeAlsoInTopicsHeadings: [Heading] = []
    public var problems: [Problem] {
        guard !seeAlsoInTopicsHeadings.isEmpty else {
            return []
        }
        return seeAlsoInTopicsHeadings.compactMap { heading -> Problem? in
            guard let headingRange = heading.range else { return nil }
            let diagnostic = Diagnostic(
                source: sourceFile,
                severity: .warning,
                range: headingRange,
                identifier: "org.swift.docc.SeeAlsoInTopicsHeadings",
                summary: #"Level-3 heading "See Also" can't form a See Also section. Did you mean to use a level-2 heading?"#,
                explanation: #"A level-2 heading with the name "See Also" is a reserved heading name you use to begin a section to groups related symbols or links. To resolve this issue, change the heading level to a level-2 heading to form a See Also section or change the name of this heading to form a task group."#
            )
            let solutions = [
                Solution(
                    summary: "Change to level-2 heading",
                    replacements: [Replacement(range: headingRange, replacement: "## \(heading.plainText)")]
                ),
                Solution(
                    summary: "Change heading name",
                    replacements: [Replacement(range: headingRange, replacement: "### <#name#>" )]
                ),
            ]
            return Problem(diagnostic: diagnostic, possibleSolutions: solutions)
        }
    }

    private var sourceFile: URL?

    public init(sourceFile: URL?) {
        self.sourceFile = sourceFile
    }

    public mutating func visitHeading(_ heading: Heading) {
        if heading.level == 3, heading.plainText == "See Also" {
            seeAlsoInTopicsHeadings.append(heading)
            return
        }
    }
}