[ROOT] / doc / toc / ARCCore / Class / REx
REx = 'TooDeepRecursiveDepthException'
Functionality that helps to guard against infinite recursion.
Usage:
void RecursiveMethod() {
try {
REx.Inc()
.... Some code calling RecursiveMethod again, either directly or indirectly ...
} finally {
REx.Dec()
}
}
Alternatively, you can just do:
REx.Inc() + RecursiveMethod() + REx.Inc()
whenever RecursiveMethod returns a string.
This later approach is useful in expressions, meaning you do not have to build statements in order to use this class. If exceptions should occur in RecursiveMethod however, the recursive counter may 'leak' upwards.
Note how the class uses a recursion counter that is 1) static and 2) common for the whole application.
1) Using a static counter is due to the fact that some methods may be recursive without directly calling itself. For instance methodA could call B, which calls C, which then calls A without knowing about call coming from A (This means that passing a recursion counter would not help because it would get lost on its way.
2) Having a common counter for the whole application is just a pragmatic choice.
One has to be aware of threading of course, that is, the max recursion depth (default = 100) has to take into account other threads, and therefore be set to a somewhat higher value than the one suitable for single-threaded environments.
NOTE: Infinite recursion problems manifest themselves as a StackOverflowException (unless caught by safeguards like this).
Dec | This method should be called from inside a 'finally' block, in order to secure its execution, if not then your static recursion depth counter could slowly increase over time due to exceptions ocurring after call to Inc but before call to Dec. |
Inc | Increases recursive count. |
Generated 2025-10-24 00:46:49.905 UTC