TypeItem.hs revision cfe294850faf3d3dbcc68828f31c20532ea57557
{- HetCATS/CASL/TypeItem.hs
$Id$
Authors: Christian Maeder
Year: 2002
parse DATATYPE-DECL
http://www.cofi.info/Documents/CASL/Summary/
from 25 March 2001
C.2.1 Basic Specifications with Subsorts
-}
module TypeItem where
import Id
import Keywords
import Lexer
import AS_Basic_CASL
import AS_Annotation
import Parsec
import Token
import Formula
import ItemList(annos, itemList)
-- ------------------------------------------------------------------------
-- datatypes
-- ------------------------------------------------------------------------
datatype :: GenParser Char st DATATYPE_DECL
datatype = do s <- sortId
e <- asKey defnS
a <- annos
(Annoted v _ _ b:as, ps) <- aAlternative
`separatedBy` barT
return (Datatype_decl s (Annoted v [] a b:as)
(map tokPos (e:ps)))
aAlternative :: GenParser Char st (Annoted ALTERNATIVE)
aAlternative = do a <- alternative
an <- annos
return (Annoted a [] [] an)
alternative :: GenParser Char st ALTERNATIVE
alternative = do s <- pluralKeyword sortS
(ts, cs) <- sortId `separatedBy` commaT
return (Subsorts ts (map tokPos (s:cs)))
<|>
do i <- parseId
do o <- oParenT
(cs, ps) <- component `separatedBy` semiT
c <- cParenT
let qs = toPos o ps c in
do q <- quMarkT
return (Partial_construct i cs
(qs++[tokPos q]))
<|> return (Total_construct i cs qs)
<|> return (Total_construct i [] [])
isSortId :: Id -> Bool
isSortId (Id is _ _) = length is == 1 && not (null (tokStr (head is)))
&& head (tokStr (head is)) `elem` caslLetters
component :: GenParser Char st COMPONENTS
component = do (is, cs) <- parseId `separatedBy` commaT
if length is == 1 && isSortId (head is) then
compSort is cs
<|> return (Sort (head is))
else compSort is cs
compSort :: [OP_NAME] -> [Token] -> GenParser Char st COMPONENTS
compSort is cs = do c <- colonST
(b, t, _) <- opSort
let p = map tokPos (cs++[c]) in
return (if b then Partial_select is t p
else Total_select is t p)
-- ------------------------------------------------------------------------
-- sigItems
-- ------------------------------------------------------------------------
typeItems :: GenParser Char st SIG_ITEMS
typeItems = itemList typeS datatype Datatype_items