Cursor
public protocol Cursor : AnyObjectA type that supplies the values of some external resource, one at a time.
Overview
The most common way to iterate over the elements of a cursor is to use a
while loop:
let cursor = ...
while let element = try cursor.next() {
    ...
}
Relationship with standard Sequence and IteratorProtocol
Cursors share traits with lazy sequences and iterators from the Swift standard library. Differences are:
- Cursor types are classes, and have a lifetime.
- Cursor iteration may throw errors.
- A cursor can not be repeated.
The protocol comes with default implementations for many operations similar
to those defined by Swift’s Sequence protocol: contains, dropFirst,
dropLast, drop(while:), enumerated, filter, first, flatMap,
forEach, joined, joined(separator:), max, max(by:), min,
min(by:), map, prefix, prefix(while:), reduce, reduce(into:),
suffix.
- 
                  
                  The type of element traversed by the cursor. DeclarationSwift associatedtype Element
- 
                  
                  Advances to the next element and returns it, or nil if no next element exists. Once nil has been returned, all subsequent calls return nil. DeclarationSwift func next() throws -> Element?
- 
                  isEmpty()Extension methodReturns a Boolean value indicating whether the cursor contains an element. DeclarationSwift public func isEmpty() throws -> Bool
- 
                  contains(where:Extension method) Returns a Boolean value indicating whether the cursor contains an element that satisfies the given predicate. DeclarationSwift public func contains(where predicate: (Element) throws -> Bool) throws -> BoolParameterspredicateA closure that takes an element of the cursor as its argument and returns a Boolean value that indicates whether the passed element represents a match. Return Valuetrue if the cursor contains an element that satisfies predicate; otherwise, false. 
- 
                  enumerated()Extension methodReturns a cursor of pairs (n, x), where n represents a consecutive integer starting at zero, and x represents an element of the cursor. let cursor = try String.fetchCursor(db, sql: "SELECT 'foo' UNION ALL SELECT 'bar'") let c = cursor.enumerated() while let (n, x) = c.next() { print("\(n): \(x)") } // Prints: "0: foo" // Prints: "1: bar"DeclarationSwift public func enumerated() -> EnumeratedCursor<Self>
- 
                  filter(_:Extension method) Returns the elements of the cursor that satisfy the given predicate. DeclarationSwift public func filter(_ isIncluded: @escaping (Element) throws -> Bool) -> FilterCursor<Self>
- 
                  first(where:Extension method) Returns the first element of the cursor that satisfies the given predicate or nil if no such element is found. 
- 
                  compactMap(_:Extension method) Returns a cursor over the concatenated non-nil results of mapping transform over this cursor. DeclarationSwift public func compactMap<ElementOfResult>(_ transform: @escaping (Element) throws -> ElementOfResult?) -> MapCursor<FilterCursor<MapCursor<Self, ElementOfResult?>>, ElementOfResult>
- 
                  drop(while:Extension method) Returns a cursor that skips any initial elements that satisfy predicate.DeclarationSwift public func drop(while predicate: @escaping (Element) throws -> Bool) -> DropWhileCursor<Self>ParameterspredicateA closure that takes an element of the cursir as its argument and returns trueif the element should be skipped orfalseotherwise. Oncepredicatereturnsfalseit will not be called again.
- 
                  dropFirst(_:Extension method) Returns a cursor containing all but the given number of initial elements. If the number of elements to drop exceeds the number of elements in the cursor, the result is an empty cursor. let numbers = AnyCursor([1, 2, 3, 4, 5]) try print(numbers.dropFirst(2)) // Prints "[3, 4, 5]" try print(numbers.dropFirst(10)) // Prints "[]"DeclarationSwift public func dropFirst(_ n: Int) -> DropFirstCursor<Self>ParametersnThe number of elements to drop from the beginning of the cursor. nmust be greater than or equal to zero.Return ValueA cursor starting after the specified number of elements. 
- 
                  dropFirst()Extension methodReturns a cursor containing all but the first element of the cursor. The following example drops the first element from a cursor of integers. let numbers = AnyCursor([1, 2, 3, 4, 5]) try print(numbers.dropFirst()) // Prints "[2, 3, 4, 5]"If the cursor has no elements, the result is an empty cursor. DeclarationSwift public func dropFirst() -> DropFirstCursor<Self>Return ValueA cursor starting after the first element of the cursor. 
- 
                  dropLast(_:Extension method) Returns an array containing all but the given number of final elements. The cursor must be finite. If the number of elements to drop exceeds the number of elements in the cursor, the result is an empty array. let numbers = AnyCursor([1, 2, 3, 4, 5]) try print(numbers.dropLast(2)) // Prints "[1, 2, 3]" try print(numbers.dropLast(10)) // Prints "[]"DeclarationSwift public func dropLast(_ n: Int) throws -> [Element]ParametersnThe number of elements to drop off the end of the cursor. nmust be greater than or equal to zero.Return ValueAn array leaving off the specified number of elements. 
- 
                  dropLast()Extension methodReturns an array containing all but the last element of the cursor. The following example drops the last element from a cursor of integers. let numbers = AnyCursor([1, 2, 3, 4, 5]) try print(numbers.dropLast()) // Prints "[1, 2, 3, 4]"If the cursor has no elements, the result is an empty cursor. DeclarationSwift public func dropLast() throws -> [Element]Return ValueAn array leaving off the last element of the cursor. 
- 
                  flatMap(_:Extension method) Returns a cursor over the concatenated results of mapping transform over self. Declaration
- 
                  flatMap(_:Extension method) Returns a cursor over the concatenated results of mapping transform over self. DeclarationSwift public func flatMap<SegmentOfResult>(_ transform: @escaping (Element) throws -> SegmentOfResult) -> FlattenCursor<MapCursor<Self, SegmentOfResult>> where SegmentOfResult: Cursor
- 
                  forEach(_:Extension method) Calls the given closure on each element in the cursor. DeclarationSwift public func forEach(_ body: (Element) throws -> Void) throws
- 
                  map(_:Extension method) Returns a cursor over the results of the transform function applied to this cursor’s elements. DeclarationSwift public func map<T>(_ transform: @escaping (Element) throws -> T) -> MapCursor<Self, T>
- 
                  max(by:Extension method) Returns the maximum element in the cursor, using the given predicate as the comparison between elements. DeclarationParametersareInIncreasingOrderA predicate that returns trueif its first argument should be ordered before its second argument; otherwise,false.Return ValueThe cursor’s maximum element, according to areInIncreasingOrder. If the cursor has no elements, returnsnil.
- 
                  min(by:Extension method) Returns the minimum element in the cursor, using the given predicate as the comparison between elements. DeclarationParametersareInIncreasingOrderA predicate that returns trueif its first argument should be ordered before its second argument; otherwise,false.Return ValueThe cursor’s minimum element, according to areInIncreasingOrder. If the cursor has no elements, returnsnil.
- 
                  prefix(_:Extension method) Returns a cursor, up to the specified maximum length, containing the initial elements of the cursor. If the maximum length exceeds the number of elements in the cursor, the result contains all the elements in the cursor. let numbers = AnyCursor([1, 2, 3, 4, 5]) try print(numbers.prefix(2)) // Prints "[1, 2]" try print(numbers.prefix(10)) // Prints "[1, 2, 3, 4, 5]"DeclarationSwift public func prefix(_ maxLength: Int) -> PrefixCursor<Self>ParametersmaxLengthThe maximum number of elements to return. The value of maxLengthmust be greater than or equal to zero.Return ValueA cursor starting at the beginning of this cursor with at most maxLengthelements.
- 
                  prefix(while:Extension method) Returns a cursor of the initial consecutive elements that satisfy predicate.DeclarationSwift public func prefix(while predicate: @escaping (Element) throws -> Bool) -> PrefixWhileCursor<Self>ParameterspredicateA closure that takes an element of the cursor as its argument and returns trueif the element should be included orfalseotherwise. Oncepredicatereturnsfalseit will not be called again.
- 
                  reduce(_:Extension method_: ) Returns the result of calling the given combining closure with each element of this cursor and an accumulating value. DeclarationSwift public func reduce<Result>( _ initialResult: Result, _ nextPartialResult: (Result, Element) throws -> Result) throws -> Result
- 
                  reduce(into:Extension method_: ) Returns the result of calling the given combining closure with each element of this cursor and an accumulating value. DeclarationSwift public func reduce<Result>( into initialResult: Result, _ updateAccumulatingResult: (inout Result, Element) throws -> Void) throws -> Result
- 
                  suffix(_:Extension method) Returns an array, up to the given maximum length, containing the final elements of the cursor. The cursor must be finite. If the maximum length exceeds the number of elements in the cursor, the result contains all the elements in the cursor. let numbers = AnyCursor([1, 2, 3, 4, 5]) try print(numbers.suffix(2)) // Prints "[4, 5]" try print(numbers.suffix(10)) // Prints "[1, 2, 3, 4, 5]"DeclarationSwift public func suffix(_ maxLength: Int) throws -> [Element]ParametersmaxLengthThe maximum number of elements to return. The value of maxLengthmust be greater than or equal to zero.
- 
                  contains(_:Extension method) Returns a Boolean value indicating whether the cursor contains the given element. DeclarationSwift public func contains(_ element: Element) throws -> Bool
- 
                  max()Extension methodReturns the maximum element in the cursor. DeclarationSwift public func max() throws -> Element?ParametersareInIncreasingOrderA predicate that returns trueif its first argument should be ordered before its second argument; otherwise,false.Return ValueThe cursor’s maximum element, according to areInIncreasingOrder. If the cursor has no elements, returnsnil.
- 
                  min()Extension methodReturns the minimum element in the cursor. DeclarationSwift public func min() throws -> Element?ParametersareInIncreasingOrderA predicate that returns trueif its first argument should be ordered before its second argument; otherwise,false.Return ValueThe cursor’s minimum element, according to areInIncreasingOrder. If the cursor has no elements, returnsnil.
- 
                  joined()Extension methodReturns the elements of this cursor of cursors, concatenated. DeclarationSwift public func joined() -> FlattenCursor<Self>
- 
                  joined()Extension methodReturns the elements of this cursor of sequences, concatenated. Declaration
- 
                  joined(separator:Extension method) Returns the elements of this cursor of sequences, concatenated. DeclarationSwift public func joined(separator: String = "") throws -> String
 View on GitHub
View on GitHub Install in Dash
Install in Dash Cursor Protocol Reference
        Cursor Protocol Reference