-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathF24.hs
82 lines (67 loc) · 2.04 KB
/
F24.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
module F24 where
import Data.DateTime
import Data.Maybe
data Game = Game {
gid :: Int,
away_team_id :: Int,
away_team_name :: String,
competition_id :: Int,
competition_name :: String,
game_date :: DateTime,
home_team_id :: Int,
home_team_name :: String,
matchday :: Int,
period_1_start :: DateTime,
period_2_start :: DateTime,
season_id :: Int,
season_name :: String,
events :: [Event]
}
instance Eq Game where
g1 == g2 = gid g1 == gid g2
instance Show Game where
show g = show (gid g) ++ " " ++ home_team_name g ++ " vs " ++ away_team_name g ++ " on " ++ show (game_date g)
data Event = Event {
eid :: Int,
event_id :: Int,
type_id :: Int,
period_id :: Int,
min :: Int,
sec :: Int,
player_id :: Maybe Int,
team_id :: Int,
outcome :: Maybe Int,
x :: Maybe Float,
y :: Maybe Float,
timestamp :: DateTime, -- FIXME Should be more granular timestamp type.
last_modified :: DateTime,
qs :: [Q]
}
instance Eq Event where
e1 == e2 = eid e1 == eid e2
instance Show Event where
show e = let t = show (type_id e)
i = show (eid e)
p = maybe "" (\pid -> "by player " ++ show pid) (player_id e)
c = show (team_id e)
in "E[" ++ i ++ "]" ++ " of type " ++ t ++ " for " ++ c ++ p
hasq :: Int -> Event -> Bool
hasq i e = any (\q -> qualifier_id q == i) (qs e)
-- FIXME: Consider throwing an exception on duplicated qualifiers
qval :: Int -> Event -> Maybe String
qval i e = let qq = filter (\q -> qualifier_id q == i) (qs e)
in case qq of
[] -> Nothing
q:_ -> value q
data Q = Q {
qid :: Int,
qualifier_id :: Int,
value :: Maybe String
}
instance Eq Q where
q1 == q2 = qid q1 == qid q2
instance Show Q where
show q = "Q" ++ show (qualifier_id q) ++ if isNothing (value q) then "" else " (value: " ++ show (value q) ++ ")"
-- F24 data may be loaded from different resources
class F24Loader a where
loadGame :: a -> IO Game