forked from GitHub/gf-core
RunGHCC for testing
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
module GF.Canon.GFCC.DataGFCM where
|
module GF.Canon.GFCC.DataGFCC where
|
||||||
|
|
||||||
import GF.Canon.GFCC.AbsGFCC
|
import GF.Canon.GFCC.AbsGFCC
|
||||||
import Data.Map
|
import Data.Map
|
||||||
@@ -28,6 +28,8 @@ realize trm = case trm of
|
|||||||
S ss -> unwords $ Prelude.map realize ss
|
S ss -> unwords $ Prelude.map realize ss
|
||||||
K (KS s) -> s
|
K (KS s) -> s
|
||||||
K (KP s _) -> unwords s ---- prefix choice TODO
|
K (KP s _) -> unwords s ---- prefix choice TODO
|
||||||
|
W s t -> s ++ " " ++ realize t
|
||||||
|
_ -> "ERROR " ++ show trm ---- debug
|
||||||
|
|
||||||
linExp :: GFCC -> CId -> Exp -> Term
|
linExp :: GFCC -> CId -> Exp -> Term
|
||||||
linExp mcfg lang tree@(Tr at trees) =
|
linExp mcfg lang tree@(Tr at trees) =
|
||||||
@@ -46,10 +48,13 @@ kks = K . KS
|
|||||||
compute :: GFCC -> CId -> [Term] -> Term -> Term
|
compute :: GFCC -> CId -> [Term] -> Term -> Term
|
||||||
compute mcfg lang args trm = case trm of
|
compute mcfg lang args trm = case trm of
|
||||||
P r p -> case (comp r, comp p) of
|
P r p -> case (comp r, comp p) of
|
||||||
(W s (R ss), C i) -> case comp $ ss !! (fromInteger i) of
|
(W s t, C i) -> case comp t of
|
||||||
K (KS u) -> kks (s ++ u) -- the only case where W occurs
|
R ss -> case comp $ ss !! (fromInteger i) of
|
||||||
|
K (KS u) -> kks (s ++ u) -- the only case where W occurs
|
||||||
(R rs, C i) -> comp $ rs !! (fromInteger i)
|
(R rs, C i) -> comp $ rs !! (fromInteger i)
|
||||||
(r',p') -> P r' p'
|
(r',p') -> P r' p'
|
||||||
|
W s t -> W s (comp t)
|
||||||
|
R ts -> R $ Prelude.map comp ts
|
||||||
V i -> args !! (fromInteger i) -- already computed
|
V i -> args !! (fromInteger i) -- already computed
|
||||||
S ts -> S (Prelude.map comp ts)
|
S ts -> S (Prelude.map comp ts)
|
||||||
F c -> comp $ look c -- global constant: not yet comp'd (if contains argvar)
|
F c -> comp $ look c -- global constant: not yet comp'd (if contains argvar)
|
||||||
@@ -68,5 +73,6 @@ mkGFCC (Grm (Hdr a cs) ab@(Abs funs) ccs) = GFCC {
|
|||||||
concretes = fromAscList [(lang, mkCnc lins) | Cnc lang lins <- ccs]
|
concretes = fromAscList [(lang, mkCnc lins) | Cnc lang lins <- ccs]
|
||||||
}
|
}
|
||||||
where
|
where
|
||||||
mkCnc lins = fromAscList [(fun,lin) | Lin fun lin <- lins]
|
mkCnc lins = fromList [(fun,lin) | Lin fun lin <- lins] ---- Asc
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{-# OPTIONS -fglasgow-exts -cpp #-}
|
{-# OPTIONS -fglasgow-exts -cpp #-}
|
||||||
{-# LINE 3 "LexGFCC.x" #-}
|
{-# LINE 3 "LexGFCC.x" #-}
|
||||||
{-# OPTIONS -fno-warn-incomplete-patterns #-}
|
{-# OPTIONS -fno-warn-incomplete-patterns #-}
|
||||||
module LexGFCC where
|
module GF.Canon.GFCC.LexGFCC where
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
{-# OPTIONS -fglasgow-exts -cpp #-}
|
{-# OPTIONS -fglasgow-exts -cpp #-}
|
||||||
{-# OPTIONS -fno-warn-incomplete-patterns -fno-warn-overlapping-patterns #-}
|
{-# OPTIONS -fno-warn-incomplete-patterns -fno-warn-overlapping-patterns #-}
|
||||||
module ParGFCC where
|
module GF.Canon.GFCC.ParGFCC where
|
||||||
import AbsGFCC
|
import GF.Canon.GFCC.AbsGFCC
|
||||||
import LexGFCC
|
import GF.Canon.GFCC.LexGFCC
|
||||||
import ErrM
|
import GF.Data.Operations
|
||||||
import Array
|
import Data.Array
|
||||||
#if __GLASGOW_HASKELL__ >= 503
|
#if __GLASGOW_HASKELL__ >= 503
|
||||||
import GHC.Exts
|
import GHC.Exts
|
||||||
#else
|
#else
|
||||||
|
|||||||
57
src/GF/Canon/GFCC/RunGFCC.hs
Normal file
57
src/GF/Canon/GFCC/RunGFCC.hs
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
module Main where
|
||||||
|
|
||||||
|
import GF.Canon.GFCC.DataGFCC
|
||||||
|
import GF.Canon.GFCC.AbsGFCC
|
||||||
|
import GF.Canon.GFCC.ParGFCC
|
||||||
|
import GF.Canon.GFCC.PrintGFCC
|
||||||
|
import GF.Data.Operations
|
||||||
|
import Data.Map
|
||||||
|
import System
|
||||||
|
|
||||||
|
-- Simple translation application built on GFCC. AR 7/9/2006
|
||||||
|
|
||||||
|
main :: IO ()
|
||||||
|
main = do
|
||||||
|
file <- getLine ----getArgs
|
||||||
|
grammar <- file2gfcc file
|
||||||
|
loop grammar
|
||||||
|
|
||||||
|
loop :: GFCC -> IO ()
|
||||||
|
loop grammar = do
|
||||||
|
s <- getLine
|
||||||
|
if s == "quit" then return () else do
|
||||||
|
treat grammar s
|
||||||
|
loop grammar
|
||||||
|
|
||||||
|
treat :: GFCC -> String -> IO ()
|
||||||
|
treat grammar s = do
|
||||||
|
let t = readExp s
|
||||||
|
putStrLn $ printTree $ linExp grammar lang t
|
||||||
|
putStrLn $ linearize grammar lang t
|
||||||
|
where
|
||||||
|
lang = head $ cncnames grammar
|
||||||
|
|
||||||
|
--- should be in an API
|
||||||
|
|
||||||
|
file2gfcc :: FilePath -> IO GFCC
|
||||||
|
file2gfcc f =
|
||||||
|
readFile f >>= err (error "no parse") (return . mkGFCC) . pGrammar . myLexer
|
||||||
|
|
||||||
|
readExp :: String -> Exp
|
||||||
|
readExp = err (error "no parse") id . (pExp . myLexer)
|
||||||
|
|
||||||
|
|
||||||
|
{-
|
||||||
|
treat grammar s = putStrLn $ case comm of
|
||||||
|
["lin"] -> unlines $ linearizeAll grammar $ readTree grammar rest
|
||||||
|
["lin",lang] -> linearize grammar lang $ readTree grammar rest
|
||||||
|
["parse",cat] -> unlines $ map showTree $ concat $ parseAll grammar cat rest
|
||||||
|
["parse",lang,cat] -> unlines $ map showTree $ parse grammar lang cat rest
|
||||||
|
["langs"] -> unwords $ languages grammar
|
||||||
|
["cats"] -> unwords $ categories grammar
|
||||||
|
["help"] -> helpMsg
|
||||||
|
_ -> "command not interpreted: " ++ s
|
||||||
|
where
|
||||||
|
(comm,rest) = (words c,drop 1 r) where
|
||||||
|
(c,r) = span (/=':') s
|
||||||
|
-}
|
||||||
Reference in New Issue
Block a user