summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--devel/bug-buddy/Makefile3
-rw-r--r--devel/bug-buddy/files/patch-breakpad_freebsd615
-rw-r--r--devel/bug-buddy/files/patch-gnome-breakpad_Makefile.in74
-rw-r--r--devel/bug-buddy/files/patch-google-breakpad_src_client_linux_handler_exception_handler.cc11
4 files changed, 682 insertions, 21 deletions
diff --git a/devel/bug-buddy/Makefile b/devel/bug-buddy/Makefile
index a785499ef..5b45df6ac 100644
--- a/devel/bug-buddy/Makefile
+++ b/devel/bug-buddy/Makefile
@@ -3,11 +3,12 @@
# Whom: Joe Marcus Clarke <marcus@FreeBSD.org>
#
# $FreeBSD$
-# $MCom: ports/devel/bug-buddy/Makefile,v 1.48 2007/08/02 06:42:10 marcus Exp $
+# $MCom: ports/devel/bug-buddy/Makefile,v 1.49 2007/08/04 21:14:15 marcus Exp $
#
PORTNAME= bug-buddy
PORTVERSION= 2.19.0
+PORTREVISION= 1
CATEGORIES= devel gnome
MASTER_SITES= ${MASTER_SITE_GNOME}
MASTER_SITE_SUBDIR= sources/${PORTNAME}/${PORTVERSION:C/^([0-9]+\.[0-9]+).*/\1/}
diff --git a/devel/bug-buddy/files/patch-breakpad_freebsd b/devel/bug-buddy/files/patch-breakpad_freebsd
new file mode 100644
index 000000000..3b4783b18
--- /dev/null
+++ b/devel/bug-buddy/files/patch-breakpad_freebsd
@@ -0,0 +1,615 @@
+diff -rupN client.orig/freebsd/handler/exception_handler.cc client/freebsd/handler/exception_handler.cc
+--- google-breakpad/src/client.orig/freebsd/handler/exception_handler.cc 1969-12-31 19:00:00.000000000 -0500
++++ google-breakpad/src/client/freebsd/handler/exception_handler.cc 2007-08-05 13:54:19.000000000 -0400
+@@ -0,0 +1,265 @@
++// Copyright (c) 2006, Google Inc.
++// All rights reserved.
++//
++// Author: Li Liu
++//
++// Redistribution and use in source and binary forms, with or without
++// modification, are permitted provided that the following conditions are
++// met:
++//
++// * Redistributions of source code must retain the above copyright
++// notice, this list of conditions and the following disclaimer.
++// * Redistributions in binary form must reproduce the above
++// copyright notice, this list of conditions and the following disclaimer
++// in the documentation and/or other materials provided with the
++// distribution.
++// * Neither the name of Google Inc. nor the names of its
++// contributors may be used to endorse or promote products derived from
++// this software without specific prior written permission.
++//
++// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
++// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
++// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
++// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
++// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
++// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
++// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
++// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
++// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
++// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
++// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
++
++#include <signal.h>
++#include <sys/stat.h>
++#include <sys/types.h>
++#include <unistd.h>
++
++#include <cassert>
++#include <cstdlib>
++#include <ctime>
++
++#include "client/linux/handler/exception_handler.h"
++#include "common/linux/guid_creator.h"
++#include "google_breakpad/common/minidump_format.h"
++
++namespace google_breakpad {
++
++// Signals that we are interested.
++int SigTable[] = {
++#if defined(SIGSEGV)
++ SIGSEGV,
++#endif
++#ifdef SIGABRT
++ SIGABRT,
++#endif
++#ifdef SIGFPE
++ SIGFPE,
++#endif
++#ifdef SIGILL
++ SIGILL,
++#endif
++#ifdef SIGBUS
++ SIGBUS,
++#endif
++};
++
++std::vector<ExceptionHandler*> *ExceptionHandler::handler_stack_ = NULL;
++int ExceptionHandler::handler_stack_index_ = 0;
++pthread_mutex_t ExceptionHandler::handler_stack_mutex_ =
++PTHREAD_MUTEX_INITIALIZER;
++
++ExceptionHandler::ExceptionHandler(const string &dump_path,
++ FilterCallback filter,
++ MinidumpCallback callback,
++ void *callback_context,
++ bool install_handler)
++ : filter_(filter),
++ callback_(callback),
++ callback_context_(callback_context),
++ dump_path_(),
++ installed_handler_(install_handler) {
++ set_dump_path(dump_path);
++
++ if (install_handler) {
++ SetupHandler();
++ pthread_mutex_lock(&handler_stack_mutex_);
++ if (handler_stack_ == NULL)
++ handler_stack_ = new std::vector<ExceptionHandler *>;
++ handler_stack_->push_back(this);
++ pthread_mutex_unlock(&handler_stack_mutex_);
++ }
++}
++
++ExceptionHandler::~ExceptionHandler() {
++ TeardownAllHandler();
++ pthread_mutex_lock(&handler_stack_mutex_);
++ if (handler_stack_->back() == this) {
++ handler_stack_->pop_back();
++ } else {
++ fprintf(stderr, "warning: removing Breakpad handler out of order\n");
++ for (std::vector<ExceptionHandler *>::iterator iterator =
++ handler_stack_->begin();
++ iterator != handler_stack_->end();
++ ++iterator) {
++ if (*iterator == this) {
++ handler_stack_->erase(iterator);
++ }
++ }
++ }
++
++ if (handler_stack_->empty()) {
++ // When destroying the last ExceptionHandler that installed a handler,
++ // clean up the handler stack.
++ delete handler_stack_;
++ handler_stack_ = NULL;
++ }
++ pthread_mutex_unlock(&handler_stack_mutex_);
++}
++
++bool ExceptionHandler::WriteMinidump() {
++ return InternalWriteMinidump(0, 0, NULL);
++}
++
++// static
++bool ExceptionHandler::WriteMinidump(const string &dump_path,
++ MinidumpCallback callback,
++ void *callback_context) {
++ ExceptionHandler handler(dump_path, NULL, callback,
++ callback_context, false);
++ return handler.InternalWriteMinidump(0, 0, NULL);
++}
++
++void ExceptionHandler::SetupHandler() {
++ // Signal on a different stack to avoid using the stack
++ // of the crashing thread.
++ struct sigaltstack sig_stack;
++ sig_stack.ss_sp = (char *) malloc(MINSIGSTKSZ);
++ if (sig_stack.ss_sp == NULL)
++ return;
++ sig_stack.ss_size = MINSIGSTKSZ;
++ sig_stack.ss_flags = 0;
++
++ if (sigaltstack(&sig_stack, NULL) < 0)
++ return;
++ for (size_t i = 0; i < sizeof(SigTable) / sizeof(SigTable[0]); ++i)
++ SetupHandler(SigTable[i]);
++}
++
++void ExceptionHandler::SetupHandler(int signo) {
++ struct sigaction act, old_act;
++ act.sa_handler = HandleException;
++ act.sa_flags = SA_ONSTACK;
++ if (sigaction(signo, &act, &old_act) < 0)
++ return;
++ old_handlers_[signo] = old_act.sa_handler;
++}
++
++void ExceptionHandler::TeardownHandler(int signo) {
++ if (old_handlers_.find(signo) != old_handlers_.end()) {
++ struct sigaction act;
++ act.sa_handler = old_handlers_[signo];
++ act.sa_flags = 0;
++ sigaction(signo, &act, 0);
++ }
++}
++
++void ExceptionHandler::TeardownAllHandler() {
++ for (size_t i = 0; i < sizeof(SigTable) / sizeof(SigTable[0]); ++i) {
++ TeardownHandler(SigTable[i]);
++ }
++}
++
++// static
++void ExceptionHandler::HandleException(int signo) {
++ // In Linux, the context information about the signal is put on the stack of
++ // the signal handler frame as value parameter. For some reasons, the
++ // prototype of the handler doesn't declare this information as parameter, we
++ // will do it by hand. It is the second parameter above the signal number.
++ // However, if we are being called by another signal handler passing the
++ // signal up the chain, then we may not have this random extra parameter,
++ // so we may have to walk the stack to find it. We do the actual work
++ // on another thread, where it's a little safer, but we want the ebp
++ // from this frame to find it.
++ uintptr_t current_ebp = 0;
++ asm volatile ("movl %%ebp, %0"
++ :"=m"(current_ebp));
++
++ pthread_mutex_lock(&handler_stack_mutex_);
++ ExceptionHandler *current_handler =
++ handler_stack_->at(handler_stack_->size() - ++handler_stack_index_);
++ pthread_mutex_unlock(&handler_stack_mutex_);
++
++ // Restore original handler.
++ current_handler->TeardownHandler(signo);
++
++ struct sigcontext *sig_ctx = NULL;
++ if (current_handler->InternalWriteMinidump(signo, current_ebp, &sig_ctx)) {
++ // Fully handled this exception, safe to exit.
++ exit(EXIT_FAILURE);
++ } else {
++ // Exception not fully handled, will call the next handler in stack to
++ // process it.
++ typedef void (*SignalHandler)(int signo, struct sigcontext);
++ SignalHandler old_handler =
++ reinterpret_cast<SignalHandler>(current_handler->old_handlers_[signo]);
++ if (old_handler != NULL && sig_ctx != NULL)
++ old_handler(signo, *sig_ctx);
++ }
++
++ pthread_mutex_lock(&handler_stack_mutex_);
++ current_handler->SetupHandler(signo);
++ --handler_stack_index_;
++ // All the handlers in stack have been invoked to handle the exception,
++ // normally the process should be terminated and should not reach here.
++ // In case we got here, ask the OS to handle it to avoid endless loop,
++ // normally the OS will generate a core and termiate the process. This
++ // may be desired to debug the program.
++ if (handler_stack_index_ == 0)
++ signal(signo, SIG_DFL);
++ pthread_mutex_unlock(&handler_stack_mutex_);
++}
++
++bool ExceptionHandler::InternalWriteMinidump(int signo,
++ uintptr_t sighandler_ebp,
++ struct sigcontext **sig_ctx) {
++ if (filter_ && !filter_(callback_context_))
++ return false;
++
++ GUID guid;
++ bool success = false;;
++ char guid_str[kGUIDStringLength + 1];
++ if (CreateGUID(&guid) && GUIDToString(&guid, guid_str, sizeof(guid_str))) {
++ char minidump_path[PATH_MAX];
++ snprintf(minidump_path, sizeof(minidump_path), "%s/%s.dmp",
++ dump_path_c_,
++ guid_str);
++
++ // Block all the signals we want to process when writting minidump.
++ // We don't want it to be interrupted.
++ sigset_t sig_blocked, sig_old;
++ bool blocked = true;
++ sigfillset(&sig_blocked);
++ for (size_t i = 0; i < sizeof(SigTable) / sizeof(SigTable[0]); ++i)
++ sigdelset(&sig_blocked, SigTable[i]);
++ if (sigprocmask(SIG_BLOCK, &sig_blocked, &sig_old) != 0) {
++ blocked = false;
++ fprintf(stderr, "google_breakpad::ExceptionHandler::HandleException: "
++ "failed to block signals.\n");
++ }
++
++ success = minidump_generator_.WriteMinidumpToFile(
++ minidump_path, signo, sighandler_ebp, sig_ctx);
++
++ // Unblock the signals.
++ if (blocked) {
++ sigprocmask(SIG_SETMASK, &sig_old, &sig_old);
++ }
++
++ if (callback_)
++ success = callback_(dump_path_c_, guid_str,
++ callback_context_, success);
++ }
++ return success;
++}
++
++} // namespace google_breakpad
+diff -rupN client.orig/freebsd/handler/exception_handler.h client/freebsd/handler/exception_handler.h
+--- google-breakpad/src/client.orig/freebsd/handler/exception_handler.h 1969-12-31 19:00:00.000000000 -0500
++++ google-breakpad/src/client/freebsd/handler/exception_handler.h 2007-08-05 13:54:19.000000000 -0400
+@@ -0,0 +1,201 @@
++// Copyright (c) 2006, Google Inc.
++// All rights reserved.
++//
++// Author: Li Liu
++//
++// Redistribution and use in source and binary forms, with or without
++// modification, are permitted provided that the following conditions are
++// met:
++//
++// * Redistributions of source code must retain the above copyright
++// notice, this list of conditions and the following disclaimer.
++// * Redistributions in binary form must reproduce the above
++// copyright notice, this list of conditions and the following disclaimer
++// in the documentation and/or other materials provided with the
++// distribution.
++// * Neither the name of Google Inc. nor the names of its
++// contributors may be used to endorse or promote products derived from
++// this software without specific prior written permission.
++//
++// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
++// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
++// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
++// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
++// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
++// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
++// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
++// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
++// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
++// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
++// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
++
++#ifndef CLIENT_LINUX_HANDLER_EXCEPTION_HANDLER_H__
++#define CLIENT_LINUX_HANDLER_EXCEPTION_HANDLER_H__
++
++#include <pthread.h>
++
++#include <map>
++#include <string>
++#include <vector>
++
++#include "client/linux/handler/minidump_generator.h"
++
++// Context information when exception occured.
++struct sigcontex;
++
++namespace google_breakpad {
++
++using std::string;
++
++//
++// ExceptionHandler
++//
++// ExceptionHandler can write a minidump file when an exception occurs,
++// or when WriteMinidump() is called explicitly by your program.
++//
++// To have the exception handler write minidumps when an uncaught exception
++// (crash) occurs, you should create an instance early in the execution
++// of your program, and keep it around for the entire time you want to
++// have crash handling active (typically, until shutdown).
++// (NOTE): There should be only be one this kind of exception handler
++// object per process.
++//
++// If you want to write minidumps without installing the exception handler,
++// you can create an ExceptionHandler with install_handler set to false,
++// then call WriteMinidump. You can also use this technique if you want to
++// use different minidump callbacks for different call sites.
++//
++// In either case, a callback function is called when a minidump is written,
++// which receives the unqiue id of the minidump. The caller can use this
++// id to collect and write additional application state, and to launch an
++// external crash-reporting application.
++//
++// Caller should try to make the callbacks as crash-friendly as possible,
++// it should avoid use heap memory allocation as much as possible.
++//
++class ExceptionHandler {
++ public:
++ // A callback function to run before Breakpad performs any substantial
++ // processing of an exception. A FilterCallback is called before writing
++ // a minidump. context is the parameter supplied by the user as
++ // callback_context when the handler was created.
++ //
++ // If a FilterCallback returns true, Breakpad will continue processing,
++ // attempting to write a minidump. If a FilterCallback returns false,
++ // Breakpad will immediately report the exception as unhandled without
++ // writing a minidump, allowing another handler the opportunity to handle it.
++ typedef bool (*FilterCallback)(void *context);
++
++ // A callback function to run after the minidump has been written.
++ // minidump_id is a unique id for the dump, so the minidump
++ // file is <dump_path>\<minidump_id>.dmp. context is the parameter supplied
++ // by the user as callback_context when the handler was created. succeeded
++ // indicates whether a minidump file was successfully written.
++ //
++ // If an exception occurred and the callback returns true, Breakpad will
++ // treat the exception as fully-handled, suppressing any other handlers from
++ // being notified of the exception. If the callback returns false, Breakpad
++ // will treat the exception as unhandled, and allow another handler to handle
++ // it. If there are no other handlers, Breakpad will report the exception to
++ // the system as unhandled, allowing a debugger or native crash dialog the
++ // opportunity to handle the exception. Most callback implementations
++ // should normally return the value of |succeeded|, or when they wish to
++ // not report an exception of handled, false. Callbacks will rarely want to
++ // return true directly (unless |succeeded| is true).
++ typedef bool (*MinidumpCallback)(const char *dump_path,
++ const char *minidump_id,
++ void *context,
++ bool succeeded);
++
++ // Creates a new ExceptionHandler instance to handle writing minidumps.
++ // Before writing a minidump, the optional filter callback will be called.
++ // Its return value determines whether or not Breakpad should write a
++ // minidump. Minidump files will be written to dump_path, and the optional
++ // callback is called after writing the dump file, as described above.
++ // If install_handler is true, then a minidump will be written whenever
++ // an unhandled exception occurs. If it is false, minidumps will only
++ // be written when WriteMinidump is called.
++ ExceptionHandler(const string &dump_path,
++ FilterCallback filter, MinidumpCallback callback,
++ void *callback_context,
++ bool install_handler);
++ ~ExceptionHandler();
++
++ // Get and set the minidump path.
++ string dump_path() const { return dump_path_; }
++ void set_dump_path(const string &dump_path) {
++ dump_path_ = dump_path;
++ dump_path_c_ = dump_path_.c_str();
++ }
++
++ // Writes a minidump immediately. This can be used to capture the
++ // execution state independently of a crash. Returns true on success.
++ bool WriteMinidump();
++
++ // Convenience form of WriteMinidump which does not require an
++ // ExceptionHandler instance.
++ static bool WriteMinidump(const string &dump_path,
++ MinidumpCallback callback,
++ void *callback_context);
++
++ private:
++ // Setup crash handler.
++ void SetupHandler();
++ // Setup signal handler for a signal.
++ void SetupHandler(int signo);
++ // Teardown the handler for a signal.
++ void TeardownHandler(int signo);
++ // Teardown all handlers.
++ void TeardownAllHandler();
++
++ // Signal handler.
++ static void HandleException(int signo);
++
++ // If called from a signal handler, sighandler_ebp is the ebp of
++ // that signal handler's frame, and sig_ctx is an out parameter
++ // that will be set to point at the sigcontext that was placed
++ // on the stack by the kernel. You can pass zero and NULL
++ // for the second and third parameters if you are not calling
++ // this from a signal handler.
++ bool InternalWriteMinidump(int signo, uintptr_t sighandler_ebp,
++ struct sigcontext **sig_ctx);
++
++ private:
++ FilterCallback filter_;
++ MinidumpCallback callback_;
++ void *callback_context_;
++
++ // The directory in which a minidump will be written, set by the dump_path
++ // argument to the constructor, or set_dump_path.
++ string dump_path_;
++ // C style dump path. Keep this when setting dump path, since calling
++ // c_str() of std::string when crashing may not be safe.
++ const char *dump_path_c_;
++
++ // True if the ExceptionHandler installed an unhandled exception filter
++ // when created (with an install_handler parameter set to true).
++ bool installed_handler_;
++
++ // Keep the previous handlers for the signal.
++ typedef void (*sighandler_t)(int);
++ std::map<int, sighandler_t> old_handlers_;
++
++ // The global exception handler stack. This is need becuase there may exist
++ // multiple ExceptionHandler instances in a process. Each will have itself
++ // registered in this stack.
++ static std::vector<ExceptionHandler *> *handler_stack_;
++ // The index of the handler that should handle the next exception.
++ static int handler_stack_index_;
++ static pthread_mutex_t handler_stack_mutex_;
++
++ // The minidump generator.
++ MinidumpGenerator minidump_generator_;
++
++ // disallow copy ctor and operator=
++ explicit ExceptionHandler(const ExceptionHandler &);
++ void operator=(const ExceptionHandler &);
++};
++
++} // namespace google_breakpad
++
++#endif // CLIENT_LINUX_HANDLER_EXCEPTION_HANDLER_H__
+diff -rupN client.orig/freebsd/handler/minidump_generator.cc client/freebsd/handler/minidump_generator.cc
+--- google-breakpad/src/client.orig/freebsd/handler/minidump_generator.cc 1969-12-31 19:00:00.000000000 -0500
++++ google-breakpad/src/client/freebsd/handler/minidump_generator.cc 2007-08-05 13:57:11.000000000 -0400
+@@ -0,0 +1,66 @@
++// Copyright (c) 2006, Google Inc.
++// All rights reserved.
++//
++// Author: Li Liu
++//
++// Redistribution and use in source and binary forms, with or without
++// modification, are permitted provided that the following conditions are
++// met:
++//
++// * Redistributions of source code must retain the above copyright
++// notice, this list of conditions and the following disclaimer.
++// * Redistributions in binary form must reproduce the above
++// copyright notice, this list of conditions and the following disclaimer
++// in the documentation and/or other materials provided with the
++// distribution.
++// * Neither the name of Google Inc. nor the names of its
++// contributors may be used to endorse or promote products derived from
++// this software without specific prior written permission.
++//
++// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
++// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
++// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
++// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
++// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
++// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
++// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
++// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
++// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
++// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
++// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
++
++#include <fcntl.h>
++#include <pthread.h>
++#include <signal.h>
++#include <sys/stat.h>
++#include <sys/types.h>
++#include <unistd.h>
++#include <sys/utsname.h>
++#include <sys/wait.h>
++
++#include <cstdlib>
++#include <ctime>
++
++#include "google_breakpad/common/minidump_format.h"
++#include "client/freebsd/handler/minidump_generator.h"
++
++namespace google_breakpad {
++
++MinidumpGenerator::MinidumpGenerator() {
++ AllocateStack();
++}
++
++MinidumpGenerator::~MinidumpGenerator() {
++}
++
++void MinidumpGenerator::AllocateStack() {
++}
++
++bool MinidumpGenerator::WriteMinidumpToFile(const char *file_pathname,
++ int signo,
++ uintptr_t sighandler_ebp,
++ struct sigcontext **sig_ctx) const {
++ return false;
++}
++
++} // namespace google_breakpad
+diff -rupN client.orig/freebsd/handler/minidump_generator.h client/freebsd/handler/minidump_generator.h
+--- google-breakpad/src/client.orig/freebsd/handler/minidump_generator.h 1969-12-31 19:00:00.000000000 -0500
++++ google-breakpad/src/client/freebsd/handler/minidump_generator.h 2007-08-05 13:57:45.000000000 -0400
+@@ -0,0 +1,67 @@
++// Copyright (c) 2006, Google Inc.
++// All rights reserved.
++//
++// Author: Li Liu
++//
++// Redistribution and use in source and binary forms, with or without
++// modification, are permitted provided that the following conditions are
++// met:
++//
++// * Redistributions of source code must retain the above copyright
++// notice, this list of conditions and the following disclaimer.
++// * Redistributions in binary form must reproduce the above
++// copyright notice, this list of conditions and the following disclaimer
++// in the documentation and/or other materials provided with the
++// distribution.
++// * Neither the name of Google Inc. nor the names of its
++// contributors may be used to endorse or promote products derived from
++// this software without specific prior written permission.
++//
++// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
++// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
++// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
++// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
++// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
++// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
++// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
++// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
++// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
++// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
++// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
++
++#ifndef CLIENT_LINUX_HANDLER_MINIDUMP_GENERATOR_H__
++#define CLIENT_LINUX_HANDLER_MINIDUMP_GENERATOR_H__
++
++#include <stdint.h>
++
++#include "google_breakpad/common/breakpad_types.h"
++#include "processor/scoped_ptr.h"
++
++namespace google_breakpad {
++
++//
++// MinidumpGenerator
++//
++// Write a minidump to file based on the signo and sig_ctx.
++// A minidump generator should be created before any exception happen.
++//
++class MinidumpGenerator {
++ public:
++ MinidumpGenerator();
++
++ ~MinidumpGenerator();
++
++ // Write minidump.
++ bool WriteMinidumpToFile(const char *file_pathname,
++ int signo,
++ uintptr_t sighandler_ebp,
++ struct sigcontext **sig_ctx) const;
++ private:
++ // Allocate memory for stack.
++ void AllocateStack();
++
++};
++
++} // namespace google_breakpad
++
++#endif // CLIENT_LINUX_HANDLER_MINIDUMP_GENERATOR_H__
diff --git a/devel/bug-buddy/files/patch-gnome-breakpad_Makefile.in b/devel/bug-buddy/files/patch-gnome-breakpad_Makefile.in
index 57efdea51..558ec264a 100644
--- a/devel/bug-buddy/files/patch-gnome-breakpad_Makefile.in
+++ b/devel/bug-buddy/files/patch-gnome-breakpad_Makefile.in
@@ -1,31 +1,87 @@
---- gnome-breakpad/Makefile.in.orig 2007-08-02 02:20:43.000000000 -0400
-+++ gnome-breakpad/Makefile.in 2007-08-02 02:27:50.000000000 -0400
-@@ -58,10 +58,7 @@ am__DEPENDENCIES_1 =
+--- gnome-breakpad/Makefile.in.orig 2007-08-05 14:22:25.000000000 -0400
++++ gnome-breakpad/Makefile.in 2007-08-05 14:26:27.000000000 -0400
+@@ -58,10 +58,9 @@ am__DEPENDENCIES_1 =
libgnomebreakpad_la_DEPENDENCIES = \
$(top_builddir)/google-breakpad/src/libbreakpad.la \
$(am__DEPENDENCIES_1)
-am__objects_1 = gnome-breakpad.lo exception_handler.lo linux_thread.lo \
-- minidump_file_writer.lo minidump_generator.lo \
++am__objects_1 = gnome-breakpad.lo exception_handler.lo \
+ minidump_file_writer.lo minidump_generator.lo \
- string_conversion.lo convert_UTF.lo guid_creator.lo file_id.lo \
- md5.lo
-+am__objects_1 = gnome-breakpad.lo exception_handler.lo
++ string_conversion.lo convert_UTF.lo
am_libgnomebreakpad_la_OBJECTS = $(am__objects_1)
libgnomebreakpad_la_OBJECTS = $(am_libgnomebreakpad_la_OBJECTS)
DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir)
-@@ -268,15 +265,7 @@ INCLUDES = -I. -I$(top_srcdir)/google-br
+@@ -268,15 +267,11 @@ INCLUDES = -I. -I$(top_srcdir)/google-br
#cc_sources = exception_handler.cc linux_thread.cc minidump_file_writer.cc minidump_generator.cc gnome-breakpad.cc string_conversion.cc convert_UTF.c
cc_sources = gnome-breakpad.cc \
- $(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc \
- $(top_srcdir)/google-breakpad/src/client/linux/handler/linux_thread.cc \
-- $(top_srcdir)/google-breakpad/src/client/minidump_file_writer.cc \
++ $(top_srcdir)/google-breakpad/src/client/freebsd/handler/exception_handler.cc \
+ $(top_srcdir)/google-breakpad/src/client/minidump_file_writer.cc \
- $(top_srcdir)/google-breakpad/src/client/linux/handler/minidump_generator.cc \
-- $(top_srcdir)/google-breakpad/src/common/string_conversion.cc \
++ $(top_srcdir)/google-breakpad/src/client/freebsd/handler/minidump_generator.cc \
+ $(top_srcdir)/google-breakpad/src/common/string_conversion.cc \
- $(top_srcdir)/google-breakpad/src/common/convert_UTF.c \
- $(top_srcdir)/google-breakpad/src/common/linux/guid_creator.cc \
- $(top_srcdir)/google-breakpad/src/common/linux/file_id.cc \
- $(top_srcdir)/google-breakpad/src/common/linux/md5.c
-+ $(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc \
++ $(top_srcdir)/google-breakpad/src/common/convert_UTF.c
module_LTLIBRARIES = libgnomebreakpad.la
moduledir = $(libdir)/gtk-2.0/modules
+@@ -353,11 +348,7 @@ distclean-compile:
+
+ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/convert_UTF.Plo@am__quote@
+ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/exception_handler.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/file_id.Plo@am__quote@
+ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/gnome-breakpad.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/guid_creator.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/linux_thread.Plo@am__quote@
+-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/md5.Plo@am__quote@
+ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/minidump_file_writer.Plo@am__quote@
+ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/minidump_generator.Plo@am__quote@
+ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/string_conversion.Plo@am__quote@
+@@ -418,19 +409,12 @@ md5.lo: $(top_srcdir)/google-breakpad/sr
+ @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+ @am__fastdepCXX_FALSE@ $(LTCXXCOMPILE) -c -o $@ $<
+
+-exception_handler.lo: $(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc
+-@am__fastdepCXX_TRUE@ if $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT exception_handler.lo -MD -MP -MF "$(DEPDIR)/exception_handler.Tpo" -c -o exception_handler.lo `test -f '$(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc; \
++exception_handler.lo: $(top_srcdir)/google-breakpad/src/client/freebsd/handler/exception_handler.cc
++@am__fastdepCXX_TRUE@ if $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT exception_handler.lo -MD -MP -MF "$(DEPDIR)/exception_handler.Tpo" -c -o exception_handler.lo `test -f '$(top_srcdir)/google-breakpad/src/client/freebsd/handler/exception_handler.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/freebsd/handler/exception_handler.cc; \
+ @am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/exception_handler.Tpo" "$(DEPDIR)/exception_handler.Plo"; else rm -f "$(DEPDIR)/exception_handler.Tpo"; exit 1; fi
+-@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc' object='exception_handler.lo' libtool=yes @AMDEPBACKSLASH@
++@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(top_srcdir)/google-breakpad/src/client/freebsd/handler/exception_handler.cc' object='exception_handler.lo' libtool=yes @AMDEPBACKSLASH@
+ @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+-@am__fastdepCXX_FALSE@ $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o exception_handler.lo `test -f '$(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/linux/handler/exception_handler.cc
+-
+-linux_thread.lo: $(top_srcdir)/google-breakpad/src/client/linux/handler/linux_thread.cc
+-@am__fastdepCXX_TRUE@ if $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT linux_thread.lo -MD -MP -MF "$(DEPDIR)/linux_thread.Tpo" -c -o linux_thread.lo `test -f '$(top_srcdir)/google-breakpad/src/client/linux/handler/linux_thread.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/linux/handler/linux_thread.cc; \
+-@am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/linux_thread.Tpo" "$(DEPDIR)/linux_thread.Plo"; else rm -f "$(DEPDIR)/linux_thread.Tpo"; exit 1; fi
+-@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(top_srcdir)/google-breakpad/src/client/linux/handler/linux_thread.cc' object='linux_thread.lo' libtool=yes @AMDEPBACKSLASH@
+-@AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+-@am__fastdepCXX_FALSE@ $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o linux_thread.lo `test -f '$(top_srcdir)/google-breakpad/src/client/linux/handler/linux_thread.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/linux/handler/linux_thread.cc
++@am__fastdepCXX_FALSE@ $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o exception_handler.lo `test -f '$(top_srcdir)/google-breakpad/src/client/freebsd/handler/exception_handler.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/freebsd/handler/exception_handler.cc
+
+ minidump_file_writer.lo: $(top_srcdir)/google-breakpad/src/client/minidump_file_writer.cc
+ @am__fastdepCXX_TRUE@ if $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT minidump_file_writer.lo -MD -MP -MF "$(DEPDIR)/minidump_file_writer.Tpo" -c -o minidump_file_writer.lo `test -f '$(top_srcdir)/google-breakpad/src/client/minidump_file_writer.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/minidump_file_writer.cc; \
+@@ -439,12 +423,12 @@ minidump_file_writer.lo: $(top_srcdir)/g
+ @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+ @am__fastdepCXX_FALSE@ $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o minidump_file_writer.lo `test -f '$(top_srcdir)/google-breakpad/src/client/minidump_file_writer.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/minidump_file_writer.cc
+
+-minidump_generator.lo: $(top_srcdir)/google-breakpad/src/client/linux/handler/minidump_generator.cc
+-@am__fastdepCXX_TRUE@ if $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT minidump_generator.lo -MD -MP -MF "$(DEPDIR)/minidump_generator.Tpo" -c -o minidump_generator.lo `test -f '$(top_srcdir)/google-breakpad/src/client/linux/handler/minidump_generator.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/linux/handler/minidump_generator.cc; \
++minidump_generator.lo: $(top_srcdir)/google-breakpad/src/client/freebsd/handler/minidump_generator.cc
++@am__fastdepCXX_TRUE@ if $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT minidump_generator.lo -MD -MP -MF "$(DEPDIR)/minidump_generator.Tpo" -c -o minidump_generator.lo `test -f '$(top_srcdir)/google-breakpad/src/client/freebsd/handler/minidump_generator.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/freebsd/handler/minidump_generator.cc; \
+ @am__fastdepCXX_TRUE@ then mv -f "$(DEPDIR)/minidump_generator.Tpo" "$(DEPDIR)/minidump_generator.Plo"; else rm -f "$(DEPDIR)/minidump_generator.Tpo"; exit 1; fi
+-@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(top_srcdir)/google-breakpad/src/client/linux/handler/minidump_generator.cc' object='minidump_generator.lo' libtool=yes @AMDEPBACKSLASH@
++@AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='$(top_srcdir)/google-breakpad/src/client/freebsd/handler/minidump_generator.cc' object='minidump_generator.lo' libtool=yes @AMDEPBACKSLASH@
+ @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+-@am__fastdepCXX_FALSE@ $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o minidump_generator.lo `test -f '$(top_srcdir)/google-breakpad/src/client/linux/handler/minidump_generator.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/linux/handler/minidump_generator.cc
++@am__fastdepCXX_FALSE@ $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o minidump_generator.lo `test -f '$(top_srcdir)/google-breakpad/src/client/freebsd/handler/minidump_generator.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/client/freebsd/handler/minidump_generator.cc
+
+ string_conversion.lo: $(top_srcdir)/google-breakpad/src/common/string_conversion.cc
+ @am__fastdepCXX_TRUE@ if $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT string_conversion.lo -MD -MP -MF "$(DEPDIR)/string_conversion.Tpo" -c -o string_conversion.lo `test -f '$(top_srcdir)/google-breakpad/src/common/string_conversion.cc' || echo '$(srcdir)/'`$(top_srcdir)/google-breakpad/src/common/string_conversion.cc; \
diff --git a/devel/bug-buddy/files/patch-google-breakpad_src_client_linux_handler_exception_handler.cc b/devel/bug-buddy/files/patch-google-breakpad_src_client_linux_handler_exception_handler.cc
deleted file mode 100644
index b741aed05..000000000
--- a/devel/bug-buddy/files/patch-google-breakpad_src_client_linux_handler_exception_handler.cc
+++ /dev/null
@@ -1,11 +0,0 @@
---- google-breakpad/src/client/linux/handler/exception_handler.cc.orig 2007-08-02 01:59:39.000000000 -0400
-+++ google-breakpad/src/client/linux/handler/exception_handler.cc 2007-08-02 02:00:19.000000000 -0400
-@@ -133,7 +133,7 @@ void ExceptionHandler::SetupHandler() {
- // Signal on a different stack to avoid using the stack
- // of the crashing thread.
- struct sigaltstack sig_stack;
-- sig_stack.ss_sp = malloc(MINSIGSTKSZ);
-+ sig_stack.ss_sp = (char *) malloc(MINSIGSTKSZ);
- if (sig_stack.ss_sp == NULL)
- return;
- sig_stack.ss_size = MINSIGSTKSZ;