summaryrefslogtreecommitdiff
path: root/examples/CLE/CF2GF.hs
blob: 1bb1d66118c00ae324092da616733182ae19e8ea (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import Data.List (intersperse)
import Data.Char (isAlpha)

-- to massage cf rules to funs, in order, preserving comments
-- to get cats, use pg -printer=gf

cf2gf :: FilePath -> IO ()
cf2gf file = do
  ss <- readFile file >>= return . lines
  mapM_ (putStrLn . mkOne) ss

mkOne line = case words line of
  fun : cat : "::=" : cats -> 
    let 
      (cats0,cats2) = span (/=";") cats
      cats1 = filter (isAlpha . head) cats0 ++ [cat] 
    in
    unwords $ [init fun, ":"] ++ intersperse "->" cats1 ++ cats2
  _ -> line