File: NonOverviewHeadingChecker.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 (73 lines) | stat: -rw-r--r-- 2,658 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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
 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 NonOverviewHeadingChecker: Checker {
    public var overviewHeading: Heading?
    public var nonOverviewHeadings: [Heading] = []
    public var problems: [Problem] {
        guard !nonOverviewHeadings.isEmpty else {
            return []
        }

        return nonOverviewHeadings.compactMap { heading -> Problem? in
            guard let headingRange = heading.range else { return nil }
            let notes: [DiagnosticNote]
            if let sourceFile, let range = overviewHeading?.range {
                notes = [DiagnosticNote(source: sourceFile, range: range, message: "Overview section starts here")]
            } else {
                notes = []
            }

            let diagnostic = Diagnostic(
                source: sourceFile,
                severity: .information,
                range: heading.range,
                identifier: "org.swift.docc.NonOverviewHeadings",
                summary: #"The majority of content should be under level-3 headers under the "Overview" section"#,
                explanation: nil,
                notes: notes
            )

            let solution: Solution
            if overviewHeading == nil {
                let replacement = Replacement(range: headingRange, replacement: "## Overview")
                solution = Solution(summary: #"Change the title to "Overview""#, replacements: [replacement])
            } else {
                let replacement = Replacement(range: headingRange, replacement: "### \(heading.title)")
                solution = Solution(summary: "Change the heading to a level-3 heading", replacements: [replacement])
            }

            return Problem(diagnostic: diagnostic, possibleSolutions: [solution])
        }
    }

    private var sourceFile: URL?

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

    public mutating func visitHeading(_ heading: Heading) {
        // We don't want to flag the Topics H2 and the See Also H2.
        guard heading.level == 2, !heading.isTopicsSection, heading.title != "See Also" else {
            return
        }

        if heading.plainText == "Overview", overviewHeading == nil {
            overviewHeading = heading
            return
        }

        nonOverviewHeadings.append(heading)
    }
}