From 1a7a0a4d4ba9dfd9efb0e806165ffd7ed1df96eb Mon Sep 17 00:00:00 2001 From: "ivan.penkov@gmail.com" Date: Fri, 29 Jun 2012 22:34:04 +0000 Subject: Fixing a mem leak in test code git-svn-id: http://google-breakpad.googlecode.com/svn/trunk@975 4c0a9323-5329-0410-9bdc-e9ce6186880e --- src/processor/stackwalker_unittest_utils.h | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'src/processor/stackwalker_unittest_utils.h') diff --git a/src/processor/stackwalker_unittest_utils.h b/src/processor/stackwalker_unittest_utils.h index 551d3191..5257f816 100644 --- a/src/processor/stackwalker_unittest_utils.h +++ b/src/processor/stackwalker_unittest_utils.h @@ -176,6 +176,29 @@ class MockSymbolSupplier: public google_breakpad::SymbolSupplier { string *symbol_file, char **symbol_data)); MOCK_METHOD1(FreeSymbolData, void(const CodeModule *module)); + + // Copies the passed string contents into a newly allocated buffer. + // The newly allocated buffer will be freed during destruction. + char* CopySymbolDataAndOwnTheCopy(const std::string &info) { + unsigned int buffer_size = info.size() + 1; + char *symbol_data = new char [buffer_size]; + strcpy(symbol_data, info.c_str()); + symbol_data_to_free_.push_back(symbol_data); + return symbol_data; + } + + virtual ~MockSymbolSupplier() { + for (SymbolDataVector::const_iterator i = symbol_data_to_free_.begin(); + i != symbol_data_to_free_.end(); i++) { + char* symbol_data = *i; + delete [] symbol_data; + } + } + + private: + // List of symbol data to be freed upon destruction + typedef std::vector SymbolDataVector; + SymbolDataVector symbol_data_to_free_; }; #endif // PROCESSOR_STACKWALKER_UNITTEST_UTILS_H_ -- cgit v1.2.1