mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-11 13:59:31 -06:00
52 lines
1.5 KiB
Haskell
52 lines
1.5 KiB
Haskell
----------------------------------------------------------------------
|
|
-- |
|
|
-- Module : Lockfield
|
|
-- Maintainer : AR
|
|
-- Stability : (stable)
|
|
-- Portability : (portable)
|
|
--
|
|
-- > CVS $Date: 2005/11/11 23:24:34 $
|
|
-- > CVS $Author: aarne $
|
|
-- > CVS $Revision: 1.7 $
|
|
--
|
|
-- Creating and using lock fields in reused resource grammars.
|
|
--
|
|
-- AR 8\/2\/2005 detached from 'compile/MkResource'
|
|
-----------------------------------------------------------------------------
|
|
|
|
module GF.Grammar.Lockfield (lockRecType, unlockRecord, lockLabel, isLockLabel) where
|
|
|
|
import qualified Data.ByteString.Char8 as BS
|
|
|
|
import GF.Infra.Ident
|
|
import GF.Grammar.Grammar
|
|
import GF.Grammar.Macros
|
|
import GF.Grammar.PrGrammar
|
|
|
|
import GF.Data.Operations
|
|
|
|
lockRecType :: Ident -> Type -> Err Type
|
|
lockRecType c t@(RecType rs) =
|
|
let lab = lockLabel c in
|
|
return $ if elem lab (map fst rs) || elem (prt c) ["String","Int"]
|
|
then t --- don't add an extra copy of lock field, nor predef cats
|
|
else RecType (rs ++ [(lockLabel c, RecType [])])
|
|
lockRecType c t = plusRecType t $ RecType [(lockLabel c, RecType [])]
|
|
|
|
unlockRecord :: Ident -> Term -> Err Term
|
|
unlockRecord c ft = do
|
|
let (xs,t) = termFormCnc ft
|
|
t' <- plusRecord t $ R [(lockLabel c, (Just (RecType []),R []))]
|
|
return $ mkAbs xs t'
|
|
|
|
lockLabel :: Ident -> Label
|
|
lockLabel c = LIdent $! BS.append lockPrefix (ident2bs c)
|
|
|
|
isLockLabel :: Label -> Bool
|
|
isLockLabel l = case l of
|
|
LIdent c -> BS.isPrefixOf lockPrefix c
|
|
_ -> False
|
|
|
|
|
|
lockPrefix = BS.pack "lock_"
|