]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - win/inspircd_memory_functions.cpp
Add m_serverban, implements extban +b s:server.mask.here, allows +e. This essentially...
[user/henk/code/inspircd.git] / win / inspircd_memory_functions.cpp
index 1f269e000ea3a68b6b13bb6ce839f1ebff4590be..c48c833dc4a83d14afd825fe6e522e2a655e2933 100644 (file)
@@ -28,7 +28,7 @@
 
 void * ::operator new(size_t iSize)
 {
-       void* ptr = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, iSize);               /* zero memory for unix compatibility */
+       void* ptr = HeapAlloc(GetProcessHeap(), 0, iSize);              /* zero memory for unix compatibility */
        /* This is the correct behaviour according to C++ standards for out of memory,
         * not returning null -- Brain
         */
@@ -42,3 +42,16 @@ void ::operator delete(void * ptr)
 {
        HeapFree(GetProcessHeap(), 0, ptr);
 }
+
+void * operator new[] (size_t iSize) {
+       void* ptr = HeapAlloc(GetProcessHeap(), 0, iSize); /* Why were we initializing the memory to zeros here? This is just a waste of cpu! */
+       if (!ptr)
+               throw std::bad_alloc();
+       else
+               return ptr;
+}
+
+void operator delete[] (void* ptr)
+{
+       HeapFree(GetProcessHeap(), 0, ptr);
+}