Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
When an annotation is conditional, it may require other annotations to specify that to the analyzer.  For example, if a function has a variable that can be either synchronous or asynchronous, the function behaves as follows: In the synchronous case it always eventually succeeds, but in the asynchronous case it reports an error if it can't succeed immediately. When the function is called synchronously, checking the result value provides no value to the code analyzer because it would not have returned.  However, when the function is called asynchronously and the function result is not checked, a serious error could occur. This example illustrates a situation in which you could use the _When_ annotation—described later in this article—to enable checking.
Structural Annotations
To control when and where annotations apply, use the following structural annotations.
| Annotation | Description | 
|---|---|
| _At_(expr, anno-list) | expris an expression that yields an lvalue. The annotations inanno-listare applied to the object that is named byexpr. For each annotation inanno-list,expris interpreted in pre-condition if the annotation is interpreted in pre-condition, and in post-condition if the annotation is interpreted in post-condition. | 
| _At_buffer_(expr, iter, elem-count, anno-list) | expris an expression that yields an lvalue. The annotations inanno-listare applied to the object that is named byexpr. For each annotation inanno-list,expris interpreted in pre-condition if the annotation is interpreted in precondition, and in post-condition if the annotation is interpreted in post-condition.iteris the name of a variable that is scoped to the annotation (inclusive ofanno-list).iterhas an implicit typelong. Identically named variables in any enclosing scope are hidden from evaluation.elem-countis an expression that evaluates to an integer. | 
| _Group_(anno-list) | The annotations in anno-listare all considered to have any qualifier that applies to the group annotation that is applied to each annotation. | 
| _When_(expr, anno-list) | expris an expression that can be converted tobool. When it is non-zero (true), the annotations that are specified inanno-listare considered applicable.By default, for each annotation in anno-list,expris interpreted as using the input values if the annotation is a precondition, and as using the output values if the annotation is a post-condition. To override the default, you can use the_Old_intrinsic when you evaluate a post-condition to indicate that input values should be used. Note:  Different annotations might be enabled as a consequence of using_When_if a mutable value—for example,*pLength—is involved because the evaluated result ofexprin precondition may differ from its evaluated result in post-condition. |