Scl function: Difference between revisions
Jump to navigation
Jump to search
(→Syntax) |
|||
Line 41: | Line 41: | ||
#pragma scl_function(f) | #pragma scl_function(f) | ||
void depend(void); | |||
#pragma scl_function(depend, "DEFINITION", "IMPLICIT", "TEST_GROUP") | |||
</source> | </source> | ||
[[Category: Functions]] | [[Category: Functions]] | ||
[[Category: SCL]] | [[Category: SCL]] |
Revision as of 23:16, 19 March 2009
The scl_function pragma
The scl_function pragma allows the user to capture the function. All interfaces that STRIDE works with must be captured.
When captured for the purpose of interception optional arguments allow specification of how would it be done.
Syntax
#pragma scl_function(function-name [,context, name-mangling, group-id])
Parameters | Type | Description |
function-name | String | Name of the function to define (no quotes) |
context | String | Optional. Context in which the function is going to be intercepted. Possible values are "REFERENCE" - intercept at the function call or "DEFINITION" - intercept at the function definition. |
name-mangling | String | Optional. Type of name mangling to be used when intercepted. Possible values are "EXPLICIT" or "IMPLICIT". |
group-id | String | User defined identifier representing the group to which this function belongs when solving name mangling conflicts. Optional. |
Notes
- Identifier must be declared as a function designator with external linkage.
- A compilation error is reported if an attempt is made to capture a function more than once (with either scl_func or scl_function).
Example
int f(int x);
#pragma scl_function(f)
void depend(void);
#pragma scl_function(depend, "DEFINITION", "IMPLICIT", "TEST_GROUP")