GooglePlacesSwift Framework Reference

Money

struct Money
extension Money : Copyable, CustomStringConvertible, Equatable, Escapable, Hashable, Sendable, SendableMetatype

Represents an amount of money with its currency type.

  • Returns a Boolean value indicating whether two values are equal.

    Equality is the inverse of inequality. For any values a and b, a == b implies that a != b is false.

    Declaration

    Swift

    static func == (lhs: Money, rhs: Money) -> Bool

    Parameters

    lhs

    A value to compare.

    rhs

    Another value to compare.

  • The three-letter currency code defined in ISO 4217.

    Declaration

    Swift

    var currencyCode: String { get }
  • A textual representation of this instance.

    Calling this property directly is discouraged. Instead, convert an instance of any type to a string by using the String(describing:) initializer. This initializer works with any type, and uses the custom description property for types that conform to CustomStringConvertible:

    struct Point: CustomStringConvertible {
        let x: Int, y: Int
    
        var description: String {
            return "(\(x), \(y))"
        }
    }
    
    let p = Point(x: 21, y: 30)
    let s = String(describing: p)
    print(s)
    // Prints "(21, 30)"
    

    The conversion of p to a string in the assignment to s uses the Point type’s description property.

    Declaration

    Swift

    var description: String { get }
  • Hashes the essential components of this value by feeding them into the given hasher.

    Implement this method to conform to the Hashable protocol. The components used for hashing must be the same as the components compared in your type’s == operator implementation. Call hasher.combine(_:) with each of these components.

    Important

    In your implementation of hash(into:), don’t call finalize() on the hasher instance provided, or replace it with a different instance. Doing so may become a compile-time error in the future.

    Declaration

    Swift

    func hash(into hasher: inout Hasher)
  • The hash value.

    Hash values are not guaranteed to be equal across different executions of your program. Do not save hash values to use during a future execution.

    Important

    hashValue is deprecated as a Hashable requirement. To conform to Hashable, implement the hash(into:) requirement instead. The compiler provides an implementation for hashValue for you.

    Declaration

    Swift

    var hashValue: Int { get }
  • The number of nano (1e-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. For example $-1.75 is represented as units=-1 and nanos=-750,000,000.

    If “units” is positive, “nanos” must be positive or zero. If “units” is zero, “nanos” can be positive, zero, or negative. If “units” is negative, “nanos” must be negative or zero.

    Declaration

    Swift

    var nanos: Int { get }
  • The whole units of the amount. For example if “currencyCode” is “USD”, then 1 unit is one US dollar.

    Declaration

    Swift

    var units: Int64 { get }