Use typedef names to improve code readability.
The following declaration of the signal function does not make use of typedef names and is consequently hard to read.
| void (*signal(int, void (*)(int)))(int); | 
This compliant solution makes use of typedef names to specify exactly the same type as in the non-compliant coding example.
| typedef void fv(int), typedef void (*pfv)(int); fv *signal(int, fv *); pfv signal(int, pfv); | 
Code readability is important for discovering and eliminating vulnerabilities.
| Rule | Severity | Likelihood | Remediation Cost | Priority | Level | 
|---|---|---|---|---|---|
| DCL05-A | 1 (low) | 1 (unlikely) | 2 (medium) | P2 | L3 | 
Search for vulnerabilities resulting from the violation of this rule on the CERT website.
| \[[ISO/IEC 9899-1999:TC2|AA. C References#ISO/IEC 9899-1999TC2]\] Section 6.7.7, "Type definitions" |