You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 22 Next »

Generated Content

This page is automatically generated from the "Automated Detection" sections in the individual guidelines. Do not modify this page directly.

Version number:

v5.0

 

Checker

Guideline

 DCL01-CPP. Do not reuse variable names in subscopes
 DCL02-CPP. Use visually distinct identifiers
 DCL06-CPP. Use meaningful symbolic constants to represent literal values in program logic
 DCL13-CPP. Declare function parameters that are pointers to values not changed by the function as const
 DCL30-CPP. Declare objects with appropriate storage durations
 EXP06-CPP. Operands to the sizeof operator should not contain side effects
 EXP09-CPP. Use sizeof to determine the size of a type or variable
 EXP12-CPP. Do not ignore values returned by functions or methods
 EXP15-CPP. Beware of integer promotion when performing bitwise operations on chars or shorts
 EXP19-CPP. Do not perform assignments in conditional expressions
 EXP30-CPP. Do not depend on order of evaluation between sequence points
 EXP32-CPP. Do not access a volatile object through a non-volatile reference
 EXP35-CPP. Do not cast away a const qualification
 EXP36-CPP. Do not convert pointers into more strictly aligned pointer types
 EXP37-CPP. Call variadic functions with the arguments intended by the API
 INT07-CPP. Use only explicitly signed or unsigned char type for numeric values
 INT09-CPP. Ensure enumeration constants map to unique values
 INT12-CPP. Do not make assumptions about the type of a plain int bit-field when used in an expression
 INT13-CPP. Use bitwise operators only on unsigned operands
 INT30-CPP. Ensure that unsigned integer operations do not wrap
 INT31-CPP. Ensure that integer conversions do not result in lost or misinterpreted data
 INT33-CPP. Ensure that division and modulo operations do not result in divide-by-zero errors
 INT34-CPP. Do not shift a negative number of bits or more bits than exist in the operand
 FLP30-CPP. Do not use floating point variables as loop counters
 FLP34-CPP. Ensure that floating point conversions are within range of the new type
 ARR01-CPP. Do not apply the sizeof operator to a pointer when taking the size of an array
 ARR02-CPP. Explicitly specify array bounds, even if implicitly defined by an initializer
 ARR30-CPP. Guarantee that array and vector indices are within the valid range
 STR04-CPP. Use plain char for characters in the basic character set
 STR34-CPP. Cast characters to unsigned types before converting to larger integer sizes
 STR36-CPP. Do not specify the bound of a character array initialized with a string literal
 STR37-CPP. Arguments to character handling functions must be representable as an unsigned char
 MEM02-CPP. Immediately cast the result of a memory allocation function call into a pointer to the allocated type
 FIO07-CPP. Prefer fseek() to rewind()
 FIO12-CPP. Prefer setvbuf() to setbuf()
 FIO30-CPP. Exclude user input from format strings
 FIO32-CPP. Do not perform operations on devices that are only appropriate for files
 FIO37-CPP. Do not assume character data has been read
 FIO38-CPP. Do not use a copy of a FILE object for input and output
 FIO39-CPP. Do not alternately input and output from a stream without an intervening flush or positioning call
 FIO44-CPP. Only use values for fsetpos() that are returned from fgetpos()
 MSC05-CPP. Do not manipulate time_t typed values directly
 MSC18-CPP. Finish every set of statements associated with a case label with a break statement
 MSC30-CPP. Do not use the rand() function for generating pseudorandom numbers
  • No labels