File: ReferenceLocation.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 (39 lines) | stat: -rw-r--r-- 1,525 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
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2023 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

extension SymbolGraph.Relationship {
    /// A mixin for `references` relationships that indicates the source location of the reference.
    public struct ReferenceLocation: Mixin, Codable, Equatable {
        public static var mixinKey = "referenceLocation"

        /// The source locations where the reference occurs.
        public var range: SymbolGraph.LineList.SourceRange

        /// The URI of the source file where the reference occurs.
        public var uri: String

        /// The file URL of the source file where the reference occurs.
        @available(macOS 10.11, *)
        public var url: URL? {
            // The URI string provided in the symbol graph file may be an invalid URL (rdar://69242070)
            //
            // Using `URL.init(dataRepresentation:relativeTo:)` here handles URI strings with unescaped
            // characters without trying to escape or otherwise process the URI string in SymbolKit.
            return URL(dataRepresentation: Data(uri.utf8), relativeTo: nil)
        }

        public init(range: SymbolGraph.LineList.SourceRange, uri: String) {
            self.range = range
            self.uri = uri
        }
    }
}