summaryrefslogtreecommitdiffstats
path: root/src/Hooks/abrt-hook-python.cpp
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2010-02-04 21:19:30 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2010-02-04 21:19:30 +0100
commit75c6e1fc1113984b30a4d84c1cfe6e97c70c398f (patch)
treee982ef3d44631b6a622e5712b1d48b2b652ca69d /src/Hooks/abrt-hook-python.cpp
parentbaacc3cadfd08293e6f46bd84ab322d0cb67bf10 (diff)
downloadabrt-75c6e1fc1113984b30a4d84c1cfe6e97c70c398f.tar.gz
abrt-75c6e1fc1113984b30a4d84c1cfe6e97c70c398f.tar.xz
abrt-75c6e1fc1113984b30a4d84c1cfe6e97c70c398f.zip
use .new suffix on new crashdumps; strip it when crashdump is ready
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'src/Hooks/abrt-hook-python.cpp')
-rw-r--r--src/Hooks/abrt-hook-python.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/Hooks/abrt-hook-python.cpp b/src/Hooks/abrt-hook-python.cpp
index 90197cc..5686c17 100644
--- a/src/Hooks/abrt-hook-python.cpp
+++ b/src/Hooks/abrt-hook-python.cpp
@@ -139,8 +139,10 @@ int main(int argc, char** argv)
// Create directory with the debug dump
char path[PATH_MAX];
- snprintf(path, sizeof(path), DEBUG_DUMPS_DIR"/pyhook-%ld-%s",
+ unsigned path_len = snprintf(path, sizeof(path), DEBUG_DUMPS_DIR"/pyhook-%ld-%s.new",
(long)time(NULL), pid);
+ if (path_len >= sizeof(path))
+ exit(1);
CDebugDump dd;
try {
dd.Create(path, getuid());
@@ -160,6 +162,12 @@ int main(int argc, char** argv)
dd.SaveText(FILENAME_UID, uid);
dd.Close();
+
+ char *newpath = xstrndup(path, path_len - (sizeof(".new")-1));
+ if (rename(path, newpath) != 0)
+ strcpy(path, newpath);
+ free(newpath);
+
log("saved python crash dump of pid %s to %s", pid, path);
if (setting_MaxCrashReportsSize > 0)