summaryrefslogtreecommitdiffstats
path: root/lib/MiddleWare/test.cpp
diff options
context:
space:
mode:
authorJiri Moskovcak <jmoskovc@redhat.com>2009-02-12 12:34:25 +0100
committerJiri Moskovcak <jmoskovc@redhat.com>2009-02-12 12:34:25 +0100
commit53821dddf0b6ee66dc5f0684b17c541c157656ec (patch)
tree00dcb130b6fd32ef137cd7b139bbebfeb0c060b4 /lib/MiddleWare/test.cpp
parent356da89a4e2e6e50ceade12f286d104fe1c17eae (diff)
parentc93222d1407ede085833d3a91bfeda5f0f910eb4 (diff)
downloadabrt-53821dddf0b6ee66dc5f0684b17c541c157656ec.tar.gz
abrt-53821dddf0b6ee66dc5f0684b17c541c157656ec.tar.xz
abrt-53821dddf0b6ee66dc5f0684b17c541c157656ec.zip
Merge branch 'master' of git://git.fedorahosted.org/git/crash-catcher
Diffstat (limited to 'lib/MiddleWare/test.cpp')
-rw-r--r--lib/MiddleWare/test.cpp28
1 files changed, 19 insertions, 9 deletions
diff --git a/lib/MiddleWare/test.cpp b/lib/MiddleWare/test.cpp
index 8424aa9..57c5506 100644
--- a/lib/MiddleWare/test.cpp
+++ b/lib/MiddleWare/test.cpp
@@ -35,23 +35,33 @@ int main(int argc, char** argv)
CMiddleWare middleWare(PLUGINS_CONF_DIR,
PLUGINS_LIB_DIR,
std::string(CONF_DIR) + "/CrashCatcher.conf");
+ /* Create DebugDump */
CDebugDump dd;
-
char pid[100];
sprintf(pid, "%d", getpid());
-
- dd.Create(std::string(DEBUG_DUMPS_DIR)+"/"+pid, pid);
+ dd.Create(std::string(DEBUG_DUMPS_DIR)+"/"+pid);
+ dd.SaveProc(pid);
+ dd.SavePackage();
dd.SaveText(FILENAME_LANGUAGE, "CCpp");
dd.SaveBinary(FILENAME_BINARYDATA1, "ass0-9as", sizeof("ass0-9as"));
+ /* Try to save it into DB */
CMiddleWare::crash_info_t info;
- middleWare.SaveDebugDump(std::string(DEBUG_DUMPS_DIR)+"/"+pid, info);
-
- std::cout << "Application Crashed! " <<
- info.m_sPackage << ": " <<
- info.m_sExecutable << "(" <<
- info.m_sCount << ")" << std::endl;
+ if (middleWare.SaveDebugDump(std::string(DEBUG_DUMPS_DIR)+"/"+pid, info))
+ {
+ std::cout << "Application Crashed! " <<
+ "(" << info.m_sTime << " [" << info.m_sCount << "]) " <<
+ info.m_sPackage << ": " <<
+ info.m_sExecutable << std::endl;
+ /* Get Report, so user can change data (remove private stuff)
+ * If we do not want user interaction, just send data immediately
+ */
+ CMiddleWare::crash_report_t crashReport;
+ middleWare.CreateReport(info.m_sUUID, info.m_sUID, crashReport);
+ /* Report crash */
+ middleWare.Report(crashReport);
+ }
}
catch (std::string sError)
{