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
|
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift open source project
//
// Copyright (c) 2018 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See http://swift.org/LICENSE.txt for license information
// See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
/// The context information for a Swift package.
///
/// The context encapsulates states that are known when Swift Package Manager interprets the package manifest,
/// for example the location in the file system where the current package resides.
@available(_PackageDescription, introduced: 5.6)
public struct Context: Sendable {
private static let model = try! ContextModel.decode()
/// The directory that contains `Package.swift`.
public static var packageDirectory : String {
model.packageDirectory
}
/// Information about the git status of a given package, if available.
@available(_PackageDescription, introduced: 6.0)
public static var gitInformation: GitInformation? {
model.gitInformation.map {
GitInformation(
currentTag: $0.currentTag,
currentCommit: $0.currentCommit,
hasUncommittedChanges: $0.hasUncommittedChanges
)
}
}
/// Snapshot of the system environment variables.
public static var environment : [String : String] {
model.environment
}
private init() {
}
}
/// Information about the git status of a given package, if available.
@available(_PackageDescription, introduced: 6.0)
public struct GitInformation: Sendable {
public let currentTag: String?
public let currentCommit: String
public let hasUncommittedChanges: Bool
}
|