summaryrefslogtreecommitdiff
path: root/examples/big/MkDict.hs
blob: babf7809f3f74f55d60164e94547110488e9e0c1 (plain)
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
import Char

infile = "mywordlist1"

main = do
  s <- readFile infile
  mapM_ (putStrLn . mkOne) $ lines s

mkOne s = case words s of
  "--":_ -> ""
  ('(':_):w:cat:ws -> unwords $ mkCatf (nopar cat) (more ws) w
  _ -> "-- " ++ s
 where
  more ws = case ws of
    _ | elem "(REG" ws -> "irreg"
    _ -> "reg"
  nopar = filter (flip notElem "()")
  mkCatf c r w = case c of
    "Noun" -> ["N","regN",w]
    "PRT" -> ["Adv","mkAdv",w] ----
    "TITLE" -> ["N","regN",w] ----
    "Adject" -> ["A","regA",w]
    "AdjInf" -> ["A","regA",w] ----
    "AdjInf_LONG" -> ["A","longA",w] ----
    "AdjPrd" -> ["A","regA",w] ----
    "AdjPrd_LONG" -> ["A","longA",w] ----
    "Adject_LONG" -> ["A","longA",w]
    "Verb" | r == "irreg" -> []
    "Verb"  -> ["V","regV",w]
    "V2" | r == "irreg" -> ["V2","irreg", w, "_V"]
    "V2" -> ["V2","regV2", w]
    "PNoun" -> ["PN","regPN",toUpper (head w): tail w]
    'V':'2':'_':prep | r == "irreg" -> 
               let p = map toLower prep in ["V2","mkV2_"++p, w, "_V", p]
    x:'2':'_':prep -> 
               let p = map toLower prep in [[x]++"2","prep" ++[x]++"2"++p, w, p]
    "V3_NP" | r == "irreg" -> ["V3","irreg", w, "_V"]
    "V3_NP" -> ["V3","regV3", w]
    'V':'3':'_':'P':'P':prep | r == "irreg" -> 
               let p = map toLower prep in ["V3","mkV3_"++p, w, "_V", p]
    'V':'3':'_':'P':'P':prep -> 
               let p = map toLower prep in ["V3","mkV3_"++p, w, p]
    'V':'3':'_':'S':_ | r == "irreg" -> ["V2","mkV2_S", w, "_V"] ----
    'V':'3':'_':'S':_ -> ["V2","mkV2_S", w] ----
    'V':'3':'_':_ -> ["V3","mkV3", w] ----

    _ -> [c,"mk" ++ c, w]