/* Copyright (C) 2010 Denys Vlasenko (dvlasenk@redhat.com) Copyright (C) 2010 RedHat inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #include "abrt_types.h" #include "abrtlib.h" #include "CrashTypes.h" const char *const must_have_files[] = { FILENAME_ARCHITECTURE, FILENAME_KERNEL , FILENAME_PACKAGE , FILENAME_COMPONENT , FILENAME_RELEASE , FILENAME_EXECUTABLE , NULL }; static const char *const editable_files[] = { FILENAME_DESCRIPTION, FILENAME_COMMENT , FILENAME_REPRODUCE , FILENAME_BACKTRACE , NULL }; static bool is_editable(const char *name, const char *const *v) { while (*v) { if (strcmp(*v, name) == 0) return true; v++; } return false; } bool is_editable_file(const char *file_name) { return is_editable(file_name, editable_files); } void add_to_crash_data_ext(map_crash_data_t& pCrashData, const char *pItem, const char *pType, const char *pEditable, const char *pContent) { map_crash_data_t::iterator it = pCrashData.find(pItem); if (it == pCrashData.end()) { vector_string_t& v = pCrashData[pItem]; /* create empty vector */ v.push_back(pType); v.push_back(pEditable); v.push_back(pContent); return; } vector_string_t& v = it->second; while (v.size() < 3) v.push_back(""); v[CD_TYPE] = pType; v[CD_EDITABLE] = pEditable; v[CD_CONTENT] = pContent; } void add_to_crash_data(map_crash_data_t& pCrashData, const char *pItem, const char *pContent) { add_to_crash_data_ext(pCrashData, pItem, CD_TXT, CD_ISNOTEDITABLE, pContent); } static const std::string* helper_get_crash_data_item_content(const map_crash_data_t& crash_data, const char *key) { map_crash_data_t::const_iterator it = crash_data.find(key); if (it == crash_data.end()) { return NULL; } if (it->second.size() <= CD_CONTENT) { return NULL; } return &it->second[CD_CONTENT]; } const std::string& get_crash_data_item_content(const map_crash_data_t& crash_data, const char *key) { const std::string* sp = helper_get_crash_data_item_content(crash_data, key); if (sp == NULL) { if (crash_data.find(key) == crash_data.end()) error_msg_and_die("Error accessing crash data: no ['%s']", key); error_msg_and_die("Error accessing crash data: no ['%s'][%d]", key, CD_CONTENT); } return *sp; } const char *get_crash_data_item_content_or_NULL(const map_crash_data_t& crash_data, const char *key) { const std::string* sp = helper_get_crash_data_item_content(crash_data, key); if (!sp) { return NULL; } return sp->c_str(); } void log_map_crash_data(const map_crash_data_t& data, const char *name) { map_crash_data_t::const_iterator it = data.begin(); while (it != data.end()) { ssize_t sz = it->second.size(); log("%s[%s]:%s/%s/'%.20s'", name, it->first.c_str(), sz > 0 ? it->second[0].c_str() : "", sz > 1 ? it->second[1].c_str() : "", sz > 2 ? it->second[2].c_str() : "" ); it++; } }