blob: 0843b82c7e2be31d9da150f9f3cc6e9de5c1c5a1 [file] [log] [blame]
// 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
//
// Flags(s) that can be passed to the factory to indicate that a operator operating on strings should do so in a case insensitive fashion.
public struct NSComparisonPredicateOptions : OptionSet {
public let rawValue : UInt
public init(rawValue: UInt) { self.rawValue = rawValue }
public static let CaseInsensitivePredicateOption = NSComparisonPredicateOptions(rawValue : 0x1)
public static let DiacriticInsensitivePredicateOption = NSComparisonPredicateOptions(rawValue : 0x2)
public static let NormalizedPredicateOption = NSComparisonPredicateOptions(rawValue : 0x4) /* Indicate that the strings to be compared have been preprocessed; this supersedes other options and is intended as a performance optimization option */
}
// Describes how the operator is modified: can be direct, ALL, or ANY
public enum NSComparisonPredicateModifier : UInt {
case DirectPredicateModifier // Do a direct comparison
case AllPredicateModifier // ALL toMany.x = y
case AnyPredicateModifier // ANY toMany.x = y
}
// Type basic set of operators defined. Most are obvious
public enum NSPredicateOperatorType : UInt {
case LessThanPredicateOperatorType // compare: returns NSOrderedAscending
case LessThanOrEqualToPredicateOperatorType // compare: returns NSOrderedAscending || NSOrderedSame
case GreaterThanPredicateOperatorType // compare: returns NSOrderedDescending
case GreaterThanOrEqualToPredicateOperatorType // compare: returns NSOrderedDescending || NSOrderedSame
case EqualToPredicateOperatorType // isEqual: returns true
case NotEqualToPredicateOperatorType // isEqual: returns false
case MatchesPredicateOperatorType
case LikePredicateOperatorType
case BeginsWithPredicateOperatorType
case EndsWithPredicateOperatorType
case InPredicateOperatorType // rhs contains lhs returns true
case ContainsPredicateOperatorType // lhs contains rhs returns true
case BetweenPredicateOperatorType
}
// Comparison predicates are predicates which do some form of comparison between the results of two expressions and return a BOOL. They take an operator, a left expression, and a right expression, and return the result of invoking the operator with the results of evaluating the expressions.
public class NSComparisonPredicate : NSPredicate {
public init(leftExpression lhs: NSExpression, rightExpression rhs: NSExpression, modifier: NSComparisonPredicateModifier, type: NSPredicateOperatorType, options: NSComparisonPredicateOptions) { NSUnimplemented() }
public required init?(coder: NSCoder) { NSUnimplemented() }
public var predicateOperatorType: NSPredicateOperatorType { NSUnimplemented() }
public var comparisonPredicateModifier: NSComparisonPredicateModifier { NSUnimplemented() }
public var leftExpression: NSExpression { NSUnimplemented() }
public var rightExpression: NSExpression { NSUnimplemented() }
public var options: NSComparisonPredicateOptions { NSUnimplemented() }
}