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.
This simple class does not store any seller information.
Parameters
description
a short description of the item
duration
the maximum number of days the sale will remain open
Records one day as having passed. In practice, what this means is that the item becomes one day closer to expiring, assuming the item is open for purchase (as per isOpen) to begin with. This method does nothing in case the item has already been bought or in case the sale has expired.
Records one day as having passed. In practice, what this means is that the item becomes one day closer to expiring, assuming the item is open for purchase (as per isOpen) to begin with. This method does nothing in case the item has already been bought or in case the sale has expired.
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.
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.
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.
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.
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.
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.
Determines if the sale is open, that is, if the item can still be bought. A fixed-price sale is always open if nobody has yet bought the item and the sale has not yet expired.
Determines if the sale is open, that is, if the item can still be bought. A fixed-price sale is always open if nobody has yet bought the item and the sale has not yet expired.