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
|
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift open source project
//
// Copyright (c) 2023-2024 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 the list of Swift project authors
//
//===----------------------------------------------------------------------===//
import struct _AsyncFileSystem.OpenReadableFile
// FIXME: need a new swift-system tag to remove `@preconcurrency`
@preconcurrency package import struct SystemPackage.FilePath
package struct FileCacheRecord: Sendable {
package let path: FilePath
package let hash: String
}
extension FileCacheRecord: Codable {
enum CodingKeys: CodingKey {
case path
case hash
}
// FIXME: `Codable` on `FilePath` is broken, thus all `Codable` types with `FilePath` properties need a custom impl.
package init(from decoder: any Decoder) throws {
let container = try decoder.container(keyedBy: CodingKeys.self)
self.path = try FilePath(container.decode(String.self, forKey: .path))
self.hash = try container.decode(String.self, forKey: .hash)
}
package func encode(to encoder: any Encoder) throws {
var container = encoder.container(keyedBy: CodingKeys.self)
try container.encode(self.path.string, forKey: .path)
try container.encode(self.hash, forKey: .hash)
}
}
extension OpenReadableFile {
func hash(with hashFunction: inout some HashFunction) async throws {
let stream = try await self.read()
for try await bytes in stream {
hashFunction.update(data: bytes)
}
}
}
|