1 /******* BEGIN LICENSE BLOCK ******* 2 * Version: MPL 1.1/GPL 2.0/LGPL 2.1 3 * 4 * The contents of this file are subject to the Mozilla Public License Version 5 * 1.1 (the "License"); you may not use this file except in compliance with 6 * the License. You may obtain a copy of the License at 7 * http://www.mozilla.org/MPL/ 8 * 9 * Software distributed under the License is distributed on an "AS IS" basis, 10 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 11 * for the specific language governing rights and limitations under the 12 * License. 13 * 14 * The Initial Developers of the Original Code is Mozilla Foundation. 15 * Portions created by the Initial Developers 16 * are Copyright (C) 2011 the Initial Developers. All Rights Reserved. 17 * 18 * Contributor(s): 19 * 20 * Alternatively, the contents of this file may be used under the terms of 21 * either the GNU General Public License Version 2 or later (the "GPL"), or 22 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), 23 * in which case the provisions of the GPL or the LGPL are applicable instead 24 * of those above. If you wish to allow use of your version of this file only 25 * under the terms of either the GPL or the LGPL, and not to allow others to 26 * use your version of this file under the terms of the MPL, indicate your 27 * decision by deleting the provisions above and replace them with the notice 28 * and other provisions required by the GPL or the LGPL. If you do not delete 29 * the provisions above, a recipient may use your version of this file under 30 * the terms of any one of the MPL, the GPL or the LGPL. 31 * 32 ******* END LICENSE BLOCK *******/ 33 34 #ifndef alloc_hooks_h__ 35 #define alloc_hooks_h__ 36 37 /** 38 * This file is force-included in hunspell code. Its purpose is to add memory 39 * reporting to hunspell without modifying its code, in order to ease future 40 * upgrades. 41 * 42 * Currently, the memory allocated using operator new/new[] is not being 43 * tracked, but that's OK, since almost all of the memory used by Hunspell is 44 * allocated using C memory allocation functions. 45 */ 46 47 #include "mozHunspellAllocator.h" 48 49 // Ensure that malloc is imported before we set our malloc-counting hooks below. 50 // Otherwise, if malloc is imported afterwards, its source will be trampled 51 // over by the "#define"s. 52 #include "mozmemory.h" 53 54 #define malloc(size) HunspellAllocator::CountingMalloc(size) 55 #define calloc(count, size) HunspellAllocator::CountingCalloc(count, size) 56 #define free(ptr) HunspellAllocator::CountingFree(ptr) 57 #define realloc(ptr, size) HunspellAllocator::CountingRealloc(ptr, size) 58 59 #endif 60