projects
/
claws.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Coverity fixes
[claws.git]
/
src
/
plugins
/
vcalendar
/
vcal_manager.c
diff --git
a/src/plugins/vcalendar/vcal_manager.c
b/src/plugins/vcalendar/vcal_manager.c
index 7ae557e959022b44ce50496330311c2b2bb944f2..7a4cef28f4f24746f4cb377d3bd0057179baa444 100644
(file)
--- a/
src/plugins/vcalendar/vcal_manager.c
+++ b/
src/plugins/vcalendar/vcal_manager.c
@@
-638,8
+638,8
@@
gchar *vcal_manager_dateevent_dump(const gchar *uid, FolderItem *item)
if (str_write_to_file(body, tmpfile) < 0) {
g_free(tmpfile);
tmpfile = NULL;
if (str_write_to_file(body, tmpfile) < 0) {
g_free(tmpfile);
tmpfile = NULL;
- }
- chmod(tmpfile, S_IRUSR|S_IWUSR);
+ }
else
+
chmod(tmpfile, S_IRUSR|S_IWUSR);
g_free(body);
g_free(headers);
g_free(body);
g_free(headers);
@@
-751,8
+751,8
@@
gchar *vcal_manager_icalevent_dump(icalcomponent *event, gchar *orga, icalcompon
if (str_write_to_file(body, tmpfile) < 0) {
g_free(tmpfile);
tmpfile = NULL;
if (str_write_to_file(body, tmpfile) < 0) {
g_free(tmpfile);
tmpfile = NULL;
- }
- chmod(tmpfile, S_IRUSR|S_IWUSR);
+ }
else
+
chmod(tmpfile, S_IRUSR|S_IWUSR);
g_strfreev(lines);
g_free(body);
g_strfreev(lines);
g_free(body);
@@
-776,7
+776,7
@@
VCalEvent * vcal_manager_new_event (const gchar *uid,
const gchar *url,
enum icalproperty_method method,
gint sequence,
const gchar *url,
enum icalproperty_method method,
gint sequence,
- enum ical
property
_kind type)
+ enum ical
component
_kind type)
{
VCalEvent *event = g_new0(VCalEvent, 1);
{
VCalEvent *event = g_new0(VCalEvent, 1);
@@
-953,14
+953,20
@@
void vcal_manager_save_event (VCalEvent *event, gboolean export_after)
path = vcal_manager_get_event_file(event->uid);
if ((pfile = prefs_write_open(path)) == NULL) {
path = vcal_manager_get_event_file(event->uid);
if ((pfile = prefs_write_open(path)) == NULL) {
- make_dir(vcal_manager_get_event_path());
+ gchar *dir_path = vcal_manager_get_event_path();
+ if (!is_dir_exist(dir_path) && make_dir(vcal_manager_get_event_path()) != 0) {
+ g_free(dir_path);
+ g_free(path);
+ return;
+ }
+ g_free(dir_path);
if ((pfile = prefs_write_open(path)) == NULL) {
if ((pfile = prefs_write_open(path)) == NULL) {
- free(path);
+
g_
free(path);
return;
}
}
return;
}
}
- free(path);
+
g_
free(path);
xml_file_put_xml_decl(pfile->fp);
xml_write_tree(rootnode, pfile->fp);
xml_free_tree(rootnode);
xml_file_put_xml_decl(pfile->fp);
xml_write_tree(rootnode, pfile->fp);
xml_free_tree(rootnode);
@@
-1174,6
+1180,8
@@
static gchar *write_headers(PrefsAccount *account,
gchar msgid[128];
gchar *calmsgid = NULL;
gchar msgid[128];
gchar *calmsgid = NULL;
+ cm_return_val_if_fail(account != NULL, NULL);
+
memset(date, 0, sizeof(date));
if (is_pseudo_display) {
memset(date, 0, sizeof(date));
if (is_pseudo_display) {