| Maintainer | mainland@cs.drexel.edu |
|---|---|
| Safe Haskell | None |
Language.C.Quote
Description
There are five modules that provide quasiquoters, each for a different C
variant. C parses C99, GCC parses C99
plus GNU extensions, CUDA parses C99 plus GNU and CUDA
extensions, OpenCL parses C99 plus GNU and OpenCL
extensions and, ObjC parses C99 plus a subset of Objective-C
For version of GHC prior to 7.4, the quasiquoters generate Template Haskell expressions that use data constructors that must be in scope where the quasiquoted expression occurs. You will be safe if you add the following imports to any module using the quasiquoters provided by this package:
import qualified Data.Loc import qualified Data.Symbol import qualified Language.C.Syntax
These modules may also be imported unqualified, of course. The quasiquoters also use some constructors defined in the standard Prelude, so if it is not imported by default, it must be imported qualified. On GHC 7.4 and above, you can use the quasiquoters without worrying about what names are in scope.
The following quasiquoters are defined:
cdecl- Declaration, of type
.InitGroup cedecl- External declarations (top-level declarations in a C file,
including function definitions and declarations), of type
.Definition cenum- Component of an
enumdefinition, of type.CEnum cexp- Expression, of type
.Exp cstm- Statement, of type
.Stm citem- Block item, of type
. A block item is either a declaration or a statement.BlockItem cfun- Function definition, of type
.Func cinit- Initializer, of type
.Initializer cparam- Declaration of a function parameter, of type
.Param csdecl- Declaration of a struct member, of type
.FieldGroup cty- A C type, of type
.Type cunit- A compilation unit, of type
[.Definition]
Antiquotations allow splicing in subterms during quotation. These subterms
may bound to a Haskell variable or may be the value of a Haskell
expression. Antiquotations appear in a quasiquotation in the form
$ANTI:VARID, where ANTI is a valid antiquote specifier and VARID is a
Haskell variable identifier, or in the form $ANTI:(EXP), where EXP is a
Haskell expressions (the parentheses must appear in this case). The Haskell
expression may itself contain a quasiquote, but in that case the final |]
must be escaped as \|\]. Additionally, $VARID is shorthand for
$exp:VARID and $(EXP) is shorthand for $exp:(EXP), i.e., exp is the
default antiquote specifier.
It is often useful to use typedefs that aren't in scope when quasiquoting,
e.g., [cdecl|uint32_t foo;|]. The quasiquoter will complain when it sees
this because it thinks uint32_t is an identifier. The solution is to use
the typename keyword, borrowed from C++, to tell the parser that the
identifier is actually a type name. That is, we can write [cdecl|typename
uint32_t foo;|] to get the desired behavior.
Valid antiquote specifiers are:
id- A C identifier. The argument must be an instance of
.ToIdent const- A constant. The argument must be an instance of
.ToConst int- An
integerconstant. The argument must be an instance of.Integral uint- An
unsigned integerconstant. The argument must be an instance of.Integral lint- A
long integerconstant. The argument must be an instance of.Integral ulint- An
unsigned long integerconstant. The argument must be an instance of.Integral llint- A
long long integerconstant. The argument must be an instance of.Integral ullint- An
unsigned long long integerconstant. The argument must be an instance of.Integral float- A
floatconstant. The argument must be an instance of.Fractional double- A
doubleconstant. The argument must be an instance of.Fractional long double- A
long doubleconstant. The argument must be an instance of.Fractional char- A
charconstant. The argument must have type.Char string- A string (
char*) constant. The argument must have type.String exp- A C expression. The argument must be an instance of
.ToExp func- A function definition. The argument must have type
.Func args- A list of function arguments. The argument must have type
[.Exp] decl- A declaration. The argument must have type
.InitGroup decls- A list of declarations. The argument must have type
[.InitGroup] sdecl- A struct member declaration. The argument must have type
.FieldGroup sdecls- A list of struct member declarations. The argument must have type
[.FieldGroup] enum- An enum member. The argument must have type
.CEnum enums- An list of enum members. The argument must have type
[.CEnum] esc- An arbitrary top-level C definition, such as an
#includeor a#define. The argument must have type.String edecl- An external definition. The argument must have type
.Definition edecls- An list of external definitions. The argument must have type
[.Definition] item- A statement block item. The argument must have type
.BlockItem items- A list of statement block item. The argument must have type
[.BlockItem] stm- A statement. The argument must have type
.Stm stms- A list statements. The argument must have type
[.Stm] ty- A C type. The argument must have type
.Type spec- A declaration specifier. The argument must have type
.DeclSpec param- A function parameter. The argument must have type
.Param params- A list of function parameters. The argument must have type
[.Param] pragma- A pragma statement. The argument must have type
.String init- An initializer. The argument must have type
.Initializer inits- A list of initializers. The argument must have type
[.Initializer]