aboutsummaryrefslogtreecommitdiff
path: root/Haskell-book/11/Vehicle.hs
diff options
context:
space:
mode:
Diffstat (limited to 'Haskell-book/11/Vehicle.hs')
-rw-r--r--Haskell-book/11/Vehicle.hs40
1 files changed, 40 insertions, 0 deletions
diff --git a/Haskell-book/11/Vehicle.hs b/Haskell-book/11/Vehicle.hs
new file mode 100644
index 0000000..b4dd705
--- /dev/null
+++ b/Haskell-book/11/Vehicle.hs
@@ -0,0 +1,40 @@
+module Vehicle where
+
+data Price = Price Integer deriving (Eq, Show)
+
+data Size = Size Integer deriving (Eq, Show)
+
+data Manufacturer = Mini
+ | Mazda
+ | Tata
+ deriving (Eq, Show)
+
+data Airline = PapuAir
+ | CatapultsR'Us
+ | TakeYourChancesUnited
+ deriving (Eq, Show)
+
+data Vehicle = Car Manufacturer Price
+ | Plane Airline Size
+ deriving (Eq, Show)
+
+myCar = Car Mini (Price 14000)
+urCar = Car Mazda (Price 20000)
+clownCar = Car Tata (Price 7000)
+doge = Plane PapuAir (Size 1234)
+
+isCar :: Vehicle -> Bool
+isCar (Car _ _) = True
+isCar _ = False
+
+isPlane :: Vehicle -> Bool
+isPlane (Plane _ _) = True
+isPlane _ = False
+
+areCars :: [Vehicle] -> [Bool]
+areCars = map isCar
+
+getManu :: Vehicle -> Manufacturer
+getManu (Car m _) = m
+
+data Example = MakeExample Int deriving Show