Packages

c

o1.auctionhouse

FixedPriceSale

class FixedPriceSale extends InstantPurchase

Each instance of the class FixedPriceSale represents an item that has been put up for sale in an (imaginary) electronic auction house. Each such item is being sold for a fixed price (as opposed to being auctioned).

Apart from a price, each sale has a duration measured in days. Every day, the method advanceOneDay must be called. If the set number of days is reached without anyone buying the item, the sale expires and the item can no longer be bought.

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. FixedPriceSale
  2. InstantPurchase
  3. ItemForSale
  4. AnyRef
  5. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Instance Constructors

  1. new FixedPriceSale(description: String, price: Int, duration: Int)

    description

    a short description of the item

    price

    the price the item is being sold for

    duration

    the maximum number of days the sale will remain open

Value Members

  1. def advanceOneDay(): Unit

    Records one day as having passed.

    Records one day as having passed. In practice, what this means is that the item becomes one day closer to expiring unless it has already been bought.

    Definition Classes
    FixedPriceSaleItemForSale
  2. def buy(buyer: String): Boolean

    Buys the item for the given customer.

    Buys the item for the given customer. The sale now has a buyer (and is therefore no longer open). This only works, however, if the sale was open to begin with. The method returns true if the item was successfully bought, false if the purchase failed.

    Definition Classes
    InstantPurchase
  3. def buyer: Option[String]

    Returns the buyer of the item, wrapped in an Option; None is returned if nobody has bought the item yet.

    Returns the buyer of the item, wrapped in an Option; None is returned if nobody has bought the item yet.

    Definition Classes
    InstantPurchaseItemForSale
  4. def daysLeft: Int

    Returns the number of days remaining until the sale expires, unless someone buys the item.

    Returns the number of days remaining until the sale expires, unless someone buys the item. Initially, this number will be equal to the sale's duration, but will decrease with each passing day until it reaches zero or the item is bought.

    If the item has been already bought when this method is called, the number of days that were remaining at the time of purchase is returned. A return value of zero means that time has already run out to buy the item.

  5. val description: String
    Definition Classes
    ItemForSale
  6. def isExpired: Boolean

    Determines whether the sale has expired.

    Determines whether the sale has expired. That is, determines whether the item is no longer available because time has run out. Note that if the item is unavailable because it was bought, it has not "expired" in this sense and this method will return false.

    Definition Classes
    FixedPriceSaleItemForSale
  7. def isOpen: Boolean

    Determines if the sale is open, that is, if the item can still be bought.

    Determines if the sale is open, that is, if the item can still be bought. An item like this is always open if nobody has yet bought it and the opportunity to buy it has not yet expired.

    Definition Classes
    InstantPurchaseItemForSale
  8. val price: Int

    Returns the current price of the item, that is, the price that the item is selling for at the moment.

    Returns the current price of the item, that is, the price that the item is selling for at the moment. If the item is not open, the sale price (if bought) or closing price (if expired) is returned.

    Definition Classes
    FixedPriceSaleItemForSale
  9. def toString: String

    Returns a textual description of the item.

    Returns a textual description of the item. This text is the same as that returned by description.

    Definition Classes
    ItemForSale → AnyRef → Any