| Authors: | Staf Verhaegen Sebastian Rittau Stefan Rieken Matt Parsons Adam Chodorowski Fabio Alemagna Matthias Rustler | 
|---|---|
| Copyright: | Copyright © 1995-2006, The AROS Development Team | 
| Version: | $Revision$ | 
| Date: | $Date$ | 
| Status: | Unfinished; integration started (looong way left to go). | 
| ToDo: | Integrate the various parts. Update and revise. Complete... | 
Warning
This document is not finished! It is highly likely that many parts are out-of-date, contain incorrect information, or are simply missing altogether. If you want to help rectify this, please contact us.
Contents
Everyone talks about Resource Tracking (RT) but what is it anyway? RT means three things:
The current implementation in AROS can do all three the things mentioned in the Introduction, but to enable it, you must make some modifications to your code. The only disadvantage of the current implementation is that the resources won't be freed if the program crashes.
Add the following lines to your code. It should be the first thing seen by the compiler:
#define ENABLE_RT 1
If you replace the 1 by 0, then RT will be silently disabled.
Add #include <aros/rt.h> after the last include from proto/
Add RT_Init(); as the first command in main().
Call RT_Exit() before you terminate your program.
Recompile.
The advantages are that you will get errors if you try to access resources which you didn't allocate and that you will get a list of resources which you didn't free at the end of your program. All messages will contain the position in the code where the error happened (if available) and the position in the code where the resource was allocated (this is the reason why RT has to be compiled in. It could be built into the OS, too, but it would be hard to gather the information where an error occurred).
A good example about how to use RT and what it can do can be found in AROS/workbench/demos/rtdemo.c.
The following resources are tracked: