The macros.h
file defines several commonly used macros in the SWMM5 project to simplify and optimize code. These macros are used for error checking, memory management, mathematical operations, and function calls. Here's a breakdown of each section:
Key Macros:
Memory Management:
-
MEMCHECK(x)
:- Checks whether a pointer
x
isNULL
. Ifx
isNULL
, it returns101
, otherwise0
. This is useful for checking if memory allocation was successful.
- Checks whether a pointer
-
FREE(x)
:- Frees a pointer
x
if it is notNULL
, and sets it toNULL
afterward. This is a safe way to deallocate memory.
- Frees a pointer
Mathematical Operations:
-
ABS(x)
:- Computes the absolute value of
x
. Ifx
is negative, it returns-x
; otherwise, it returnsx
.
- Computes the absolute value of
-
MIN(x, y)
:- Returns the minimum of
x
andy
.
- Returns the minimum of
-
MAX(x, y)
:- Returns the maximum of
x
andy
.
- Returns the maximum of
-
MOD(x, y)
:- Computes the modulus of
x
byy
(i.e.,x % y
).
- Computes the modulus of
-
LOG10(x)
:- Computes the base-10 logarithm of
x
. It checks ifx
is greater than0.0
before applyinglog10()
, otherwise, it returnsx
unchanged. This ensures that the logarithm is only calculated for positive values.
- Computes the base-10 logarithm of
-
SQR(x)
:- Computes the square of
x
(i.e.,x * x
).
- Computes the square of
-
SGN(x)
:- Returns the sign of
x
:-1
for negativex
,1
for positivex
, and0
forx
equal to0
.
- Returns the sign of
-
SIGN(x, y)
:- Returns the absolute value of
x
ify
is non-negative, or the negative absolute value ofx
ify
is negative. This macro is useful for computing values that depend on the sign of a second variable.
- Returns the absolute value of
-
UCHAR(x)
:- Converts a lowercase character
x
to uppercase if it's a letter betweena
andz
. Ifx
is not a lowercase letter, it returnsx
unchanged.
- Converts a lowercase character
-
ARRAY_LENGTH(x)
:- Computes the length of an array
x
by dividing the total size of the array by the size of its first element. This is useful for determining the number of elements in a statically allocated array.
- Computes the length of an array
Error Checking:
CALL(x)
:- Executes the function or expression
x
, but only ifErrorCode
is not positive (i.e.,ErrorCode
is0
or a negative value). IfErrorCode
is positive, it prevents the execution ofx
. This is useful for error handling, ensuring that subsequent operations are only performed if no errors have occurred.
- Executes the function or expression
Summary:
The macros.h
file defines a set of utility macros for handling memory, mathematical operations, and error checking. These macros help improve code readability, reduce redundancy, and ensure safe memory management and error handling throughout the SWMM5 project.