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

 Copyright (c) 2021-2022 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.Symbol {
    /**
     The place where a symbol was originally declared in a source file.

     This information may not always be available for many reasons, such
     as compiler infrastructure limitations, or filesystem security concerns.
     */
    public struct Location: Mixin {
        public static let mixinKey = "location"

        /**
         The URI of the file in which the symbol was originally declared,
         suitable for display in a user interface.
         */
        public var uri: String

        /**
         The file URL of the source file where the symbol was originally declared.
         */
        @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.
            URL(dataRepresentation: Data(uri.utf8), relativeTo: nil)
        }
        
        /**
         The range of the declaration in the file, not including its documentation comment.
         */
        public var position: SymbolGraph.LineList.SourceRange.Position
        
        /**
         Creates a new symbol location with the given source file URI and position.
         */
        public init(uri: String, position: SymbolGraph.LineList.SourceRange.Position) {
            self.uri = uri
            self.position = position
        }
    }
}