Files
swift-mirror/stdlib/core/EmptyCollection.swift
2014-07-08 02:17:46 +00:00

56 lines
1.5 KiB
Swift

//===--- EmptyCollection.swift - A collection with no elements ------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2015 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
//
//===----------------------------------------------------------------------===//
//
// Sometimes an operation is best expressed in terms of some other,
// larger operation where one of the parameters is an empty
// collection. For example, we can erase elements from an Array by
// replacing a subrange with the empty collection.
//
//===----------------------------------------------------------------------===//
public struct EmptyGenerator<T> : Generator, Sequence {
public func generate() -> EmptyGenerator {
return self
}
public mutating func next() -> T? {
return nil
}
}
public struct EmptyCollection<T> : Collection {
public typealias IndexType = Int
public init() {}
public var startIndex: IndexType {
return 0
}
public var endIndex: IndexType {
return 0
}
public func generate() -> EmptyGenerator<T> {
return EmptyGenerator()
}
public subscript(i: IndexType) -> T {
_preconditionFailure("Index out of range")
}
}
// Specialization of countElements for EmptyCollection<T>
public func ~> <T>(x:EmptyCollection<T>, _:(_CountElements, ())) -> Int {
return 0
}