blob: 366c0d39399da6e871919ef5dc58ae19c1382dbd [file] [log] [blame]
// RUN: %target-swift-frontend -emit-sil %s -Onone -Xllvm \
// RUN: -sil-print-after=raw-sil-inst-lowering -Xllvm \
// RUN: -sil-print-only-functions=$s2fs36RecursibleDirectoryContentsGeneratorC4path10fileSystemAcA12AbsolutePathV_AA04FileH0_ptKc33_F8B132991B28208F48606E87DC165393Llfc \
// RUN: -Xllvm -sil-print-debuginfo -o /dev/null 2>&1 | %FileCheck %s
// REQUIRES: objc_interop
// CHECK: [[ADR:%.*]] = ref_element_addr %{{.*}} : $RecursibleDirectoryContentsGenerator, #RecursibleDirectoryContentsGenerator.fileSystem, loc {{.*}}:38:5, scope 2
// CHECK: destroy_addr [[ADR]] : $*FileSystem, loc {{.*}}:38:5, scope 2
import Foundation
public struct AbsolutePath {
public init(_ absStr: String) {}
}
public protocol FileSystem: class {
func getDirectoryContents(_ path: AbsolutePath) throws -> [String]
}
public extension FileSystem {
}
public var currentWorkingDirectory: AbsolutePath {
let cwdStr = FileManager.default.currentDirectoryPath
return AbsolutePath(cwdStr)
}
public class RecursibleDirectoryContentsGenerator {
private var current: (path: AbsolutePath, iterator: IndexingIterator<[String]>)
private let fileSystem: FileSystem
fileprivate init(
path: AbsolutePath,
fileSystem: FileSystem
) throws {
self.fileSystem = fileSystem
current = (path, try fileSystem.getDirectoryContents(path).makeIterator())
}
}