safeDelete.h 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. //-----------------------------------------------------------------------------
  2. // Copyright (c) 2013 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. /// @addtogroup utility_macros Utility Macros
  23. // @{
  24. #undef SAFE_DELETE
  25. //////////////////////////////////////////////////////////////////////////
  26. /// @brief Safely delete an object and set the pointer to NULL
  27. ///
  28. /// @param a Object to delete
  29. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  30. //////////////////////////////////////////////////////////////////////////
  31. #define SAFE_DELETE(a) if( (a) != NULL ) delete (a); (a) = NULL;
  32. #undef SAFE_DELETE_ARRAY
  33. //////////////////////////////////////////////////////////////////////////
  34. /// @brief Safely delete an array and set the pointer to NULL
  35. ///
  36. /// @param a Array to delete
  37. /// @see #SAFE_DELETE(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  38. //////////////////////////////////////////////////////////////////////////
  39. #define SAFE_DELETE_ARRAY(a) if( (a) != NULL ) delete [] (a); (a) = NULL;
  40. #undef SAFE_DELETE_OBJECT
  41. //////////////////////////////////////////////////////////////////////////
  42. /// @brief Safely delete a SimObject and set the pointer to NULL
  43. ///
  44. /// @param a Object to delete
  45. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  46. //////////////////////////////////////////////////////////////////////////
  47. #define SAFE_DELETE_OBJECT(a) if( (a) != NULL ) (a)->deleteObject(); (a) = NULL;
  48. #undef SAFE_FREE
  49. //////////////////////////////////////////////////////////////////////////
  50. /// @brief Safely free memory and set the pointer to NULL
  51. ///
  52. /// @param a Pointer to memory to free
  53. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_DELETE(), #SAFE_FREE_REFERENCE()
  54. //////////////////////////////////////////////////////////////////////////
  55. #define SAFE_FREE(a) if( (a) != NULL ) dFree ((void *)a); (a) = NULL;
  56. #undef SAFE_FREE_REFERENCE
  57. //////////////////////////////////////////////////////////////////////////
  58. /// @brief Safely free a reference to a Message and set the pointer to NULL
  59. ///
  60. /// @param a Pointer to message to free
  61. /// @see #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_DELETE()
  62. //////////////////////////////////////////////////////////////////////////
  63. #define SAFE_FREE_REFERENCE(a) if((a) != NULL) (a)->freeReference(); (a) = NULL;
  64. #undef SAFE_DELETE_MESSAGE
  65. //////////////////////////////////////////////////////////////////////////
  66. /// @brief Synonym for SAFE_FREE_REFERENCE()
  67. ///
  68. /// @param a Object to delete
  69. /// @see #SAFE_DELETE(), #SAFE_DELETE_ARRAY(), #SAFE_DELETE_OBJECT(), #SAFE_FREE(), #SAFE_FREE_REFERENCE()
  70. //////////////////////////////////////////////////////////////////////////
  71. #define SAFE_DELETE_MESSAGE SAFE_FREE_REFERENCE
  72. // @}