mirror of
https://github.com/apple/swift-nio.git
synced 2026-05-20 20:30:36 +00:00
66a85ba0e2
Motivation: In #3363 we converted `_NIOFileSystem` to `NIOFileSystem` and removed the (unreleased) overloads for FilePath/NIOFilePath. This change adds back `_NIOFileSystem` such that it matches the API it had at 2.86.0. Modifications: - Add back `_NIOFileSystem` and `_NIOFileSystemFoundationCompat` such that their API is at 2.86.0 Result: - `NIOFileSystem` uses `NIOFilePath` - `_NIOFileSystem` uses `FilePath`
58 lines
1.9 KiB
Swift
58 lines
1.9 KiB
Swift
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This source file is part of the SwiftNIO open source project
|
|
//
|
|
// Copyright (c) 2025 Apple Inc. and the SwiftNIO project authors
|
|
// Licensed under Apache License v2.0
|
|
//
|
|
// See LICENSE.txt for license information
|
|
// See CONTRIBUTORS.txt for the list of SwiftNIO project authors
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#if canImport(Darwin) || os(Linux) || os(Android)
|
|
import _NIOFileSystem
|
|
import NIOCore
|
|
import NIOFoundationCompat
|
|
import struct Foundation.Data
|
|
|
|
@available(macOS 10.15, iOS 13.0, watchOS 6.0, tvOS 13.0, *)
|
|
extension Data {
|
|
/// Reads the contents of the file at the path.
|
|
///
|
|
/// - Parameters:
|
|
/// - path: The path of the file to read.
|
|
/// - maximumSizeAllowed: The maximum size of file which can be read, in bytes, as a ``ByteCount``.
|
|
/// - fileSystem: The ``FileSystemProtocol`` instance to use to read the file.
|
|
public init(
|
|
contentsOf path: FilePath,
|
|
maximumSizeAllowed: ByteCount,
|
|
fileSystem: some FileSystemProtocol
|
|
) async throws {
|
|
let byteBuffer = try await fileSystem.withFileHandle(forReadingAt: path) { handle in
|
|
try await handle.readToEnd(maximumSizeAllowed: maximumSizeAllowed)
|
|
}
|
|
|
|
self = Data(buffer: byteBuffer)
|
|
}
|
|
|
|
/// Reads the contents of the file at the path using ``FileSystem``.
|
|
///
|
|
/// - Parameters:
|
|
/// - path: The path of the file to read.
|
|
/// - maximumSizeAllowed: The maximum size of file which can be read, as a ``ByteCount``.
|
|
public init(
|
|
contentsOf path: FilePath,
|
|
maximumSizeAllowed: ByteCount
|
|
) async throws {
|
|
self = try await Self(
|
|
contentsOf: path,
|
|
maximumSizeAllowed: maximumSizeAllowed,
|
|
fileSystem: .shared
|
|
)
|
|
}
|
|
}
|
|
#endif
|