|
NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.64
">7.6. PragmasGHC supports several pragmas, or instructions to the compiler placed in the source code. Pragmas don't normally affect the meaning of the program, but they might affect the efficiency of the generated code. Pragmas all take the form {-# word ... #-} where word indicates the type of pragma, and is followed optionally by information specific to that type of pragma. Case is ignored in word. The various values for word that GHC understands are described in the following sections; any pragma encountered with an unrecognised word is (silently) ignored. 7.6.1. INLINE pragmaGHC (with -O, as always) tries to inline (or “unfold”) functions/values that are “small enough,” thus avoiding the call overhead and possibly exposing other more-wonderful optimisations. You will probably see these unfoldings (in Core syntax) in your interface files. Normally, if GHC decides a function is “too expensive” to inline, it will not do so, nor will it export that unfolding for other modules to use. The sledgehammer you can bring to bear is the INLINE pragma, used thusly:
The major effect of an INLINE pragma is to declare a function's “cost” to be very low. The normal unfolding machinery will then be very keen to inline it. An INLINE pragma for a function can be put anywhere its type signature could be put. INLINE pragmas are a particularly good idea for the then/return (or bind/unit) functions in a monad. For example, in GHC's own UniqueSupply monad code, we have:
7.6.2. NOINLINE pragmaThe NOINLINE pragma does exactly what you'd expect: it stops the named function from being inlined by the compiler. You shouldn't ever need to do this, unless you're very cautious about code size. NOTINLINE is a synonym for NOINLINE (NOTINLINE is specified by Haskell 98 as the standard way to disable inlining, so it should be used if you want your code to be portable). 7.6.3. SPECIALIZE pragma(UK spelling also accepted.) For key overloaded functions, you can create extra versions (NB: more code space) specialised to particular types. Thus, if you have an overloaded function:
If it is heavily used on lists with Widget keys, you could specialise it as follows:
To get very fancy, you can also specify a named function to use for the specialised value, as in:
where blah is an implementation of hammerdLookup written specialy for Widget lookups. It's Your Responsibility to make sure that blah really behaves as a specialised version of hammeredLookup!!! Note we use the RULE pragma here to indicate that hammeredLookup applied at a certain type should be replaced by blah. See Section 7.6.6 for more information on RULES. An example in which using RULES for specialisation will Win Big:
A SPECIALIZE pragma for a function can be put anywhere its type signature could be put. 7.6.4. SPECIALIZE instance pragmaSame idea, except for instance declarations. For example:
Compatible with HBC, by the way, except perhaps in the placement of the pragma. 7.6.5. LINE pragma
This pragma is similar to C's #line pragma, and is mainly for use in automatically generated Haskell code. It lets you specify the line number and filename of the original code; for example
if you'd generated the current file from something called Foo.vhs and this line corresponds to line 42 in the original. GHC will adjust its error messages to refer to the line/file named in the LINE pragma. 7.6.6. RULES pragmaThe RULES pragma lets you specify rewrite rules. It is described in Section 7.7. 7.6.7. DEPRECATED pragmaThe DEPRECATED pragma lets you specify that a particular function, class, or type, is deprecated. There are two forms.
You can suppress the warnings with the flag -fno-warn-deprecations. |