Skip to content
This repository has been archived by the owner on Aug 4, 2022. It is now read-only.

Commit

Permalink
Bug 669116 - Add memory reporter for the spell checker; r=njn,khuey
Browse files Browse the repository at this point in the history
  • Loading branch information
ehsan committed Aug 11, 2011
1 parent 9b1b2b9 commit 7a16c02
Show file tree
Hide file tree
Showing 5 changed files with 153 additions and 1 deletion.
10 changes: 10 additions & 0 deletions configure.in
Original file line number Diff line number Diff line change
Expand Up @@ -9366,6 +9366,16 @@ _EGREP_PATTERN="${_EGREP_PATTERN}dummy_never_defined)"
* is defined before <stdint.h> is included. */
#define __STDC_LIMIT_MACROS

/* Force-include hunspell_alloc_hooks.h for hunspell, so that we don't need to
* modify it directly.
*
* HUNSPELL_STATIC is defined in extensions/spellcheck/hunspell/src/Makefile.in,
* unless --enable-system-hunspell is defined.
*/
#if defined(HUNSPELL_STATIC)
#include "hunspell_alloc_hooks.h"
#endif

#endif /* _MOZILLA_CONFIG_H_ */

EOF
Expand Down
2 changes: 2 additions & 0 deletions extensions/spellcheck/hunspell/src/Makefile.in
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,8 @@ CPPSRCS += affentry.cpp \
suggestmgr.cpp \
$(NULL)

# This variable is referenced in configure.in. Make sure to change that file
# too if you need to change this variable.
DEFINES = -DHUNSPELL_STATIC
endif

Expand Down
108 changes: 108 additions & 0 deletions extensions/spellcheck/hunspell/src/hunspell_alloc_hooks.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,108 @@
/******* BEGIN LICENSE BLOCK *******
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Initial Developers of the Original Code is Mozilla Foundation.
* Portions created by the Initial Developers
* are Copyright (C) 2011 the Initial Developers. All Rights Reserved.
*
* Contributor(s):
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
******* END LICENSE BLOCK *******/

#ifndef alloc_hooks_h__
#define alloc_hooks_h__

/**
* This file is force-included in hunspell code. Its purpose is to add memory
* reporting to hunspell without modifying its code, in order to ease future
* upgrades.
*
* This file is force-included through mozilla-config.h which is generated
* during the configure step.
*
* Currently, the memory allocated using operator new/new[] is not being
* tracked, but that's OK, since almost all of the memory used by Hunspell is
* allocated using C memory allocation functions.
*/

// Prevent the standard macros from being redefined
#define mozilla_mozalloc_macro_wrappers_h

#include "mozilla/mozalloc.h"

extern void HunspellReportMemoryAllocation(void*);
extern void HunspellReportMemoryDeallocation(void*);

inline void* hunspell_malloc(size_t size)
{
void* result = moz_malloc(size);
HunspellReportMemoryAllocation(result);
return result;
}
#define malloc(size) hunspell_malloc(size)

inline void* hunspell_calloc(size_t count, size_t size)
{
void* result = moz_calloc(count, size);
HunspellReportMemoryAllocation(result);
return result;
}
#define calloc(count, size) hunspell_calloc(count, size)

inline void hunspell_free(void* ptr)
{
HunspellReportMemoryDeallocation(ptr);
moz_free(ptr);
}
#define free(ptr) hunspell_free(ptr)

inline void* hunspell_realloc(void* ptr, size_t size)
{
HunspellReportMemoryDeallocation(ptr);
void* result = moz_realloc(ptr, size);
HunspellReportMemoryAllocation(result);
return result;
}
#define realloc(ptr, size) hunspell_realloc(ptr, size)

inline char* hunspell_strdup(const char* str)
{
char* result = moz_strdup(str);
HunspellReportMemoryAllocation(result);
return result;
}
#define strdup(str) hunspell_strdup(str)

#if defined(HAVE_STRNDUP)
inline char* hunspell_strndup(const char* str, size_t size)
{
char* result = moz_strndup(str, size);
HunspellReportMemoryAllocation(result);
return result;
}
#define strndup(str, size) hunspell_strndup(str, size)
#endif

#endif
28 changes: 28 additions & 0 deletions extensions/spellcheck/hunspell/src/mozHunspell.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@
#include "nsUnicharUtils.h"
#include "nsCRT.h"
#include <stdlib.h>
#include "nsIMemoryReporter.h"

static NS_DEFINE_CID(kCharsetConverterManagerCID, NS_ICHARSETCONVERTERMANAGER_CID);
static NS_DEFINE_CID(kUnicharUtilCID, NS_UNICHARUTIL_CID);
Expand All @@ -91,6 +92,28 @@ NS_IMPL_CYCLE_COLLECTION_3(mozHunspell,
mEncoder,
mDecoder)

// Memory reporting stuff
static PRInt64 gHunspellAllocatedSize = 0;

void HunspellReportMemoryAllocation(void* ptr) {
gHunspellAllocatedSize += moz_malloc_usable_size(ptr);
}
void HunspellReportMemoryDeallocation(void* ptr) {
gHunspellAllocatedSize -= moz_malloc_usable_size(ptr);
}
static PRInt64 HunspellGetCurrentAllocatedSize() {
return gHunspellAllocatedSize;
}

NS_MEMORY_REPORTER_IMPLEMENT(Hunspell,
"explicit/spell-check",
KIND_HEAP,
UNITS_BYTES,
HunspellGetCurrentAllocatedSize,
"Memory used by the Hunspell spell checking engine. This number accounts "
"for the memory in use by Hunspell's internal data structures."
);

nsresult
mozHunspell::Init()
{
Expand All @@ -105,13 +128,18 @@ mozHunspell::Init()
obs->AddObserver(this, "profile-do-change", PR_TRUE);
}

mHunspellReporter = new NS_MEMORY_REPORTER_NAME(Hunspell);
NS_RegisterMemoryReporter(mHunspellReporter);

return NS_OK;
}

mozHunspell::~mozHunspell()
{
mPersonalDictionary = nsnull;
delete mHunspell;

NS_UnregisterMemoryReporter(mHunspellReporter);
}

/* attribute wstring dictionary; */
Expand Down
6 changes: 5 additions & 1 deletion extensions/spellcheck/hunspell/src/mozHunspell.h
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,8 @@
{ 0x56c778e4, 0x1bee, 0x45f3, \
{ 0xa6, 0x89, 0x88, 0x66, 0x92, 0xa9, 0x7f, 0xe7 } }

class nsIMemoryReporter;

class mozHunspell : public mozISpellCheckingEngine,
public nsIObserver,
public nsSupportsWeakReference
Expand All @@ -87,7 +89,7 @@ class mozHunspell : public mozISpellCheckingEngine,
NS_DECL_NSIOBSERVER
NS_DECL_CYCLE_COLLECTION_CLASS_AMBIGUOUS(mozHunspell, mozISpellCheckingEngine)

mozHunspell() : mHunspell(nsnull) { }
mozHunspell() : mHunspell(nsnull), mHunspellReporter(nsnull) { }
virtual ~mozHunspell();

nsresult Init();
Expand All @@ -109,6 +111,8 @@ class mozHunspell : public mozISpellCheckingEngine,
nsString mLanguage;

Hunspell *mHunspell;

nsIMemoryReporter* mHunspellReporter;
};

#endif

0 comments on commit 7a16c02

Please sign in to comment.