File: Section.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 (66 lines) | stat: -rw-r--r-- 2,344 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
/*
 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 Markdown

/// A structured piece of documentation content.
public protocol Section {
    /// The title of the section.
    static var title: String? { get }
    
    /// The section's markup content.
    var content: [Markup] { get }
}

extension Markup {
    /**
     Returns the index of the first child element that is a heading with the given level and text.
     
     - parameter level: The level of the heading.
     - parameter name: The text of the heading.
     - returns: The index of the first child element that is a heading with the given level and text.
                If no child of this element is a matching heading element, returns `nil`.
     */
    func sectionHeadingIndex(level: Int, named name: String? = nil) -> Int? {
        return (0..<childCount).first { index -> Bool in
            guard let child = child(at: index),
                  let heading = child as? Heading,
                heading.level == level else {
                    return false
            }
            if let name {
                guard heading.plainText == name else {
                    return false
                }
            }
            return true
        }
    }
    
    /**
     Returns the index of the first child element that is a heading with the given level, starting the search at the given index.
     
     - parameter startIndex: The index from which to start the search.
     - parameter level: The level of the heading.
     - returns: The index of the first child element that is a heading of the given level.
                If no child of this element is a matching heading element, returns `nil`.
     */
    func indexToNextHeading(from startIndex: Int, level: Int) -> Int? {

        return (startIndex..<childCount).first { index -> Bool in
            guard let child = child(at: index),
                  let heading = child as? Heading,
                heading.level == level else {
                    return false
            }
            return true
        }
    }
}