Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
3.7 KiB

  1. #ifndef _NEW_HPP_
  2. #define _NEW_HPP_
  3. // Ruler
  4. // 1 2 3 4 5 6 7 8
  5. //345678901234567890123456789012345678901234567890123456789012345678901234567890
  6. /********************************************************************/
  7. /* */
  8. /* The standard layout. */
  9. /* */
  10. /* The standard layout for 'hpp' files for this code is as */
  11. /* follows: */
  12. /* */
  13. /* 1. Include files. */
  14. /* 2. Constants exported from the class. */
  15. /* 3. Data structures exported from the class. */
  16. /* 4. Forward references to other data structures. */
  17. /* 5. Class specifications (including inline functions). */
  18. /* 6. Additional large inline functions. */
  19. /* */
  20. /* Any portion that is not required is simply omitted. */
  21. /* */
  22. /********************************************************************/
  23. #include "Global.hpp"
  24. /********************************************************************/
  25. /* */
  26. /* The placement new and delete macros. */
  27. /* */
  28. /* The placement new and delete macros allow the constructor */
  29. /* and destructos of a type to be called as needed. */
  30. /* */
  31. /********************************************************************/
  32. #define PLACEMENT_NEW( Address,Type ) new( Address ) Type
  33. #define PLACEMENT_DELETE( Address,Type ) (((Type*) Address) -> ~Type())
  34. #ifndef DISABLE_GLOBAL_NEW
  35. /********************************************************************/
  36. /* */
  37. /* The memory allocation operator. */
  38. /* */
  39. /* The memory allocation operator 'new' is overloaded to */
  40. /* provide a consistent interface. */
  41. /* */
  42. /********************************************************************/
  43. INLINE VOID *operator new( size_t Size )
  44. {
  45. REGISTER VOID *Store = malloc( Size );
  46. if ( Store == NULL )
  47. { Failure( "Out of system memory" ); }
  48. return Store;
  49. }
  50. /********************************************************************/
  51. /* */
  52. /* The memory deallocation operator. */
  53. /* */
  54. /* The memory deallocation operator releases allocated memory. */
  55. /* */
  56. /********************************************************************/
  57. INLINE VOID operator delete( VOID *Store )
  58. { free( Store ); }
  59. #endif
  60. #endif