Logic_COL.hs revision 4c7f058cdd19ce67b2b5d4b7f69703d0f8a21e38
faf8ae9e57aecf780f77f114de886af4c1a0f0ccChristian Maeder{- |
faf8ae9e57aecf780f77f114de886af4c1a0f0ccChristian MaederModule : $Header$
faf8ae9e57aecf780f77f114de886af4c1a0f0ccChristian MaederDescription : COL instance of class Logic
faf8ae9e57aecf780f77f114de886af4c1a0f0ccChristian MaederCopyright : (c) Till Mossakowski, Uni Bremen 2002-2004
faf8ae9e57aecf780f77f114de886af4c1a0f0ccChristian MaederLicense : similar to LGPL, see HetCATS/LICENSE.txt or LIZENZ.txt
aa1c971871ba8f793a9e2e62189369cbfbbe0054Christian Maeder
9db48b4604636bfdf03e60890fc094b7bec775dcChristian MaederMaintainer : till@informatik.uni-bremen.de
9db48b4604636bfdf03e60890fc094b7bec775dcChristian MaederStability : provisional
9db48b4604636bfdf03e60890fc094b7bec775dcChristian MaederPortability : non-portable (via Logic)
faf8ae9e57aecf780f77f114de886af4c1a0f0ccChristian Maeder
COL instance of class Logic
-}
module COL.Logic_COL where
import COL.AS_COL
import COL.COLSign
import COL.ATC_COL()
import COL.Parse_AS()
import COL.StatAna
import COL.Print_AS()
import CASL.Sign
import CASL.StaticAna
import CASL.MixfixParser
import CASL.Morphism
import CASL.SymbolMapAnalysis
import CASL.AS_Basic_CASL
import CASL.Parse_AS_Basic
import CASL.MapSentence
import CASL.SymbolParser
import CASL.Logic_CASL ()
import Logic.Logic
data COL = COL deriving Show
instance Language COL where
description _ =
"COLCASL extends CASL by constructors and observers"
type C_BASIC_SPEC = BASIC_SPEC () COL_SIG_ITEM ()
type CSign = Sign () COLSign
type COLMor = Morphism () COLSign ()
type COLFORMULA = FORMULA ()
instance Syntax COL C_BASIC_SPEC
SYMB_ITEMS SYMB_MAP_ITEMS
where
parse_basic_spec COL = Just $ basicSpec col_reserved_words
parse_symb_items COL = Just $ symbItems col_reserved_words
parse_symb_map_items COL = Just $ symbMapItems col_reserved_words
instance Sentences COL COLFORMULA CSign COLMor Symbol where
map_sen COL m = return . mapSen (\ _ -> id) m
parse_sentence COL = Nothing
sym_of COL = symOf
symmap_of COL = morphismToSymbMap
sym_name COL = symName
instance StaticAnalysis COL C_BASIC_SPEC COLFORMULA
SYMB_ITEMS SYMB_MAP_ITEMS
CSign
COLMor
Symbol RawSymbol where
basic_analysis COL = Just $ basicAnalysis (const return)
(const return) ana_COL_SIG_ITEM
emptyMix
stat_symb_map_items COL = statSymbMapItems
stat_symb_items COL = statSymbItems
ensures_amalgamability COL _ =
fail "COL: ensures_amalgamability nyi" -- ???
sign_to_basic_spec COL _sigma _sens = Basic_spec [] -- ???
symbol_to_raw COL = symbolToRaw
id_to_raw COL = idToRaw
matches COL = CASL.Morphism.matches
empty_signature COL = emptySign emptyCOLSign
signature_union COL sigma1 sigma2 =
return $ addSig addCOLSign sigma1 sigma2
morphism_union COL = morphismUnion (const id) addCOLSign
final_union COL = finalUnion addCOLSign
inclusion COL = sigInclusion () isSubCOLSign diffCOLSign
cogenerated_sign COL = cogeneratedSign ()
generated_sign COL = generatedSign ()
induced_from_morphism COL = inducedFromMorphism ()
induced_from_to_morphism COL =
inducedFromToMorphism () isSubCOLSign diffCOLSign
instance Logic COL ()
C_BASIC_SPEC COLFORMULA SYMB_ITEMS SYMB_MAP_ITEMS
CSign
COLMor
Symbol RawSymbol () where
empty_proof_tree _ = ()