language-c-0.9.4: Analysis and generation of C code
Copyright(c) 2008 Benedikt Huber
LicenseBSD-style
Maintainerbenedikt.huber@gmail.com
Stabilityalpha
Portabilityghc
Safe HaskellSafe-Inferred
LanguageHaskell2010

Language.C.Analysis.TravMonad

Description

Monad for Traversals of the C AST.

For the traversal, we maintain a symboltable and need MonadError and unique name generation facilities. Furthermore, the user may provide callbacks to handle declarations and definitions.

Synopsis

Name generation monad

class Monad m => MonadName m where Source #

Methods

genName :: m Name Source #

unique name generation

Instances

Instances details
Monad m => MonadName (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

genName :: TravT s m Name Source #

Symbol table monad

class Monad m => MonadSymtab m where Source #

Methods

getDefTable :: m DefTable Source #

return the definition table

withDefTable :: (DefTable -> (a, DefTable)) -> m a Source #

perform an action modifying the definition table

Instances

Instances details
Monad m => MonadSymtab (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Specialized C error-handling monad

class Monad m => MonadCError m where Source #

Methods

throwTravError :: Error e => e -> m a Source #

throw an Error

catchTravError :: m a -> (CError -> m a) -> m a Source #

catch an Error (we could implement dynamically-typed catch here)

recordError :: Error e => e -> m () Source #

remember that an Error occurred (without throwing it)

getErrors :: m [CError] Source #

return the list of recorded errors

Instances

Instances details
Monad m => MonadCError (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

throwTravError :: Error e => e -> TravT s m a Source #

catchTravError :: TravT s m a -> (CError -> TravT s m a) -> TravT s m a Source #

recordError :: Error e => e -> TravT s m () Source #

getErrors :: TravT s m [CError] Source #

AST traversal monad

class (MonadName m, MonadSymtab m, MonadCError m) => MonadTrav m where Source #

Traversal monad

Methods

handleDecl :: DeclEvent -> m () Source #

handling declarations and definitions

Instances

Instances details
Monad m => MonadTrav (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

handleDecl :: DeclEvent -> TravT s m () Source #

Handling declarations

handleTagDecl :: (MonadCError m, MonadSymtab m) => TagFwdDecl -> m () Source #

forward declaration of a tag. Only necessary for name analysis, but otherwise no semantic consequences.

handleTagDef :: MonadTrav m => TagDef -> m () Source #

define the given composite type or enumeration If there is a declaration visible, overwrite it with the definition. Otherwise, enter a new definition in the current namespace. If there is already a definition present, yield an error (redeclaration).

handleObjectDef :: MonadTrav m => Bool -> Ident -> ObjDef -> m () Source #

handle object defintions (maybe tentative)

handleFunDef :: MonadTrav m => Ident -> FunDef -> m () Source #

handle function definitions

handleVarDecl :: MonadTrav m => Bool -> Decl -> m () Source #

handle variable declarations (external object declarations and function prototypes) variable declarations are either function prototypes, or external declarations, and not very interesting on their own. we only put them in the symbol table and call the handle. declarations never override definitions

handleParamDecl :: MonadTrav m => ParamDecl -> m () Source #

handle parameter declaration. The interesting part is that parameters can be abstract (if they are part of a type). If they have a name, we enter the name (usually in function prototype or function scope), checking if there are duplicate definitions. FIXME: I think it would be more transparent to handle parameter declarations in a special way

Symbol table scope modification

Symbol table lookup (delegate)

lookupTypeDef :: (MonadCError m, MonadSymtab m) => Ident -> m Type Source #

lookup a type definition the 'wrong kind of object' is an internal error here, because the parser should distinguish typeDefs and other objects

lookupObject :: (MonadCError m, MonadSymtab m) => Ident -> m (Maybe IdentDecl) Source #

lookup an object, function or enumerator

Symbol table modification

createSUERef :: (MonadCError m, MonadSymtab m) => NodeInfo -> Maybe Ident -> m SUERef Source #

create a reference to a struct/union/enum

This currently depends on the fact the structs are tagged with unique names. We could use the name generation of TravMonad as well, which might be the better choice when dealing with autogenerated code.

Additional error handling facilities

hadHardErrors :: [CError] -> Bool Source #

check wheter non-recoverable errors occurred

throwOnLeft :: (MonadCError m, Error e) => Either e a -> m a Source #

raise an error based on an Either argument

astError :: MonadCError m => NodeInfo -> String -> m a Source #

raise an error caused by a malformed AST

warn :: (Error e, MonadCError m) => e -> m () Source #

Trav - default MonadTrav implementation

type Trav s a = TravT s Identity a Source #

data TravT s m a Source #

simple traversal monad, providing user state and callbacks

Instances

Instances details
MonadTrans (TravT s) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

lift :: Monad m => m a -> TravT s m a #

MonadIO m => MonadIO (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

liftIO :: IO a -> TravT s m a #

Monad f => Applicative (TravT s f) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

pure :: a -> TravT s f a #

(<*>) :: TravT s f (a -> b) -> TravT s f a -> TravT s f b #

liftA2 :: (a -> b -> c) -> TravT s f a -> TravT s f b -> TravT s f c #

(*>) :: TravT s f a -> TravT s f b -> TravT s f b #

(<*) :: TravT s f a -> TravT s f b -> TravT s f a #

Monad f => Functor (TravT s f) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

fmap :: (a -> b) -> TravT s f a -> TravT s f b #

(<$) :: a -> TravT s f b -> TravT s f a #

Monad m => Monad (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

(>>=) :: TravT s m a -> (a -> TravT s m b) -> TravT s m b #

(>>) :: TravT s m a -> TravT s m b -> TravT s m b #

return :: a -> TravT s m a #

Monad m => MonadCError (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

throwTravError :: Error e => e -> TravT s m a Source #

catchTravError :: TravT s m a -> (CError -> TravT s m a) -> TravT s m a Source #

recordError :: Error e => e -> TravT s m () Source #

getErrors :: TravT s m [CError] Source #

Monad m => MonadName (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

genName :: TravT s m Name Source #

Monad m => MonadSymtab (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Monad m => MonadTrav (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

handleDecl :: DeclEvent -> TravT s m () Source #

Monad m => MonadState (TravState m s) (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

get :: TravT s m (TravState m s) #

put :: TravState m s -> TravT s m () #

state :: (TravState m s -> (a, TravState m s)) -> TravT s m a #

runTravT :: forall m s a. Monad m => s -> TravT s m a -> m (Either [CError] (a, TravState m s)) Source #

runTravTWithTravState :: forall s m a. Monad m => TravState m s -> TravT s m a -> m (Either [CError] (a, TravState m s)) Source #

runTrav :: forall s a. s -> Trav s a -> Either [CError] (a, TravState Identity s) Source #

runTrav_ :: Trav () a -> Either [CError] (a, [CError]) Source #

data TravState m s Source #

Instances

Instances details
Monad m => MonadState (TravState m s) (TravT s m) Source # 
Instance details

Defined in Language.C.Analysis.TravMonad

Methods

get :: TravT s m (TravState m s) #

put :: TravState m s -> TravT s m () #

state :: (TravState m s -> (a, TravState m s)) -> TravT s m a #

withExtDeclHandler :: Monad m => TravT s m a -> (DeclEvent -> TravT s m ()) -> TravT s m a Source #

modifyUserState :: (s -> s) -> Trav s () Source #

data TravOptions Source #

Constructors

TravOptions 

Fields

Language options

data CLanguage Source #

The variety of the C language to accept. Note: this is not yet enforced.

Constructors

C89 
C99 
GNU89 
GNU99 

Helpers

mapMaybeM :: Monad m => Maybe a -> (a -> m b) -> m (Maybe b) Source #

maybeM :: Monad m => Maybe a -> (a -> m ()) -> m () Source #

mapSndM :: Monad m => (b -> m c) -> (a, b) -> m (a, c) Source #

concatMapM :: Monad m => (a -> m [b]) -> [a] -> m [b] Source #