|
|
06486d |
From 40823feb83cc2a7ad7aac8fb0da1ff7c0773eb2a Mon Sep 17 00:00:00 2001
|
|
|
06486d |
From: Jakub Filak <jfilak@redhat.com>
|
|
|
06486d |
Date: Mon, 14 Jul 2014 16:06:17 +0200
|
|
|
06486d |
Subject: [ABRT PATCH 44/66] localization fixes
|
|
|
06486d |
|
|
|
06486d |
commit fc0f32d878bb93e7498340224281fa526b4aeaf7
|
|
|
06486d |
Author: Jakub Filak <jfilak@redhat.com>
|
|
|
06486d |
Date: Wed Apr 16 12:03:31 2014 +0200
|
|
|
06486d |
|
|
|
06486d |
localization: fix gettext
|
|
|
06486d |
|
|
|
06486d |
https://www.gnu.org/software/gettext/manual/html_node/Libraries.html
|
|
|
06486d |
|
|
|
06486d |
commit f8533576b349f346acafdc7c0182a995a569a443
|
|
|
06486d |
Author: Jakub Filak <jfilak@redhat.com>
|
|
|
06486d |
Date: Wed Apr 16 21:08:29 2014 +0200
|
|
|
06486d |
|
|
|
06486d |
do not clear LANG env variable
|
|
|
06486d |
abrt-action-install-debuginfo-to-abrt-cache
|
|
|
06486d |
|
|
|
06486d |
commit d05e231eaf05dc6680be031741d1d7593445f70d
|
|
|
06486d |
Author: Jakub Filak <jfilak@redhat.com>
|
|
|
06486d |
Date: Wed Apr 16 21:13:44 2014 +0200
|
|
|
06486d |
|
|
|
06486d |
a-a-a-core: fix localization
|
|
|
06486d |
|
|
|
06486d |
The strings of that file are not translated at all because
|
|
|
06486d |
the file was not included in POTFILES.in
|
|
|
06486d |
|
|
|
06486d |
Resolves rhbz#1087880
|
|
|
06486d |
|
|
|
06486d |
Signed-off-by: Jakub Filak <jfilak@redhat.com>
|
|
|
06486d |
---
|
|
|
06486d |
po/POTFILES.in | 1 +
|
|
|
06486d |
src/configuration-gui/system-config-abrt.c | 4 +-
|
|
|
06486d |
src/include/Makefile.am | 3 +
|
|
|
06486d |
src/include/internal_libabrt.h | 50 ++++++
|
|
|
06486d |
src/include/libabrt.h | 15 --
|
|
|
06486d |
src/lib/Makefile.am | 3 +
|
|
|
06486d |
src/lib/hooklib.c | 4 +-
|
|
|
06486d |
src/lib/ignored_problems.c | 4 +-
|
|
|
06486d |
src/lib/libabrt_init.c | 28 ++++
|
|
|
06486d |
src/lib/problem_api_dbus.c | 10 +-
|
|
|
06486d |
src/plugins/Makefile.am | 8 +-
|
|
|
06486d |
src/plugins/abrt-action-analyze-core | 186 ---------------------
|
|
|
06486d |
src/plugins/abrt-action-analyze-core.in | 186 +++++++++++++++++++++
|
|
|
06486d |
.../abrt-action-install-debuginfo-to-abrt-cache.c | 3 +-
|
|
|
06486d |
14 files changed, 298 insertions(+), 207 deletions(-)
|
|
|
06486d |
create mode 100644 src/include/internal_libabrt.h
|
|
|
06486d |
create mode 100644 src/lib/libabrt_init.c
|
|
|
06486d |
delete mode 100644 src/plugins/abrt-action-analyze-core
|
|
|
06486d |
create mode 100644 src/plugins/abrt-action-analyze-core.in
|
|
|
06486d |
|
|
|
06486d |
diff --git a/po/POTFILES.in b/po/POTFILES.in
|
|
|
06486d |
index 2c36802..ff9b97a 100644
|
|
|
06486d |
--- a/po/POTFILES.in
|
|
|
06486d |
+++ b/po/POTFILES.in
|
|
|
06486d |
@@ -21,6 +21,7 @@ src/lib/problem_api_dbus.c
|
|
|
06486d |
src/lib/ignored_problems.c
|
|
|
06486d |
src/plugins/abrt-action-analyze-backtrace.c
|
|
|
06486d |
src/plugins/abrt-action-analyze-c.c
|
|
|
06486d |
+src/plugins/abrt-action-analyze-core.in
|
|
|
06486d |
src/plugins/abrt-action-analyze-oops.c
|
|
|
06486d |
src/plugins/abrt-action-analyze-xorg.c
|
|
|
06486d |
src/plugins/abrt-action-analyze-python.c
|
|
|
06486d |
diff --git a/src/configuration-gui/system-config-abrt.c b/src/configuration-gui/system-config-abrt.c
|
|
|
06486d |
index b15a5ef..bd9f13f 100644
|
|
|
06486d |
--- a/src/configuration-gui/system-config-abrt.c
|
|
|
06486d |
+++ b/src/configuration-gui/system-config-abrt.c
|
|
|
06486d |
@@ -18,7 +18,7 @@
|
|
|
06486d |
#include "system-config-abrt.h"
|
|
|
06486d |
#include "abrt-config-widget.h"
|
|
|
06486d |
|
|
|
06486d |
-#include <libabrt.h>
|
|
|
06486d |
+#include "internal_libabrt.h"
|
|
|
06486d |
|
|
|
06486d |
#define CLOSE_BUTTON_DATA_NAME_CALLBACK "my-close-callback"
|
|
|
06486d |
#define CLOSE_BUTTON_DATA_NAME_USER_DATA "my-close-user-data"
|
|
|
06486d |
@@ -105,6 +105,8 @@ system_config_abrt_dialog_delete_event(GtkWidget *dialog, GdkEvent *event, gpoin
|
|
|
06486d |
|
|
|
06486d |
void show_system_config_abrt_dialog(GtkWindow *parent)
|
|
|
06486d |
{
|
|
|
06486d |
+ INITIALIZE_LIBABRT();
|
|
|
06486d |
+
|
|
|
06486d |
GtkWidget *dialog = gtk_dialog_new();
|
|
|
06486d |
|
|
|
06486d |
gtk_window_set_title(GTK_WINDOW(dialog), _("Problem Reporting Configuration"));
|
|
|
06486d |
diff --git a/src/include/Makefile.am b/src/include/Makefile.am
|
|
|
06486d |
index 49a6f5c..c1952cb 100644
|
|
|
06486d |
--- a/src/include/Makefile.am
|
|
|
06486d |
+++ b/src/include/Makefile.am
|
|
|
06486d |
@@ -6,3 +6,6 @@ libabrt_include_HEADERS = \
|
|
|
06486d |
abrt-dbus.h \
|
|
|
06486d |
hooklib.h \
|
|
|
06486d |
problem_api.h
|
|
|
06486d |
+
|
|
|
06486d |
+EXTRA_DIST = \
|
|
|
06486d |
+ internal_libabrt.h
|
|
|
06486d |
diff --git a/src/include/internal_libabrt.h b/src/include/internal_libabrt.h
|
|
|
06486d |
new file mode 100644
|
|
|
06486d |
index 0000000..3ad22fc
|
|
|
06486d |
--- /dev/null
|
|
|
06486d |
+++ b/src/include/internal_libabrt.h
|
|
|
06486d |
@@ -0,0 +1,50 @@
|
|
|
06486d |
+/*
|
|
|
06486d |
+ Copyright (C) 2014 ABRT team
|
|
|
06486d |
+ Copyright (C) 2014 RedHat Inc
|
|
|
06486d |
+
|
|
|
06486d |
+ This program is free software; you can redistribute it and/or modify
|
|
|
06486d |
+ it under the terms of the GNU General Public License as published by
|
|
|
06486d |
+ the Free Software Foundation; either version 2 of the License, or
|
|
|
06486d |
+ (at your option) any later version.
|
|
|
06486d |
+
|
|
|
06486d |
+ This program is distributed in the hope that it will be useful,
|
|
|
06486d |
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
06486d |
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
06486d |
+ GNU General Public License for more details.
|
|
|
06486d |
+
|
|
|
06486d |
+ You should have received a copy of the GNU General Public License along
|
|
|
06486d |
+ with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
06486d |
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
06486d |
+*/
|
|
|
06486d |
+
|
|
|
06486d |
+#include "libabrt.h"
|
|
|
06486d |
+
|
|
|
06486d |
+#ifdef HAVE_CONFIG_H
|
|
|
06486d |
+# include "config.h"
|
|
|
06486d |
+#endif
|
|
|
06486d |
+
|
|
|
06486d |
+#undef NORETURN
|
|
|
06486d |
+#define NORETURN __attribute__ ((noreturn))
|
|
|
06486d |
+
|
|
|
06486d |
+/* Must be after #include "config.h" */
|
|
|
06486d |
+#if ENABLE_NLS
|
|
|
06486d |
+# include <libintl.h>
|
|
|
06486d |
+# define _(S) dgettext(PACKAGE, S)
|
|
|
06486d |
+#else
|
|
|
06486d |
+# define _(S) (S)
|
|
|
06486d |
+#endif
|
|
|
06486d |
+
|
|
|
06486d |
+extern int g_libabrt_inited;
|
|
|
06486d |
+void libabrt_init(void);
|
|
|
06486d |
+
|
|
|
06486d |
+#define INITIALIZE_LIBABRT() \
|
|
|
06486d |
+ do \
|
|
|
06486d |
+ { \
|
|
|
06486d |
+ if (!g_libabrt_inited) \
|
|
|
06486d |
+ { \
|
|
|
06486d |
+ g_libabrt_inited = 1; \
|
|
|
06486d |
+ libabrt_init(); \
|
|
|
06486d |
+ } \
|
|
|
06486d |
+ } \
|
|
|
06486d |
+ while (0)
|
|
|
06486d |
+
|
|
|
06486d |
diff --git a/src/include/libabrt.h b/src/include/libabrt.h
|
|
|
06486d |
index d5911e7..3e42a09 100644
|
|
|
06486d |
--- a/src/include/libabrt.h
|
|
|
06486d |
+++ b/src/include/libabrt.h
|
|
|
06486d |
@@ -15,21 +15,6 @@
|
|
|
06486d |
#include <libreport/internal_libreport.h>
|
|
|
06486d |
#include "hooklib.h"
|
|
|
06486d |
|
|
|
06486d |
-#ifdef HAVE_CONFIG_H
|
|
|
06486d |
-# include "config.h"
|
|
|
06486d |
-#endif
|
|
|
06486d |
-
|
|
|
06486d |
-/* Must be after #include "config.h" */
|
|
|
06486d |
-#if ENABLE_NLS
|
|
|
06486d |
-# include <libintl.h>
|
|
|
06486d |
-# define _(S) gettext(S)
|
|
|
06486d |
-#else
|
|
|
06486d |
-# define _(S) (S)
|
|
|
06486d |
-#endif
|
|
|
06486d |
-
|
|
|
06486d |
-#undef NORETURN
|
|
|
06486d |
-#define NORETURN __attribute__ ((noreturn))
|
|
|
06486d |
-
|
|
|
06486d |
#undef ARRAY_SIZE
|
|
|
06486d |
#define ARRAY_SIZE(x) ((unsigned)(sizeof(x) / sizeof((x)[0])))
|
|
|
06486d |
|
|
|
06486d |
diff --git a/src/lib/Makefile.am b/src/lib/Makefile.am
|
|
|
06486d |
index 5c281d2..32a054a 100644
|
|
|
06486d |
--- a/src/lib/Makefile.am
|
|
|
06486d |
+++ b/src/lib/Makefile.am
|
|
|
06486d |
@@ -5,6 +5,7 @@ lib_LTLIBRARIES = \
|
|
|
06486d |
libabrt.la
|
|
|
06486d |
|
|
|
06486d |
libabrt_la_SOURCES = \
|
|
|
06486d |
+ libabrt_init.c \
|
|
|
06486d |
abrt_conf.c \
|
|
|
06486d |
hooklib.c \
|
|
|
06486d |
daemon_is_ok.c \
|
|
|
06486d |
@@ -40,3 +41,5 @@ libabrt_la_LIBADD = \
|
|
|
06486d |
$(GIO_LIBS) \
|
|
|
06486d |
$(LIBREPORT_LIBS) \
|
|
|
06486d |
$(SATYR_LIBS)
|
|
|
06486d |
+
|
|
|
06486d |
+DEFS = -DLOCALEDIR=\"$(localedir)\" @DEFS@
|
|
|
06486d |
diff --git a/src/lib/hooklib.c b/src/lib/hooklib.c
|
|
|
06486d |
index 23447df..4a50727 100644
|
|
|
06486d |
--- a/src/lib/hooklib.c
|
|
|
06486d |
+++ b/src/lib/hooklib.c
|
|
|
06486d |
@@ -16,7 +16,7 @@
|
|
|
06486d |
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
06486d |
*/
|
|
|
06486d |
#include <sys/statvfs.h>
|
|
|
06486d |
-#include "libabrt.h"
|
|
|
06486d |
+#include "internal_libabrt.h"
|
|
|
06486d |
|
|
|
06486d |
int low_free_space(unsigned setting_MaxCrashReportsSize, const char *dump_location)
|
|
|
06486d |
{
|
|
|
06486d |
@@ -241,6 +241,8 @@ char *run_unstrip_n(const char *dump_dir_name, unsigned timeout_sec)
|
|
|
06486d |
|
|
|
06486d |
char *get_backtrace(const char *dump_dir_name, unsigned timeout_sec, const char *debuginfo_dirs)
|
|
|
06486d |
{
|
|
|
06486d |
+ INITIALIZE_LIBABRT();
|
|
|
06486d |
+
|
|
|
06486d |
struct dump_dir *dd = dd_opendir(dump_dir_name, /*flags:*/ 0);
|
|
|
06486d |
if (!dd)
|
|
|
06486d |
return NULL;
|
|
|
06486d |
diff --git a/src/lib/ignored_problems.c b/src/lib/ignored_problems.c
|
|
|
06486d |
index df138d8..7779c4c 100644
|
|
|
06486d |
--- a/src/lib/ignored_problems.c
|
|
|
06486d |
+++ b/src/lib/ignored_problems.c
|
|
|
06486d |
@@ -17,7 +17,7 @@
|
|
|
06486d |
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
06486d |
*/
|
|
|
06486d |
|
|
|
06486d |
-#include "libabrt.h"
|
|
|
06486d |
+#include "internal_libabrt.h"
|
|
|
06486d |
|
|
|
06486d |
#define IGN_COLUMN_DELIMITER ';'
|
|
|
06486d |
#define IGN_DD_OPEN_FLAGS (DD_OPEN_READONLY | DD_FAIL_QUIETLY_ENOENT | DD_FAIL_QUIETLY_EACCES)
|
|
|
06486d |
@@ -193,6 +193,8 @@ void ignored_problems_add(ignored_problems_t *set, const char *problem_id)
|
|
|
06486d |
void ignored_problems_remove_row(ignored_problems_t *set, const char *problem_id,
|
|
|
06486d |
const char *uuid, const char *duphash)
|
|
|
06486d |
{
|
|
|
06486d |
+ INITIALIZE_LIBABRT();
|
|
|
06486d |
+
|
|
|
06486d |
VERB1 log("Going to remove problem '%s' from ignored problems", problem_id);
|
|
|
06486d |
|
|
|
06486d |
FILE *orig_fp;
|
|
|
06486d |
diff --git a/src/lib/libabrt_init.c b/src/lib/libabrt_init.c
|
|
|
06486d |
new file mode 100644
|
|
|
06486d |
index 0000000..f9c1449
|
|
|
06486d |
--- /dev/null
|
|
|
06486d |
+++ b/src/lib/libabrt_init.c
|
|
|
06486d |
@@ -0,0 +1,28 @@
|
|
|
06486d |
+/*
|
|
|
06486d |
+ Copyright (C) 2014 ABRT team
|
|
|
06486d |
+ Copyright (C) 2014 RedHat Inc
|
|
|
06486d |
+
|
|
|
06486d |
+ This program is free software; you can redistribute it and/or modify
|
|
|
06486d |
+ it under the terms of the GNU General Public License as published by
|
|
|
06486d |
+ the Free Software Foundation; either version 2 of the License, or
|
|
|
06486d |
+ (at your option) any later version.
|
|
|
06486d |
+
|
|
|
06486d |
+ This program is distributed in the hope that it will be useful,
|
|
|
06486d |
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
06486d |
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
06486d |
+ GNU General Public License for more details.
|
|
|
06486d |
+
|
|
|
06486d |
+ You should have received a copy of the GNU General Public License along
|
|
|
06486d |
+ with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
06486d |
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
06486d |
+*/
|
|
|
06486d |
+#include "internal_libabrt.h"
|
|
|
06486d |
+
|
|
|
06486d |
+int g_libabrt_inited;
|
|
|
06486d |
+
|
|
|
06486d |
+void libabrt_init(void)
|
|
|
06486d |
+{
|
|
|
06486d |
+#if ENABLE_NLS
|
|
|
06486d |
+ bindtextdomain(PACKAGE, LOCALEDIR);
|
|
|
06486d |
+#endif
|
|
|
06486d |
+}
|
|
|
06486d |
diff --git a/src/lib/problem_api_dbus.c b/src/lib/problem_api_dbus.c
|
|
|
06486d |
index 784a43f..2d77898 100644
|
|
|
06486d |
--- a/src/lib/problem_api_dbus.c
|
|
|
06486d |
+++ b/src/lib/problem_api_dbus.c
|
|
|
06486d |
@@ -18,7 +18,7 @@
|
|
|
06486d |
*/
|
|
|
06486d |
|
|
|
06486d |
#include "abrt_glib.h"
|
|
|
06486d |
-#include "libabrt.h"
|
|
|
06486d |
+#include "internal_libabrt.h"
|
|
|
06486d |
|
|
|
06486d |
static GDBusProxy *get_dbus_proxy(void)
|
|
|
06486d |
{
|
|
|
06486d |
@@ -48,6 +48,8 @@ static GDBusProxy *get_dbus_proxy(void)
|
|
|
06486d |
|
|
|
06486d |
int chown_dir_over_dbus(const char *problem_dir_path)
|
|
|
06486d |
{
|
|
|
06486d |
+ INITIALIZE_LIBABRT();
|
|
|
06486d |
+
|
|
|
06486d |
GDBusProxy *proxy = get_dbus_proxy();
|
|
|
06486d |
if (!proxy)
|
|
|
06486d |
return 1;
|
|
|
06486d |
@@ -72,6 +74,8 @@ int chown_dir_over_dbus(const char *problem_dir_path)
|
|
|
06486d |
|
|
|
06486d |
int delete_problem_dirs_over_dbus(const GList *problem_dir_paths)
|
|
|
06486d |
{
|
|
|
06486d |
+ INITIALIZE_LIBABRT();
|
|
|
06486d |
+
|
|
|
06486d |
GDBusProxy *proxy = get_dbus_proxy();
|
|
|
06486d |
if (!proxy)
|
|
|
06486d |
return 1;
|
|
|
06486d |
@@ -99,6 +103,8 @@ int delete_problem_dirs_over_dbus(const GList *problem_dir_paths)
|
|
|
06486d |
|
|
|
06486d |
problem_data_t *get_problem_data_dbus(const char *problem_dir_path)
|
|
|
06486d |
{
|
|
|
06486d |
+ INITIALIZE_LIBABRT();
|
|
|
06486d |
+
|
|
|
06486d |
GDBusProxy *proxy = get_dbus_proxy();
|
|
|
06486d |
if (!proxy)
|
|
|
06486d |
return NULL;
|
|
|
06486d |
@@ -143,6 +149,8 @@ problem_data_t *get_problem_data_dbus(const char *problem_dir_path)
|
|
|
06486d |
|
|
|
06486d |
GList *get_problems_over_dbus(bool authorize)
|
|
|
06486d |
{
|
|
|
06486d |
+ INITIALIZE_LIBABRT();
|
|
|
06486d |
+
|
|
|
06486d |
GDBusProxy *proxy = get_dbus_proxy();
|
|
|
06486d |
if (!proxy)
|
|
|
06486d |
return ERR_PTR;
|
|
|
06486d |
diff --git a/src/plugins/Makefile.am b/src/plugins/Makefile.am
|
|
|
06486d |
index dd32c7d..727dae0 100644
|
|
|
06486d |
--- a/src/plugins/Makefile.am
|
|
|
06486d |
+++ b/src/plugins/Makefile.am
|
|
|
06486d |
@@ -89,6 +89,7 @@ EXTRA_DIST = \
|
|
|
06486d |
analyze_LocalGDB.xml.in \
|
|
|
06486d |
analyze_RetraceServer.xml.in \
|
|
|
06486d |
analyze_VMcore.xml.in \
|
|
|
06486d |
+ abrt-action-analyze-core.in \
|
|
|
06486d |
abrt-action-analyze-vmcore \
|
|
|
06486d |
abrt-action-check-oops-for-hw-error \
|
|
|
06486d |
abrt-action-save-kernel-data \
|
|
|
06486d |
@@ -306,7 +307,7 @@ endif
|
|
|
06486d |
|
|
|
06486d |
DEFS = -DLOCALEDIR=\"$(localedir)\" @DEFS@
|
|
|
06486d |
|
|
|
06486d |
-DISTCLEANFILES = abrt-action-analyze-ccpp-local
|
|
|
06486d |
+DISTCLEANFILES = abrt-action-analyze-ccpp-local abrt-action-analyze-core
|
|
|
06486d |
|
|
|
06486d |
abrt-action-perform-ccpp-analysis: abrt-action-perform-ccpp-analysis.in
|
|
|
06486d |
sed -e s,\@libexecdir\@,$(libexecdir),g \
|
|
|
06486d |
@@ -315,3 +316,8 @@ abrt-action-perform-ccpp-analysis: abrt-action-perform-ccpp-analysis.in
|
|
|
06486d |
abrt-action-analyze-ccpp-local: abrt-action-analyze-ccpp-local.in
|
|
|
06486d |
sed -e s,\@LIBEXEC_DIR\@,$(libexecdir),g \
|
|
|
06486d |
$< >$@
|
|
|
06486d |
+
|
|
|
06486d |
+abrt-action-analyze-core: abrt-action-analyze-core.in
|
|
|
06486d |
+ sed -e s,\@localedir\@,$(localedir),g \
|
|
|
06486d |
+ -e s,\@PACKAGE\@,$(PACKAGE),g \
|
|
|
06486d |
+ $< >$@
|
|
|
06486d |
diff --git a/src/plugins/abrt-action-analyze-core b/src/plugins/abrt-action-analyze-core
|
|
|
06486d |
deleted file mode 100644
|
|
|
06486d |
index 806cc26..0000000
|
|
|
06486d |
--- a/src/plugins/abrt-action-analyze-core
|
|
|
06486d |
+++ /dev/null
|
|
|
06486d |
@@ -1,186 +0,0 @@
|
|
|
06486d |
-#!/usr/bin/python -u
|
|
|
06486d |
-# -*- coding: utf-8 -*-
|
|
|
06486d |
-# WARNING: python -u means unbuffered I/O. Without it the messages are
|
|
|
06486d |
-# passed to the parent asynchronously which looks bad in clients.
|
|
|
06486d |
-
|
|
|
06486d |
-from subprocess import Popen, PIPE
|
|
|
06486d |
-import sys
|
|
|
06486d |
-import os
|
|
|
06486d |
-import getopt
|
|
|
06486d |
-
|
|
|
06486d |
-GETTEXT_PROGNAME = "abrt"
|
|
|
06486d |
-import locale
|
|
|
06486d |
-import gettext
|
|
|
06486d |
-
|
|
|
06486d |
-_ = lambda x: gettext.lgettext(x)
|
|
|
06486d |
-
|
|
|
06486d |
-
|
|
|
06486d |
-verbose = 0
|
|
|
06486d |
-
|
|
|
06486d |
-def log(s):
|
|
|
06486d |
- sys.stderr.write("%s\n" % s)
|
|
|
06486d |
-
|
|
|
06486d |
-def log1(message):
|
|
|
06486d |
- if verbose > 0:
|
|
|
06486d |
- log(message)
|
|
|
06486d |
-
|
|
|
06486d |
-def log2(message):
|
|
|
06486d |
- if verbose > 1:
|
|
|
06486d |
- log(message)
|
|
|
06486d |
-
|
|
|
06486d |
-def error_msg(s):
|
|
|
06486d |
- sys.stderr.write("%s\n" % s)
|
|
|
06486d |
-
|
|
|
06486d |
-def error_msg_and_die(s):
|
|
|
06486d |
- sys.stderr.write("%s\n" % s)
|
|
|
06486d |
- sys.exit(1)
|
|
|
06486d |
-
|
|
|
06486d |
-def xopen(name, mode):
|
|
|
06486d |
- try:
|
|
|
06486d |
- r = open(name, mode)
|
|
|
06486d |
- except IOError, ex:
|
|
|
06486d |
- error_msg_and_die("Can't open '%s': %s" % (name, ex))
|
|
|
06486d |
- return r
|
|
|
06486d |
-
|
|
|
06486d |
-
|
|
|
06486d |
-def init_gettext():
|
|
|
06486d |
- try:
|
|
|
06486d |
- locale.setlocale(locale.LC_ALL, "")
|
|
|
06486d |
- except locale.Error:
|
|
|
06486d |
- os.environ['LC_ALL'] = 'C'
|
|
|
06486d |
- locale.setlocale(locale.LC_ALL, "")
|
|
|
06486d |
- # Defeat "AttributeError: 'module' object has no attribute 'nl_langinfo'"
|
|
|
06486d |
- try:
|
|
|
06486d |
- gettext.bind_textdomain_codeset(GETTEXT_PROGNAME, locale.nl_langinfo(locale.CODESET))
|
|
|
06486d |
- except AttributeError:
|
|
|
06486d |
- pass
|
|
|
06486d |
- gettext.bindtextdomain(GETTEXT_PROGNAME, '/usr/share/locale')
|
|
|
06486d |
- gettext.textdomain(GETTEXT_PROGNAME)
|
|
|
06486d |
-
|
|
|
06486d |
-#eu_unstrip_OUT=`eu-unstrip "--core=$core" -n 2>eu_unstrip.ERR`
|
|
|
06486d |
-def extract_info_from_core(coredump_name):
|
|
|
06486d |
- """
|
|
|
06486d |
- Extracts builds with filenames,
|
|
|
06486d |
- Returns a list of tuples (build_id, filename)
|
|
|
06486d |
- """
|
|
|
06486d |
- #OFFSET = 0
|
|
|
06486d |
- BUILD_ID = 1
|
|
|
06486d |
- LIBRARY = 2
|
|
|
06486d |
- #SEP = 3
|
|
|
06486d |
- EXECUTABLE = 4
|
|
|
06486d |
-
|
|
|
06486d |
- log(_("Analyzing coredump '%s'") % coredump_name)
|
|
|
06486d |
- eu_unstrip_OUT = Popen(["eu-unstrip","--core=%s" % coredump_name, "-n"], stdout=PIPE, bufsize=-1).communicate()[0]
|
|
|
06486d |
- # parse eu_unstrip_OUT and return the list of build_ids
|
|
|
06486d |
-
|
|
|
06486d |
- # eu_unstrip_OUT = (
|
|
|
06486d |
- # "0x7f42362ca000+0x204000 c4d35d993598a6242f7525d024b5ec3becf5b447@0x7f42362ca1a0 /usr/lib64/libcanberra-gtk.so.0 - libcanberra-gtk.so.0\n"
|
|
|
06486d |
- # "0x3afa400000+0x210000 607308f916c13c3ad9ee503008d31fa671ba73ce@0x3afa4001a0 /usr/lib64/libcanberra.so.0 - libcanberra.so.0\n"
|
|
|
06486d |
- # "0x3afa400000+0x210000 607308f916c13c3ad9ee503008d31fa671ba73ce@0x3afa4001a0 /usr/lib64/libcanberra.so.0 - libcanberra.so.0\n"
|
|
|
06486d |
- # "0x3bc7000000+0x208000 3be016bb723e85779a23e111a8ab1a520b209422@0x3bc70001a0 /usr/lib64/libvorbisfile.so.3 - libvorbisfile.so.3\n"
|
|
|
06486d |
- # "0x7f423609e000+0x22c000 87f9c7d9844f364c73aa2566d6cfc9c5fa36d35d@0x7f423609e1a0 /usr/lib64/libvorbis.so.0 - libvorbis.so.0\n"
|
|
|
06486d |
- # "0x7f4235e99000+0x205000 b5bc98c125a11b571cf4f2746268a6d3cfa95b68@0x7f4235e991a0 /usr/lib64/libogg.so.0 - libogg.so.0\n"
|
|
|
06486d |
- # "0x7f4235c8b000+0x20e000 f1ff6c8ee30dba27e90ef0c5b013df2833da2889@0x7f4235c8b1a0 /usr/lib64/libtdb.so.1 - libtdb.so.1\n"
|
|
|
06486d |
- # "0x3bc3000000+0x209000 8ef56f789fd914e8d0678eb0cdfda1bfebb00b40@0x3bc30001a0 /usr/lib64/libltdl.so.7 - libltdl.so.7\n"
|
|
|
06486d |
- # "0x7f4231b64000+0x22b000 3ca5b83798349f78b362b1ea51c8a4bc8114b8b1@0x7f4231b641a0 /usr/lib64/gio/modules/libgvfsdbus.so - libgvfsdbus.so\n"
|
|
|
06486d |
- # "0x7f423192a000+0x218000 ad024a01ad132737a8cfc7c95beb7c77733a652d@0x7f423192a1a0 /usr/lib64/libgvfscommon.so.0 - libgvfscommon.so.0\n"
|
|
|
06486d |
- # "0x7f423192a000+0x218000 ad024a01ad132737a8cfc7c95beb7c77733a652d@0x7f423192a1a0 /usr/lib64/libgvfscommon.so.0 - libgvfscommon.so.0\n"
|
|
|
06486d |
- # "0x3bb8e00000+0x20e000 d240ac5755184a95c783bb98a2d05530e0cf958a@0x3bb8e001a0 /lib64/libudev.so.0 - libudev.so.0\n"
|
|
|
06486d |
- # )
|
|
|
06486d |
- #print eu_unstrip_OUT
|
|
|
06486d |
- # we failed to get build ids from the core -> die
|
|
|
06486d |
- if not eu_unstrip_OUT:
|
|
|
06486d |
- error_msg_and_die("Can't get build ids from %s" % coredump_name)
|
|
|
06486d |
-
|
|
|
06486d |
- lines = eu_unstrip_OUT.split('\n')
|
|
|
06486d |
- # using set ensures the unique values
|
|
|
06486d |
- build_ids = set()
|
|
|
06486d |
- libraries = set()
|
|
|
06486d |
-
|
|
|
06486d |
- for line in lines:
|
|
|
06486d |
- b_ids_line = line.split()
|
|
|
06486d |
- if len(b_ids_line) >= EXECUTABLE:
|
|
|
06486d |
- # [exe] -> the executable itself
|
|
|
06486d |
- # linux-vdso.so.1 -> Virtual Dynamic Shared Object
|
|
|
06486d |
- # linux-gate.so.1 -> the same as vdso
|
|
|
06486d |
- # See https://bugzilla.redhat.com/show_bug.cgi?id=706969
|
|
|
06486d |
- # "Please split kernel debuginfo packages so that VDSO debuginfos are separate" -
|
|
|
06486d |
- # we might want to remove this special-casing later.
|
|
|
06486d |
- if b_ids_line[BUILD_ID] == '-':
|
|
|
06486d |
- log(_("Missing build id: %s" % b_ids_line[EXECUTABLE]))
|
|
|
06486d |
- elif ((len(b_ids_line) == EXECUTABLE) or (b_ids_line[EXECUTABLE] not in ["linux-vdso.so.1", "linux-gate.so.1"])):
|
|
|
06486d |
- build_id = b_ids_line[BUILD_ID].split('@')[0]
|
|
|
06486d |
- build_ids.add(build_id)
|
|
|
06486d |
- library = b_ids_line[LIBRARY]
|
|
|
06486d |
- libraries.add(library)
|
|
|
06486d |
- else:
|
|
|
06486d |
- log2("skipping line '%s'" % line)
|
|
|
06486d |
- log1("Found %i build_ids" % len(build_ids))
|
|
|
06486d |
- log1("Found %i libs" % len(libraries))
|
|
|
06486d |
- return build_ids
|
|
|
06486d |
-
|
|
|
06486d |
-def build_ids_to_path(build_ids):
|
|
|
06486d |
- """
|
|
|
06486d |
- build_id1=${build_id:0:2}
|
|
|
06486d |
- build_id2=${build_id:2}
|
|
|
06486d |
- file="usr/lib/debug/.build-id/$build_id1/$build_id2.debug"
|
|
|
06486d |
- """
|
|
|
06486d |
- return ["/usr/lib/debug/.build-id/%s/%s.debug" % (b_id[:2], b_id[2:]) for b_id in build_ids]
|
|
|
06486d |
-
|
|
|
06486d |
-if __name__ == "__main__":
|
|
|
06486d |
- # localization
|
|
|
06486d |
- init_gettext()
|
|
|
06486d |
-
|
|
|
06486d |
- ABRT_VERBOSE = os.getenv("ABRT_VERBOSE")
|
|
|
06486d |
- if (ABRT_VERBOSE):
|
|
|
06486d |
- try:
|
|
|
06486d |
- verbose = int(ABRT_VERBOSE)
|
|
|
06486d |
- except:
|
|
|
06486d |
- pass
|
|
|
06486d |
-
|
|
|
06486d |
- progname = os.path.basename(sys.argv[0])
|
|
|
06486d |
- help_text = _("Usage: %s [-v] [-o OUTFILE] -c COREFILE") % progname
|
|
|
06486d |
- try:
|
|
|
06486d |
- opts, args = getopt.getopt(sys.argv[1:], "vhc:o:", ["help", "core="])
|
|
|
06486d |
- except getopt.GetoptError, err:
|
|
|
06486d |
- error_msg(err) # prints something like "option -a not recognized"
|
|
|
06486d |
- error_msg_and_die(help_text)
|
|
|
06486d |
-
|
|
|
06486d |
- core = None
|
|
|
06486d |
- opt_o = None
|
|
|
06486d |
-
|
|
|
06486d |
- for opt, arg in opts:
|
|
|
06486d |
- if opt in ("-h", "--help"):
|
|
|
06486d |
- print help_text
|
|
|
06486d |
- exit(0)
|
|
|
06486d |
- elif opt == "-v":
|
|
|
06486d |
- verbose += 1
|
|
|
06486d |
- elif opt == "-o":
|
|
|
06486d |
- opt_o = arg
|
|
|
06486d |
- elif opt in ("-c", "--core"):
|
|
|
06486d |
- core = arg
|
|
|
06486d |
-
|
|
|
06486d |
- if not core:
|
|
|
06486d |
- error_msg(_("COREFILE is not specified"))
|
|
|
06486d |
- error_msg_and_die(help_text)
|
|
|
06486d |
-
|
|
|
06486d |
- b_ids = extract_info_from_core(core)
|
|
|
06486d |
-
|
|
|
06486d |
- try:
|
|
|
06486d |
- # Note that we open -o FILE only when we reach the point
|
|
|
06486d |
- # when we are definitely going to write something to it
|
|
|
06486d |
- outfile = sys.stdout
|
|
|
06486d |
- outname = opt_o
|
|
|
06486d |
- # Make sure the file is readable for all
|
|
|
06486d |
- oldmask = os.umask(0002)
|
|
|
06486d |
- for bid in b_ids:
|
|
|
06486d |
- if outname:
|
|
|
06486d |
- outfile = xopen(outname, "w")
|
|
|
06486d |
- outname = None
|
|
|
06486d |
- outfile.write("%s\n" % bid)
|
|
|
06486d |
- outfile.close()
|
|
|
06486d |
- os.umask(oldmask)
|
|
|
06486d |
- except IOError, e:
|
|
|
06486d |
- if not opt_o:
|
|
|
06486d |
- opt_o = "<stdout>"
|
|
|
06486d |
- error_msg_and_die("Error writing to '%s': %s" % (opt_o, e))
|
|
|
06486d |
diff --git a/src/plugins/abrt-action-analyze-core.in b/src/plugins/abrt-action-analyze-core.in
|
|
|
06486d |
new file mode 100644
|
|
|
06486d |
index 0000000..0185ac5
|
|
|
06486d |
--- /dev/null
|
|
|
06486d |
+++ b/src/plugins/abrt-action-analyze-core.in
|
|
|
06486d |
@@ -0,0 +1,186 @@
|
|
|
06486d |
+#!/usr/bin/python -u
|
|
|
06486d |
+# -*- coding: utf-8 -*-
|
|
|
06486d |
+# WARNING: python -u means unbuffered I/O. Without it the messages are
|
|
|
06486d |
+# passed to the parent asynchronously which looks bad in clients.
|
|
|
06486d |
+
|
|
|
06486d |
+from subprocess import Popen, PIPE
|
|
|
06486d |
+import sys
|
|
|
06486d |
+import os
|
|
|
06486d |
+import getopt
|
|
|
06486d |
+
|
|
|
06486d |
+GETTEXT_PROGNAME = "@PACKAGE@"
|
|
|
06486d |
+import locale
|
|
|
06486d |
+import gettext
|
|
|
06486d |
+
|
|
|
06486d |
+_ = lambda x: gettext.lgettext(x)
|
|
|
06486d |
+
|
|
|
06486d |
+
|
|
|
06486d |
+verbose = 0
|
|
|
06486d |
+
|
|
|
06486d |
+def log(s):
|
|
|
06486d |
+ sys.stderr.write("%s\n" % s)
|
|
|
06486d |
+
|
|
|
06486d |
+def log1(message):
|
|
|
06486d |
+ if verbose > 0:
|
|
|
06486d |
+ log(message)
|
|
|
06486d |
+
|
|
|
06486d |
+def log2(message):
|
|
|
06486d |
+ if verbose > 1:
|
|
|
06486d |
+ log(message)
|
|
|
06486d |
+
|
|
|
06486d |
+def error_msg(s):
|
|
|
06486d |
+ sys.stderr.write("%s\n" % s)
|
|
|
06486d |
+
|
|
|
06486d |
+def error_msg_and_die(s):
|
|
|
06486d |
+ sys.stderr.write("%s\n" % s)
|
|
|
06486d |
+ sys.exit(1)
|
|
|
06486d |
+
|
|
|
06486d |
+def xopen(name, mode):
|
|
|
06486d |
+ try:
|
|
|
06486d |
+ r = open(name, mode)
|
|
|
06486d |
+ except IOError, ex:
|
|
|
06486d |
+ error_msg_and_die("Can't open '%s': %s" % (name, ex))
|
|
|
06486d |
+ return r
|
|
|
06486d |
+
|
|
|
06486d |
+
|
|
|
06486d |
+def init_gettext():
|
|
|
06486d |
+ try:
|
|
|
06486d |
+ locale.setlocale(locale.LC_ALL, "")
|
|
|
06486d |
+ except locale.Error:
|
|
|
06486d |
+ os.environ['LC_ALL'] = 'C'
|
|
|
06486d |
+ locale.setlocale(locale.LC_ALL, "")
|
|
|
06486d |
+ # Defeat "AttributeError: 'module' object has no attribute 'nl_langinfo'"
|
|
|
06486d |
+ try:
|
|
|
06486d |
+ gettext.bind_textdomain_codeset(GETTEXT_PROGNAME, locale.nl_langinfo(locale.CODESET))
|
|
|
06486d |
+ except AttributeError:
|
|
|
06486d |
+ pass
|
|
|
06486d |
+ gettext.bindtextdomain(GETTEXT_PROGNAME, "@localedir@")
|
|
|
06486d |
+ gettext.textdomain(GETTEXT_PROGNAME)
|
|
|
06486d |
+
|
|
|
06486d |
+#eu_unstrip_OUT=`eu-unstrip "--core=$core" -n 2>eu_unstrip.ERR`
|
|
|
06486d |
+def extract_info_from_core(coredump_name):
|
|
|
06486d |
+ """
|
|
|
06486d |
+ Extracts builds with filenames,
|
|
|
06486d |
+ Returns a list of tuples (build_id, filename)
|
|
|
06486d |
+ """
|
|
|
06486d |
+ #OFFSET = 0
|
|
|
06486d |
+ BUILD_ID = 1
|
|
|
06486d |
+ LIBRARY = 2
|
|
|
06486d |
+ #SEP = 3
|
|
|
06486d |
+ EXECUTABLE = 4
|
|
|
06486d |
+
|
|
|
06486d |
+ log(_("Analyzing coredump '%s'") % coredump_name)
|
|
|
06486d |
+ eu_unstrip_OUT = Popen(["eu-unstrip","--core=%s" % coredump_name, "-n"], stdout=PIPE, bufsize=-1).communicate()[0]
|
|
|
06486d |
+ # parse eu_unstrip_OUT and return the list of build_ids
|
|
|
06486d |
+
|
|
|
06486d |
+ # eu_unstrip_OUT = (
|
|
|
06486d |
+ # "0x7f42362ca000+0x204000 c4d35d993598a6242f7525d024b5ec3becf5b447@0x7f42362ca1a0 /usr/lib64/libcanberra-gtk.so.0 - libcanberra-gtk.so.0\n"
|
|
|
06486d |
+ # "0x3afa400000+0x210000 607308f916c13c3ad9ee503008d31fa671ba73ce@0x3afa4001a0 /usr/lib64/libcanberra.so.0 - libcanberra.so.0\n"
|
|
|
06486d |
+ # "0x3afa400000+0x210000 607308f916c13c3ad9ee503008d31fa671ba73ce@0x3afa4001a0 /usr/lib64/libcanberra.so.0 - libcanberra.so.0\n"
|
|
|
06486d |
+ # "0x3bc7000000+0x208000 3be016bb723e85779a23e111a8ab1a520b209422@0x3bc70001a0 /usr/lib64/libvorbisfile.so.3 - libvorbisfile.so.3\n"
|
|
|
06486d |
+ # "0x7f423609e000+0x22c000 87f9c7d9844f364c73aa2566d6cfc9c5fa36d35d@0x7f423609e1a0 /usr/lib64/libvorbis.so.0 - libvorbis.so.0\n"
|
|
|
06486d |
+ # "0x7f4235e99000+0x205000 b5bc98c125a11b571cf4f2746268a6d3cfa95b68@0x7f4235e991a0 /usr/lib64/libogg.so.0 - libogg.so.0\n"
|
|
|
06486d |
+ # "0x7f4235c8b000+0x20e000 f1ff6c8ee30dba27e90ef0c5b013df2833da2889@0x7f4235c8b1a0 /usr/lib64/libtdb.so.1 - libtdb.so.1\n"
|
|
|
06486d |
+ # "0x3bc3000000+0x209000 8ef56f789fd914e8d0678eb0cdfda1bfebb00b40@0x3bc30001a0 /usr/lib64/libltdl.so.7 - libltdl.so.7\n"
|
|
|
06486d |
+ # "0x7f4231b64000+0x22b000 3ca5b83798349f78b362b1ea51c8a4bc8114b8b1@0x7f4231b641a0 /usr/lib64/gio/modules/libgvfsdbus.so - libgvfsdbus.so\n"
|
|
|
06486d |
+ # "0x7f423192a000+0x218000 ad024a01ad132737a8cfc7c95beb7c77733a652d@0x7f423192a1a0 /usr/lib64/libgvfscommon.so.0 - libgvfscommon.so.0\n"
|
|
|
06486d |
+ # "0x7f423192a000+0x218000 ad024a01ad132737a8cfc7c95beb7c77733a652d@0x7f423192a1a0 /usr/lib64/libgvfscommon.so.0 - libgvfscommon.so.0\n"
|
|
|
06486d |
+ # "0x3bb8e00000+0x20e000 d240ac5755184a95c783bb98a2d05530e0cf958a@0x3bb8e001a0 /lib64/libudev.so.0 - libudev.so.0\n"
|
|
|
06486d |
+ # )
|
|
|
06486d |
+ #print eu_unstrip_OUT
|
|
|
06486d |
+ # we failed to get build ids from the core -> die
|
|
|
06486d |
+ if not eu_unstrip_OUT:
|
|
|
06486d |
+ error_msg_and_die("Can't get build ids from %s" % coredump_name)
|
|
|
06486d |
+
|
|
|
06486d |
+ lines = eu_unstrip_OUT.split('\n')
|
|
|
06486d |
+ # using set ensures the unique values
|
|
|
06486d |
+ build_ids = set()
|
|
|
06486d |
+ libraries = set()
|
|
|
06486d |
+
|
|
|
06486d |
+ for line in lines:
|
|
|
06486d |
+ b_ids_line = line.split()
|
|
|
06486d |
+ if len(b_ids_line) >= EXECUTABLE:
|
|
|
06486d |
+ # [exe] -> the executable itself
|
|
|
06486d |
+ # linux-vdso.so.1 -> Virtual Dynamic Shared Object
|
|
|
06486d |
+ # linux-gate.so.1 -> the same as vdso
|
|
|
06486d |
+ # See https://bugzilla.redhat.com/show_bug.cgi?id=706969
|
|
|
06486d |
+ # "Please split kernel debuginfo packages so that VDSO debuginfos are separate" -
|
|
|
06486d |
+ # we might want to remove this special-casing later.
|
|
|
06486d |
+ if b_ids_line[BUILD_ID] == '-':
|
|
|
06486d |
+ log(_("Missing build id: %s" % b_ids_line[EXECUTABLE]))
|
|
|
06486d |
+ elif ((len(b_ids_line) == EXECUTABLE) or (b_ids_line[EXECUTABLE] not in ["linux-vdso.so.1", "linux-gate.so.1"])):
|
|
|
06486d |
+ build_id = b_ids_line[BUILD_ID].split('@')[0]
|
|
|
06486d |
+ build_ids.add(build_id)
|
|
|
06486d |
+ library = b_ids_line[LIBRARY]
|
|
|
06486d |
+ libraries.add(library)
|
|
|
06486d |
+ else:
|
|
|
06486d |
+ log2("skipping line '%s'" % line)
|
|
|
06486d |
+ log1("Found %i build_ids" % len(build_ids))
|
|
|
06486d |
+ log1("Found %i libs" % len(libraries))
|
|
|
06486d |
+ return build_ids
|
|
|
06486d |
+
|
|
|
06486d |
+def build_ids_to_path(build_ids):
|
|
|
06486d |
+ """
|
|
|
06486d |
+ build_id1=${build_id:0:2}
|
|
|
06486d |
+ build_id2=${build_id:2}
|
|
|
06486d |
+ file="usr/lib/debug/.build-id/$build_id1/$build_id2.debug"
|
|
|
06486d |
+ """
|
|
|
06486d |
+ return ["/usr/lib/debug/.build-id/%s/%s.debug" % (b_id[:2], b_id[2:]) for b_id in build_ids]
|
|
|
06486d |
+
|
|
|
06486d |
+if __name__ == "__main__":
|
|
|
06486d |
+ # localization
|
|
|
06486d |
+ init_gettext()
|
|
|
06486d |
+
|
|
|
06486d |
+ ABRT_VERBOSE = os.getenv("ABRT_VERBOSE")
|
|
|
06486d |
+ if (ABRT_VERBOSE):
|
|
|
06486d |
+ try:
|
|
|
06486d |
+ verbose = int(ABRT_VERBOSE)
|
|
|
06486d |
+ except:
|
|
|
06486d |
+ pass
|
|
|
06486d |
+
|
|
|
06486d |
+ progname = os.path.basename(sys.argv[0])
|
|
|
06486d |
+ help_text = _("Usage: %s [-v] [-o OUTFILE] -c COREFILE") % progname
|
|
|
06486d |
+ try:
|
|
|
06486d |
+ opts, args = getopt.getopt(sys.argv[1:], "vhc:o:", ["help", "core="])
|
|
|
06486d |
+ except getopt.GetoptError, err:
|
|
|
06486d |
+ error_msg(err) # prints something like "option -a not recognized"
|
|
|
06486d |
+ error_msg_and_die(help_text)
|
|
|
06486d |
+
|
|
|
06486d |
+ core = None
|
|
|
06486d |
+ opt_o = None
|
|
|
06486d |
+
|
|
|
06486d |
+ for opt, arg in opts:
|
|
|
06486d |
+ if opt in ("-h", "--help"):
|
|
|
06486d |
+ print help_text
|
|
|
06486d |
+ exit(0)
|
|
|
06486d |
+ elif opt == "-v":
|
|
|
06486d |
+ verbose += 1
|
|
|
06486d |
+ elif opt == "-o":
|
|
|
06486d |
+ opt_o = arg
|
|
|
06486d |
+ elif opt in ("-c", "--core"):
|
|
|
06486d |
+ core = arg
|
|
|
06486d |
+
|
|
|
06486d |
+ if not core:
|
|
|
06486d |
+ error_msg(_("COREFILE is not specified"))
|
|
|
06486d |
+ error_msg_and_die(help_text)
|
|
|
06486d |
+
|
|
|
06486d |
+ b_ids = extract_info_from_core(core)
|
|
|
06486d |
+
|
|
|
06486d |
+ try:
|
|
|
06486d |
+ # Note that we open -o FILE only when we reach the point
|
|
|
06486d |
+ # when we are definitely going to write something to it
|
|
|
06486d |
+ outfile = sys.stdout
|
|
|
06486d |
+ outname = opt_o
|
|
|
06486d |
+ # Make sure the file is readable for all
|
|
|
06486d |
+ oldmask = os.umask(0002)
|
|
|
06486d |
+ for bid in b_ids:
|
|
|
06486d |
+ if outname:
|
|
|
06486d |
+ outfile = xopen(outname, "w")
|
|
|
06486d |
+ outname = None
|
|
|
06486d |
+ outfile.write("%s\n" % bid)
|
|
|
06486d |
+ outfile.close()
|
|
|
06486d |
+ os.umask(oldmask)
|
|
|
06486d |
+ except IOError, e:
|
|
|
06486d |
+ if not opt_o:
|
|
|
06486d |
+ opt_o = "<stdout>"
|
|
|
06486d |
+ error_msg_and_die("Error writing to '%s': %s" % (opt_o, e))
|
|
|
06486d |
diff --git a/src/plugins/abrt-action-install-debuginfo-to-abrt-cache.c b/src/plugins/abrt-action-install-debuginfo-to-abrt-cache.c
|
|
|
06486d |
index cf74326..e0eccc0 100644
|
|
|
06486d |
--- a/src/plugins/abrt-action-install-debuginfo-to-abrt-cache.c
|
|
|
06486d |
+++ b/src/plugins/abrt-action-install-debuginfo-to-abrt-cache.c
|
|
|
06486d |
@@ -74,7 +74,8 @@ int main(int argc, char **argv)
|
|
|
06486d |
// However since we communicate through environment variables
|
|
|
06486d |
// we have to keep a whitelist of variables to keep.
|
|
|
06486d |
static const char *whitelist[] = {
|
|
|
06486d |
- "REPORT_CLIENT_SLAVE" // Check if the app is being run as a slave
|
|
|
06486d |
+ "REPORT_CLIENT_SLAVE", // Check if the app is being run as a slave
|
|
|
06486d |
+ "LANG",
|
|
|
06486d |
};
|
|
|
06486d |
const size_t wlsize = sizeof(whitelist)/sizeof(char*);
|
|
|
06486d |
char *setlist[sizeof(whitelist)/sizeof(char*)] = { 0 };
|
|
|
06486d |
--
|
|
|
06486d |
1.8.3.1
|
|
|
06486d |
|