safeDelete.h 4.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. //-----------------------------------------------------------------------------
  2. // Copyright (c) 2012 GarageGames, LLC
  3. //
  4. // Permission is hereby granted, free of charge, to any person obtaining a copy
  5. // of this software and associated documentation files (the "Software"), to
  6. // deal in the Software without restriction, including without limitation the
  7. // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
  8. // sell copies of the Software, and to permit persons to whom the Software is
  9. // furnished to do so, subject to the following conditions:
  10. //
  11. // The above copyright notice and this permission notice shall be included in
  12. // all copies or substantial portions of the Software.
  13. //
  14. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  20. // IN THE SOFTWARE.
  21. //-----------------------------------------------------------------------------
  22. #ifndef _TORQUE_SAFEDELETE_H_
  23. #define _TORQUE_SAFEDELETE_H_
  24. /// @addtogroup utility_macros Utility Macros
  25. // @{
  26. #undef SAFE_DELETE
  27. //-----------------------------------------------------------------------------
  28. /// @brief Safely delete an object and set the pointer to NULL
  29. ///
  30. /// @param a Object to delete
  31. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  32. //-----------------------------------------------------------------------------
  33. #define SAFE_DELETE(a) {delete (a); (a) = NULL; }
  34. #undef SAFE_DELETE_ARRAY
  35. //-----------------------------------------------------------------------------
  36. /// @brief Safely delete an array and set the pointer to NULL
  37. ///
  38. /// @param a Array to delete
  39. /// @see #SAFE_DELETE(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  40. //-----------------------------------------------------------------------------
  41. #define SAFE_DELETE_ARRAY(a) { delete [] (a); (a) = NULL; }
  42. #undef SAFE_DELETE_OBJECT
  43. //-----------------------------------------------------------------------------
  44. /// @brief Safely delete a SimObject and set the pointer to NULL
  45. ///
  46. /// @param a Object to delete
  47. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  48. //-----------------------------------------------------------------------------
  49. #define SAFE_DELETE_OBJECT(a) { if( (a) != NULL ) (a)->deleteObject(); (a) = NULL; }
  50. #undef SAFE_FREE
  51. //-----------------------------------------------------------------------------
  52. /// @brief Safely free memory and set the pointer to NULL
  53. ///
  54. /// @param a Pointer to memory to free
  55. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_DELETE(), #SAFE_FREE_REFERENCE()
  56. //-----------------------------------------------------------------------------
  57. #define SAFE_FREE(a) { if( (a) != NULL ) dFree ((void *)a); (a) = NULL; }
  58. // CodeReview: Is the NULL conditional needed? [5/14/2007 Pat]
  59. #undef SAFE_FREE_REFERENCE
  60. //-----------------------------------------------------------------------------
  61. /// @brief Safely free a reference to a Message and set the pointer to NULL
  62. ///
  63. /// @param a Pointer to message to free
  64. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_DELETE()
  65. //-----------------------------------------------------------------------------
  66. #define SAFE_FREE_REFERENCE(a) { if((a) != NULL) (a)->freeReference(); (a) = NULL; }
  67. #undef SAFE_DELETE_MESSAGE
  68. //-----------------------------------------------------------------------------
  69. /// @brief Synonym for SAFE_FREE_REFERENCE()
  70. ///
  71. /// @param a Object to delete
  72. /// @see #SAFE_DELETE(), #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  73. //-----------------------------------------------------------------------------
  74. #define SAFE_DELETE_MESSAGE SAFE_FREE_REFERENCE
  75. // @}
  76. #endif // _TORQUE_SAFEDELETE_H_