replaced g_free() by mhl_mem_free()

This commit is contained in:
Enrico Weigelt, metux IT service 2009-01-30 19:28:35 +01:00
parent 8bc0e27a54
commit 15d7d47c15
73 changed files with 1146 additions and 1054 deletions

View File

@ -1,5 +1,10 @@
2009-01-30 Enrico Weigelt, metux ITS <weigelt@metux.de>
* replaced calls to g_free() by mhl_mem_free()
2009-01-29 Mikhail S. Pobolovets <styx.mp@gmail.com> 2009-01-29 Mikhail S. Pobolovets <styx.mp@gmail.com>
* lib/mc.ext.in: update for OpenOffice and StarOffice viewer. * lib/mc.ext.in: update for OpenOffice and StarOffice viewer.
odt2txt is now used odt2txt is now used

View File

@ -28,11 +28,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -158,13 +159,13 @@ int book_mark_clear (WEdit * edit, int line, int c)
p->prev->next = p->next; p->prev->next = p->next;
if (p->next) if (p->next)
p->next->prev = p->prev; p->next->prev = p->prev;
g_free (p); mhl_mem_free (p);
break; break;
} }
} }
/* if there is only our dummy book mark left, clear it for speed */ /* if there is only our dummy book mark left, clear it for speed */
if (edit->book_mark->line == -1 && !edit->book_mark->next) { if (edit->book_mark->line == -1 && !edit->book_mark->next) {
g_free (edit->book_mark); mhl_mem_free (edit->book_mark);
edit->book_mark = 0; edit->book_mark = 0;
} }
return r; return r;
@ -185,11 +186,11 @@ void book_mark_flush (WEdit * edit, int c)
q->prev->next = q->next; q->prev->next = q->next;
if (p) if (p)
p->prev = q->prev; p->prev = q->prev;
g_free (q); mhl_mem_free (q);
} }
} }
if (!edit->book_mark->next) { if (!edit->book_mark->next) {
g_free (edit->book_mark); mhl_mem_free (edit->book_mark);
edit->book_mark = 0; edit->book_mark = 0;
} }
} }

View File

@ -17,6 +17,9 @@
*/ */
#include <config.h> #include <config.h>
#include <mhl/memory.h>
#include "edit.h" #include "edit.h"
#include "../src/global.h" #include "../src/global.h"
#include "../src/wtools.h" #include "../src/wtools.h"
@ -70,9 +73,9 @@ edit_syntax_dialog (void) {
if ((syntax = exec_edit_syntax_dialog ((const char**) names)) < 0) { if ((syntax = exec_edit_syntax_dialog ((const char**) names)) < 0) {
for (i = 0; names[i]; i++) { for (i = 0; names[i]; i++) {
g_free (names[i]); mhl_mem_free (names[i]);
} }
g_free (names); mhl_mem_free (names);
return; return;
} }
@ -88,7 +91,7 @@ edit_syntax_dialog (void) {
break; break;
default: default:
option_auto_syntax = 0; option_auto_syntax = 0;
g_free (option_syntax_type); mhl_mem_free (option_syntax_type);
option_syntax_type = g_strdup (names[syntax - N_DFLT_ENTRIES]); option_syntax_type = g_strdup (names[syntax - N_DFLT_ENTRIES]);
} }
@ -100,8 +103,8 @@ edit_syntax_dialog (void) {
edit_load_syntax (wedit, NULL, option_syntax_type); edit_load_syntax (wedit, NULL, option_syntax_type);
for (i = 0; names[i]; i++) { for (i = 0; names[i]; i++) {
g_free (names[i]); mhl_mem_free (names[i]);
} }
g_free (names); mhl_mem_free (names);
g_free (old_syntax_type); mhl_mem_free (old_syntax_type);
} }

View File

@ -22,6 +22,7 @@
*/ */
#include <config.h> #include <config.h>
#include <stdio.h> #include <stdio.h>
#include <stdarg.h> #include <stdarg.h>
#include <sys/types.h> #include <sys/types.h>
@ -30,9 +31,10 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -216,7 +218,7 @@ edit_get_filter (const char *filename)
l = strlen (quoted_name); l = strlen (quoted_name);
p = g_malloc (strlen (all_filters[i].read) + l + 2); p = g_malloc (strlen (all_filters[i].read) + l + 2);
sprintf (p, all_filters[i].read, quoted_name); sprintf (p, all_filters[i].read, quoted_name);
g_free (quoted_name); mhl_mem_free (quoted_name);
return p; return p;
} }
@ -232,7 +234,7 @@ edit_get_write_filter (const char *write_name, const char *filename)
l = strlen (writename); l = strlen (writename);
p = g_malloc (strlen (all_filters[i].write) + l + 2); p = g_malloc (strlen (all_filters[i].write) + l + 2);
sprintf (p, all_filters[i].write, writename); sprintf (p, all_filters[i].write, writename);
g_free (writename); mhl_mem_free (writename);
return p; return p;
} }
@ -276,7 +278,7 @@ edit_insert_file (WEdit *edit, const char *filename)
g_string_sprintf (errmsg, _(" Error reading from pipe: %s "), p); g_string_sprintf (errmsg, _(" Error reading from pipe: %s "), p);
edit_error_dialog (_("Error"), errmsg->str); edit_error_dialog (_("Error"), errmsg->str);
g_string_free (errmsg, TRUE); g_string_free (errmsg, TRUE);
g_free (p); mhl_mem_free (p);
return 0; return 0;
} }
} else { } else {
@ -284,10 +286,10 @@ edit_insert_file (WEdit *edit, const char *filename)
g_string_sprintf (errmsg, _(" Cannot open pipe for reading: %s "), p); g_string_sprintf (errmsg, _(" Cannot open pipe for reading: %s "), p);
edit_error_dialog (_("Error"), errmsg->str); edit_error_dialog (_("Error"), errmsg->str);
g_string_free (errmsg, TRUE); g_string_free (errmsg, TRUE);
g_free (p); mhl_mem_free (p);
return 0; return 0;
} }
g_free (p); mhl_mem_free (p);
} else { } else {
int i, file, blocklen; int i, file, blocklen;
long current = edit->curs1; long current = edit->curs1;
@ -300,7 +302,7 @@ edit_insert_file (WEdit *edit, const char *filename)
edit_insert (edit, buf[i]); edit_insert (edit, buf[i]);
} }
edit_cursor_move (edit, current - edit->curs1); edit_cursor_move (edit, current - edit->curs1);
g_free (buf); mhl_mem_free (buf);
mc_close (file); mc_close (file);
if (blocklen) if (blocklen)
return 0; return 0;
@ -447,7 +449,7 @@ edit_load_position (WEdit *edit)
filename = vfs_canon (edit->filename); filename = vfs_canon (edit->filename);
load_file_position (filename, &line, &column); load_file_position (filename, &line, &column);
g_free (filename); mhl_mem_free (filename);
edit_move_to_line (edit, line - 1); edit_move_to_line (edit, line - 1);
edit->prev_col = column; edit->prev_col = column;
@ -466,7 +468,7 @@ edit_save_position (WEdit *edit)
filename = vfs_canon (edit->filename); filename = vfs_canon (edit->filename);
save_file_position (filename, edit->curs_line + 1, edit->curs_col); save_file_position (filename, edit->curs_line + 1, edit->curs_col);
g_free (filename); mhl_mem_free (filename);
} }
/* Clean the WEdit stricture except the widget part */ /* Clean the WEdit stricture except the widget part */
@ -540,7 +542,7 @@ edit_init (WEdit *edit, int lines, int columns, const char *filename,
if (edit_load_file (edit)) { if (edit_load_file (edit)) {
/* edit_load_file already gives an error message */ /* edit_load_file already gives an error message */
if (to_free) if (to_free)
g_free (edit); mhl_mem_free (edit);
return 0; return 0;
} }
edit->loading_done = 1; edit->loading_done = 1;
@ -591,13 +593,13 @@ edit_clean (WEdit *edit)
edit_free_syntax_rules (edit); edit_free_syntax_rules (edit);
book_mark_flush (edit, -1); book_mark_flush (edit, -1);
for (; j <= MAXBUFF; j++) { for (; j <= MAXBUFF; j++) {
g_free (edit->buffers1[j]); mhl_mem_free (edit->buffers1[j]);
g_free (edit->buffers2[j]); mhl_mem_free (edit->buffers2[j]);
} }
g_free (edit->undo_stack); mhl_mem_free (edit->undo_stack);
g_free (edit->filename); mhl_mem_free (edit->filename);
g_free (edit->dir); mhl_mem_free (edit->dir);
edit_purge_widget (edit); edit_purge_widget (edit);
@ -637,12 +639,12 @@ edit_reload (WEdit *edit, const char *filename)
e = g_malloc0 (sizeof (WEdit)); e = g_malloc0 (sizeof (WEdit));
e->widget = edit->widget; e->widget = edit->widget;
if (!edit_init (e, lines, columns, filename, 0)) { if (!edit_init (e, lines, columns, filename, 0)) {
g_free (e); mhl_mem_free (e);
return 0; return 0;
} }
edit_clean (edit); edit_clean (edit);
memcpy (edit, e, sizeof (WEdit)); memcpy (edit, e, sizeof (WEdit));
g_free (e); mhl_mem_free (e);
return 1; return 1;
} }
@ -928,7 +930,7 @@ int edit_delete (WEdit * edit)
p = edit->buffers2[(edit->curs2 - 1) >> S_EDIT_BUF_SIZE][EDIT_BUF_SIZE - ((edit->curs2 - 1) & M_EDIT_BUF_SIZE) - 1]; p = edit->buffers2[(edit->curs2 - 1) >> S_EDIT_BUF_SIZE][EDIT_BUF_SIZE - ((edit->curs2 - 1) & M_EDIT_BUF_SIZE) - 1];
if (!(edit->curs2 & M_EDIT_BUF_SIZE)) { if (!(edit->curs2 & M_EDIT_BUF_SIZE)) {
g_free (edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE]); mhl_mem_free (edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE]);
edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] = NULL; edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] = NULL;
} }
edit->last_byte--; edit->last_byte--;
@ -965,7 +967,7 @@ edit_backspace (WEdit * edit)
p = *(edit->buffers1[(edit->curs1 - 1) >> S_EDIT_BUF_SIZE] + ((edit->curs1 - 1) & M_EDIT_BUF_SIZE)); p = *(edit->buffers1[(edit->curs1 - 1) >> S_EDIT_BUF_SIZE] + ((edit->curs1 - 1) & M_EDIT_BUF_SIZE));
if (!((edit->curs1 - 1) & M_EDIT_BUF_SIZE)) { if (!((edit->curs1 - 1) & M_EDIT_BUF_SIZE)) {
g_free (edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE]); mhl_mem_free (edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE]);
edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE] = NULL; edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE] = NULL;
} }
edit->last_byte--; edit->last_byte--;
@ -1050,7 +1052,7 @@ edit_move_backward_lots (WEdit *edit, long increment)
edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] = edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] =
g_malloc (EDIT_BUF_SIZE); g_malloc (EDIT_BUF_SIZE);
} else { } else {
g_free (p); mhl_mem_free (p);
} }
s = edit->curs1 & M_EDIT_BUF_SIZE; s = edit->curs1 & M_EDIT_BUF_SIZE;
@ -1088,7 +1090,7 @@ edit_move_backward_lots (WEdit *edit, long increment)
edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] = edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] =
g_malloc (EDIT_BUF_SIZE); g_malloc (EDIT_BUF_SIZE);
} else { } else {
g_free (p); mhl_mem_free (p);
} }
} }
return edit_get_byte (edit, edit->curs1); return edit_get_byte (edit, edit->curs1);
@ -1124,7 +1126,7 @@ void edit_cursor_move (WEdit * edit, long increment)
edit->curs2++; edit->curs2++;
c = edit->buffers1[(edit->curs1 - 1) >> S_EDIT_BUF_SIZE][(edit->curs1 - 1) & M_EDIT_BUF_SIZE]; c = edit->buffers1[(edit->curs1 - 1) >> S_EDIT_BUF_SIZE][(edit->curs1 - 1) & M_EDIT_BUF_SIZE];
if (!((edit->curs1 - 1) & M_EDIT_BUF_SIZE)) { if (!((edit->curs1 - 1) & M_EDIT_BUF_SIZE)) {
g_free (edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE]); mhl_mem_free (edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE]);
edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE] = NULL; edit->buffers1[edit->curs1 >> S_EDIT_BUF_SIZE] = NULL;
} }
edit->curs1--; edit->curs1--;
@ -1148,7 +1150,7 @@ void edit_cursor_move (WEdit * edit, long increment)
edit->curs1++; edit->curs1++;
c = edit->buffers2[(edit->curs2 - 1) >> S_EDIT_BUF_SIZE][EDIT_BUF_SIZE - ((edit->curs2 - 1) & M_EDIT_BUF_SIZE) - 1]; c = edit->buffers2[(edit->curs2 - 1) >> S_EDIT_BUF_SIZE][EDIT_BUF_SIZE - ((edit->curs2 - 1) & M_EDIT_BUF_SIZE) - 1];
if (!(edit->curs2 & M_EDIT_BUF_SIZE)) { if (!(edit->curs2 & M_EDIT_BUF_SIZE)) {
g_free (edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE]); mhl_mem_free (edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE]);
edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] = 0; edit->buffers2[edit->curs2 >> S_EDIT_BUF_SIZE] = 0;
} }
edit->curs2--; edit->curs2--;
@ -2698,5 +2700,5 @@ user_menu (WEdit * edit)
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
cleanup: cleanup:
g_free (block_file); mhl_mem_free (block_file);
} }

View File

@ -28,7 +28,6 @@
#include <assert.h> #include <assert.h>
#include <ctype.h> #include <ctype.h>
#include <stdio.h> #include <stdio.h>
#include <stdarg.h> #include <stdarg.h>
#include <sys/types.h> #include <sys/types.h>
@ -36,9 +35,10 @@
#include <string.h> #include <string.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/history.h" #include "../src/history.h"
@ -166,7 +166,7 @@ catstrs (const char *first,...)
len++; len++;
i = (i + 1) % 16; i = (i + 1) % 16;
g_free (stacked[i]); mhl_mem_free (stacked[i]);
stacked[i] = g_malloc (len); stacked[i] = g_malloc (len);
va_end (ap); va_end (ap);
@ -185,7 +185,7 @@ void freestrs(void)
size_t i; size_t i;
for (i = 0; i < sizeof(stacked) / sizeof(stacked[0]); i++) { for (i = 0; i < sizeof(stacked) / sizeof(stacked[0]); i++) {
g_free (stacked[i]); mhl_mem_free (stacked[i]);
stacked[i] = NULL; stacked[i] = NULL;
} }
} }
@ -237,7 +237,7 @@ edit_save_file (WEdit *edit, const char *filename)
if (*filename != PATH_SEP && edit->dir) { if (*filename != PATH_SEP && edit->dir) {
savename = concat_dir_and_file (edit->dir, filename); savename = concat_dir_and_file (edit->dir, filename);
filename = catstrs (savename, (char *) NULL); filename = catstrs (savename, (char *) NULL);
g_free (savename); mhl_mem_free (savename);
} }
this_save_mode = option_save_mode; this_save_mode = option_save_mode;
@ -302,9 +302,9 @@ edit_save_file (WEdit *edit, const char *filename)
} else } else
savedir = g_strdup ("."); savedir = g_strdup (".");
saveprefix = concat_dir_and_file (savedir, "cooledit"); saveprefix = concat_dir_and_file (savedir, "cooledit");
g_free (savedir); mhl_mem_free (savedir);
fd = mc_mkstemps (&savename, saveprefix, NULL); fd = mc_mkstemps (&savename, saveprefix, NULL);
g_free (saveprefix); mhl_mem_free (saveprefix);
if (!savename) if (!savename)
return 0; return 0;
/* FIXME: /* FIXME:
@ -340,7 +340,7 @@ edit_save_file (WEdit *edit, const char *filename)
edit_error_dialog (_("Error"), edit_error_dialog (_("Error"),
catstrs (_(" Error writing to pipe: "), catstrs (_(" Error writing to pipe: "),
p, " ", (char *) NULL)); p, " ", (char *) NULL));
g_free (p); mhl_mem_free (p);
goto error_save; goto error_save;
} }
#endif #endif
@ -350,10 +350,10 @@ edit_save_file (WEdit *edit, const char *filename)
(_ (_
(" Cannot open pipe for writing: "), (" Cannot open pipe for writing: "),
p, " ", (char *) NULL))); p, " ", (char *) NULL)));
g_free (p); mhl_mem_free (p);
goto error_save; goto error_save;
} }
g_free (p); mhl_mem_free (p);
} else { } else {
long buf; long buf;
buf = 0; buf = 0;
@ -414,14 +414,14 @@ edit_save_file (WEdit *edit, const char *filename)
if (this_save_mode != EDIT_QUICK_SAVE) if (this_save_mode != EDIT_QUICK_SAVE)
if (mc_rename (savename, filename) == -1) if (mc_rename (savename, filename) == -1)
goto error_save; goto error_save;
g_free (savename); mhl_mem_free (savename);
return 1; return 1;
error_save: error_save:
/* FIXME: Is this safe ? /* FIXME: Is this safe ?
* if (this_save_mode != EDIT_QUICK_SAVE) * if (this_save_mode != EDIT_QUICK_SAVE)
* mc_unlink (savename); * mc_unlink (savename);
*/ */
g_free (savename); mhl_mem_free (savename);
return 0; return 0;
} }
@ -492,7 +492,7 @@ void menu_save_mode_cmd (void)
return; return;
option_save_mode = save_mode_new; option_save_mode = save_mode_new;
g_free (option_backup_ext); mhl_mem_free (option_backup_ext);
option_backup_ext = str_result; option_backup_ext = str_result;
str_result = NULL; str_result = NULL;
} }
@ -500,7 +500,7 @@ void menu_save_mode_cmd (void)
void void
edit_set_filename (WEdit *edit, const char *f) edit_set_filename (WEdit *edit, const char *f)
{ {
g_free (edit->filename); mhl_mem_free (edit->filename);
if (!f) if (!f)
f = ""; f = "";
edit->filename = g_strdup (f); edit->filename = g_strdup (f);
@ -529,7 +529,7 @@ edit_save_as_cmd (WEdit *edit)
if (exp) { if (exp) {
if (!*exp) { if (!*exp) {
g_free (exp); mhl_mem_free (exp);
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
return 0; return 0;
} else { } else {
@ -546,7 +546,7 @@ edit_save_as_cmd (WEdit *edit)
_(" A file already exists with this name. "), _(" A file already exists with this name. "),
_("&Overwrite"), _("&Cancel"))) { _("&Overwrite"), _("&Cancel"))) {
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
g_free (exp); mhl_mem_free (exp);
return 0; return 0;
} }
} }
@ -572,7 +572,7 @@ edit_save_as_cmd (WEdit *edit)
} }
edit_set_filename (edit, exp); edit_set_filename (edit, exp);
g_free (exp); mhl_mem_free (exp);
edit->modified = 0; edit->modified = 0;
edit->delete_file = 0; edit->delete_file = 0;
if (different_filename) if (different_filename)
@ -588,7 +588,7 @@ edit_save_as_cmd (WEdit *edit)
/* Failed, so maintain modify (not save) lock */ /* Failed, so maintain modify (not save) lock */
if (save_lock) if (save_lock)
edit_unlock_file (exp); edit_unlock_file (exp);
g_free (exp); mhl_mem_free (exp);
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
return 0; return 0;
} }
@ -880,13 +880,13 @@ edit_load_file_from_filename (WEdit * edit, char *exp)
char *prev_filename = g_strdup (edit->filename); char *prev_filename = g_strdup (edit->filename);
if (!edit_reload (edit, exp)) { if (!edit_reload (edit, exp)) {
g_free (prev_filename); mhl_mem_free (prev_filename);
return 1; return 1;
} }
if (prev_locked) if (prev_locked)
edit_unlock_file (prev_filename); edit_unlock_file (prev_filename);
g_free (prev_filename); mhl_mem_free (prev_filename);
return 0; return 0;
} }
@ -912,7 +912,7 @@ edit_load_cmd (WEdit *edit)
if (exp) { if (exp) {
if (*exp) if (*exp)
edit_load_file_from_filename (edit, exp); edit_load_file_from_filename (edit, exp);
g_free (exp); mhl_mem_free (exp);
} }
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
return 0; return 0;
@ -1013,7 +1013,7 @@ edit_block_copy_cmd (WEdit *edit)
edit_insert_ahead (edit, copy_buf[size]); edit_insert_ahead (edit, copy_buf[size]);
} }
g_free (copy_buf); mhl_mem_free (copy_buf);
edit_scroll_screen_over_cursor (edit); edit_scroll_screen_over_cursor (edit);
if (column_highlighting) { if (column_highlighting) {
@ -1114,7 +1114,7 @@ edit_block_move_cmd (WEdit *edit)
edit->curs1 + end_mark - start_mark, 0, 0); edit->curs1 + end_mark - start_mark, 0, 0);
} }
edit_scroll_screen_over_cursor (edit); edit_scroll_screen_over_cursor (edit);
g_free (copy_buf); mhl_mem_free (copy_buf);
edit->force |= REDRAW_PAGE; edit->force |= REDRAW_PAGE;
} }
@ -1450,7 +1450,7 @@ string_regexp_search (char *pattern, char *string, int match_type,
|| old_type != match_type || old_icase != icase) { || old_type != match_type || old_icase != icase) {
if (old_pattern) { if (old_pattern) {
regfree (&r); regfree (&r);
g_free (old_pattern); mhl_mem_free (old_pattern);
old_pattern = 0; old_pattern = 0;
} }
if (regcomp (&r, pattern, REG_EXTENDED | (icase ? REG_ICASE : 0) | if (regcomp (&r, pattern, REG_EXTENDED | (icase ? REG_ICASE : 0) |
@ -1826,9 +1826,9 @@ edit_replace_cmd (WEdit *edit, int again)
int argord[NUM_REPL_ARGS]; int argord[NUM_REPL_ARGS];
if (!edit) { if (!edit) {
g_free (saved1), saved1 = NULL; mhl_mem_free (saved1), saved1 = NULL;
g_free (saved2), saved2 = NULL; mhl_mem_free (saved2), saved2 = NULL;
g_free (saved3), saved3 = NULL; mhl_mem_free (saved3), saved3 = NULL;
return; return;
} }
@ -1856,9 +1856,9 @@ edit_replace_cmd (WEdit *edit, int again)
edit_replace_dialog (edit, disp1, disp2, disp3, &input1, &input2, edit_replace_dialog (edit, disp1, disp2, disp3, &input1, &input2,
&input3); &input3);
g_free (disp1); mhl_mem_free (disp1);
g_free (disp2); mhl_mem_free (disp2);
g_free (disp3); mhl_mem_free (disp3);
convert_from_input (input1); convert_from_input (input1);
convert_from_input (input2); convert_from_input (input2);
@ -1870,9 +1870,9 @@ edit_replace_cmd (WEdit *edit, int again)
goto cleanup; goto cleanup;
} }
g_free (saved1), saved1 = g_strdup (input1); mhl_mem_free (saved1), saved1 = g_strdup (input1);
g_free (saved2), saved2 = g_strdup (input2); mhl_mem_free (saved2), saved2 = g_strdup (input2);
g_free (saved3), saved3 = g_strdup (input3); mhl_mem_free (saved3), saved3 = g_strdup (input3);
} }
@ -2064,9 +2064,9 @@ edit_replace_cmd (WEdit *edit, int again)
edit->force = REDRAW_COMPLETELY; edit->force = REDRAW_COMPLETELY;
edit_scroll_screen_over_cursor (edit); edit_scroll_screen_over_cursor (edit);
cleanup: cleanup:
g_free (input1); mhl_mem_free (input1);
g_free (input2); mhl_mem_free (input2);
g_free (input3); mhl_mem_free (input3);
} }
@ -2078,7 +2078,7 @@ void edit_search_cmd (WEdit * edit, int again)
char *exp = ""; char *exp = "";
if (!edit) { if (!edit) {
g_free (old); mhl_mem_free (old);
old = NULL; old = NULL;
return; return;
} }
@ -2108,7 +2108,7 @@ void edit_search_cmd (WEdit * edit, int again)
if (exp) { if (exp) {
if (*exp) { if (*exp) {
int len = 0; int len = 0;
g_free (old); mhl_mem_free (old);
old = g_strdup (exp); old = g_strdup (exp);
if (search_create_bookmark) { if (search_create_bookmark) {
@ -2165,7 +2165,7 @@ void edit_search_cmd (WEdit * edit, int again)
} }
} }
} }
g_free (exp); mhl_mem_free (exp);
} }
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
edit_scroll_screen_over_cursor (edit); edit_scroll_screen_over_cursor (edit);
@ -2204,7 +2204,7 @@ edit_ok_to_exit (WEdit *edit)
#define TEMP_BUF_LEN 1024 #define TEMP_BUF_LEN 1024
/* Return a null terminated length of text. Result must be g_free'd */ /* Return a null terminated length of text. Result must be mhl_mem_free'd */
static unsigned char * static unsigned char *
edit_get_block (WEdit *edit, long start, long finish, int *l) edit_get_block (WEdit *edit, long start, long finish, int *l)
{ {
@ -2257,7 +2257,7 @@ edit_save_block (WEdit * edit, const char *filename, long start,
p += r; p += r;
len -= r; len -= r;
} }
g_free (block); mhl_mem_free (block);
} else { } else {
unsigned char *buf; unsigned char *buf;
int i = start, end; int i = start, end;
@ -2270,7 +2270,7 @@ edit_save_block (WEdit * edit, const char *filename, long start,
len -= mc_write (file, (char *) buf, end - start); len -= mc_write (file, (char *) buf, end - start);
start = end; start = end;
} }
g_free (buf); mhl_mem_free (buf);
} }
mc_close (file); mc_close (file);
if (len) if (len)
@ -2344,13 +2344,13 @@ edit_goto_cmd (WEdit *edit)
return; return;
if (!*f) { if (!*f) {
g_free (f); mhl_mem_free (f);
return; return;
} }
l = strtol (f, &error, 0); l = strtol (f, &error, 0);
if (*error) { if (*error) {
g_free (f); mhl_mem_free (f);
return; return;
} }
@ -2360,7 +2360,7 @@ edit_goto_cmd (WEdit *edit)
edit_move_display (edit, l - edit->num_widget_lines / 2 - 1); edit_move_display (edit, l - edit->num_widget_lines / 2 - 1);
edit_move_to_line (edit, l - 1); edit_move_to_line (edit, l - 1);
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
g_free (f); mhl_mem_free (f);
} }
@ -2379,15 +2379,15 @@ edit_save_block_cmd (WEdit *edit)
edit_push_action (edit, KEY_PRESS + edit->start_display); edit_push_action (edit, KEY_PRESS + edit->start_display);
if (exp) { if (exp) {
if (!*exp) { if (!*exp) {
g_free (exp); mhl_mem_free (exp);
return 0; return 0;
} else { } else {
if (edit_save_block (edit, exp, start_mark, end_mark)) { if (edit_save_block (edit, exp, start_mark, end_mark)) {
g_free (exp); mhl_mem_free (exp);
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
return 1; return 1;
} else { } else {
g_free (exp); mhl_mem_free (exp);
edit_error_dialog (_(" Save Block "), edit_error_dialog (_(" Save Block "),
get_sys_error (_ get_sys_error (_
(" Cannot save file. "))); (" Cannot save file. ")));
@ -2409,15 +2409,15 @@ edit_insert_file_cmd (WEdit *edit)
edit_push_action (edit, KEY_PRESS + edit->start_display); edit_push_action (edit, KEY_PRESS + edit->start_display);
if (exp) { if (exp) {
if (!*exp) { if (!*exp) {
g_free (exp); mhl_mem_free (exp);
return 0; return 0;
} else { } else {
if (edit_insert_file (edit, exp)) { if (edit_insert_file (edit, exp)) {
g_free (exp); mhl_mem_free (exp);
edit->force |= REDRAW_COMPLETELY; edit->force |= REDRAW_COMPLETELY;
return 1; return 1;
} else { } else {
g_free (exp); mhl_mem_free (exp);
edit_error_dialog (_(" Insert File "), edit_error_dialog (_(" Insert File "),
get_sys_error (_ get_sys_error (_
(" Cannot insert file. "))); (" Cannot insert file. ")));
@ -2448,7 +2448,7 @@ int edit_sort_cmd (WEdit * edit)
if (!exp) if (!exp)
return 1; return 1;
g_free (old); mhl_mem_free (old);
old = exp; old = exp;
e = system (catstrs (" sort ", exp, " ", home_dir, PATH_SEP_STR BLOCK_FILE, " > ", home_dir, PATH_SEP_STR TEMP_FILE, (char *) NULL)); e = system (catstrs (" sort ", exp, " ", home_dir, PATH_SEP_STR BLOCK_FILE, " > ", home_dir, PATH_SEP_STR TEMP_FILE, (char *) NULL));
@ -2492,7 +2492,7 @@ edit_ext_cmd (WEdit *edit)
return 1; return 1;
e = system (catstrs (exp, " > ", home_dir, PATH_SEP_STR TEMP_FILE, (char *) NULL)); e = system (catstrs (exp, " > ", home_dir, PATH_SEP_STR TEMP_FILE, (char *) NULL));
g_free (exp); mhl_mem_free (exp);
if (e) { if (e) {
edit_error_dialog (_("External command"), edit_error_dialog (_("External command"),
@ -2588,7 +2588,7 @@ edit_block_process_cmd (WEdit *edit, const char *shell_cmd, int block)
system (catstrs (" ", home_dir, PATH_SEP_STR EDIT_DIR, shell_cmd, " ", system (catstrs (" ", home_dir, PATH_SEP_STR EDIT_DIR, shell_cmd, " ",
quoted_name, (char *) NULL)); quoted_name, (char *) NULL));
} }
g_free (quoted_name); mhl_mem_free (quoted_name);
close_error_pipe (D_NORMAL, NULL); close_error_pipe (D_NORMAL, NULL);
edit_refresh_cmd (edit); edit_refresh_cmd (edit);
@ -2629,13 +2629,13 @@ static void pipe_mail (WEdit *edit, char *to, char *subject, char *cc)
subject = name_quote (subject, 0); subject = name_quote (subject, 0);
cc = name_quote (cc, 0); cc = name_quote (cc, 0);
s = g_strconcat ("mail -s ", subject, *cc ? " -c " : "" , cc, " ", to, (char *) NULL); s = g_strconcat ("mail -s ", subject, *cc ? " -c " : "" , cc, " ", to, (char *) NULL);
g_free (to); mhl_mem_free (to);
g_free (subject); mhl_mem_free (subject);
g_free (cc); mhl_mem_free (cc);
if (s) { if (s) {
p = popen (s, "w"); p = popen (s, "w");
g_free (s); mhl_mem_free (s);
} }
if (p) { if (p) {
@ -2694,9 +2694,9 @@ void edit_mail_dialog (WEdit * edit)
Quick_input.widgets = quick_widgets; Quick_input.widgets = quick_widgets;
if (quick_dialog (&Quick_input) != B_CANCEL) { if (quick_dialog (&Quick_input) != B_CANCEL) {
g_free (mail_cc_last); mhl_mem_free (mail_cc_last);
g_free (mail_subject_last); mhl_mem_free (mail_subject_last);
g_free (mail_to_last); mhl_mem_free (mail_to_last);
mail_cc_last = tmail_cc; mail_cc_last = tmail_cc;
mail_subject_last = tmail_subject; mail_subject_last = tmail_subject;
mail_to_last = tmail_to; mail_to_last = tmail_to;
@ -2938,10 +2938,10 @@ edit_complete_word_cmd (WEdit *edit)
} }
} }
g_free (match_expr); mhl_mem_free (match_expr);
/* release memory before return */ /* release memory before return */
for (i = 0; i < num_compl; i++) for (i = 0; i < num_compl; i++)
g_free (compl[i].text); mhl_mem_free (compl[i].text);
/* restore search parameters */ /* restore search parameters */
edit_set_search_parameters (old_rs, old_rb, old_rr, old_rw, old_rc); edit_set_search_parameters (old_rs, old_rb, old_rr, old_rw, old_rc);

View File

@ -34,6 +34,8 @@
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -145,7 +147,7 @@ edit_status (WEdit *edit)
printwstr (status, w - (fname_len + gap)); printwstr (status, w - (fname_len + gap));
attrset (EDITOR_NORMAL_COLOR); attrset (EDITOR_NORMAL_COLOR);
g_free (status); mhl_mem_free (status);
} }
/* this scrolls the text so that cursor is on the screen */ /* this scrolls the text so that cursor is on the screen */

View File

@ -22,8 +22,8 @@
*/ */
#include <config.h> #include <config.h>
#include <signal.h> /* kill() */
#include <signal.h> /* kill() */
#include <stdio.h> #include <stdio.h>
#include <stdarg.h> #include <stdarg.h>
#include <sys/types.h> #include <sys/types.h>
@ -34,9 +34,10 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -99,7 +100,7 @@ lock_build_symlink_name (const char *fname)
fname_copy = g_strdup (fname); fname_copy = g_strdup (fname);
absolute_fname[fname - absolute_fname] = '\0'; absolute_fname[fname - absolute_fname] = '\0';
symlink_name = g_strconcat (absolute_fname, ".#", fname_copy, (char *) NULL); symlink_name = g_strconcat (absolute_fname, ".#", fname_copy, (char *) NULL);
g_free (fname_copy); mhl_mem_free (fname_copy);
return symlink_name; return symlink_name;
} }
@ -174,7 +175,7 @@ edit_lock_file (const char *fname)
if (lstat (lockfname, &statbuf) == 0) { if (lstat (lockfname, &statbuf) == 0) {
lock = lock_get_info (lockfname); lock = lock_get_info (lockfname);
if (!lock) { if (!lock) {
g_free (lockfname); mhl_mem_free (lockfname);
return 0; return 0;
} }
lockinfo = lock_extract_info (lock); lockinfo = lock_extract_info (lock);
@ -195,11 +196,11 @@ edit_lock_file (const char *fname)
break; break;
case 1: case 1:
case -1: case -1:
g_free (lockfname); mhl_mem_free (lockfname);
g_free (msg); mhl_mem_free (msg);
return 0; return 0;
} }
g_free (msg); mhl_mem_free (msg);
} }
unlink (lockfname); unlink (lockfname);
} }
@ -207,13 +208,13 @@ edit_lock_file (const char *fname)
/* Create lock symlink */ /* Create lock symlink */
newlock = lock_build_name (); newlock = lock_build_name ();
if (symlink (newlock, lockfname) == -1) { if (symlink (newlock, lockfname) == -1) {
g_free (lockfname); mhl_mem_free (lockfname);
g_free (newlock); mhl_mem_free (newlock);
return 0; return 0;
} }
g_free (lockfname); mhl_mem_free (lockfname);
g_free (newlock); mhl_mem_free (newlock);
return 1; return 1;
} }
@ -235,7 +236,7 @@ edit_unlock_file (const char *fname)
/* Check if lock exists */ /* Check if lock exists */
if (lstat (lockfname, &statbuf) == -1) { if (lstat (lockfname, &statbuf) == -1) {
g_free (lockfname); mhl_mem_free (lockfname);
return 0; return 0;
} }
@ -243,13 +244,13 @@ edit_unlock_file (const char *fname)
if (lock) { if (lock) {
/* Don't touch if lock is not ours */ /* Don't touch if lock is not ours */
if (lock_extract_info (lock)->pid != getpid ()) { if (lock_extract_info (lock)->pid != getpid ()) {
g_free (lockfname); mhl_mem_free (lockfname);
return 0; return 0;
} }
} }
/* Remove lock */ /* Remove lock */
unlink (lockfname); unlink (lockfname);
g_free (lockfname); mhl_mem_free (lockfname);
return 0; return 0;
} }

View File

@ -33,9 +33,10 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -475,7 +476,7 @@ edit_done_menu (struct WMenu *wmenu)
for (i = 0; i < N_menus; i++) for (i = 0; i < N_menus; i++)
destroy_menu (wmenu->menu[i]); destroy_menu (wmenu->menu[i]);
g_free(wmenu->menu); mhl_mem_free(wmenu->menu);
} }

View File

@ -33,9 +33,10 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -186,13 +187,13 @@ edit_options_dialog (void)
if (p) { if (p) {
option_word_wrap_line_length = atoi (p); option_word_wrap_line_length = atoi (p);
g_free (p); mhl_mem_free (p);
} }
if (q) { if (q) {
option_tab_spacing = atoi (q); option_tab_spacing = atoi (q);
if (option_tab_spacing <= 0) if (option_tab_spacing <= 0)
option_tab_spacing = 8; option_tab_spacing = 8;
g_free (q); mhl_mem_free (q);
} }
option_syntax_highlighting = tedit_syntax_highlighting; option_syntax_highlighting = tedit_syntax_highlighting;

View File

@ -33,9 +33,10 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -176,7 +177,7 @@ edit_file (const char *_file, int line)
if (!made_directory) { if (!made_directory) {
char *dir = concat_dir_and_file (home_dir, EDIT_DIR); char *dir = concat_dir_and_file (home_dir, EDIT_DIR);
made_directory = (mkdir (dir, 0700) != -1 || errno == EEXIST); made_directory = (mkdir (dir, 0700) != -1 || errno == EEXIST);
g_free (dir); mhl_mem_free (dir);
} }
if (!(wedit = edit_init (NULL, LINES - 2, COLS, _file, line))) { if (!(wedit = edit_init (NULL, LINES - 2, COLS, _file, line))) {

View File

@ -30,9 +30,10 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -102,7 +103,7 @@ int option_syntax_highlighting = 1;
int option_auto_syntax = 1; int option_auto_syntax = 1;
char *option_syntax_type = NULL; char *option_syntax_type = NULL;
#define syntax_g_free(x) do {g_free(x); (x)=0;} while (0) #define _FREEPTR(x) do {mhl_mem_free(x); (x)=0;} while (0)
static gint static gint
mc_defines_destroy (gpointer key, gpointer value, gpointer data) mc_defines_destroy (gpointer key, gpointer value, gpointer data)
@ -111,10 +112,10 @@ mc_defines_destroy (gpointer key, gpointer value, gpointer data)
(void) data; (void) data;
g_free (key); mhl_mem_free (key);
while (*values) while (*values)
g_free (*values++); mhl_mem_free (*values++);
g_free (value); mhl_mem_free (value);
return FALSE; return FALSE;
} }
@ -471,7 +472,7 @@ static struct syntax_rule edit_get_rule (WEdit * edit, long byte_index)
break; break;
} }
s = edit->syntax_marker->next; s = edit->syntax_marker->next;
syntax_g_free (edit->syntax_marker); _FREEPTR (edit->syntax_marker);
edit->syntax_marker = s; edit->syntax_marker = s;
} }
} }
@ -666,19 +667,19 @@ static FILE *open_include_file (const char *filename)
{ {
FILE *f; FILE *f;
syntax_g_free (error_file_name); _FREEPTR (error_file_name);
error_file_name = g_strdup (filename); error_file_name = g_strdup (filename);
if (*filename == PATH_SEP) if (*filename == PATH_SEP)
return fopen (filename, "r"); return fopen (filename, "r");
g_free (error_file_name); mhl_mem_free (error_file_name);
error_file_name = g_strconcat (home_dir, PATH_SEP_STR EDIT_DIR PATH_SEP_STR, error_file_name = g_strconcat (home_dir, PATH_SEP_STR EDIT_DIR PATH_SEP_STR,
filename, (char *) NULL); filename, (char *) NULL);
f = fopen (error_file_name, "r"); f = fopen (error_file_name, "r");
if (f) if (f)
return f; return f;
g_free (error_file_name); mhl_mem_free (error_file_name);
error_file_name = g_strconcat (mc_home, PATH_SEP_STR "syntax" PATH_SEP_STR, error_file_name = g_strconcat (mc_home, PATH_SEP_STR "syntax" PATH_SEP_STR,
filename, (char *) NULL); filename, (char *) NULL);
return fopen (error_file_name, "r"); return fopen (error_file_name, "r");
@ -725,8 +726,8 @@ edit_read_syntax_rules (WEdit *edit, FILE *f, char **args, int args_size)
f = g; f = g;
g = 0; g = 0;
line = save_line + 1; line = save_line + 1;
syntax_g_free (error_file_name); _FREEPTR (error_file_name);
syntax_g_free (l); _FREEPTR (l);
if (!read_one_line (&l, f)) if (!read_one_line (&l, f))
break; break;
} else { } else {
@ -745,7 +746,7 @@ edit_read_syntax_rules (WEdit *edit, FILE *f, char **args, int args_size)
g = f; g = f;
f = open_include_file (args[1]); f = open_include_file (args[1]);
if (!f) { if (!f) {
syntax_g_free (error_file_name); _FREEPTR (error_file_name);
result = line; result = line;
break; break;
} }
@ -922,10 +923,10 @@ edit_read_syntax_rules (WEdit *edit, FILE *f, char **args, int args_size)
break_a; break_a;
} }
free_args (args); free_args (args);
syntax_g_free (l); _FREEPTR (l);
} }
free_args (args); free_args (args);
syntax_g_free (l); _FREEPTR (l);
/* Terminate context array. */ /* Terminate context array. */
if (num_contexts > 0) { if (num_contexts > 0) {
@ -934,7 +935,7 @@ edit_read_syntax_rules (WEdit *edit, FILE *f, char **args, int args_size)
} }
if (!edit->rules[0]) if (!edit->rules[0])
syntax_g_free (edit->rules); _FREEPTR (edit->rules);
if (result) if (result)
return result; return result;
@ -958,7 +959,7 @@ edit_read_syntax_rules (WEdit *edit, FILE *f, char **args, int args_size)
c->keyword_first_chars = g_strdup (first_chars); c->keyword_first_chars = g_strdup (first_chars);
} }
g_free (first_chars); mhl_mem_free (first_chars);
} }
return result; return result;
@ -976,34 +977,34 @@ void edit_free_syntax_rules (WEdit * edit)
return; return;
edit_get_rule (edit, -1); edit_get_rule (edit, -1);
syntax_g_free (edit->syntax_type); _FREEPTR (edit->syntax_type);
edit->syntax_type = 0; edit->syntax_type = 0;
for (i = 0; edit->rules[i]; i++) { for (i = 0; edit->rules[i]; i++) {
if (edit->rules[i]->keyword) { if (edit->rules[i]->keyword) {
for (j = 0; edit->rules[i]->keyword[j]; j++) { for (j = 0; edit->rules[i]->keyword[j]; j++) {
syntax_g_free (edit->rules[i]->keyword[j]->keyword); _FREEPTR (edit->rules[i]->keyword[j]->keyword);
syntax_g_free (edit->rules[i]->keyword[j]->whole_word_chars_left); _FREEPTR (edit->rules[i]->keyword[j]->whole_word_chars_left);
syntax_g_free (edit->rules[i]->keyword[j]->whole_word_chars_right); _FREEPTR (edit->rules[i]->keyword[j]->whole_word_chars_right);
syntax_g_free (edit->rules[i]->keyword[j]); _FREEPTR (edit->rules[i]->keyword[j]);
} }
} }
syntax_g_free (edit->rules[i]->left); _FREEPTR (edit->rules[i]->left);
syntax_g_free (edit->rules[i]->right); _FREEPTR (edit->rules[i]->right);
syntax_g_free (edit->rules[i]->whole_word_chars_left); _FREEPTR (edit->rules[i]->whole_word_chars_left);
syntax_g_free (edit->rules[i]->whole_word_chars_right); _FREEPTR (edit->rules[i]->whole_word_chars_right);
syntax_g_free (edit->rules[i]->keyword); _FREEPTR (edit->rules[i]->keyword);
syntax_g_free (edit->rules[i]->keyword_first_chars); _FREEPTR (edit->rules[i]->keyword_first_chars);
syntax_g_free (edit->rules[i]); _FREEPTR (edit->rules[i]);
} }
while (edit->syntax_marker) { while (edit->syntax_marker) {
struct _syntax_marker *s = edit->syntax_marker->next; struct _syntax_marker *s = edit->syntax_marker->next;
syntax_g_free (edit->syntax_marker); _FREEPTR (edit->syntax_marker);
edit->syntax_marker = s; edit->syntax_marker = s;
} }
syntax_g_free (edit->rules); _FREEPTR (edit->rules);
} }
/* returns -1 on file error, line number on error in file syntax */ /* returns -1 on file error, line number on error in file syntax */
@ -1028,7 +1029,7 @@ edit_read_syntax_file (WEdit * edit, char ***pnames, const char *syntax_file,
if (!f){ if (!f){
lib_file = concat_dir_and_file (mc_home, "syntax" PATH_SEP_STR "Syntax"); lib_file = concat_dir_and_file (mc_home, "syntax" PATH_SEP_STR "Syntax");
f = fopen (lib_file, "r"); f = fopen (lib_file, "r");
g_free (lib_file); mhl_mem_free (lib_file);
if (!f) if (!f)
return -1; return -1;
} }
@ -1036,7 +1037,7 @@ edit_read_syntax_file (WEdit * edit, char ***pnames, const char *syntax_file,
args[0] = 0; args[0] = 0;
for (;;) { for (;;) {
line++; line++;
syntax_g_free (l); _FREEPTR (l);
if (!read_one_line (&l, f)) if (!read_one_line (&l, f))
break; break;
(void)get_args (l, args, 1023); /* Final NULL */ (void)get_args (l, args, 1023); /* Final NULL */
@ -1117,7 +1118,7 @@ edit_read_syntax_file (WEdit * edit, char ***pnames, const char *syntax_file,
else else
result = line_error; result = line_error;
} else { } else {
syntax_g_free (edit->syntax_type); _FREEPTR (edit->syntax_type);
edit->syntax_type = g_strdup (syntax_type); edit->syntax_type = g_strdup (syntax_type);
/* if there are no rules then turn off syntax highlighting for speed */ /* if there are no rules then turn off syntax highlighting for speed */
@ -1136,7 +1137,7 @@ edit_read_syntax_file (WEdit * edit, char ***pnames, const char *syntax_file,
} }
} }
} }
syntax_g_free (l); _FREEPTR (l);
fclose (f); fclose (f);
return result; return result;
} }
@ -1201,9 +1202,9 @@ edit_load_syntax (WEdit *edit, char ***pnames, const char *type)
message (D_ERROR, _(" Load syntax file "), message (D_ERROR, _(" Load syntax file "),
_(" Error in file %s on line %d "), _(" Error in file %s on line %d "),
error_file_name ? error_file_name : f, r); error_file_name ? error_file_name : f, r);
syntax_g_free (error_file_name); _FREEPTR (error_file_name);
} else { } else {
/* succeeded */ /* succeeded */
} }
g_free (f); mhl_mem_free (f);
} }

View File

@ -26,11 +26,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -241,7 +242,7 @@ cfg_free_maps(config_t *cfg)
cfg->ext_keymap = NULL; cfg->ext_keymap = NULL;
for (i = 0; i < 10; i++) for (i = 0; i < 10; i++)
g_free(cfg->labels[i]); mhl_mem_free(cfg->labels[i]);
} }
/* Returns an array containing the words in str. WARNING: As long as /* Returns an array containing the words in str. WARNING: As long as
@ -553,7 +554,7 @@ parse_file(config_t *cfg, const char *file, const command_t *cmd)
char *ss = g_strdup(error_msg); char *ss = g_strdup(error_msg);
snprintf(error_msg, sizeof(error_msg), snprintf(error_msg, sizeof(error_msg),
_("%s:%d: %s"), file, line, ss); _("%s:%d: %s"), file, line, ss);
g_free(ss); mhl_mem_free(ss);
g_ptr_array_free(args, TRUE); g_ptr_array_free(args, TRUE);
fclose(fp); fclose(fp);
return FALSE; return FALSE;
@ -601,8 +602,8 @@ edit_load_user_map(WEdit *edit)
if (stat(file, &s) < 0) { if (stat(file, &s) < 0) {
char *msg = g_strdup_printf(_("%s not found!"), file); char *msg = g_strdup_printf(_("%s not found!"), file);
edit_error_dialog(_("Error"), msg); edit_error_dialog(_("Error"), msg);
g_free(msg); mhl_mem_free(msg);
g_free(file); mhl_mem_free(file);
return FALSE; return FALSE;
} }
@ -613,7 +614,7 @@ edit_load_user_map(WEdit *edit)
if (!load_user_keymap(&new_cfg, file)) { if (!load_user_keymap(&new_cfg, file)) {
edit_error_dialog(_("Error"), error_msg); edit_error_dialog(_("Error"), error_msg);
cfg_free_maps(&new_cfg); cfg_free_maps(&new_cfg);
g_free(file); mhl_mem_free(file);
return FALSE; return FALSE;
} else { } else {
cfg_free_maps(&cfg); cfg_free_maps(&cfg);
@ -625,7 +626,7 @@ edit_load_user_map(WEdit *edit)
edit->ext_map = (edit_key_map_type *) cfg.ext_keymap->data; edit->ext_map = (edit_key_map_type *) cfg.ext_keymap->data;
memcpy(edit->labels, cfg.labels, sizeof(edit->labels)); memcpy(edit->labels, cfg.labels, sizeof(edit->labels));
g_free(file); mhl_mem_free(file);
return TRUE; return TRUE;
} }

View File

@ -30,9 +30,10 @@
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <stdlib.h> #include <stdlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "edit.h" #include "edit.h"
@ -349,13 +350,13 @@ format_paragraph (WEdit *edit, int force)
if (!force) { if (!force) {
int i; int i;
if (strchr (NO_FORMAT_CHARS_START, *t)) { if (strchr (NO_FORMAT_CHARS_START, *t)) {
g_free (t); mhl_mem_free (t);
return; return;
} }
for (i = 0; i < size - 1; i++) { for (i = 0; i < size - 1; i++) {
if (t[i] == '\n') { if (t[i] == '\n') {
if (strchr (NO_FORMAT_CHARS_START "\t ", t[i + 1])) { if (strchr (NO_FORMAT_CHARS_START "\t ", t[i + 1])) {
g_free (t); mhl_mem_free (t);
return; return;
} }
} }
@ -363,7 +364,7 @@ format_paragraph (WEdit *edit, int force)
} }
format_this (t, q - p, indent); format_this (t, q - p, indent);
put_paragraph (edit, t, p, indent, size); put_paragraph (edit, t, p, indent, size);
g_free (t); mhl_mem_free (t);
/* Scroll left as much as possible to show the formatted paragraph */ /* Scroll left as much as possible to show the formatted paragraph */
edit_scroll_left (edit, -edit->start_col); edit_scroll_left (edit, -edit->start_col);

View File

@ -22,11 +22,12 @@
#include <errno.h> #include <errno.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "win.h" #include "win.h"
@ -596,7 +597,7 @@ init_chown_advanced (void)
static void static void
chown_advanced_done (void) chown_advanced_done (void)
{ {
g_free (sf_stat); mhl_mem_free (sf_stat);
if (need_update) if (need_update)
update_panels (UP_OPTIMIZE, UP_KEEPSEL); update_panels (UP_OPTIMIZE, UP_KEEPSEL);
repaint_screen (); repaint_screen ();

View File

@ -31,11 +31,12 @@
#include <stdarg.h> #include <stdarg.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "background.h" #include "background.h"
#include "tty.h" /* doupdate() */ #include "tty.h" /* doupdate() */
@ -89,8 +90,8 @@ unregister_task_running (pid_t pid, int fd)
prev->next = p->next; prev->next = p->next;
else else
task_list = p->next; task_list = p->next;
g_free (p->info); mhl_mem_free (p->info);
g_free (p); mhl_mem_free (p);
break; break;
} }
prev = p; prev = p;
@ -321,7 +322,7 @@ background_attention (int fd, void *closure)
write (fd, &len, sizeof (len)); write (fd, &len, sizeof (len));
if (len){ if (len){
write (fd, resstr, len); write (fd, resstr, len);
g_free (resstr); mhl_mem_free (resstr);
} }
} else { } else {
len = 0; len = 0;
@ -329,7 +330,7 @@ background_attention (int fd, void *closure)
} }
} }
for (i = 0; i < argc; i++) for (i = 0; i < argc; i++)
g_free (data [i]); mhl_mem_free (data [i]);
do_refresh (); do_refresh ();
mc_refresh (); mc_refresh ();

View File

@ -27,10 +27,11 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "win.h" /* Our window tools */ #include "win.h" /* Our window tools */
@ -233,11 +234,11 @@ display_box (WPanel *panel, char **userp, char **minip, int *use_msformat, int n
panel->user_status_format[i] = g_strdup (DEFAULT_USER_FORMAT); panel->user_status_format[i] = g_strdup (DEFAULT_USER_FORMAT);
section = g_strconcat ("Temporal:", p, (char *) NULL); section = g_strconcat ("Temporal:", p, (char *) NULL);
if (!profile_has_section (section, profile_name)) { if (!profile_has_section (section, profile_name)) {
g_free (section); mhl_mem_free (section);
section = g_strdup (p); section = g_strdup (p);
} }
panel_load_setup (panel, section); panel_load_setup (panel, section);
g_free (section); mhl_mem_free (section);
} }
current_mode = panel->list_type; current_mode = panel->list_type;
@ -249,10 +250,10 @@ display_box (WPanel *panel, char **userp, char **minip, int *use_msformat, int n
result = -1; result = -1;
if (section) { if (section) {
g_free (panel->user_format); mhl_mem_free (panel->user_format);
for (i = 0; i < LIST_TYPES; i++) for (i = 0; i < LIST_TYPES; i++)
g_free (panel->user_status_format [i]); mhl_mem_free (panel->user_status_format [i]);
g_free (panel); mhl_mem_free (panel);
} }
if (dd->ret_value != B_CANCEL){ if (dd->ret_value != B_CANCEL){
@ -782,19 +783,19 @@ configure_vfs (void)
if (quick_dialog (&confvfs_dlg) != B_CANCEL) { if (quick_dialog (&confvfs_dlg) != B_CANCEL) {
vfs_timeout = atoi (ret_timeout); vfs_timeout = atoi (ret_timeout);
g_free (ret_timeout); mhl_mem_free (ret_timeout);
if (vfs_timeout < 0 || vfs_timeout > 10000) if (vfs_timeout < 0 || vfs_timeout > 10000)
vfs_timeout = 10; vfs_timeout = 10;
#if defined(USE_NETCODE) #if defined(USE_NETCODE)
g_free (ftpfs_anonymous_passwd); mhl_mem_free (ftpfs_anonymous_passwd);
ftpfs_anonymous_passwd = ret_passwd; ftpfs_anonymous_passwd = ret_passwd;
g_free (ftpfs_proxy_host); mhl_mem_free (ftpfs_proxy_host);
ftpfs_proxy_host = ret_ftp_proxy; ftpfs_proxy_host = ret_ftp_proxy;
ftpfs_directory_timeout = atoi(ret_directory_timeout); ftpfs_directory_timeout = atoi(ret_directory_timeout);
use_netrc = ret_use_netrc; use_netrc = ret_use_netrc;
ftpfs_use_passive_connections = ret_ftpfs_use_passive_connections; ftpfs_use_passive_connections = ret_ftpfs_use_passive_connections;
ftpfs_use_passive_connections_over_proxy = ret_ftpfs_use_passive_connections_over_proxy; ftpfs_use_passive_connections_over_proxy = ret_ftpfs_use_passive_connections_over_proxy;
g_free (ret_directory_timeout); mhl_mem_free (ret_directory_timeout);
#endif #endif
} }
} }
@ -905,7 +906,7 @@ jobs_fill_listbox (void)
s = g_strconcat (state_str [tl->state], " ", tl->info, (char *) NULL); s = g_strconcat (state_str [tl->state], " ", tl->info, (char *) NULL);
listbox_add_item (bg_list, LISTBOX_APPEND_AT_END, 0, s, (void *) tl); listbox_add_item (bg_list, LISTBOX_APPEND_AT_END, 0, s, (void *) tl);
g_free (s); mhl_mem_free (s);
tl = tl->next; tl = tl->next;
} }
} }
@ -1083,7 +1084,7 @@ vfs_smb_get_authinfo (const char *host, const char *share, const char *domain,
auth_dlg = create_dlg (0, 0, dialog_y, dialog_x, dialog_colors, NULL, auth_dlg = create_dlg (0, 0, dialog_y, dialog_x, dialog_colors, NULL,
"[Smb Authinfo]", title, DLG_CENTER | DLG_REVERSE); "[Smb Authinfo]", title, DLG_CENTER | DLG_REVERSE);
g_free (title); mhl_mem_free (title);
in_user = input_new (5, istart, INPUT_COLOR, ilen, user, "auth_name"); in_user = input_new (5, istart, INPUT_COLOR, ilen, user, "auth_name");
add_widget (auth_dlg, in_user); add_widget (auth_dlg, in_user);

View File

@ -51,10 +51,10 @@ load_codepages_list (void)
fname = concat_dir_and_file (mc_home, CHARSETS_INDEX); fname = concat_dir_and_file (mc_home, CHARSETS_INDEX);
if (!(f = fopen (fname, "r"))) { if (!(f = fopen (fname, "r"))) {
fprintf (stderr, _("Warning: file %s not found\n"), fname); fprintf (stderr, _("Warning: file %s not found\n"), fname);
g_free (fname); mhl_mem_free (fname);
return -1; return -1;
} }
g_free (fname); mhl_mem_free (fname);
for (n_codepages = 0; fgets (buf, sizeof (buf), f);) for (n_codepages = 0; fgets (buf, sizeof (buf), f);)
if (buf[0] != '\n' && buf[0] != '\0' && buf[0] != '#') if (buf[0] != '\n' && buf[0] != '\0' && buf[0] != '#')
@ -97,7 +97,7 @@ load_codepages_list (void)
if (default_codepage) { if (default_codepage) {
display_codepage = get_codepage_index (default_codepage); display_codepage = get_codepage_index (default_codepage);
g_free (default_codepage); mhl_mem_free (default_codepage);
} }
result = n_codepages; result = n_codepages;
@ -112,11 +112,11 @@ free_codepages_list (void)
if (n_codepages > 0) { if (n_codepages > 0) {
int i; int i;
for (i = 0; i < n_codepages; i++) { for (i = 0; i < n_codepages; i++) {
g_free (codepages[i].id); mhl_mem_free (codepages[i].id);
g_free (codepages[i].name); mhl_mem_free (codepages[i].name);
} }
n_codepages = 0; n_codepages = 0;
g_free (codepages); mhl_mem_free (codepages);
codepages = 0; codepages = 0;
} }
} }

View File

@ -23,7 +23,6 @@
#include <errno.h> #include <errno.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#ifdef HAVE_MMAP #ifdef HAVE_MMAP
@ -34,6 +33,8 @@
#endif #endif
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "cmd.h" /* Our definitions */ #include "cmd.h" /* Our definitions */
#include "fileopctx.h" /* file_op_context_new() */ #include "fileopctx.h" /* file_op_context_new() */
@ -239,7 +240,7 @@ view_file_cmd (void)
return; return;
view_file (filename, 0, use_internal_view); view_file (filename, 0, use_internal_view);
g_free (filename); mhl_mem_free (filename);
} }
/* Run plain internal viewer on the currently selected file */ /* Run plain internal viewer on the currently selected file */
@ -264,7 +265,7 @@ filtered_view_cmd (void)
mc_internal_viewer (command, "", NULL, 0); mc_internal_viewer (command, "", NULL, 0);
g_free (command); mhl_mem_free (command);
} }
void do_edit_at_line (const char *what, int start_line) void do_edit_at_line (const char *what, int start_line)
@ -382,8 +383,8 @@ mkdir_cmd (void)
message (D_ERROR, MSG_ERROR, " %s ", unix_error_string (errno)); message (D_ERROR, MSG_ERROR, " %s ", unix_error_string (errno));
} }
g_free (absdir); mhl_mem_free (absdir);
g_free (dir); mhl_mem_free (dir);
} }
void delete_cmd (void) void delete_cmd (void)
@ -415,13 +416,13 @@ void find_cmd (void)
static void static void
set_panel_filter_to (WPanel *p, char *allocated_filter_string) set_panel_filter_to (WPanel *p, char *allocated_filter_string)
{ {
g_free (p->filter); mhl_mem_free (p->filter);
p->filter = 0; p->filter = 0;
if (!(allocated_filter_string [0] == '*' && allocated_filter_string [1] == 0)) if (!(allocated_filter_string [0] == '*' && allocated_filter_string [1] == 0))
p->filter = allocated_filter_string; p->filter = allocated_filter_string;
else else
g_free (allocated_filter_string); mhl_mem_free (allocated_filter_string);
reread_cmd (); reread_cmd ();
} }
@ -493,7 +494,7 @@ select_unselect_cmd (const char *title, const char *history_name, int cmd)
if (!reg_exp) if (!reg_exp)
return; return;
if (!*reg_exp) { if (!*reg_exp) {
g_free (reg_exp); mhl_mem_free (reg_exp);
return; return;
} }
@ -523,14 +524,14 @@ select_unselect_cmd (const char *title, const char *history_name, int cmd)
match_file); match_file);
if (c == -1) { if (c == -1) {
message (D_ERROR, MSG_ERROR, _(" Malformed regular expression ")); message (D_ERROR, MSG_ERROR, _(" Malformed regular expression "));
g_free (reg_exp); mhl_mem_free (reg_exp);
return; return;
} }
if (c) { if (c) {
do_file_mark (current_panel, i, cmd); do_file_mark (current_panel, i, cmd);
} }
} }
g_free (reg_exp); mhl_mem_free (reg_exp);
} }
void select_cmd (void) void select_cmd (void)
@ -583,11 +584,11 @@ void ext_cmd (void)
buffer = concat_dir_and_file (home_dir, MC_USER_EXT); buffer = concat_dir_and_file (home_dir, MC_USER_EXT);
check_for_default (extdir, buffer); check_for_default (extdir, buffer);
do_edit (buffer); do_edit (buffer);
g_free (buffer); mhl_mem_free (buffer);
} else if (dir == 1) } else if (dir == 1)
do_edit (extdir); do_edit (extdir);
g_free (extdir); mhl_mem_free (extdir);
flush_extension_file (); flush_extension_file ();
} }
@ -625,14 +626,14 @@ menu_edit_cmd (int where)
break; break;
default: default:
g_free (menufile); mhl_mem_free (menufile);
return; return;
} }
do_edit (buffer); do_edit (buffer);
if (dir == 0) if (dir == 0)
chmod(buffer, 0600); chmod(buffer, 0600);
g_free (buffer); mhl_mem_free (buffer);
g_free (menufile); mhl_mem_free (menufile);
} }
void quick_chdir_cmd (void) void quick_chdir_cmd (void)
@ -648,7 +649,7 @@ void quick_chdir_cmd (void)
else else
if (!do_cd (target, cd_exact)) if (!do_cd (target, cd_exact))
message (D_ERROR, MSG_ERROR, _("Cannot change directory") ); message (D_ERROR, MSG_ERROR, _("Cannot change directory") );
g_free (target); mhl_mem_free (target);
} }
/* edit file menu for mc */ /* edit file menu for mc */
@ -686,11 +687,11 @@ edit_syntax_cmd (void)
buffer = concat_dir_and_file (home_dir, SYNTAX_FILE); buffer = concat_dir_and_file (home_dir, SYNTAX_FILE);
check_for_default (extdir, buffer); check_for_default (extdir, buffer);
do_edit (buffer); do_edit (buffer);
g_free (buffer); mhl_mem_free (buffer);
} else if (dir == 1) } else if (dir == 1)
do_edit (extdir); do_edit (extdir);
g_free (extdir); mhl_mem_free (extdir);
} }
#endif #endif
@ -705,7 +706,7 @@ void reselect_vfs (void)
if (!do_cd (target, cd_exact)) if (!do_cd (target, cd_exact))
message (D_ERROR, MSG_ERROR, _("Cannot change directory") ); message (D_ERROR, MSG_ERROR, _("Cannot change directory") );
g_free (target); mhl_mem_free (target);
} }
#endif /* USE_VFS */ #endif /* USE_VFS */
@ -818,8 +819,8 @@ compare_dir (WPanel *panel, WPanel *other, enum CompareMode mode)
dst_name = concat_dir_and_file (other->cwd, target->fname); dst_name = concat_dir_and_file (other->cwd, target->fname);
if (compare_files (src_name, dst_name, source->st.st_size)) if (compare_files (src_name, dst_name, source->st.st_size))
do_file_mark (panel, i, 1); do_file_mark (panel, i, 1);
g_free (src_name); mhl_mem_free (src_name);
g_free (dst_name); mhl_mem_free (dst_name);
} }
} /* for (i ...) */ } /* for (i ...) */
} }
@ -878,7 +879,7 @@ history_cmd (void)
else else
current = listbox->list->current->data; current = listbox->list->current->data;
destroy_dlg (listbox->dlg); destroy_dlg (listbox->dlg);
g_free (listbox); mhl_mem_free (listbox);
if (!current) if (!current)
return; return;
@ -938,8 +939,8 @@ do_link (int symbolic_link, const char *fname)
} }
symlink_dialog (s, d, &dest, &src); symlink_dialog (s, d, &dest, &src);
g_free (d); mhl_mem_free (d);
g_free (s); mhl_mem_free (s);
if (!dest || !*dest || !src || !*src) if (!dest || !*dest || !src || !*src)
goto cleanup; goto cleanup;
@ -952,8 +953,8 @@ do_link (int symbolic_link, const char *fname)
repaint_screen (); repaint_screen ();
cleanup: cleanup:
g_free (src); mhl_mem_free (src);
g_free (dest); mhl_mem_free (dest);
} }
void link_cmd (void) void link_cmd (void)
@ -1001,10 +1002,10 @@ void edit_symlink_cmd (void)
update_panels (UP_OPTIMIZE, UP_KEEPSEL); update_panels (UP_OPTIMIZE, UP_KEEPSEL);
repaint_screen (); repaint_screen ();
} }
g_free (dest); mhl_mem_free (dest);
} }
} }
g_free (q); mhl_mem_free (q);
} else { } else {
message (D_ERROR, MSG_ERROR, _("`%s' is not a symbolic link"), message (D_ERROR, MSG_ERROR, _("`%s' is not a symbolic link"),
selection (current_panel)->fname); selection (current_panel)->fname);
@ -1023,7 +1024,7 @@ user_file_menu_cmd (void)
} }
/* partly taken from dcigettext.c, returns "" for default locale */ /* partly taken from dcigettext.c, returns "" for default locale */
/* value should be freed by calling function g_free() */ /* value should be freed by calling function mhl_mem_free() */
char *guess_message_value (void) char *guess_message_value (void)
{ {
static const char * const var[] = { static const char * const var[] = {
@ -1093,7 +1094,7 @@ get_random_hint (int force)
if (eol) if (eol)
*eol = 0; *eol = 0;
result = g_strdup (&data[start]); result = g_strdup (&data[start]);
g_free (data); mhl_mem_free (data);
return result; return result;
} }
@ -1124,8 +1125,8 @@ nice_cd (const char *text, const char *xtext, const char *help,
directory_history_add (MENU_PANEL, (MENU_PANEL)->cwd); directory_history_add (MENU_PANEL, (MENU_PANEL)->cwd);
else else
message (D_ERROR, MSG_ERROR, _(" Cannot chdir to %s "), cd_path); message (D_ERROR, MSG_ERROR, _(" Cannot chdir to %s "), cd_path);
g_free (cd_path); mhl_mem_free (cd_path);
g_free (machine); mhl_mem_free (machine);
} }
#endif /* USE_NETCODE || USE_EXT2FSLIB */ #endif /* USE_NETCODE || USE_EXT2FSLIB */
@ -1185,9 +1186,9 @@ void quick_cd_cmd (void)
char *q = g_strconcat ("cd ", p, (char *) NULL); char *q = g_strconcat ("cd ", p, (char *) NULL);
do_cd_command (q); do_cd_command (q);
g_free (q); mhl_mem_free (q);
} }
g_free (p); mhl_mem_free (p);
} }
void void
@ -1253,17 +1254,17 @@ configure_panel_listing (WPanel *p, int view_type, int use_msformat, char *user,
p->list_type = view_type; p->list_type = view_type;
if (view_type == list_user || use_msformat){ if (view_type == list_user || use_msformat){
g_free (p->user_format); mhl_mem_free (p->user_format);
p->user_format = user; p->user_format = user;
g_free (p->user_status_format [view_type]); mhl_mem_free (p->user_status_format [view_type]);
p->user_status_format [view_type] = status; p->user_status_format [view_type] = status;
set_panel_formats (p); set_panel_formats (p);
} }
else { else {
g_free (user); mhl_mem_free (user);
g_free (status); mhl_mem_free (status);
} }
set_panel_formats (p); set_panel_formats (p);

View File

@ -22,6 +22,8 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "setup.h" /* For the externs */ #include "setup.h" /* For the externs */
@ -252,7 +254,7 @@ static void configure_colors_string (const char *the_color_string)
color_string++; color_string++;
} }
} }
g_free (p); mhl_mem_free (p);
} }
static void configure_colors (void) static void configure_colors (void)
@ -464,9 +466,9 @@ done_colors (void)
for (p = c.next; p; p = next) { for (p = c.next; p; p = next) {
next = p->next; next = p->next;
g_free (p->fg); mhl_mem_free (p->fg);
g_free (p->bg); mhl_mem_free (p->bg);
g_free (p); mhl_mem_free (p);
} }
c.next = NULL; c.next = NULL;
} }

View File

@ -27,6 +27,8 @@
#include <errno.h> #include <errno.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "global.h" /* home_dir */ #include "global.h" /* home_dir */
#include "tty.h" #include "tty.h"
#include "widget.h" /* WInput */ #include "widget.h" /* WInput */
@ -126,15 +128,15 @@ examine_cd (char *path)
if (*p) { if (*p) {
r = concat_dir_and_file (p, q); r = concat_dir_and_file (p, q);
result = do_cd (r, cd_parse_command); result = do_cd (r, cd_parse_command);
g_free (r); mhl_mem_free (r);
} }
*s = c; *s = c;
p = s + 1; p = s + 1;
} }
g_free (cdpath); mhl_mem_free (cdpath);
} }
g_free (q); mhl_mem_free (q);
g_free (path_tilde); mhl_mem_free (path_tilde);
return result; return result;
} }
@ -178,14 +180,14 @@ void do_cd_command (char *cmd)
char *new; char *new;
new = concat_dir_and_file (old, cmd+3); new = concat_dir_and_file (old, cmd+3);
sync_tree (new); sync_tree (new);
g_free (new); mhl_mem_free (new);
} }
} else } else
if (!examine_cd (&cmd [3])) { if (!examine_cd (&cmd [3])) {
char *d = strip_password (g_strdup (&cmd [3]), 1); char *d = strip_password (g_strdup (&cmd [3]), 1);
message (D_ERROR, MSG_ERROR, _(" Cannot chdir to \"%s\" \n %s "), message (D_ERROR, MSG_ERROR, _(" Cannot chdir to \"%s\" \n %s "),
d, unix_error_string (errno)); d, unix_error_string (errno));
g_free (d); mhl_mem_free (d);
return; return;
} }
} }
@ -239,7 +241,7 @@ enter (WInput *cmdline)
s = expand_format (NULL, cmd[i], 1); s = expand_format (NULL, cmd[i], 1);
command = g_realloc (command, j + strlen (s) + cmd_len - i + 1); command = g_realloc (command, j + strlen (s) + cmd_len - i + 1);
strcpy (command + j, s); strcpy (command + j, s);
g_free (s); mhl_mem_free (s);
j = strlen (command); j = strlen (command);
} else { } else {
command[j] = cmd[i]; command[j] = cmd[i];
@ -249,7 +251,7 @@ enter (WInput *cmdline)
} }
new_input (cmdline); new_input (cmdline);
shell_execute (command, 0); shell_execute (command, 0);
g_free (command); mhl_mem_free (command);
#ifdef HAVE_SUBSHELL_SUPPORT #ifdef HAVE_SUBSHELL_SUPPORT
if (quit & SUBSHELL_EXIT) { if (quit & SUBSHELL_EXIT) {
@ -310,6 +312,6 @@ command_insert (WInput * in, const char *text, int insert_extra_space)
quoted_text = name_quote (text, 1); quoted_text = name_quote (text, 1);
stuff (in, quoted_text, insert_extra_space); stuff (in, quoted_text, insert_extra_space);
g_free (quoted_text); mhl_mem_free (quoted_text);
} }

View File

@ -26,11 +26,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "win.h" #include "win.h"
@ -67,9 +68,9 @@ filename_completion_function (char *text, int state)
if (!state){ if (!state){
const char *temp; const char *temp;
g_free (dirname); mhl_mem_free (dirname);
g_free (filename); mhl_mem_free (filename);
g_free (users_dirname); mhl_mem_free (users_dirname);
if ((*text) && (temp = strrchr (text, PATH_SEP))){ if ((*text) && (temp = strrchr (text, PATH_SEP))){
filename = g_strdup (++temp); filename = g_strdup (++temp);
@ -133,7 +134,7 @@ filename_completion_function (char *text, int state)
isexec = 1; isexec = 1;
} }
} }
g_free (tmp); mhl_mem_free (tmp);
} }
switch (look_for_executables) switch (look_for_executables)
{ {
@ -154,11 +155,11 @@ filename_completion_function (char *text, int state)
mc_closedir (directory); mc_closedir (directory);
directory = NULL; directory = NULL;
} }
g_free (dirname); mhl_mem_free (dirname);
dirname = NULL; dirname = NULL;
g_free (filename); mhl_mem_free (filename);
filename = NULL; filename = NULL;
g_free (users_dirname); mhl_mem_free (users_dirname);
users_dirname = NULL; users_dirname = NULL;
return NULL; return NULL;
} else { } else {
@ -333,7 +334,7 @@ static void fetch_hosts (const char *filename)
*(hosts_p++) = name; *(hosts_p++) = name;
*hosts_p = NULL; *hosts_p = NULL;
} else } else
g_free (name); mhl_mem_free (name);
} }
} }
} }
@ -351,8 +352,8 @@ hostname_completion_function (char *text, int state)
if (hosts != NULL){ if (hosts != NULL){
for (host_p = hosts; *host_p; host_p++) for (host_p = hosts; *host_p; host_p++)
g_free (*host_p); mhl_mem_free (*host_p);
g_free (hosts); mhl_mem_free (hosts);
} }
hosts = g_new (char *, (hosts_alloclen = 30) + 1); hosts = g_new (char *, (hosts_alloclen = 30) + 1);
*hosts = NULL; *hosts = NULL;
@ -373,8 +374,8 @@ hostname_completion_function (char *text, int state)
if (!*host_p){ if (!*host_p){
for (host_p = hosts; *host_p; host_p++) for (host_p = hosts; *host_p; host_p++)
g_free (*host_p); mhl_mem_free (*host_p);
g_free (hosts); mhl_mem_free (hosts);
hosts = NULL; hosts = NULL;
return NULL; return NULL;
} else { } else {
@ -475,7 +476,7 @@ command_completion_function (char *text, int state)
break; break;
expanded = tilde_expand (*cur_path ? cur_path : "."); expanded = tilde_expand (*cur_path ? cur_path : ".");
cur_word = concat_dir_and_file (expanded, text); cur_word = concat_dir_and_file (expanded, text);
g_free (expanded); mhl_mem_free (expanded);
canonicalize_pathname (cur_word); canonicalize_pathname (cur_word);
cur_path = strchr (cur_path, 0) + 1; cur_path = strchr (cur_path, 0) + 1;
init_state = state; init_state = state;
@ -484,7 +485,7 @@ command_completion_function (char *text, int state)
filename_completion_function (cur_word, filename_completion_function (cur_word,
state - init_state); state - init_state);
if (!found) { if (!found) {
g_free (cur_word); mhl_mem_free (cur_word);
cur_word = NULL; cur_word = NULL;
} }
} }
@ -492,14 +493,14 @@ command_completion_function (char *text, int state)
if (!found) { if (!found) {
look_for_executables = 0; look_for_executables = 0;
g_free (path); mhl_mem_free (path);
path = NULL; path = NULL;
return NULL; return NULL;
} }
if ((p = strrchr (found, PATH_SEP)) != NULL) { if ((p = strrchr (found, PATH_SEP)) != NULL) {
p++; p++;
p = g_strdup (p); p = g_strdup (p);
g_free (found); mhl_mem_free (found);
return p; return p;
} }
return found; return found;
@ -572,7 +573,7 @@ completion_matches (char *text, CompletionFunction entry_function)
if (c1 != c2) break; if (c1 != c2) break;
if (!c1 && !match_list [j][si]){ /* Two equal strings */ if (!c1 && !match_list [j][si]){ /* Two equal strings */
g_free (match_list [j]); mhl_mem_free (match_list [j]);
j++; j++;
if (j > matches) if (j > matches)
break; break;
@ -588,7 +589,7 @@ completion_matches (char *text, CompletionFunction entry_function)
match_list[0] = g_strndup(match_list[1], low); match_list[0] = g_strndup(match_list[1], low);
} }
} else { /* There were no matches. */ } else { /* There were no matches. */
g_free (match_list); mhl_mem_free (match_list);
match_list = NULL; match_list = NULL;
} }
return match_list; return match_list;
@ -744,17 +745,17 @@ try_complete (char *text, int *start, int *end, int flags)
ignore_filenames = 1; ignore_filenames = 1;
matches = completion_matches (r, filename_completion_function); matches = completion_matches (r, filename_completion_function);
ignore_filenames = 0; ignore_filenames = 0;
g_free (r); mhl_mem_free (r);
} }
*s = c; *s = c;
cdpath = s + 1; cdpath = s + 1;
} }
g_free (cdpath_ref); mhl_mem_free (cdpath_ref);
} }
} }
} }
g_free (word); mhl_mem_free (word);
return matches; return matches;
} }
@ -766,8 +767,8 @@ void free_completions (WInput *in)
if (!in->completions) if (!in->completions)
return; return;
for (p=in->completions; *p; p++) for (p=in->completions; *p; p++)
g_free (*p); mhl_mem_free (*p);
g_free (in->completions); mhl_mem_free (in->completions);
in->completions = NULL; in->completions = NULL;
} }

View File

@ -265,7 +265,7 @@ console_shutdown (void)
if (!console_flag) if (!console_flag)
return; return;
g_free (screen_shot.buf); mhl_mem_free (screen_shot.buf);
console_flag = 0; console_flag = 0;
} }

View File

@ -24,6 +24,8 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "mouse.h" #include "mouse.h"
@ -218,7 +220,7 @@ create_dlg (int y1, int x1, int lines, int cols, const int *color_set,
char *t; char *t;
t = g_strstrip (g_strdup (title)); t = g_strstrip (g_strdup (title));
new_d->title = g_strconcat (" ", t, " ", (char *) NULL); new_d->title = g_strconcat (" ", t, " ", (char *) NULL);
g_free (t); mhl_mem_free (t);
} }
return (new_d); return (new_d);
@ -813,11 +815,11 @@ destroy_dlg (Dlg_head *h)
c = h->current; c = h->current;
for (i = 0; i < h->count; i++) { for (i = 0; i < h->count; i++) {
c = c->next; c = c->next;
g_free (h->current); mhl_mem_free (h->current);
h->current = c; h->current = c;
} }
g_free (h->title); mhl_mem_free (h->title);
g_free (h); mhl_mem_free (h);
do_refresh (); do_refresh ();
} }

View File

@ -22,9 +22,10 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "dir.h" #include "dir.h"
@ -254,7 +255,7 @@ clean_dir (dir_list *list, int count)
int i; int i;
for (i = 0; i < count; i++){ for (i = 0; i < count; i++){
g_free (list->list [i].fname); mhl_mem_free (list->list [i].fname);
list->list [i].fname = 0; list->list [i].fname = 0;
} }
} }
@ -471,9 +472,9 @@ alloc_dir_copy (int size)
if (dir_copy.list){ if (dir_copy.list){
for (i = 0; i < dir_copy.size; i++) { for (i = 0; i < dir_copy.size; i++) {
g_free (dir_copy.list [i].fname); mhl_mem_free (dir_copy.list [i].fname);
} }
g_free (dir_copy.list); mhl_mem_free (dir_copy.list);
dir_copy.list = 0; dir_copy.list = 0;
} }

View File

@ -75,12 +75,12 @@ test_locale_en_US_UTF_8(void)
valid = ecs_mbstr_to_str(&ecs, teststr_mb); valid = ecs_mbstr_to_str(&ecs, teststr_mb);
assert(valid); assert(valid);
assert(ecs_strlen(ecs) == 10); assert(ecs_strlen(ecs) == 10);
g_free(ecs); mhl_mem_free(ecs);
valid = ecs_str_to_mbstr(&mbs, teststr_ecs); valid = ecs_str_to_mbstr(&mbs, teststr_ecs);
assert(valid); assert(valid);
assert(strlen(mbs) == 11); assert(strlen(mbs) == 11);
g_free(mbs); mhl_mem_free(mbs);
} }
#endif #endif

View File

@ -45,7 +45,7 @@ extern gboolean ecs_mbstr_to_str(ecs_char **ret_str, const char *s)
str = g_new(ecs_char, maxlen + 1); str = g_new(ecs_char, maxlen + 1);
len = mbstowcs(str, s, maxlen + 1); len = mbstowcs(str, s, maxlen + 1);
if (len == (size_t) -1) { if (len == (size_t) -1) {
g_free(str); mhl_mem_free(str);
return FALSE; return FALSE;
} }
@ -69,7 +69,7 @@ extern gboolean ecs_str_to_mbstr(char **ret_str, const ecs_char *s)
str = g_new(char, maxlen + 1); str = g_new(char, maxlen + 1);
len = wcstombs(str, s, maxlen + 1); len = wcstombs(str, s, maxlen + 1);
if (len == (size_t) -1) { if (len == (size_t) -1) {
g_free(str); mhl_mem_free(str);
return FALSE; return FALSE;
} }

View File

@ -47,7 +47,7 @@ typedef char ecs_char;
/* /*
* String conversion functions between the wide character encoding and * String conversion functions between the wide character encoding and
* the multibyte encoding. The returned strings should be freed using * the multibyte encoding. The returned strings should be freed using
* g_free after use. The return value is TRUE if the string is valid * mhl_mem_free after use. The return value is TRUE if the string is valid
* and has been converted, FALSE otherwise. * and has been converted, FALSE otherwise.
*/ */

View File

@ -19,6 +19,8 @@
#include <signal.h> #include <signal.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "win.h" #include "win.h"
@ -161,7 +163,7 @@ do_execute (const char *shell, const char *command, int flags)
#ifdef USE_VFS #ifdef USE_VFS
if (old_vfs_dir) { if (old_vfs_dir) {
mc_chdir (old_vfs_dir); mc_chdir (old_vfs_dir);
g_free (old_vfs_dir); mhl_mem_free (old_vfs_dir);
} }
#endif /* USE_VFS */ #endif /* USE_VFS */
@ -195,7 +197,7 @@ shell_execute (const char *command, int flags)
#endif /* HAVE_SUBSHELL_SUPPORT */ #endif /* HAVE_SUBSHELL_SUPPORT */
do_execute (shell, cmd ? cmd : command, flags | EXECUTE_AS_SHELL); do_execute (shell, cmd ? cmd : command, flags | EXECUTE_AS_SHELL);
g_free (cmd); mhl_mem_free (cmd);
} }
@ -368,6 +370,6 @@ execute_with_vfs_arg (const char *command, const char *filename)
do_execute (command, localcopy, EXECUTE_INTERNAL); do_execute (command, localcopy, EXECUTE_INTERNAL);
mc_stat (localcopy, &st); mc_stat (localcopy, &st);
mc_ungetlocalcopy (fn, localcopy, mtime != st.st_mtime); mc_ungetlocalcopy (fn, localcopy, mtime != st.st_mtime);
g_free (localcopy); mhl_mem_free (localcopy);
g_free (fn); mhl_mem_free (fn);
} }

View File

@ -25,9 +25,10 @@
#include <errno.h> #include <errno.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "user.h" #include "user.h"
@ -52,7 +53,7 @@ static char *data = NULL;
void void
flush_extension_file (void) flush_extension_file (void)
{ {
g_free (data); mhl_mem_free (data);
data = NULL; data = NULL;
} }
@ -121,14 +122,14 @@ exec_extension (const char *filename, const char *data, int *move_dir,
unlink (file_name); unlink (file_name);
if (localcopy) { if (localcopy) {
mc_ungetlocalcopy (filename, localcopy, 0); mc_ungetlocalcopy (filename, localcopy, 0);
g_free (localcopy); mhl_mem_free (localcopy);
} }
g_free (file_name); mhl_mem_free (file_name);
return; return;
} }
fputs (parameter, cmd_file); fputs (parameter, cmd_file);
written_nonspace = 1; written_nonspace = 1;
g_free (parameter); mhl_mem_free (parameter);
} else { } else {
size_t len = strlen (prompt); size_t len = strlen (prompt);
@ -156,7 +157,7 @@ exec_extension (const char *filename, const char *data, int *move_dir,
data += i - 1; data += i - 1;
} else if ((i = check_format_var (data, &v)) > 0 && v) { } else if ((i = check_format_var (data, &v)) > 0 && v) {
fputs (v, cmd_file); fputs (v, cmd_file);
g_free (v); mhl_mem_free (v);
data += i; data += i;
} else { } else {
char *text; char *text;
@ -167,7 +168,7 @@ exec_extension (const char *filename, const char *data, int *move_dir,
if (localcopy == NULL) { if (localcopy == NULL) {
fclose (cmd_file); fclose (cmd_file);
unlink (file_name); unlink (file_name);
g_free (file_name); mhl_mem_free (file_name);
return; return;
} }
mc_stat (localcopy, &mystat); mc_stat (localcopy, &mystat);
@ -184,7 +185,7 @@ exec_extension (const char *filename, const char *data, int *move_dir,
strcpy (p, text); strcpy (p, text);
p = strchr (p, 0); p = strchr (p, 0);
} }
g_free (text); mhl_mem_free (text);
written_nonspace = 1; written_nonspace = 1;
} }
} }
@ -215,7 +216,7 @@ exec_extension (const char *filename, const char *data, int *move_dir,
if ((run_view && !written_nonspace) || is_cd) { if ((run_view && !written_nonspace) || is_cd) {
unlink (file_name); unlink (file_name);
g_free (file_name); mhl_mem_free (file_name);
file_name = NULL; file_name = NULL;
} else { } else {
/* Set executable flag on the command file ... */ /* Set executable flag on the command file ... */
@ -274,14 +275,14 @@ exec_extension (const char *filename, const char *data, int *move_dir,
} }
} }
g_free (file_name); mhl_mem_free (file_name);
g_free (cmd); mhl_mem_free (cmd);
if (localcopy) { if (localcopy) {
mc_stat (localcopy, &mystat); mc_stat (localcopy, &mystat);
mc_ungetlocalcopy (filename, localcopy, mc_ungetlocalcopy (filename, localcopy,
localmtime != mystat.st_mtime); localmtime != mystat.st_mtime);
g_free (localcopy); mhl_mem_free (localcopy);
} }
} }
@ -304,8 +305,8 @@ get_file_type_local (const char *filename, char *buf, int buflen)
char *command = g_strconcat (FILE_CMD, tmp, " 2>/dev/null", (char *) 0); char *command = g_strconcat (FILE_CMD, tmp, " 2>/dev/null", (char *) 0);
FILE *f = popen (command, "r"); FILE *f = popen (command, "r");
g_free (tmp); mhl_mem_free (tmp);
g_free (command); mhl_mem_free (command);
if (f != NULL) { if (f != NULL) {
#ifdef __QNXNTO__ #ifdef __QNXNTO__
if (setvbuf (f, NULL, _IOFBF, 0) != 0) { if (setvbuf (f, NULL, _IOFBF, 0) != 0) {
@ -386,7 +387,7 @@ regex_check_type (const char *filename, const char *ptr, int *have_type)
/* No data */ /* No data */
content_string[0] = 0; content_string[0] = 0;
} }
g_free (realname); mhl_mem_free (realname);
} }
if (got_data == -1) { if (got_data == -1) {
@ -442,20 +443,20 @@ regex_command (const char *filename, const char *action, int *move_dir)
extension_file = concat_dir_and_file (home_dir, MC_USER_EXT); extension_file = concat_dir_and_file (home_dir, MC_USER_EXT);
if (!exist_file (extension_file)) { if (!exist_file (extension_file)) {
g_free (extension_file); mhl_mem_free (extension_file);
check_stock_mc_ext: check_stock_mc_ext:
extension_file = concat_dir_and_file (mc_home, MC_LIB_EXT); extension_file = concat_dir_and_file (mc_home, MC_LIB_EXT);
mc_user_ext = 0; mc_user_ext = 0;
} }
data = load_file (extension_file); data = load_file (extension_file);
g_free (extension_file); mhl_mem_free (extension_file);
if (data == NULL) if (data == NULL)
return 0; return 0;
if (!strstr (data, "default/")) { if (!strstr (data, "default/")) {
if (!strstr (data, "regex/") && !strstr (data, "shell/") if (!strstr (data, "regex/") && !strstr (data, "shell/")
&& !strstr (data, "type/")) { && !strstr (data, "type/")) {
g_free (data); mhl_mem_free (data);
data = NULL; data = NULL;
if (mc_user_ext) { if (mc_user_ext) {
home_error = 1; home_error = 1;
@ -469,7 +470,7 @@ regex_command (const char *filename, const char *action, int *move_dir)
"the installation failed. Please fetch a fresh " "the installation failed. Please fetch a fresh "
"copy from the Midnight Commander package."), "copy from the Midnight Commander package."),
mc_home); mc_home);
g_free (title); mhl_mem_free (title);
return 0; return 0;
} }
} }
@ -481,7 +482,7 @@ regex_command (const char *filename, const char *action, int *move_dir)
"changed with version 3.0. You may either want to copy " "changed with version 3.0. You may either want to copy "
"it from %smc.ext or use that file as an example of how " "it from %smc.ext or use that file as an example of how "
"to write it."), MC_USER_EXT, mc_home); "to write it."), MC_USER_EXT, mc_home);
g_free (title); mhl_mem_free (title);
} }
} }
mc_stat (filename, &mystat); mc_stat (filename, &mystat);
@ -594,7 +595,7 @@ regex_command (const char *filename, const char *action, int *move_dir)
exec_extension (filename_copy, r + 1, move_dir, exec_extension (filename_copy, r + 1, move_dir,
view_at_line_number); view_at_line_number);
g_free (filename_copy); mhl_mem_free (filename_copy);
ret = 1; ret = 1;
} }

View File

@ -247,7 +247,7 @@ transform_source (FileOpContext *ctx, const char *source)
*q = ' '; *q = ' ';
} }
p = do_transform_source (ctx, s); p = do_transform_source (ctx, s);
g_free (s); mhl_mem_free (s);
return p; return p;
} }
@ -258,7 +258,7 @@ free_linklist (struct link **linklist)
for (lp = *linklist; lp != NULL; lp = lp2) { for (lp = *linklist; lp != NULL; lp = lp2) {
lp2 = lp->next; lp2 = lp->next;
g_free (lp); mhl_mem_free (lp);
} }
*linklist = NULL; *linklist = NULL;
} }
@ -390,17 +390,17 @@ make_symlink (FileOpContext *ctx, const char *src_path, const char *dst_path)
if (s) { if (s) {
s[1] = 0; s[1] = 0;
s = g_strconcat (p, link_target, (char *) NULL); s = g_strconcat (p, link_target, (char *) NULL);
g_free (p); mhl_mem_free (p);
g_strlcpy (link_target, s, sizeof (link_target)); g_strlcpy (link_target, s, sizeof (link_target));
g_free (s); mhl_mem_free (s);
s = diff_two_paths (q, link_target); s = diff_two_paths (q, link_target);
if (s) { if (s) {
g_strlcpy (link_target, s, sizeof (link_target)); g_strlcpy (link_target, s, sizeof (link_target));
g_free (s); mhl_mem_free (s);
} }
} else } else
g_free (p); mhl_mem_free (p);
g_free (q); mhl_mem_free (q);
} }
} }
retry_dst_symlink: retry_dst_symlink:
@ -751,7 +751,7 @@ copy_file_file (FileOpContext *ctx, const char *src_path, const char *dst_path,
dst_status = DEST_FULL; /* copy successful, don't remove target file */ dst_status = DEST_FULL; /* copy successful, don't remove target file */
ret: ret:
g_free (buf); mhl_mem_free (buf);
while (src_desc != -1 && mc_close (src_desc) < 0) { while (src_desc != -1 && mc_close (src_desc) < 0) {
temp_status = file_error ( temp_status = file_error (
@ -889,7 +889,7 @@ copy_dir_dir (FileOpContext *ctx, const char *s, const char *d, int toplevel,
if (move_over) { if (move_over) {
if (mc_rename (s, d) == 0) { if (mc_rename (s, d) == 0) {
g_free (parent_dirs); mhl_mem_free (parent_dirs);
return FILE_CONT; return FILE_CONT;
} }
} }
@ -908,7 +908,7 @@ copy_dir_dir (FileOpContext *ctx, const char *s, const char *d, int toplevel,
_(" Destination \"%s\" must be a directory \n %s "), d); _(" Destination \"%s\" must be a directory \n %s "), d);
if (return_status == FILE_RETRY) if (return_status == FILE_RETRY)
goto retry_dst_stat; goto retry_dst_stat;
g_free (parent_dirs); mhl_mem_free (parent_dirs);
return return_status; return return_status;
} }
/* Dive into subdir if exists */ /* Dive into subdir if exists */
@ -972,12 +972,12 @@ copy_dir_dir (FileOpContext *ctx, const char *s, const char *d, int toplevel,
*/ */
return_status = copy_dir_dir (ctx, path, mdpath, 0, 0, delete, return_status = copy_dir_dir (ctx, path, mdpath, 0, 0, delete,
parent_dirs, progress_count, progress_bytes); parent_dirs, progress_count, progress_bytes);
g_free (mdpath); mhl_mem_free (mdpath);
} else { } else {
dest_file = concat_dir_and_file (dest_dir, x_basename (path)); dest_file = concat_dir_and_file (dest_dir, x_basename (path));
return_status = copy_file_file (ctx, path, dest_file, 1, return_status = copy_file_file (ctx, path, dest_file, 1,
progress_count, progress_bytes, 0); progress_count, progress_bytes, 0);
g_free (dest_file); mhl_mem_free (dest_file);
} }
if (delete && return_status == FILE_CONT) { if (delete && return_status == FILE_CONT) {
if (ctx->erase_at_end) { if (ctx->erase_at_end) {
@ -998,7 +998,7 @@ copy_dir_dir (FileOpContext *ctx, const char *s, const char *d, int toplevel,
return_status = erase_file (ctx, path, 0, 0, 0); return_status = erase_file (ctx, path, 0, 0, 0);
} }
} }
g_free (path); mhl_mem_free (path);
} }
mc_closedir (reading); mc_closedir (reading);
@ -1010,8 +1010,8 @@ copy_dir_dir (FileOpContext *ctx, const char *s, const char *d, int toplevel,
} }
ret: ret:
g_free (dest_dir); mhl_mem_free (dest_dir);
g_free (parent_dirs); mhl_mem_free (parent_dirs);
return return_status; return return_status;
} }
@ -1206,7 +1206,7 @@ move_dir_dir (FileOpContext *ctx, const char *s, const char *d,
if (return_status == FILE_RETRY) if (return_status == FILE_RETRY)
goto retry_dst_stat; goto retry_dst_stat;
} }
g_free (destdir); mhl_mem_free (destdir);
return return_status; return return_status;
} }
@ -1249,17 +1249,17 @@ move_dir_dir (FileOpContext *ctx, const char *s, const char *d,
erase_file (ctx, erase_list->name, 0, 0, 0); erase_file (ctx, erase_list->name, 0, 0, 0);
lp = erase_list; lp = erase_list;
erase_list = erase_list->next; erase_list = erase_list->next;
g_free (lp); mhl_mem_free (lp);
} }
} }
erase_dir_iff_empty (ctx, s); erase_dir_iff_empty (ctx, s);
ret: ret:
g_free (destdir); mhl_mem_free (destdir);
while (erase_list) { while (erase_list) {
lp = erase_list; lp = erase_list;
erase_list = erase_list->next; erase_list = erase_list->next;
g_free (lp); mhl_mem_free (lp);
} }
return return_status; return return_status;
} }
@ -1323,7 +1323,7 @@ recursive_erase (FileOpContext *ctx, const char *s, off_t *progress_count,
continue; continue;
path = concat_dir_and_file (s, next->d_name); path = concat_dir_and_file (s, next->d_name);
if (mc_lstat (path, &buf)) { if (mc_lstat (path, &buf)) {
g_free (path); mhl_mem_free (path);
mc_closedir (reading); mc_closedir (reading);
return 1; return 1;
} }
@ -1335,7 +1335,7 @@ recursive_erase (FileOpContext *ctx, const char *s, off_t *progress_count,
else else
return_status = return_status =
erase_file (ctx, path, progress_count, progress_bytes, 0); erase_file (ctx, path, progress_count, progress_bytes, 0);
g_free (path); mhl_mem_free (path);
} }
mc_closedir (reading); mc_closedir (reading);
if (return_status != FILE_CONT) if (return_status != FILE_CONT)
@ -1517,7 +1517,7 @@ compute_dir_size (const char *dirname, off_t *ret_marked, double *ret_total)
res = mc_lstat (fullname, &s); res = mc_lstat (fullname, &s);
if (res != 0) { if (res != 0) {
g_free (fullname); mhl_mem_free (fullname);
continue; continue;
} }
@ -1533,7 +1533,7 @@ compute_dir_size (const char *dirname, off_t *ret_marked, double *ret_total)
(*ret_marked)++; (*ret_marked)++;
*ret_total += s.st_size; *ret_total += s.st_size;
} }
g_free (fullname); mhl_mem_free (fullname);
} }
mc_closedir (dir); mc_closedir (dir);
@ -1574,7 +1574,7 @@ panel_compute_totals (WPanel *panel, off_t *ret_marked, double *ret_total)
*ret_marked += subdir_count; *ret_marked += subdir_count;
*ret_total += subdir_bytes; *ret_total += subdir_bytes;
g_free (dir_name); mhl_mem_free (dir_name);
} else { } else {
(*ret_marked)++; (*ret_marked)++;
*ret_total += s->st_size; *ret_total += s->st_size;
@ -1820,7 +1820,7 @@ panel_operate (void *source_panel, FileOperation operation,
} }
if (!*dest) { if (!*dest) {
file_op_context_destroy (ctx); file_op_context_destroy (ctx);
g_free (dest); mhl_mem_free (dest);
return 0; return 0;
} }
} }
@ -1893,7 +1893,7 @@ panel_operate (void *source_panel, FileOperation operation,
value = transform_error; value = transform_error;
} else { } else {
char *temp2 = concat_dir_and_file (dest, temp); char *temp2 = concat_dir_and_file (dest, temp);
g_free (dest); mhl_mem_free (dest);
dest = temp2; dest = temp2;
temp = NULL; temp = NULL;
@ -1969,7 +1969,7 @@ panel_operate (void *source_panel, FileOperation operation,
src_stat = panel->dir.list[i].st; src_stat = panel->dir.list[i].st;
#ifdef WITH_FULL_PATHS #ifdef WITH_FULL_PATHS
g_free (source_with_path); mhl_mem_free (source_with_path);
source_with_path = concat_dir_and_file (panel->cwd, source); source_with_path = concat_dir_and_file (panel->cwd, source);
#endif /* WITH_FULL_PATHS */ #endif /* WITH_FULL_PATHS */
@ -2021,7 +2021,7 @@ panel_operate (void *source_panel, FileOperation operation,
/* Unknown file operation */ /* Unknown file operation */
abort (); abort ();
} }
g_free (temp2); mhl_mem_free (temp2);
} }
} /* Copy or move operation */ } /* Copy or move operation */
@ -2053,20 +2053,20 @@ panel_operate (void *source_panel, FileOperation operation,
if (save_cwd) { if (save_cwd) {
mc_setctl (save_cwd, VFS_SETCTL_STALE_DATA, NULL); mc_setctl (save_cwd, VFS_SETCTL_STALE_DATA, NULL);
g_free (save_cwd); mhl_mem_free (save_cwd);
} }
if (save_dest) { if (save_dest) {
mc_setctl (save_dest, VFS_SETCTL_STALE_DATA, NULL); mc_setctl (save_dest, VFS_SETCTL_STALE_DATA, NULL);
g_free (save_dest); mhl_mem_free (save_dest);
} }
free_linklist (&linklist); free_linklist (&linklist);
free_linklist (&dest_dirs); free_linklist (&dest_dirs);
#ifdef WITH_FULL_PATHS #ifdef WITH_FULL_PATHS
g_free (source_with_path); mhl_mem_free (source_with_path);
#endif /* WITH_FULL_PATHS */ #endif /* WITH_FULL_PATHS */
g_free (dest); mhl_mem_free (dest);
g_free (ctx->dest_mask); mhl_mem_free (ctx->dest_mask);
ctx->dest_mask = NULL; ctx->dest_mask = NULL;
#ifdef WITH_BACKGROUND #ifdef WITH_BACKGROUND
/* Let our parent know we are saying bye bye */ /* Let our parent know we are saying bye bye */
@ -2160,7 +2160,7 @@ real_query_recursive (FileOpContext *ctx, enum OperationMode mode, const char *s
if (ctx->recursive_result != RECURSIVE_ABORT) if (ctx->recursive_result != RECURSIVE_ABORT)
do_refresh (); do_refresh ();
g_free (text); mhl_mem_free (text);
} }
switch (ctx->recursive_result) { switch (ctx->recursive_result) {

View File

@ -48,11 +48,12 @@
#include <ctype.h> #include <ctype.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "setup.h" /* verbose */ #include "setup.h" /* verbose */
#include "dialog.h" /* do_refresh() */ #include "dialog.h" /* do_refresh() */
@ -256,7 +257,7 @@ file_op_context_destroy_ui (FileOpContext *ctx)
dlg_run_done (ui->op_dlg); dlg_run_done (ui->op_dlg);
destroy_dlg (ui->op_dlg); destroy_dlg (ui->op_dlg);
g_free (ui); mhl_mem_free (ui);
} }
the_hint->widget.y = last_hint_line; the_hint->widget.y = last_hint_line;
@ -904,10 +905,10 @@ file_mask_dialog (FileOpContext *ctx, FileOperation operation, const char *text,
ask_file_mask: ask_file_mask:
if ((val = quick_dialog_skip (&Quick_input, SKIP)) == B_CANCEL) { if ((val = quick_dialog_skip (&Quick_input, SKIP)) == B_CANCEL) {
g_free (def_text_secure); mhl_mem_free (def_text_secure);
return 0; return 0;
} }
g_free (def_text_secure); mhl_mem_free (def_text_secure);
if (ctx->follow_links) if (ctx->follow_links)
ctx->stat_func = mc_stat; ctx->stat_func = mc_stat;
@ -928,7 +929,7 @@ file_mask_dialog (FileOpContext *ctx, FileOperation operation, const char *text,
orig_mask = source_mask; orig_mask = source_mask;
if (!dest_dir || !*dest_dir) { if (!dest_dir || !*dest_dir) {
g_free (source_mask); mhl_mem_free (source_mask);
return dest_dir; return dest_dir;
} }
if (source_easy_patterns) { if (source_easy_patterns) {
@ -939,7 +940,7 @@ file_mask_dialog (FileOpContext *ctx, FileOperation operation, const char *text,
error = error =
re_compile_pattern (source_mask, strlen (source_mask), re_compile_pattern (source_mask, strlen (source_mask),
&ctx->rx); &ctx->rx);
g_free (source_mask); mhl_mem_free (source_mask);
} else } else
error = error =
re_compile_pattern (source_mask, strlen (source_mask), re_compile_pattern (source_mask, strlen (source_mask),
@ -948,14 +949,14 @@ file_mask_dialog (FileOpContext *ctx, FileOperation operation, const char *text,
if (error) { if (error) {
message (D_ERROR, MSG_ERROR, _("Invalid source pattern `%s' \n %s "), message (D_ERROR, MSG_ERROR, _("Invalid source pattern `%s' \n %s "),
orig_mask, error); orig_mask, error);
g_free (orig_mask); mhl_mem_free (orig_mask);
goto ask_file_mask; goto ask_file_mask;
} }
g_free (orig_mask); mhl_mem_free (orig_mask);
tmpdest = dest_dir; tmpdest = dest_dir;
dest_dir = tilde_expand(tmpdest); dest_dir = tilde_expand(tmpdest);
g_free(tmpdest); mhl_mem_free(tmpdest);
ctx->dest_mask = strrchr (dest_dir, PATH_SEP); ctx->dest_mask = strrchr (dest_dir, PATH_SEP);
if (ctx->dest_mask == NULL) if (ctx->dest_mask == NULL)
@ -977,7 +978,7 @@ file_mask_dialog (FileOpContext *ctx, FileOperation operation, const char *text,
*orig_mask = 0; *orig_mask = 0;
} }
if (!*dest_dir) { if (!*dest_dir) {
g_free (dest_dir); mhl_mem_free (dest_dir);
dest_dir = g_strdup ("./"); dest_dir = g_strdup ("./");
} }
if (val == B_USER) if (val == B_USER)

View File

@ -27,6 +27,8 @@
#include <errno.h> #include <errno.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
static char * static char *
@ -62,12 +64,12 @@ my_mkdir_rec (char *s, mode_t mode)
p = concat_dir_and_file (s, ".."); p = concat_dir_and_file (s, "..");
q = vfs_canon (p); q = vfs_canon (p);
g_free (p); mhl_mem_free (p);
if (!(result = my_mkdir_rec (q, mode))) if (!(result = my_mkdir_rec (q, mode)))
result = mc_mkdir (s, mode); result = mc_mkdir (s, mode);
g_free (q); mhl_mem_free (q);
return result; return result;
} }
@ -82,7 +84,7 @@ my_mkdir (const char *s, mode_t mode)
char *p = vfs_canon (s); char *p = vfs_canon (s);
result = my_mkdir_rec (p, mode); result = my_mkdir_rec (p, mode);
g_free (p); mhl_mem_free (p);
} }
if (result == 0) { if (result == 0) {
my_s = get_absolute_name (s); my_s = get_absolute_name (s);
@ -91,7 +93,7 @@ my_mkdir (const char *s, mode_t mode)
tree_add_entry (tree, my_s); tree_add_entry (tree, my_s);
#endif #endif
g_free (my_s); mhl_mem_free (my_s);
} }
return result; return result;
} }
@ -114,7 +116,7 @@ my_rmdir (const char *s)
tree_remove_entry (tree, my_s); tree_remove_entry (tree, my_s);
#endif #endif
g_free (my_s); mhl_mem_free (my_s);
} }
return result; return result;
} }

View File

@ -25,6 +25,8 @@
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "fileopctx.h" #include "fileopctx.h"
@ -77,5 +79,5 @@ file_op_context_destroy (FileOpContext *ctx)
/* FIXME: do we need to free ctx->dest_mask? */ /* FIXME: do we need to free ctx->dest_mask? */
g_free (ctx); mhl_mem_free (ctx);
} }

View File

@ -25,9 +25,10 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "win.h" #include "win.h"
@ -306,14 +307,14 @@ find_parameters (char **start_dir, char **pattern, char **content)
find_regex_flag = find_regex_cbox->state & C_BOOL; find_regex_flag = find_regex_cbox->state & C_BOOL;
find_recursively = recursively_cbox->state & C_BOOL; find_recursively = recursively_cbox->state & C_BOOL;
destroy_dlg (find_dlg); destroy_dlg (find_dlg);
g_free (in_start_dir); mhl_mem_free (in_start_dir);
if (strcmp (temp_dir, ".") == 0) { if (strcmp (temp_dir, ".") == 0) {
g_free (temp_dir); mhl_mem_free (temp_dir);
temp_dir = g_strdup (current_panel->cwd); temp_dir = g_strdup (current_panel->cwd);
} }
in_start_dir = tree_box (temp_dir); in_start_dir = tree_box (temp_dir);
if (in_start_dir) if (in_start_dir)
g_free (temp_dir); mhl_mem_free (temp_dir);
else else
in_start_dir = temp_dir; in_start_dir = temp_dir;
/* Warning: Dreadful goto */ /* Warning: Dreadful goto */
@ -321,7 +322,7 @@ find_parameters (char **start_dir, char **pattern, char **content)
break; break;
default: default:
g_free (in_contents); mhl_mem_free (in_contents);
if (in_with->buffer[0]) { if (in_with->buffer[0]) {
*content = g_strdup (in_with->buffer); *content = g_strdup (in_with->buffer);
in_contents = g_strdup (*content); in_contents = g_strdup (*content);
@ -337,9 +338,9 @@ find_parameters (char **start_dir, char **pattern, char **content)
*start_dir = g_strdup (in_start->buffer); *start_dir = g_strdup (in_start->buffer);
*pattern = g_strdup (in_name->buffer); *pattern = g_strdup (in_name->buffer);
g_free (in_start_dir); mhl_mem_free (in_start_dir);
in_start_dir = g_strdup (*start_dir); in_start_dir = g_strdup (*start_dir);
g_free (in_start_name); mhl_mem_free (in_start_name);
in_start_name = g_strdup (*pattern); in_start_name = g_strdup (*pattern);
} }
@ -368,7 +369,7 @@ pop_directory (void)
if (dir_stack_base){ if (dir_stack_base){
name = dir_stack_base->name; name = dir_stack_base->name;
next = dir_stack_base->prev; next = dir_stack_base->prev;
g_free (dir_stack_base); mhl_mem_free (dir_stack_base);
dir_stack_base = next; dir_stack_base = next;
return name; return name;
} else } else
@ -386,7 +387,7 @@ insert_file (const char *dir, const char *file)
if (old_dir){ if (old_dir){
if (strcmp (old_dir, dir)){ if (strcmp (old_dir, dir)){
g_free (old_dir); mhl_mem_free (old_dir);
old_dir = g_strdup (dir); old_dir = g_strdup (dir);
dirname = add_to_list (dir, NULL); dirname = add_to_list (dir, NULL);
} }
@ -397,7 +398,7 @@ insert_file (const char *dir, const char *file)
tmp_name = g_strconcat (" ", file, (char *) NULL); tmp_name = g_strconcat (" ", file, (char *) NULL);
add_to_list (tmp_name, dirname); add_to_list (tmp_name, dirname);
g_free (tmp_name); mhl_mem_free (tmp_name);
} }
static void static void
@ -519,12 +520,12 @@ search_content (Dlg_head *h, const char *directory, const char *filename)
fname = concat_dir_and_file (directory, filename); fname = concat_dir_and_file (directory, filename);
if (mc_stat (fname, &s) != 0 || !S_ISREG (s.st_mode)){ if (mc_stat (fname, &s) != 0 || !S_ISREG (s.st_mode)){
g_free (fname); mhl_mem_free (fname);
return 0; return 0;
} }
file_fd = mc_open (fname, O_RDONLY); file_fd = mc_open (fname, O_RDONLY);
g_free (fname); mhl_mem_free (fname);
if (file_fd == -1) if (file_fd == -1)
return 0; return 0;
@ -560,7 +561,7 @@ search_content (Dlg_head *h, const char *directory, const char *filename)
if (found == 0){ /* Search in binary line once */ if (found == 0){ /* Search in binary line once */
if (find_regex_flag) { if (find_regex_flag) {
if (regexec (r, p, 1, 0, 0) == 0){ if (regexec (r, p, 1, 0, 0) == 0){
g_free (p); mhl_mem_free (p);
p = g_strdup_printf ("%d:%s", line, filename); p = g_strdup_printf ("%d:%s", line, filename);
find_add_match (h, directory, p); find_add_match (h, directory, p);
found = 1; found = 1;
@ -577,7 +578,7 @@ search_content (Dlg_head *h, const char *directory, const char *filename)
line++; line++;
found = 0; found = 0;
} }
g_free (p); mhl_mem_free (p);
if ((line & 0xff) == 0) { if ((line & 0xff) == 0) {
FindProgressStatus res; FindProgressStatus res;
@ -620,7 +621,7 @@ do_search (struct Dlg_head *h)
mc_closedir (dirp); mc_closedir (dirp);
dirp = 0; dirp = 0;
} }
g_free (directory); mhl_mem_free (directory);
directory = NULL; directory = NULL;
dp = 0; dp = 0;
return 1; return 1;
@ -650,16 +651,16 @@ do_search (struct Dlg_head *h)
char *temp_dir = g_strconcat (":", tmp, ":", (char *) NULL); char *temp_dir = g_strconcat (":", tmp, ":", (char *) NULL);
found = strstr (find_ignore_dirs, temp_dir) != 0; found = strstr (find_ignore_dirs, temp_dir) != 0;
g_free (temp_dir); mhl_mem_free (temp_dir);
if (found) if (found)
g_free (tmp); mhl_mem_free (tmp);
else else
break; break;
} else } else
break; break;
} }
g_free (directory); mhl_mem_free (directory);
directory = tmp; directory = tmp;
if (verbose){ if (verbose){
@ -698,7 +699,7 @@ do_search (struct Dlg_head *h)
push_directory (tmp_name); push_directory (tmp_name);
subdirs_left--; subdirs_left--;
} }
g_free (tmp_name); mhl_mem_free (tmp_name);
} }
if (regexp_match (find_pattern, dp->d_name, match_file)){ if (regexp_match (find_pattern, dp->d_name, match_file)){
@ -735,14 +736,14 @@ init_find_vars (void)
{ {
char *dir; char *dir;
g_free (old_dir); mhl_mem_free (old_dir);
old_dir = 0; old_dir = 0;
count = 0; count = 0;
matches = 0; matches = 0;
/* Remove all the items in the stack */ /* Remove all the items in the stack */
while ((dir = pop_directory ()) != NULL) while ((dir = pop_directory ()) != NULL)
g_free (dir); mhl_mem_free (dir);
} }
static char * static char *
@ -776,7 +777,7 @@ find_do_view_edit (int unparsed_view, int edit, char *dir, char *file)
do_edit_at_line (fullname, line); do_edit_at_line (fullname, line);
else else
view_file_at_line (fullname, unparsed_view, use_internal_view, line); view_file_at_line (fullname, unparsed_view, use_internal_view, line);
g_free (fullname); mhl_mem_free (fullname);
} }
static int static int
@ -976,7 +977,7 @@ find_file (char *start_dir, char *pattern, char *content, char **dirname,
/* Remove all the items in the stack */ /* Remove all the items in the stack */
while ((dir = pop_directory ()) != NULL) while ((dir = pop_directory ()) != NULL)
g_free (dir); mhl_mem_free (dir);
get_list_info (&file_tmp, &dir_tmp); get_list_info (&file_tmp, &dir_tmp);
@ -1011,18 +1012,18 @@ find_file (char *start_dir, char *pattern, char *content, char **dirname,
handle_path (list, name, &st, next_free, &link_to_dir, handle_path (list, name, &st, next_free, &link_to_dir,
&stale_link); &stale_link);
if (status == 0) { if (status == 0) {
g_free (name); mhl_mem_free (name);
continue; continue;
} }
if (status == -1) { if (status == -1) {
g_free (name); mhl_mem_free (name);
break; break;
} }
/* don't add files more than once to the panel */ /* don't add files more than once to the panel */
if (content_pattern && next_free > 0) { if (content_pattern && next_free > 0) {
if (strcmp (list->list[next_free - 1].fname, name) == 0) { if (strcmp (list->list[next_free - 1].fname, name) == 0) {
g_free (name); mhl_mem_free (name);
continue; continue;
} }
} }
@ -1059,7 +1060,7 @@ find_file (char *start_dir, char *pattern, char *content, char **dirname,
kill_gui (); kill_gui ();
do_search (0); /* force do_search to release resources */ do_search (0); /* force do_search to release resources */
g_free (old_dir); mhl_mem_free (old_dir);
old_dir = 0; old_dir = 0;
return return_value; return return_value;
@ -1078,8 +1079,8 @@ do_find (void)
dirname = filename = NULL; dirname = filename = NULL;
is_start = 0; is_start = 0;
v = find_file (start_dir, pattern, content, &dirname, &filename); v = find_file (start_dir, pattern, content, &dirname, &filename);
g_free (start_dir); mhl_mem_free (start_dir);
g_free (pattern); mhl_mem_free (pattern);
if (find_regex_flag && r) if (find_regex_flag && r)
regfree (r); regfree (r);
@ -1094,14 +1095,14 @@ do_find (void)
do_cd (filename, cd_exact); do_cd (filename, cd_exact);
select_item (current_panel); select_item (current_panel);
} }
g_free (dirname); mhl_mem_free (dirname);
g_free (filename); mhl_mem_free (filename);
break; break;
} }
g_free (content); mhl_mem_free (content);
dir_and_file_set = dirname && filename; dir_and_file_set = dirname && filename;
g_free (dirname); mhl_mem_free (dirname);
g_free (filename); mhl_mem_free (filename);
if (v == B_CANCEL) if (v == B_CANCEL)
break; break;

View File

@ -45,10 +45,11 @@
#include <errno.h> #include <errno.h>
#include <stdio.h> #include <stdio.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "color.h" #include "color.h"
@ -127,7 +128,7 @@ search_string (const char *start, const char *text)
} }
} }
cleanup: cleanup:
g_free (local_text); mhl_mem_free (local_text);
return result; return result;
} }
@ -327,7 +328,7 @@ static void clear_link_areas (void)
while (link_area){ while (link_area){
current = link_area; current = link_area;
link_area = current -> next; link_area = current -> next;
g_free (current); mhl_mem_free (current);
} }
inside_link_area = 0; inside_link_area = 0;
} }
@ -753,7 +754,7 @@ static void
interactive_display_finish (void) interactive_display_finish (void)
{ {
clear_link_areas (); clear_link_areas ();
g_free (data); mhl_mem_free (data);
} }
void void
@ -774,7 +775,7 @@ interactive_display (const char *filename, const char *node)
} }
if (!filename) if (!filename)
g_free (hlpfile); mhl_mem_free (hlpfile);
if (!data) if (!data)
return; return;

View File

@ -32,11 +32,12 @@
#include <ctype.h> #include <ctype.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" /* COLS */ #include "tty.h" /* COLS */
#include "color.h" /* dialog_colors */ #include "color.h" /* dialog_colors */
@ -199,7 +200,7 @@ update_path_name (void)
else else
label_set_text (movelist_group, label_set_text (movelist_group,
name_trunc (p, dlg->cols - (UX * 2 + 4))); name_trunc (p, dlg->cols - (UX * 2 + 4)));
g_free (p); mhl_mem_free (p);
dlg_redraw (dlg); dlg_redraw (dlg);
} }
@ -209,7 +210,7 @@ do { \
int i; \ int i; \
\ \
if ((i = strlen (current->label) + 3) > buflen) { \ if ((i = strlen (current->label) + 3) > buflen) { \
g_free (buf); \ mhl_mem_free (buf); \
buf = g_malloc (buflen = 1024 * (i/1024 + 1)); \ buf = g_malloc (buflen = 1024 * (i/1024 + 1)); \
} \ } \
buf[0] = '\0'; \ buf[0] = '\0'; \
@ -463,7 +464,7 @@ hotlist_callback (Dlg_head *h, dlg_msg_t msg, int parm)
char *tmp = char *tmp =
g_strconcat ("cd ", hlp->directory, (char *) NULL); g_strconcat ("cd ", hlp->directory, (char *) NULL);
stuff (cmdline, tmp, 0); stuff (cmdline, tmp, 0);
g_free (tmp); mhl_mem_free (tmp);
dlg_stop (h); dlg_stop (h);
h->ret_value = B_CANCEL; h->ret_value = B_CANCEL;
return MSG_HANDLED; return MSG_HANDLED;
@ -686,7 +687,7 @@ init_movelist (int list_type, struct hotlist *item)
movelist_dlg = movelist_dlg =
create_dlg (0, 0, LINES - 6, movelist_cols, dialog_colors, create_dlg (0, 0, LINES - 6, movelist_cols, dialog_colors,
hotlist_callback, "[Hotlist]", hdr, DLG_CENTER | DLG_REVERSE); hotlist_callback, "[Hotlist]", hdr, DLG_CENTER | DLG_REVERSE);
g_free (hdr); mhl_mem_free (hdr);
for (i = 0; i < BUTTONS; i++) { for (i = 0; i < BUTTONS; i++) {
if (hotlist_but[i].type & list_type) if (hotlist_but[i].type & list_type)
@ -811,7 +812,7 @@ add2hotlist (char *label, char *directory, enum HotListType type, int pos)
char *lbl = g_strconcat ("->", new->label, (char *) NULL); char *lbl = g_strconcat ("->", new->label, (char *) NULL);
listbox_add_item (l_hotlist, pos, 0, lbl, new); listbox_add_item (l_hotlist, pos, 0, lbl, new);
g_free (lbl); mhl_mem_free (lbl);
} else } else
listbox_add_item (l_hotlist, pos, 0, new->label, new); listbox_add_item (l_hotlist, pos, 0, new->label, new);
listbox_select_entry (l_hotlist, l_hotlist->current); listbox_select_entry (l_hotlist, l_hotlist->current);
@ -937,13 +938,13 @@ static void add_new_entry_cmd (void)
ret = add_new_entry_input (_("New hotlist entry"), _("Directory label"), ret = add_new_entry_input (_("New hotlist entry"), _("Directory label"),
_("Directory path"), "[Hotlist]", &title, &url); _("Directory path"), "[Hotlist]", &title, &url);
g_free (to_free); mhl_mem_free (to_free);
if (!ret) if (!ret)
return; return;
if (!title || !*title || !url || !*url) { if (!title || !*title || !url || !*url) {
g_free (title); mhl_mem_free (title);
g_free (url); mhl_mem_free (url);
return; return;
} }
@ -1044,11 +1045,11 @@ void add2hotlist_cmd (void)
prompt = g_strdup_printf (cp, path_trunc (current_panel->cwd, COLS-2*UX-(l+8))); prompt = g_strdup_printf (cp, path_trunc (current_panel->cwd, COLS-2*UX-(l+8)));
label = input_dialog (_(" Add to hotlist "), prompt, MC_HISTORY_HOTLIST_ADD, label_string); label = input_dialog (_(" Add to hotlist "), prompt, MC_HISTORY_HOTLIST_ADD, label_string);
g_free (prompt); mhl_mem_free (prompt);
if (!label || !*label) { if (!label || !*label) {
g_free (label_string); mhl_mem_free (label_string);
g_free (label); mhl_mem_free (label);
return; return;
} }
add2hotlist (label, label_string, HL_TYPE_ENTRY, 0); add2hotlist (label, label_string, HL_TYPE_ENTRY, 0);
@ -1065,9 +1066,9 @@ static void remove_group (struct hotlist *grp)
if (current->type == HL_TYPE_GROUP) if (current->type == HL_TYPE_GROUP)
remove_group (current); remove_group (current);
g_free (current->label); mhl_mem_free (current->label);
g_free (current->directory); mhl_mem_free (current->directory);
g_free (current); mhl_mem_free (current);
current = next; current = next;
} }
@ -1094,7 +1095,7 @@ static void remove_from_hotlist (struct hotlist *entry)
_("\n Are you sure you want to remove this entry?"), _("\n Are you sure you want to remove this entry?"),
D_ERROR, 2, _("&Yes"), _("&No")); D_ERROR, 2, _("&Yes"), _("&No"));
g_free (title); mhl_mem_free (title);
if (result != 0) if (result != 0)
return; return;
@ -1112,7 +1113,7 @@ static void remove_from_hotlist (struct hotlist *entry)
result = query_dialog (header, _("\n Group not empty.\n Remove it?"), result = query_dialog (header, _("\n Group not empty.\n Remove it?"),
D_ERROR, 2, D_ERROR, 2,
_("&Yes"), _("&No")); _("&Yes"), _("&No"));
g_free (header); mhl_mem_free (header);
if (result != 0) if (result != 0)
return; return;
@ -1123,9 +1124,9 @@ static void remove_from_hotlist (struct hotlist *entry)
unlink_entry (entry); unlink_entry (entry);
g_free (entry->label); mhl_mem_free (entry->label);
g_free (entry->directory); mhl_mem_free (entry->directory);
g_free (entry); mhl_mem_free (entry);
/* now remove list entry from screen */ /* now remove list entry from screen */
listbox_remove_current (l_hotlist, 1); listbox_remove_current (l_hotlist, 1);
hotlist_state.modified = 1; hotlist_state.modified = 1;
@ -1183,7 +1184,7 @@ load_group (struct hotlist *grp)
profile_keys = profile_iterator_next (profile_keys, &key, &value); profile_keys = profile_iterator_next (profile_keys, &key, &value);
add2hotlist (g_strdup (value), g_strdup (key), HL_TYPE_GROUP, 0); add2hotlist (g_strdup (value), g_strdup (key), HL_TYPE_GROUP, 0);
} }
g_free (group_section); mhl_mem_free (group_section);
profile_keys = profile_init_iterator (grp->directory, profile_name); profile_keys = profile_init_iterator (grp->directory, profile_name);
@ -1427,7 +1428,7 @@ clean_up_hotlist_groups (const char *section)
} }
profile_clean_section (grp_section, profile_name); profile_clean_section (grp_section, profile_name);
} }
g_free (grp_section); mhl_mem_free (grp_section);
} }
@ -1572,7 +1573,7 @@ int save_hotlist (void)
hotlist_state.modified = 0; hotlist_state.modified = 0;
} else } else
rename (fbak, hotlist_file_name); rename (fbak, hotlist_file_name);
g_free (fbak); mhl_mem_free (fbak);
} }
return saved; return saved;
@ -1586,20 +1587,20 @@ void done_hotlist (void)
{ {
if (hotlist){ if (hotlist){
remove_group (hotlist); remove_group (hotlist);
g_free (hotlist->label); mhl_mem_free (hotlist->label);
g_free (hotlist->directory); mhl_mem_free (hotlist->directory);
g_free (hotlist); mhl_mem_free (hotlist);
hotlist = 0; hotlist = 0;
} }
hotlist_state.loaded = 0; hotlist_state.loaded = 0;
g_free (hotlist_file_name); mhl_mem_free (hotlist_file_name);
hotlist_file_name = 0; hotlist_file_name = 0;
l_hotlist = 0; l_hotlist = 0;
current_group = 0; current_group = 0;
if (tkn_buf){ if (tkn_buf){
g_free (tkn_buf); mhl_mem_free (tkn_buf);
tkn_buf_length = 0; tkn_buf_length = 0;
tkn_length = 0; tkn_length = 0;
tkn_buf = NULL; tkn_buf = NULL;

View File

@ -29,10 +29,11 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "mouse.h" #include "mouse.h"
@ -152,7 +153,7 @@ void delete_select_channel (int fd)
else else
select_list = p_next; select_list = p_next;
g_free (p); mhl_mem_free (p);
p = p_next; p = p_next;
continue; continue;
} }
@ -1395,7 +1396,7 @@ static void k_dispose (key_def *k)
return; return;
k_dispose (k->child); k_dispose (k->child);
k_dispose (k->next); k_dispose (k->next);
g_free (k); mhl_mem_free (k);
} }
static void s_dispose (SelectList *sel) static void s_dispose (SelectList *sel)
@ -1404,7 +1405,7 @@ static void s_dispose (SelectList *sel)
return; return;
s_dispose (sel->next); s_dispose (sel->next);
g_free (sel); mhl_mem_free (sel);
} }
void done_key () void done_key ()

View File

@ -26,7 +26,6 @@
#include <stdarg.h> #include <stdarg.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
/* /*
@ -41,6 +40,8 @@
#endif #endif
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" /* COLS */ #include "tty.h" /* COLS */
#include "win.h" #include "win.h"
@ -1050,13 +1051,13 @@ void swap_panels ()
if (panels [0].type == view_listing) { if (panels [0].type == view_listing) {
if (!strcmp (panel1->panel_name, get_nth_panel_name (0))) { if (!strcmp (panel1->panel_name, get_nth_panel_name (0))) {
g_free (panel1->panel_name); mhl_mem_free (panel1->panel_name);
panel1->panel_name = g_strdup (get_nth_panel_name (1)); panel1->panel_name = g_strdup (get_nth_panel_name (1));
} }
} }
if (panels [1].type == view_listing) { if (panels [1].type == view_listing) {
if (!strcmp (panel2->panel_name, get_nth_panel_name (1))) { if (!strcmp (panel2->panel_name, get_nth_panel_name (1))) {
g_free (panel2->panel_name); mhl_mem_free (panel2->panel_name);
panel2->panel_name = g_strdup (get_nth_panel_name (0)); panel2->panel_name = g_strdup (get_nth_panel_name (0));
} }
} }

View File

@ -25,11 +25,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "win.h" #include "win.h"
@ -88,7 +89,7 @@ _("Please press the %s\n"
_(key_name_conv_tab [action - B_USER].longname)); _(key_name_conv_tab [action - B_USER].longname));
mc_refresh (); mc_refresh ();
if (learnkeys [action - B_USER].sequence != NULL) { if (learnkeys [action - B_USER].sequence != NULL) {
g_free (learnkeys [action - B_USER].sequence); mhl_mem_free (learnkeys [action - B_USER].sequence);
learnkeys [action - B_USER].sequence = NULL; learnkeys [action - B_USER].sequence = NULL;
} }
seq = learn_key (); seq = learn_key ();
@ -117,7 +118,7 @@ _("Please press the %s\n"
_(" You have entered \"%s\""), seq); _(" You have entered \"%s\""), seq);
} }
g_free (seq); mhl_mem_free (seq);
} }
dlg_run_done (d); dlg_run_done (d);
@ -327,7 +328,7 @@ learn_save (void)
if (profile_changed) if (profile_changed)
sync_profiles (); sync_profiles ();
g_free (section); mhl_mem_free (section);
} }
void learn_keys (void) void learn_keys (void)

View File

@ -289,7 +289,7 @@ listmode_edit (char *oldlistformat)
s = g_strdup (oldlistformat); s = g_strdup (oldlistformat);
listmode_dlg = init_listmode (s); listmode_dlg = init_listmode (s);
g_free (s); mhl_mem_free (s);
if (run_dlg (listmode_dlg) == B_ENTER) { if (run_dlg (listmode_dlg) == B_ENTER) {
newformat = collect_new_format (); newformat = collect_new_format ();

View File

@ -26,6 +26,8 @@
#include <stdarg.h> #include <stdarg.h>
#include <stdio.h> #include <stdio.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "logging.h" #include "logging.h"
#include "setup.h" #include "setup.h"
@ -43,7 +45,7 @@ is_logging_enabled(void)
mc_ini = g_strdup_printf("%s/%s", home_dir, PROFILE_NAME); mc_ini = g_strdup_printf("%s/%s", home_dir, PROFILE_NAME);
logging_enabled = logging_enabled =
get_int(mc_ini, "development.enable_logging", FALSE); get_int(mc_ini, "development.enable_logging", FALSE);
g_free(mc_ini); mhl_mem_free(mc_ini);
logging_initialized = TRUE; logging_initialized = TRUE;
} }
return logging_enabled; return logging_enabled;
@ -65,6 +67,6 @@ mc_log(const char *fmt, ...)
(void)vfprintf(f, fmt, args); (void)vfprintf(f, fmt, args);
(void)fclose(f); (void)fclose(f);
} }
g_free(logfilename); mhl_mem_free(logfilename);
} }
} }

View File

@ -29,11 +29,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "dir.h" #include "dir.h"
@ -301,7 +302,7 @@ reload_panelized (WPanel *panel)
do_file_mark (panel, i, 0); do_file_mark (panel, i, 0);
} }
if (mc_lstat (list->list[i].fname, &list->list[i].st)) { if (mc_lstat (list->list[i].fname, &list->list[i].st)) {
g_free (list->list[i].fname); mhl_mem_free (list->list[i].fname);
continue; continue;
} }
if (list->list[i].f.marked) if (list->list[i].f.marked)
@ -349,7 +350,7 @@ update_one_panel_widget (WPanel *panel, int force_update,
panel->dirty = 1; panel->dirty = 1;
if (free_pointer) if (free_pointer)
g_free (my_current_file); mhl_mem_free (my_current_file);
} }
void void
@ -589,11 +590,11 @@ _do_panel_cd (WPanel *panel, const char *new_dir, enum cd_enum cd_type)
if (mc_chdir (directory) == -1) { if (mc_chdir (directory) == -1) {
strcpy (panel->cwd, olddir); strcpy (panel->cwd, olddir);
g_free (olddir); mhl_mem_free (olddir);
g_free (translated_url); mhl_mem_free (translated_url);
return 0; return 0;
} }
g_free (translated_url); mhl_mem_free (translated_url);
/* Success: save previous directory, shutdown status of previous dir */ /* Success: save previous directory, shutdown status of previous dir */
strcpy (panel->lwd, olddir); strcpy (panel->lwd, olddir);
@ -616,7 +617,7 @@ _do_panel_cd (WPanel *panel, const char *new_dir, enum cd_enum cd_type)
panel->dirty = 1; panel->dirty = 1;
update_xterm_title_path (); update_xterm_title_path ();
g_free (olddir); mhl_mem_free (olddir);
return 1; return 1;
} }
@ -687,7 +688,7 @@ directory_history_list (WPanel *panel)
directory_history_add (panel, panel->cwd); directory_history_add (panel, panel->cwd);
else else
message (D_ERROR, MSG_ERROR, _("Cannot change directory")); message (D_ERROR, MSG_ERROR, _("Cannot change directory"));
g_free (s); mhl_mem_free (s);
} }
#ifdef HAVE_SUBSHELL_SUPPORT #ifdef HAVE_SUBSHELL_SUPPORT
@ -776,7 +777,7 @@ treebox_cmd (void)
sel_dir = tree_box (selection (current_panel)->fname); sel_dir = tree_box (selection (current_panel)->fname);
if (sel_dir) { if (sel_dir) {
do_cd (sel_dir, cd_exact); do_cd (sel_dir, cd_exact);
g_free (sel_dir); mhl_mem_free (sel_dir);
} }
} }
@ -793,7 +794,7 @@ listmode_cmd (void)
if (!newmode) if (!newmode)
return; return;
g_free (current_panel->user_format); mhl_mem_free (current_panel->user_format);
current_panel->list_type = list_user; current_panel->list_type = list_user;
current_panel->user_format = newmode; current_panel->user_format = newmode;
set_panel_formats (current_panel); set_panel_formats (current_panel);
@ -1035,7 +1036,7 @@ translated_mc_chdir (char *dir)
newdir = vfs_translate_url (dir); newdir = vfs_translate_url (dir);
mc_chdir (newdir); mc_chdir (newdir);
g_free (newdir); mhl_mem_free (newdir);
} }
static void static void
@ -1141,7 +1142,7 @@ copy_readlink (WPanel *panel)
int i; int i;
i = mc_readlink (p, buffer, MC_MAXPATHLEN - 1); i = mc_readlink (p, buffer, MC_MAXPATHLEN - 1);
g_free (p); mhl_mem_free (p);
if (i > 0) { if (i > 0) {
buffer[i] = 0; buffer[i] = 0;
command_insert (cmdline, buffer, 1); command_insert (cmdline, buffer, 1);
@ -1621,7 +1622,7 @@ update_xterm_title_path (void)
numeric_keypad_mode (); numeric_keypad_mode ();
fprintf (stdout, "\33]0;mc - %s\7", p); fprintf (stdout, "\33]0;mc - %s\7", p);
fflush (stdout); fflush (stdout);
g_free (p); mhl_mem_free (p);
} }
} }
@ -1645,7 +1646,7 @@ load_hint (int force)
if ((hint = get_random_hint (force))) { if ((hint = get_random_hint (force))) {
if (*hint) if (*hint)
set_hintbar (hint); set_hintbar (hint);
g_free (hint); mhl_mem_free (hint);
} else { } else {
char text[BUF_SMALL]; char text[BUF_SMALL];
@ -1713,7 +1714,7 @@ mc_maybe_editor_or_viewer (void)
char *path = NULL; char *path = NULL;
path = prepend_cwd_on_local (view_one_file); path = prepend_cwd_on_local (view_one_file);
view_file (path, 0, 1); view_file (path, 0, 1);
g_free (path); mhl_mem_free (path);
} }
#ifdef USE_INTERNAL_EDIT #ifdef USE_INTERNAL_EDIT
else { else {
@ -2082,7 +2083,7 @@ handle_args (int argc, char *argv[])
edit_one_file = fname; edit_one_file = fname;
edit_one_file_start_line = atoi (p); edit_one_file_start_line = atoi (p);
} else { } else {
g_free (fname); mhl_mem_free (fname);
goto try_plus_filename; goto try_plus_filename;
} }
} else { } else {
@ -2251,15 +2252,15 @@ main (int argc, char *argv[])
close (last_wd_fd); close (last_wd_fd);
} }
} }
g_free (last_wd_string); mhl_mem_free (last_wd_string);
g_free (mc_home); mhl_mem_free (mc_home);
done_key (); done_key ();
#ifdef HAVE_CHARSET #ifdef HAVE_CHARSET
free_codepages_list (); free_codepages_list ();
#endif #endif
g_free (this_dir); mhl_mem_free (this_dir);
g_free (other_dir); mhl_mem_free (other_dir);
return 0; return 0;
} }

View File

@ -21,9 +21,10 @@
#include <ctype.h> #include <ctype.h>
#include <stdarg.h> #include <stdarg.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "menu.h" #include "menu.h"
@ -531,9 +532,9 @@ menubar_arrange(WMenu* menubar)
void void
destroy_menu (Menu *menu) destroy_menu (Menu *menu)
{ {
g_free (menu->name); mhl_mem_free (menu->name);
g_free (menu->help_node); mhl_mem_free (menu->help_node);
g_free (menu); mhl_mem_free (menu);
} }
WMenu * WMenu *

View File

@ -25,11 +25,12 @@
#include <errno.h> #include <errno.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" /* attrset() */ #include "tty.h" /* attrset() */
#include "win.h" #include "win.h"
@ -232,7 +233,7 @@ add2panelize_cmd (void)
if (!label) if (!label)
return; return;
if (!*label) { if (!*label) {
g_free (label); mhl_mem_free (label);
return; return;
} }
@ -254,9 +255,9 @@ static void remove_from_panelize (struct panelize *entry)
} }
} }
g_free (entry->label); mhl_mem_free (entry->label);
g_free (entry->command); mhl_mem_free (entry->command);
g_free (entry); mhl_mem_free (entry);
} }
} }
@ -296,7 +297,7 @@ external_panelize (void)
char *cmd = g_strdup (target); char *cmd = g_strdup (target);
destroy_dlg (panelize_dlg); destroy_dlg (panelize_dlg);
do_external_panelize (cmd); do_external_panelize (cmd);
g_free (cmd); mhl_mem_free (cmd);
repaint_screen (); repaint_screen ();
return; return;
} }
@ -350,9 +351,9 @@ void done_panelize (void)
for (; current; current = next){ for (; current; current = next){
next = current->next; next = current->next;
g_free (current->label); mhl_mem_free (current->label);
g_free (current->command); mhl_mem_free (current->command);
g_free (current); mhl_mem_free (current);
} }
} }

View File

@ -26,9 +26,10 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "profile.h" #include "profile.h"
@ -248,7 +249,7 @@ static TSecHeader *load (const char *file)
break; break;
case OnSecHeader: { /* Broken initialization file */ case OnSecHeader: { /* Broken initialization file */
TSecHeader *link = SecHeader->link; TSecHeader *link = SecHeader->link;
g_free (SecHeader); mhl_mem_free (SecHeader);
SecHeader = link; SecHeader = link;
fprintf (stderr, "Warning: Corrupted initialization file `%s'\n", fprintf (stderr, "Warning: Corrupted initialization file `%s'\n",
file); file);
@ -298,7 +299,7 @@ GetSetProfileChar (int set, const char *AppName, const char *KeyName,
if ( g_strcasecmp (key->KeyName, KeyName)) if ( g_strcasecmp (key->KeyName, KeyName))
continue; continue;
if (set){ if (set){
g_free (key->Value); mhl_mem_free (key->Value);
key->Value = g_strdup (Default); key->Value = g_strdup (Default);
} }
return key->Value; return key->Value;
@ -382,7 +383,7 @@ static void dump_keys (FILE * profile, TKeys * p)
dump_keys (profile, p->link); dump_keys (profile, p->link);
t = str_untranslate_newline_dup (p->Value); t = str_untranslate_newline_dup (p->Value);
fprintf (profile, "%s=%s\n", p->KeyName, t); fprintf (profile, "%s=%s\n", p->KeyName, t);
g_free (t); mhl_mem_free (t);
} }
static void dump_sections (FILE *profile, TSecHeader *p) static void dump_sections (FILE *profile, TSecHeader *p)
@ -425,9 +426,9 @@ static void free_keys (TKeys *p)
if (!p) if (!p)
return; return;
free_keys (p->link); free_keys (p->link);
g_free (p->KeyName); mhl_mem_free (p->KeyName);
g_free (p->Value); mhl_mem_free (p->Value);
g_free (p); mhl_mem_free (p);
} }
static void free_sections (TSecHeader *p) static void free_sections (TSecHeader *p)
@ -436,10 +437,10 @@ static void free_sections (TSecHeader *p)
return; return;
free_sections (p->link); free_sections (p->link);
free_keys (p->Keys); free_keys (p->Keys);
g_free (p->AppName); mhl_mem_free (p->AppName);
p->link = 0; p->link = 0;
p->Keys = 0; p->Keys = 0;
g_free (p); mhl_mem_free (p);
} }
static void free_profile (TProfile *p) static void free_profile (TProfile *p)
@ -448,8 +449,8 @@ static void free_profile (TProfile *p)
return; return;
free_profile (p->link); free_profile (p->link);
free_sections (p->Section); free_sections (p->Section);
g_free (p->FileName); mhl_mem_free (p->FileName);
g_free (p); mhl_mem_free (p);
} }
void free_profile_name (const char *s) void free_profile_name (const char *s)

View File

@ -21,10 +21,11 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" /* move, addch */ #include "tty.h" /* move, addch */
#include "cons.saver.h" #include "cons.saver.h"
@ -113,6 +114,6 @@ void show_rxvt_contents (int starty, unsigned char y1, unsigned char y2)
move (starty + (i / cols), 0); move (starty + (i / cols), 0);
addch (is_printable (k[i]) ? k[i] : ' '); addch (is_printable (k[i]) ? k[i] : ' ');
} }
g_free (k); mhl_mem_free (k);
} }

View File

@ -25,9 +25,10 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "dir.h" #include "dir.h"
@ -131,7 +132,7 @@ delete_format (format_e *format)
while (format){ while (format){
next = format->next; next = format->next;
g_free (format); mhl_mem_free (format);
format = next; format = next;
} }
} }
@ -711,7 +712,7 @@ display_mini_info (WPanel *panel)
link = concat_dir_and_file (panel->cwd, panel->dir.list [panel->selected].fname); link = concat_dir_and_file (panel->cwd, panel->dir.list [panel->selected].fname);
len = mc_readlink (link, link_target, MC_MAXPATHLEN - 1); len = mc_readlink (link, link_target, MC_MAXPATHLEN - 1);
g_free (link); mhl_mem_free (link);
if (len > 0){ if (len > 0){
link_target[len] = 0; link_target[len] = 0;
tty_printf ("-> %-*s", panel->widget.cols - 5, tty_printf ("-> %-*s", panel->widget.cols - 5,
@ -796,7 +797,7 @@ show_dir (WPanel *panel)
trim (strip_home_and_password (panel->cwd), tmp, trim (strip_home_and_password (panel->cwd), tmp,
max (panel->widget.cols - 9, 0)); max (panel->widget.cols - 9, 0));
addstr (tmp); addstr (tmp);
g_free (tmp); mhl_mem_free (tmp);
addch (' '); addch (' ');
widget_move (&panel->widget, 0, 1); widget_move (&panel->widget, 0, 1);
@ -892,7 +893,7 @@ do_try_to_select (WPanel *panel, const char *name)
for (i = 0; i < panel->count; i++){ for (i = 0; i < panel->count; i++){
if (strcmp (subdir, panel->dir.list [i].fname) == 0) { if (strcmp (subdir, panel->dir.list [i].fname) == 0) {
do_select (panel, i); do_select (panel, i);
g_free (subdir); mhl_mem_free (subdir);
return; return;
} }
} }
@ -900,7 +901,7 @@ do_try_to_select (WPanel *panel, const char *name)
/* Try to select a file near the file that is missing */ /* Try to select a file near the file that is missing */
if (panel->selected >= panel->count) if (panel->selected >= panel->count)
do_select (panel, panel->count-1); do_select (panel, panel->count-1);
g_free (subdir); mhl_mem_free (subdir);
} }
void void
@ -964,21 +965,21 @@ panel_destroy (WPanel *p)
history_put (p->hist_name, p->dir_history); history_put (p->hist_name, p->dir_history);
p->dir_history = g_list_first (p->dir_history); p->dir_history = g_list_first (p->dir_history);
g_list_foreach (p->dir_history, (GFunc) g_free, NULL); g_list_foreach (p->dir_history, (GFunc) mhl_mem_free, NULL);
g_list_free (p->dir_history); g_list_free (p->dir_history);
} }
g_free (p->hist_name); mhl_mem_free (p->hist_name);
delete_format (p->format); delete_format (p->format);
delete_format (p->status_format); delete_format (p->status_format);
g_free (p->user_format); mhl_mem_free (p->user_format);
for (i = 0; i < LIST_TYPES; i++) for (i = 0; i < LIST_TYPES; i++)
g_free (p->user_status_format[i]); mhl_mem_free (p->user_status_format[i]);
g_free (p->dir.list); mhl_mem_free (p->dir.list);
g_free (p->panel_name); mhl_mem_free (p->panel_name);
g_free (name); mhl_mem_free (name);
} }
static void static void
@ -1039,11 +1040,11 @@ panel_new (const char *panel_name)
panel->frame_size = frame_half; panel->frame_size = frame_half;
section = g_strconcat ("Temporal:", panel->panel_name, (char *) NULL); section = g_strconcat ("Temporal:", panel->panel_name, (char *) NULL);
if (!profile_has_section (section, profile_name)) { if (!profile_has_section (section, profile_name)) {
g_free (section); mhl_mem_free (section);
section = g_strdup (panel->panel_name); section = g_strdup (panel->panel_name);
} }
panel_load_setup (panel, section); panel_load_setup (panel, section);
g_free (section); mhl_mem_free (section);
/* Load format strings */ /* Load format strings */
err = set_panel_formats (panel); err = set_panel_formats (panel);
@ -1326,7 +1327,7 @@ parse_display_format (WPanel *panel, const char *format, char **error, int issta
delete_format (home); delete_format (home);
tmp_format [pos] = 0; tmp_format [pos] = 0;
*error = g_strconcat (_("Unknown tag on display format: "), tmp_format, (char *) NULL); *error = g_strconcat (_("Unknown tag on display format: "), tmp_format, (char *) NULL);
g_free (tmp_format); mhl_mem_free (tmp_format);
return 0; return 0;
} }
total_cols += darr->requested_field_len; total_cols += darr->requested_field_len;
@ -1415,7 +1416,7 @@ set_panel_formats (WPanel *p)
form = use_display_format (p, panel_format (p), &err, 0); form = use_display_format (p, panel_format (p), &err, 0);
if (err){ if (err){
g_free (err); mhl_mem_free (err);
retcode = 1; retcode = 1;
} }
else { else {
@ -1430,7 +1431,7 @@ set_panel_formats (WPanel *p)
form = use_display_format (p, mini_status_format (p), &err, 1); form = use_display_format (p, mini_status_format (p), &err, 1);
if (err){ if (err){
g_free (err); mhl_mem_free (err);
retcode += 2; retcode += 2;
} }
else { else {
@ -1447,11 +1448,11 @@ set_panel_formats (WPanel *p)
if (retcode) if (retcode)
message( 1, _("Warning" ), _( "User supplied format looks invalid, reverting to default." ) ); message( 1, _("Warning" ), _( "User supplied format looks invalid, reverting to default." ) );
if (retcode & 0x01){ if (retcode & 0x01){
g_free (p->user_format); mhl_mem_free (p->user_format);
p->user_format = g_strdup (DEFAULT_USER_FORMAT); p->user_format = g_strdup (DEFAULT_USER_FORMAT);
} }
if (retcode & 0x02){ if (retcode & 0x02){
g_free (p->user_status_format [p->list_type]); mhl_mem_free (p->user_status_format [p->list_type]);
p->user_status_format [p->list_type] = g_strdup (DEFAULT_USER_FORMAT); p->user_status_format [p->list_type] = g_strdup (DEFAULT_USER_FORMAT);
} }
@ -1976,10 +1977,10 @@ do_enter_on_file_entry (file_entry *fe)
/* Check if the file is executable */ /* Check if the file is executable */
full_name = concat_dir_and_file (current_panel->cwd, fe->fname); full_name = concat_dir_and_file (current_panel->cwd, fe->fname);
if (!is_exe (fe->st.st_mode) || !if_link_is_exe (full_name, fe)) { if (!is_exe (fe->st.st_mode) || !if_link_is_exe (full_name, fe)) {
g_free (full_name); mhl_mem_free (full_name);
return 0; return 0;
} }
g_free (full_name); mhl_mem_free (full_name);
if (confirm_execute) { if (confirm_execute) {
if (query_dialog if (query_dialog
@ -1995,7 +1996,7 @@ do_enter_on_file_entry (file_entry *fe)
tmp = concat_dir_and_file (vfs_get_current_dir (), fe->fname); tmp = concat_dir_and_file (vfs_get_current_dir (), fe->fname);
ret = mc_setctl (tmp, VFS_SETCTL_RUN, NULL); ret = mc_setctl (tmp, VFS_SETCTL_RUN, NULL);
g_free (tmp); mhl_mem_free (tmp);
/* We took action only if the dialog was shown or the execution /* We took action only if the dialog was shown or the execution
* was successful */ * was successful */
return confirm_execute || (ret == 0); return confirm_execute || (ret == 0);
@ -2005,9 +2006,9 @@ do_enter_on_file_entry (file_entry *fe)
{ {
char *tmp = name_quote (fe->fname, 0); char *tmp = name_quote (fe->fname, 0);
char *cmd = g_strconcat (".", PATH_SEP_STR, tmp, (char *) NULL); char *cmd = g_strconcat (".", PATH_SEP_STR, tmp, (char *) NULL);
g_free (tmp); mhl_mem_free (tmp);
shell_execute (cmd, 0); shell_execute (cmd, 0);
g_free (cmd); mhl_mem_free (cmd);
} }
return 1; return 1;
@ -2043,7 +2044,7 @@ chdir_other_panel (WPanel *panel)
move_down (panel); move_down (panel);
g_free (new_dir); mhl_mem_free (new_dir);
} }
/* /*
@ -2107,7 +2108,7 @@ chdir_to_readlink (WPanel *panel)
move_down (panel); move_down (panel);
g_free (new_dir); mhl_mem_free (new_dir);
} }
} }
@ -2254,7 +2255,7 @@ panel_callback (Widget *w, widget_msg_t msg, int parm)
char *cwd = strip_password (g_strdup (panel->cwd), 1); char *cwd = strip_password (g_strdup (panel->cwd), 1);
message (D_ERROR, MSG_ERROR, _(" Cannot chdir to \"%s\" \n %s "), message (D_ERROR, MSG_ERROR, _(" Cannot chdir to \"%s\" \n %s "),
cwd, unix_error_string (errno)); cwd, unix_error_string (errno));
g_free(cwd); mhl_mem_free(cwd);
} else } else
subshell_chdir (panel->cwd); subshell_chdir (panel->cwd);
@ -2474,7 +2475,7 @@ panel_re_sort (WPanel *panel)
break; break;
} }
} }
g_free (filename); mhl_mem_free (filename);
panel->top_file = panel->selected - ITEMS (panel)/2; panel->top_file = panel->selected - ITEMS (panel)/2;
if (panel->top_file < 0) if (panel->top_file < 0)
panel->top_file = 0; panel->top_file = 0;
@ -2497,7 +2498,7 @@ panel_set_sort_order (WPanel *panel, sortfn *sort_order)
current_file = g_strdup (panel->dir.list [panel->selected].fname); current_file = g_strdup (panel->dir.list [panel->selected].fname);
panel_reload (panel); panel_reload (panel);
try_to_select (panel, current_file); try_to_select (panel, current_file);
g_free (current_file); mhl_mem_free (current_file);
} }
panel_re_sort (panel); panel_re_sort (panel);
} }

View File

@ -20,10 +20,11 @@
#include <string.h> #include <string.h>
#include <stdio.h> #include <stdio.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "dir.h" #include "dir.h"
@ -292,7 +293,7 @@ save_layout (void)
save_string ("Layout", layout [i].opt_name, buffer, profile); save_string ("Layout", layout [i].opt_name, buffer, profile);
} }
g_free (profile); mhl_mem_free (profile);
} }
void void
@ -312,7 +313,7 @@ save_configure (void)
set_config_string (profile, str_options[i].opt_name, set_config_string (profile, str_options[i].opt_name,
*str_options[i].opt_addr); *str_options[i].opt_addr);
g_free (profile); mhl_mem_free (profile);
} }
static void static void
@ -379,7 +380,7 @@ save_setup (void)
get_codepage_id( display_codepage ), profile_name ); get_codepage_id( display_codepage ), profile_name );
#endif /* HAVE_CHARSET */ #endif /* HAVE_CHARSET */
g_free (profile); mhl_mem_free (profile);
saving_setup = 0; saving_setup = 0;
} }
@ -412,12 +413,12 @@ panel_load_setup (WPanel *panel, const char *section)
} }
/* User formats */ /* User formats */
g_free (panel->user_format); mhl_mem_free (panel->user_format);
panel->user_format = g_strdup (get_profile_string (section, "user_format", panel->user_format = g_strdup (get_profile_string (section, "user_format",
DEFAULT_USER_FORMAT, DEFAULT_USER_FORMAT,
profile_name)); profile_name));
for (i = 0; i < LIST_TYPES; i++){ for (i = 0; i < LIST_TYPES; i++){
g_free (panel->user_status_format [i]); mhl_mem_free (panel->user_status_format [i]);
g_snprintf (buffer, sizeof (buffer), "user_status%d", i); g_snprintf (buffer, sizeof (buffer), "user_status%d", i);
panel->user_status_format [i] = panel->user_status_format [i] =
g_strdup (get_profile_string (section, buffer, g_strdup (get_profile_string (section, buffer,
@ -470,7 +471,7 @@ do_load_string (const char *s, const char *ss, const char *def)
load_string (s, ss, def, buffer, BUF_SMALL); load_string (s, ss, def, buffer, BUF_SMALL);
p = g_strdup (buffer); p = g_strdup (buffer);
g_free (buffer); mhl_mem_free (buffer);
return p; return p;
} }
#endif /* !USE_NETCODE */ #endif /* !USE_NETCODE */
@ -488,10 +489,10 @@ setup_init (void)
if (!exist_file (profile)){ if (!exist_file (profile)){
inifile = concat_dir_and_file (mc_home, "mc.ini"); inifile = concat_dir_and_file (mc_home, "mc.ini");
if (exist_file (inifile)){ if (exist_file (inifile)){
g_free (profile); mhl_mem_free (profile);
profile = inifile; profile = inifile;
} else } else
g_free (inifile); mhl_mem_free (inifile);
} }
profile_name = profile; profile_name = profile;
@ -541,7 +542,7 @@ load_setup (void)
if (vfs_file_is_local (buffer)) if (vfs_file_is_local (buffer))
other_dir = buffer; other_dir = buffer;
else else
g_free (buffer); mhl_mem_free (buffer);
} }
boot_current_is_left = boot_current_is_left =
@ -602,8 +603,8 @@ load_anon_passwd ()
void done_setup (void) void done_setup (void)
{ {
g_free (profile_name); mhl_mem_free (profile_name);
g_free (global_profile_name); mhl_mem_free (global_profile_name);
done_hotlist (); done_hotlist ();
done_panelize (); done_panelize ();
/* directory_history_free (); */ /* directory_history_free (); */
@ -622,7 +623,7 @@ load_keys_from_section (const char *terminal, const char *profile_name)
section_name = g_strconcat ("terminal:", terminal, (char *) NULL); section_name = g_strconcat ("terminal:", terminal, (char *) NULL);
profile_keys = profile_init_iterator (section_name, profile_name); profile_keys = profile_init_iterator (section_name, profile_name);
g_free (section_name); mhl_mem_free (section_name);
while (profile_keys){ while (profile_keys){
profile_keys = profile_iterator_next (profile_keys, &key, &value); profile_keys = profile_iterator_next (profile_keys, &key, &value);
@ -636,7 +637,7 @@ load_keys_from_section (const char *terminal, const char *profile_name)
if (key_code){ if (key_code){
valcopy = convert_controls (value); valcopy = convert_controls (value);
define_sequence (key_code, valcopy, MCKEY_NOACTION); define_sequence (key_code, valcopy, MCKEY_NOACTION);
g_free (valcopy); mhl_mem_free (valcopy);
} }
} }
} }

View File

@ -44,6 +44,8 @@
# include <stropts.h> /* For I_PUSH */ # include <stropts.h> /* For I_PUSH */
#endif /* HAVE_STROPTS_H */ #endif /* HAVE_STROPTS_H */
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" /* LINES */ #include "tty.h" /* LINES */
#include "panel.h" /* current_panel */ #include "panel.h" /* current_panel */
@ -670,8 +672,8 @@ exit_subshell (void)
tcsh_fifo, unix_error_string (errno)); tcsh_fifo, unix_error_string (errno));
} }
g_free (subshell_prompt); mhl_mem_free (subshell_prompt);
g_free (pty_buffer); mhl_mem_free (pty_buffer);
subshell_prompt = NULL; subshell_prompt = NULL;
pty_buffer = NULL; pty_buffer = NULL;
} }
@ -762,7 +764,7 @@ do_subshell_chdir (const char *directory, int do_update, int reset_prompt)
char *temp = subshell_name_quote (directory); char *temp = subshell_name_quote (directory);
if (temp) { if (temp) {
write_all (subshell_pty, temp, strlen (temp)); write_all (subshell_pty, temp, strlen (temp));
g_free (temp); mhl_mem_free (temp);
} else { } else {
/* Should not happen unless the directory name is so long /* Should not happen unless the directory name is so long
that we don't have memory to quote it. */ that we don't have memory to quote it. */
@ -798,7 +800,7 @@ do_subshell_chdir (const char *directory, int do_update, int reset_prompt)
if (bPathNotEq && strcmp (current_panel->cwd, ".")) { if (bPathNotEq && strcmp (current_panel->cwd, ".")) {
char *cwd = strip_password (g_strdup (current_panel->cwd), 1); char *cwd = strip_password (g_strdup (current_panel->cwd), 1);
fprintf (stderr, _("Warning: Cannot change to %s.\n"), cwd); fprintf (stderr, _("Warning: Cannot change to %s.\n"), cwd);
g_free (cwd); mhl_mem_free (cwd);
} }
} }

View File

@ -33,6 +33,8 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "color.h" #include "color.h"
@ -126,7 +128,7 @@ static void tree_destroy (WTree *tree)
tree_store_remove_entry_remove_hook (remove_callback); tree_store_remove_entry_remove_hook (remove_callback);
save_tree (tree); save_tree (tree);
g_free (tree->tree_shown); mhl_mem_free (tree->tree_shown);
tree->tree_shown = 0; tree->tree_shown = 0;
tree->selected_ptr = NULL; tree->selected_ptr = NULL;
} }
@ -206,7 +208,7 @@ static void show_tree (WTree *tree)
x = y = 1; x = y = 1;
} }
g_free (tree->tree_shown); mhl_mem_free (tree->tree_shown);
tree->tree_shown = g_new (tree_entry*, tree_lines); tree->tree_shown = g_new (tree_entry*, tree_lines);
for (i = 0; i < tree_lines; i++) for (i = 0; i < tree_lines; i++)
@ -605,7 +607,7 @@ static void tree_copy (WTree *tree, const char *default_dest)
return; return;
if (!*dest){ if (!*dest){
g_free (dest); mhl_mem_free (dest);
return; return;
} }
@ -614,7 +616,7 @@ static void tree_copy (WTree *tree, const char *default_dest)
copy_dir_dir (ctx, tree->selected_ptr->name, dest, 1, 0, 0, 0, &count, &bytes); copy_dir_dir (ctx, tree->selected_ptr->name, dest, 1, 0, 0, 0, &count, &bytes);
file_op_context_destroy (ctx); file_op_context_destroy (ctx);
g_free (dest); mhl_mem_free (dest);
} }
static void static void
@ -646,19 +648,19 @@ static void tree_move (WTree *tree, const char *default_dest)
if (!dest) if (!dest)
return; return;
if (!*dest){ if (!*dest){
g_free (dest); mhl_mem_free (dest);
return; return;
} }
if (stat (dest, &buf)){ if (stat (dest, &buf)){
message (D_ERROR, MSG_ERROR, _(" Cannot stat the destination \n %s "), message (D_ERROR, MSG_ERROR, _(" Cannot stat the destination \n %s "),
unix_error_string (errno)); unix_error_string (errno));
g_free (dest); mhl_mem_free (dest);
return; return;
} }
if (!S_ISDIR (buf.st_mode)){ if (!S_ISDIR (buf.st_mode)){
file_error (_(" Destination \"%s\" must be a directory \n %s "), file_error (_(" Destination \"%s\" must be a directory \n %s "),
dest); dest);
g_free (dest); mhl_mem_free (dest);
return; return;
} }
@ -667,7 +669,7 @@ static void tree_move (WTree *tree, const char *default_dest)
move_dir_dir (ctx, tree->selected_ptr->name, dest, &count, &bytes); move_dir_dir (ctx, tree->selected_ptr->name, dest, &count, &bytes);
file_op_context_destroy (ctx); file_op_context_destroy (ctx);
g_free (dest); mhl_mem_free (dest);
} }
static void static void
@ -716,7 +718,7 @@ tree_rmdir_cmd (WTree *tree)
tree->selected_ptr->name); tree->selected_ptr->name);
result = result =
query_dialog (_(" Delete "), buf, D_ERROR, 2, _("&Yes"), _("&No")); query_dialog (_(" Delete "), buf, D_ERROR, 2, _("&Yes"), _("&No"));
g_free (buf); mhl_mem_free (buf);
if (result != 0) if (result != 0)
return; return;
} }

View File

@ -37,11 +37,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "treestore.h" #include "treestore.h"
#include "profile.h" #include "profile.h"
@ -236,7 +237,7 @@ tree_store_load_from(char *name)
} }
strcpy(oldname, name); strcpy(oldname, name);
} }
g_free(name); mhl_mem_free(name);
} }
fclose(file); fclose(file);
} }
@ -267,7 +268,7 @@ tree_store_load(void)
name = concat_dir_and_file(home_dir, MC_TREE); name = concat_dir_and_file(home_dir, MC_TREE);
retval = tree_store_load_from(name); retval = tree_store_load_from(name);
g_free(name); mhl_mem_free(name);
return retval; return retval;
} }
@ -334,12 +335,12 @@ tree_store_save_to(char *name)
i = fprintf(file, "%d:%d %s\n", current->scanned, common, i = fprintf(file, "%d:%d %s\n", current->scanned, common,
encoded); encoded);
g_free(encoded); mhl_mem_free(encoded);
} else { } else {
char *encoded = encode(current->name); char *encoded = encode(current->name);
i = fprintf(file, "%d:%s\n", current->scanned, encoded); i = fprintf(file, "%d:%s\n", current->scanned, encoded);
g_free(encoded); mhl_mem_free(encoded);
} }
if (i == EOF) { if (i == EOF) {
@ -375,15 +376,15 @@ tree_store_save(void)
retval = tree_store_save_to(tmp); retval = tree_store_save_to(tmp);
if (retval) { if (retval) {
g_free(tmp); mhl_mem_free(tmp);
return retval; return retval;
} }
name = concat_dir_and_file(home_dir, MC_TREE); name = concat_dir_and_file(home_dir, MC_TREE);
retval = rename(tmp, name); retval = rename(tmp, name);
g_free(tmp); mhl_mem_free(tmp);
g_free(name); mhl_mem_free(name);
if (retval) if (retval)
return errno; return errno;
@ -481,7 +482,7 @@ tree_store_add_entry(const char *name)
break; break;
} }
} }
g_free(parent); mhl_mem_free(parent);
} }
tree_store_dirty(TRUE); tree_store_dirty(TRUE);
@ -546,8 +547,8 @@ remove_entry(tree_entry * entry)
ts.tree_last = entry->prev; ts.tree_last = entry->prev;
/* Free the memory used by the entry */ /* Free the memory used by the entry */
g_free(entry->name); mhl_mem_free(entry->name);
g_free(entry); mhl_mem_free(entry);
return ret; return ret;
} }
@ -617,7 +618,7 @@ tree_store_mark_checked(const char *subname)
current = tree_store_add_entry(name); current = tree_store_add_entry(name);
ts.add_queue = g_list_prepend(ts.add_queue, g_strdup(name)); ts.add_queue = g_list_prepend(ts.add_queue, g_strdup(name));
} }
g_free(name); mhl_mem_free(name);
/* Clear the deletion mark from the subdirectory and its children */ /* Clear the deletion mark from the subdirectory and its children */
base = current; base = current;
@ -716,11 +717,11 @@ tree_store_end_check(void)
ts.add_queue = g_list_reverse(ts.add_queue); ts.add_queue = g_list_reverse(ts.add_queue);
the_queue = ts.add_queue; the_queue = ts.add_queue;
ts.add_queue = NULL; ts.add_queue = NULL;
g_free(ts.check_name); mhl_mem_free(ts.check_name);
ts.check_name = NULL; ts.check_name = NULL;
for (l = the_queue; l; l = l->next) { for (l = the_queue; l; l = l->next) {
g_free(l->data); mhl_mem_free(l->data);
} }
g_list_free(the_queue); g_list_free(the_queue);
@ -740,7 +741,7 @@ process_special_dirs(GList ** special_dirs, char *file)
*special_dirs = g_list_prepend(*special_dirs, g_strdup(token)); *special_dirs = g_list_prepend(*special_dirs, g_strdup(token));
s = NULL; s = NULL;
} }
g_free(buffer); mhl_mem_free(buffer);
} }
static gboolean static gboolean
@ -800,7 +801,7 @@ tree_store_rescan(const char *dir)
if (S_ISDIR(buf.st_mode)) if (S_ISDIR(buf.st_mode))
tree_store_mark_checked(dp->d_name); tree_store_mark_checked(dp->d_name);
} }
g_free(full_name); mhl_mem_free(full_name);
} }
mc_closedir(dirp); mc_closedir(dirp);
} }

View File

@ -23,6 +23,8 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "color.h" #include "color.h"
@ -142,7 +144,7 @@ int check_format_var (const char *p, char **v)
var_name = g_strndup (p + 4, dots-2 - (p+3)); var_name = g_strndup (p + 4, dots-2 - (p+3));
value = getenv (var_name); value = getenv (var_name);
g_free (var_name); mhl_mem_free (var_name);
if (value){ if (value){
*v = g_strdup (value); *v = g_strdup (value);
return q-p; return q-p;
@ -221,7 +223,7 @@ expand_format (struct WEdit *edit_widget, char c, int quote)
qstr = (*quote_func) (cwd, 0); qstr = (*quote_func) (cwd, 0);
g_free (cwd); mhl_mem_free (cwd);
return qstr; return qstr;
} }
@ -238,7 +240,7 @@ expand_format (struct WEdit *edit_widget, char c, int quote)
if (edit_widget) { if (edit_widget) {
char *file = g_strconcat (home_dir, PATH_SEP_STR BLOCK_FILE, (char *) NULL); char *file = g_strconcat (home_dir, PATH_SEP_STR BLOCK_FILE, (char *) NULL);
fname = (*quote_func) (file, 0); fname = (*quote_func) (file, 0);
g_free (file); mhl_mem_free (file);
return fname; return fname;
} else if (c_lc == 'b') { } else if (c_lc == 'b') {
return strip_ext ((*quote_func) (fname, 0)); return strip_ext ((*quote_func) (fname, 0));
@ -278,7 +280,7 @@ expand_format (struct WEdit *edit_widget, char c, int quote)
if (panel->dir.list[i].f.marked) { if (panel->dir.list[i].f.marked) {
strcat (block, tmp = strcat (block, tmp =
(*quote_func) (panel->dir.list[i].fname, 0)); (*quote_func) (panel->dir.list[i].fname, 0));
g_free (tmp); mhl_mem_free (tmp);
strcat (block, " "); strcat (block, " ");
if (c_lc == 'u') if (c_lc == 'u')
do_file_mark (panel, i, 0); do_file_mark (panel, i, 0);
@ -468,7 +470,7 @@ debug_out (char *start, char *end, int cond)
} }
debug_flag = 0; debug_flag = 0;
g_free (msg); mhl_mem_free (msg);
msg = NULL; msg = NULL;
} else { } else {
const char *type; const char *type;
@ -492,7 +494,7 @@ debug_out (char *start, char *end, int cond)
else else
p = g_strdup_printf ("%s%s%.*s \n", msg ? msg : "", type, p = g_strdup_printf ("%s%s%.*s \n", msg ? msg : "", type,
(int) (end - start), start); (int) (end - start), start);
g_free (msg); mhl_mem_free (msg);
msg = p; msg = p;
} }
} }
@ -610,15 +612,15 @@ execute_menu_command (WEdit *edit_widget, const char *commands)
/* User canceled */ /* User canceled */
fclose (cmd_file); fclose (cmd_file);
unlink (file_name); unlink (file_name);
g_free (file_name); mhl_mem_free (file_name);
return; return;
} }
if (do_quote) { if (do_quote) {
fputs (tmp = name_quote (parameter, 0), cmd_file); fputs (tmp = name_quote (parameter, 0), cmd_file);
g_free (tmp); mhl_mem_free (tmp);
} else } else
fputs (parameter, cmd_file); fputs (parameter, cmd_file);
g_free (parameter); mhl_mem_free (parameter);
parameter = 0; parameter = 0;
} else { } else {
if (parameter < &prompt [sizeof (prompt) - 1]) { if (parameter < &prompt [sizeof (prompt) - 1]) {
@ -637,7 +639,7 @@ execute_menu_command (WEdit *edit_widget, const char *commands)
else{ else{
char *text = expand_format (edit_widget, *commands, do_quote); char *text = expand_format (edit_widget, *commands, do_quote);
fputs (text, cmd_file); fputs (text, cmd_file);
g_free (text); mhl_mem_free (text);
} }
} else { } else {
if (*commands == '%') { if (*commands == '%') {
@ -663,10 +665,10 @@ execute_menu_command (WEdit *edit_widget, const char *commands)
* on no-exec filesystems. */ * on no-exec filesystems. */
char *cmd = g_strconcat("/bin/sh ", file_name, (char *)NULL); char *cmd = g_strconcat("/bin/sh ", file_name, (char *)NULL);
shell_execute (cmd, EXECUTE_HIDE); shell_execute (cmd, EXECUTE_HIDE);
g_free(cmd); mhl_mem_free(cmd);
} }
unlink (file_name); unlink (file_name);
g_free (file_name); mhl_mem_free (file_name);
} }
/* /*
@ -720,11 +722,11 @@ user_menu_cmd (struct WEdit *edit_widget)
menu = g_strdup (edit_widget ? CEDIT_LOCAL_MENU : MC_LOCAL_MENU); menu = g_strdup (edit_widget ? CEDIT_LOCAL_MENU : MC_LOCAL_MENU);
if (!exist_file (menu) || !menu_file_own (menu)){ if (!exist_file (menu) || !menu_file_own (menu)){
g_free (menu); mhl_mem_free (menu);
menu = concat_dir_and_file \ menu = concat_dir_and_file \
(home_dir, edit_widget ? CEDIT_HOME_MENU : MC_HOME_MENU); (home_dir, edit_widget ? CEDIT_HOME_MENU : MC_HOME_MENU);
if (!exist_file (menu)){ if (!exist_file (menu)){
g_free (menu); mhl_mem_free (menu);
menu = concat_dir_and_file \ menu = concat_dir_and_file \
(mc_home, edit_widget ? CEDIT_GLOBAL_MENU : MC_GLOBAL_MENU); (mc_home, edit_widget ? CEDIT_GLOBAL_MENU : MC_GLOBAL_MENU);
} }
@ -733,7 +735,7 @@ user_menu_cmd (struct WEdit *edit_widget)
if ((data = load_file (menu)) == NULL){ if ((data = load_file (menu)) == NULL){
message (D_ERROR, MSG_ERROR, _(" Cannot open file %s \n %s "), message (D_ERROR, MSG_ERROR, _(" Cannot open file %s \n %s "),
menu, unix_error_string (errno)); menu, unix_error_string (errno));
g_free (menu); mhl_mem_free (menu);
menu = NULL; menu = NULL;
return; return;
} }
@ -838,9 +840,9 @@ user_menu_cmd (struct WEdit *edit_widget)
} }
easy_patterns = old_patterns; easy_patterns = old_patterns;
g_free (menu); mhl_mem_free (menu);
menu = NULL; menu = NULL;
g_free (entries); mhl_mem_free (entries);
g_free (data); mhl_mem_free (data);
} }

View File

@ -30,11 +30,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "profile.h" #include "profile.h"
#include "main.h" /* mc_home */ #include "main.h" /* mc_home */
@ -263,7 +264,7 @@ path_trunc (const char *path, int trunc_len) {
char *secure_path = strip_password (g_strdup (path), 1); char *secure_path = strip_password (g_strdup (path), 1);
ret = name_trunc (secure_path, trunc_len); ret = name_trunc (secure_path, trunc_len);
g_free (secure_path); mhl_mem_free (secure_path);
return ret; return ret;
} }
@ -594,12 +595,12 @@ regexp_match (const char *pattern, const char *string, int match_type)
if (!old_pattern || STRCOMP (old_pattern, pattern) || old_type != match_type){ if (!old_pattern || STRCOMP (old_pattern, pattern) || old_type != match_type){
if (old_pattern){ if (old_pattern){
regfree (&r); regfree (&r);
g_free (old_pattern); mhl_mem_free (old_pattern);
old_pattern = NULL; old_pattern = NULL;
} }
my_pattern = convert_pattern (pattern, match_type, 0); my_pattern = convert_pattern (pattern, match_type, 0);
if (regcomp (&r, my_pattern, REG_EXTENDED|REG_NOSUB|MC_ARCH_FLAGS)) { if (regcomp (&r, my_pattern, REG_EXTENDED|REG_NOSUB|MC_ARCH_FLAGS)) {
g_free (my_pattern); mhl_mem_free (my_pattern);
return -1; return -1;
} }
old_pattern = my_pattern; old_pattern = my_pattern;
@ -674,7 +675,7 @@ load_file (const char *filename)
if (read_size > 0) if (read_size > 0)
return data; return data;
else { else {
g_free (data); mhl_mem_free (data);
return 0; return 0;
} }
} }
@ -693,7 +694,7 @@ load_mc_home_file (const char *filename, char **allocated_filename)
data = load_file (hintfile); data = load_file (hintfile);
if (!data) { if (!data) {
g_free (hintfile); mhl_mem_free (hintfile);
/* Fall back to the two-letter language code */ /* Fall back to the two-letter language code */
if (lang[0] && lang[1]) if (lang[0] && lang[1])
lang[2] = 0; lang[2] = 0;
@ -701,21 +702,21 @@ load_mc_home_file (const char *filename, char **allocated_filename)
data = load_file (hintfile); data = load_file (hintfile);
if (!data) { if (!data) {
g_free (hintfile); mhl_mem_free (hintfile);
hintfile = hintfile_base; hintfile = hintfile_base;
data = load_file (hintfile_base); data = load_file (hintfile_base);
} }
} }
g_free (lang); mhl_mem_free (lang);
if (hintfile != hintfile_base) if (hintfile != hintfile_base)
g_free (hintfile_base); mhl_mem_free (hintfile_base);
if (allocated_filename) if (allocated_filename)
*allocated_filename = hintfile; *allocated_filename = hintfile;
else else
g_free (hintfile); mhl_mem_free (hintfile);
return data; return data;
} }
@ -845,7 +846,7 @@ unix_error_string (int error_num)
strerror_currentlocale = g_locale_from_utf8(g_strerror (error_num), -1, NULL, NULL, NULL); strerror_currentlocale = g_locale_from_utf8(g_strerror (error_num), -1, NULL, NULL, NULL);
g_snprintf (buffer, sizeof (buffer), "%s (%d)", g_snprintf (buffer, sizeof (buffer), "%s (%d)",
strerror_currentlocale, error_num); strerror_currentlocale, error_num);
g_free(strerror_currentlocale); mhl_mem_free(strerror_currentlocale);
#else #else
g_snprintf (buffer, sizeof (buffer), "%s (%d)", g_snprintf (buffer, sizeof (buffer), "%s (%d)",
g_strerror (error_num), error_num); g_strerror (error_num), error_num);
@ -930,12 +931,12 @@ get_current_wd (char *buffer, int size)
len = strlen(p) + 1; len = strlen(p) + 1;
if (len > size) { if (len > size) {
g_free (p); mhl_mem_free (p);
return NULL; return NULL;
} }
memcpy (buffer, p, len); memcpy (buffer, p, len);
g_free (p); mhl_mem_free (p);
return buffer; return buffer;
} }
@ -1041,7 +1042,7 @@ execute_hooks (Hook *hook_list)
for (hook_list = p; hook_list;){ for (hook_list = p; hook_list;){
p = hook_list; p = hook_list;
hook_list = hook_list->next; hook_list = hook_list->next;
g_free (p); mhl_mem_free (p);
} }
} }
@ -1055,7 +1056,7 @@ delete_hook (Hook **hook_list, void (*hook_fn)(void *))
for (current = *hook_list; current; current = next){ for (current = *hook_list; current; current = next){
next = current->next; next = current->next;
if (current->hook_fn == hook_fn) if (current->hook_fn == hook_fn)
g_free (current); mhl_mem_free (current);
else else
add_hook (&new_list, current->hook_fn, current->hook_data); add_hook (&new_list, current->hook_fn, current->hook_data);
} }
@ -1082,7 +1083,7 @@ wipe_password (char *passwd)
return; return;
for (;*p ; p++) for (;*p ; p++)
*p = 0; *p = 0;
g_free (passwd); mhl_mem_free (passwd);
} }
/* Convert "\E" -> esc character and ^x to control-x key and ^^ to ^ key */ /* Convert "\E" -> esc character and ^x to control-x key and ^^ to ^ key */
@ -1147,8 +1148,8 @@ resolve_symlinks (const char *path)
c = *q; c = *q;
*q = 0; *q = 0;
if (mc_lstat (path, &mybuf) < 0) { if (mc_lstat (path, &mybuf) < 0) {
g_free (buf); mhl_mem_free (buf);
g_free (buf2); mhl_mem_free (buf2);
*q = c; *q = c;
return NULL; return NULL;
} }
@ -1157,8 +1158,8 @@ resolve_symlinks (const char *path)
else { else {
len = mc_readlink (path, buf2, MC_MAXPATHLEN - 1); len = mc_readlink (path, buf2, MC_MAXPATHLEN - 1);
if (len < 0) { if (len < 0) {
g_free (buf); mhl_mem_free (buf);
g_free (buf2); mhl_mem_free (buf2);
*q = c; *q = c;
return NULL; return NULL;
} }
@ -1183,7 +1184,7 @@ resolve_symlinks (const char *path)
strcpy (buf, PATH_SEP_STR); strcpy (buf, PATH_SEP_STR);
else if (*(r - 1) == PATH_SEP && r != buf + 1) else if (*(r - 1) == PATH_SEP && r != buf + 1)
*(r - 1) = 0; *(r - 1) = 0;
g_free (buf2); mhl_mem_free (buf2);
return buf; return buf;
} }
@ -1201,7 +1202,7 @@ diff_two_paths (const char *first, const char *second)
return NULL; return NULL;
my_second = resolve_symlinks (second); my_second = resolve_symlinks (second);
if (my_second == NULL) { if (my_second == NULL) {
g_free (my_first); mhl_mem_free (my_first);
return NULL; return NULL;
} }
for (j = 0; j < 2; j++) { for (j = 0; j < 2; j++) {
@ -1227,10 +1228,10 @@ diff_two_paths (const char *first, const char *second)
currlen = (i + 1) * 3 + strlen (q) + 1; currlen = (i + 1) * 3 + strlen (q) + 1;
if (j) { if (j) {
if (currlen < prevlen) if (currlen < prevlen)
g_free (buf); mhl_mem_free (buf);
else { else {
g_free (my_first); mhl_mem_free (my_first);
g_free (my_second); mhl_mem_free (my_second);
return buf; return buf;
} }
} }
@ -1240,8 +1241,8 @@ diff_two_paths (const char *first, const char *second)
strcpy (p, "../"); strcpy (p, "../");
strcpy (p, q); strcpy (p, q);
} }
g_free (my_first); mhl_mem_free (my_first);
g_free (my_second); mhl_mem_free (my_second);
return buf; return buf;
} }
@ -1275,7 +1276,7 @@ list_append_unique (GList *list, char *text)
while (link) { while (link) {
newlink = g_list_previous (link); newlink = g_list_previous (link);
if (!strcmp ((char *) link->data, text)) { if (!strcmp ((char *) link->data, text)) {
g_free (link->data); mhl_mem_free (link->data);
g_list_remove_link (list, link); g_list_remove_link (list, link);
g_list_free_1 (link); g_list_free_1 (link);
} }
@ -1294,7 +1295,7 @@ list_append_unique (GList *list, char *text)
/* /*
* Arguments: * Arguments:
* pname (output) - pointer to the name of the temp file (needs g_free). * pname (output) - pointer to the name of the temp file (needs mhl_mem_free).
* NULL if the function fails. * NULL if the function fails.
* prefix - part of the filename before the random part. * prefix - part of the filename before the random part.
* Prepend $TMPDIR or /tmp if there are no path separators. * Prepend $TMPDIR or /tmp if there are no path separators.
@ -1325,7 +1326,7 @@ mc_mkstemps (char **pname, const char *prefix, const char *suffix)
tmpname = g_strconcat (tmpbase, "XXXXXX", suffix, (char *) NULL); tmpname = g_strconcat (tmpbase, "XXXXXX", suffix, (char *) NULL);
*pname = tmpname; *pname = tmpname;
XXXXXX = &tmpname[strlen (tmpbase)]; XXXXXX = &tmpname[strlen (tmpbase)];
g_free (tmpbase); mhl_mem_free (tmpbase);
/* Get some more or less random data. */ /* Get some more or less random data. */
gettimeofday (&tv, NULL); gettimeofday (&tv, NULL);
@ -1362,7 +1363,7 @@ mc_mkstemps (char **pname, const char *prefix, const char *suffix)
} }
/* Unsuccessful. Free the filename. */ /* Unsuccessful. Free the filename. */
g_free (tmpname); mhl_mem_free (tmpname);
*pname = NULL; *pname = NULL;
return -1; return -1;
@ -1387,7 +1388,7 @@ load_file_position (const char *filename, long *line, long *column)
/* open file with positions */ /* open file with positions */
fn = concat_dir_and_file (home_dir, MC_FILEPOS); fn = concat_dir_and_file (home_dir, MC_FILEPOS);
f = fopen (fn, "r"); f = fopen (fn, "r");
g_free (fn); mhl_mem_free (fn);
if (!f) if (!f)
return; return;
@ -1438,8 +1439,8 @@ save_file_position (const char *filename, long line, long column)
/* open temporary file */ /* open temporary file */
t = fopen (tmp, "w"); t = fopen (tmp, "w");
if (!t) { if (!t) {
g_free (tmp); mhl_mem_free (tmp);
g_free (fn); mhl_mem_free (fn);
return; return;
} }
@ -1466,8 +1467,8 @@ save_file_position (const char *filename, long line, long column)
fclose (t); fclose (t);
rename (tmp, fn); rename (tmp, fn);
g_free (tmp); mhl_mem_free (tmp);
g_free (fn); mhl_mem_free (fn);
} }
extern const char * extern const char *

View File

@ -41,6 +41,8 @@
#endif #endif
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "execute.h" #include "execute.h"
#include "wtools.h" /* message() */ #include "wtools.h" /* message() */
@ -71,7 +73,7 @@ static char *i_cache_match (int id, int_cache *cache, int size)
static void i_cache_add (int id, int_cache *cache, int size, char *text, static void i_cache_add (int id, int_cache *cache, int size, char *text,
int *last) int *last)
{ {
g_free (cache [*last].string); mhl_mem_free (cache [*last].string);
cache [*last].string = g_strdup (text); cache [*last].string = g_strdup (text);
cache [*last].index = id; cache [*last].index = id;
*last = ((*last)+1) % size; *last = ((*last)+1) % size;
@ -202,7 +204,7 @@ tilde_expand (const char *directory)
name = g_strndup (p, q - p); name = g_strndup (p, q - p);
passwd = getpwnam (name); passwd = getpwnam (name);
q++; q++;
g_free (name); mhl_mem_free (name);
} }
} }
@ -292,7 +294,7 @@ mc_tmpdir (void)
/* Test if sys_tmp is suitable for temporary files */ /* Test if sys_tmp is suitable for temporary files */
fallback_prefix = g_strdup_printf ("%s/mctest", sys_tmp); fallback_prefix = g_strdup_printf ("%s/mctest", sys_tmp);
test_fd = mc_mkstemps (&test_fn, fallback_prefix, NULL); test_fd = mc_mkstemps (&test_fn, fallback_prefix, NULL);
g_free (fallback_prefix); mhl_mem_free (fallback_prefix);
if (test_fd != -1) { if (test_fd != -1) {
close (test_fd); close (test_fd);
test_fd = open (test_fn, O_RDONLY); test_fd = open (test_fn, O_RDONLY);

View File

@ -39,11 +39,12 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "cmd.h" /* For view_other_cmd */ #include "cmd.h" /* For view_other_cmd */
@ -346,7 +347,7 @@ view_hexedit_free_change_list (WView *view)
for (curr = view->change_list; curr != NULL; curr = next) { for (curr = view->change_list; curr != NULL; curr = next) {
next = curr->next; next = curr->next;
g_free (curr); mhl_mem_free (curr);
} }
view->change_list = NULL; view->change_list = NULL;
view->dirty++; view->dirty++;
@ -372,8 +373,8 @@ view_growbuf_free (WView *view)
assert (view->growbuf_in_use); assert (view->growbuf_in_use);
for (i = 0; i < view->growbuf_blocks; i++) for (i = 0; i < view->growbuf_blocks; i++)
g_free (view->growbuf_blockptr[i]); mhl_mem_free (view->growbuf_blockptr[i]);
g_free (view->growbuf_blockptr); mhl_mem_free (view->growbuf_blockptr);
view->growbuf_blockptr = NULL; view->growbuf_blockptr = NULL;
view->growbuf_in_use = FALSE; view->growbuf_in_use = FALSE;
} }
@ -413,12 +414,12 @@ view_growbuf_read_until (WView *view, offset_type ofs)
byte *newblock = g_try_malloc (VIEW_PAGE_SIZE); byte *newblock = g_try_malloc (VIEW_PAGE_SIZE);
byte **newblocks = g_try_malloc (sizeof (*newblocks) * (view->growbuf_blocks + 1)); byte **newblocks = g_try_malloc (sizeof (*newblocks) * (view->growbuf_blocks + 1));
if (!newblock || !newblocks) { if (!newblock || !newblocks) {
g_free (newblock); mhl_mem_free (newblock);
g_free (newblocks); mhl_mem_free (newblocks);
return; return;
} }
memcpy (newblocks, view->growbuf_blockptr, sizeof (*newblocks) * view->growbuf_blocks); memcpy (newblocks, view->growbuf_blockptr, sizeof (*newblocks) * view->growbuf_blocks);
g_free (view->growbuf_blockptr); mhl_mem_free (view->growbuf_blockptr);
view->growbuf_blockptr = newblocks; view->growbuf_blockptr = newblocks;
view->growbuf_blockptr[view->growbuf_blocks++] = newblock; view->growbuf_blockptr[view->growbuf_blocks++] = newblock;
view->growbuf_lastindex = 0; view->growbuf_lastindex = 0;
@ -705,11 +706,11 @@ view_close_datasource (WView *view)
case DS_FILE: case DS_FILE:
(void) mc_close (view->ds_file_fd); (void) mc_close (view->ds_file_fd);
view->ds_file_fd = -1; view->ds_file_fd = -1;
g_free (view->ds_file_data); mhl_mem_free (view->ds_file_data);
view->ds_file_data = NULL; view->ds_file_data = NULL;
break; break;
case DS_STRING: case DS_STRING:
g_free (view->ds_string_data); mhl_mem_free (view->ds_string_data);
view->ds_string_data = NULL; view->ds_string_data = NULL;
break; break;
default: default:
@ -1397,8 +1398,8 @@ view_toggle_magic_mode (WView *view)
view_done (view); view_done (view);
view_load (view, command, filename, 0); view_load (view, command, filename, 0);
g_free (filename); mhl_mem_free (filename);
g_free (command); mhl_mem_free (command);
view->dpy_bbar_dirty = TRUE; view->dpy_bbar_dirty = TRUE;
view->dirty++; view->dirty++;
} }
@ -1416,7 +1417,7 @@ view_done (WView *view)
canon_fname = vfs_canon (view->filename); canon_fname = vfs_canon (view->filename);
view_offset_to_coord (view, &line, &col, view->dpy_start); view_offset_to_coord (view, &line, &col, view->dpy_start);
save_file_position (canon_fname, line + 1, col); save_file_position (canon_fname, line + 1, col);
g_free (canon_fname); mhl_mem_free (canon_fname);
} }
/* Write back the global viewer mode */ /* Write back the global viewer mode */
@ -1429,8 +1430,8 @@ view_done (WView *view)
/* view->widget needs no destructor */ /* view->widget needs no destructor */
g_free (view->filename), view->filename = NULL; mhl_mem_free (view->filename), view->filename = NULL;
g_free (view->command), view->command = NULL; mhl_mem_free (view->command), view->command = NULL;
view_close_datasource (view); view_close_datasource (view);
/* the growing buffer is freed with the datasource */ /* the growing buffer is freed with the datasource */
@ -1544,7 +1545,7 @@ view_load (WView *view, const char *command, const char *file,
type = get_compression_type (fd); type = get_compression_type (fd);
if (view->magic_mode && (type != COMPRESSION_NONE)) { if (view->magic_mode && (type != COMPRESSION_NONE)) {
g_free (view->filename); mhl_mem_free (view->filename);
view->filename = g_strconcat (file, decompress_extension (type), (char *) NULL); view->filename = g_strconcat (file, decompress_extension (type), (char *) NULL);
} }
view_set_datasource_file (view, fd, &st); view_set_datasource_file (view, fd, &st);
@ -1567,7 +1568,7 @@ view_load (WView *view, const char *command, const char *file,
canon_fname = vfs_canon (file); canon_fname = vfs_canon (file);
load_file_position (file, &line, &col); load_file_position (file, &line, &col);
g_free (canon_fname); mhl_mem_free (canon_fname);
view_moveto (view, offset_doz(line, 1), col); view_moveto (view, offset_doz(line, 1), col);
} else if (start_line > 0) { } else if (start_line > 0) {
view_moveto (view, start_line - 1, 0); view_moveto (view, start_line - 1, 0);
@ -2163,7 +2164,7 @@ view_hexedit_save_changes (WView *view)
view->change_list = next; view->change_list = next;
view->dirty++; view->dirty++;
view_set_byte (view, curr->offset, curr->value); view_set_byte (view, curr->offset, curr->value);
g_free (curr); mhl_mem_free (curr);
} }
if (mc_close (fp) == -1) { if (mc_close (fp) == -1) {
@ -2171,7 +2172,7 @@ view_hexedit_save_changes (WView *view)
message (D_ERROR, _(" Save file "), message (D_ERROR, _(" Save file "),
_(" Error while closing the file: \n %s \n" _(" Error while closing the file: \n %s \n"
" Data may have been written or not. "), error); " Data may have been written or not. "), error);
g_free (error); mhl_mem_free (error);
} }
view_update (view); view_update (view);
return TRUE; return TRUE;
@ -2179,12 +2180,12 @@ view_hexedit_save_changes (WView *view)
save_error: save_error:
error = g_strdup (strerror (errno)); error = g_strdup (strerror (errno));
text = g_strdup_printf (_(" Cannot save file: \n %s "), error); text = g_strdup_printf (_(" Cannot save file: \n %s "), error);
g_free (error); mhl_mem_free (error);
(void) mc_close (fp); (void) mc_close (fp);
answer = query_dialog (_(" Save file "), text, D_ERROR, answer = query_dialog (_(" Save file "), text, D_ERROR,
2, _("&Retry"), _("&Cancel")); 2, _("&Retry"), _("&Cancel"));
g_free (text); mhl_mem_free (text);
if (answer == 0) if (answer == 0)
goto retry_save; goto retry_save;
@ -2389,7 +2390,7 @@ search (WView *view, char *text,
view->update_activate = 0; view->update_activate = 0;
enable_interrupt_key (); enable_interrupt_key ();
for (;; g_free (s)) { for (;; mhl_mem_free (s)) {
if (p >= view->update_activate) { if (p >= view->update_activate) {
view->update_activate += view->update_steps; view->update_activate += view->update_steps;
if (verbose) { if (verbose) {
@ -2408,7 +2409,7 @@ search (WView *view, char *text,
search_status = (*search) (view, text, s + 1, match_normal); search_status = (*search) (view, text, s + 1, match_normal);
if (search_status < 0) { if (search_status < 0) {
g_free (s); mhl_mem_free (s);
break; break;
} }
@ -2436,7 +2437,7 @@ search (WView *view, char *text,
view->dpy_start = t; view->dpy_start = t;
} }
g_free (s); mhl_mem_free (s);
break; break;
} }
disable_interrupt_key (); disable_interrupt_key ();
@ -2597,7 +2598,7 @@ hex_search (WView *view, const char *text)
/* No valid bytes in the user input */ /* No valid bytes in the user input */
if (block_len <= 0 || parse_error) { if (block_len <= 0 || parse_error) {
message (D_NORMAL, _("Search"), _("Invalid hex search expression")); message (D_NORMAL, _("Search"), _("Invalid hex search expression"));
g_free (buffer); mhl_mem_free (buffer);
view->search_length = 0; view->search_length = 0;
return; return;
} }
@ -2605,7 +2606,7 @@ hex_search (WView *view, const char *text)
/* Then start the search */ /* Then start the search */
pos = block_search (view, buffer, block_len); pos = block_search (view, buffer, block_len);
g_free (buffer); mhl_mem_free (buffer);
if (pos == INVALID_OFFSET) { if (pos == INVALID_OFFSET) {
message (D_NORMAL, _("Search"), _(" Search string not found ")); message (D_NORMAL, _("Search"), _(" Search string not found "));
@ -2637,7 +2638,7 @@ regexp_view_search (WView *view, char *pattern, char *string,
|| old_type != match_type) { || old_type != match_type) {
if (old_pattern != NULL) { if (old_pattern != NULL) {
regfree (&r); regfree (&r);
g_free (old_pattern); mhl_mem_free (old_pattern);
old_pattern = 0; old_pattern = 0;
} }
for (i = 0; pattern[i] != '\0'; i++) { for (i = 0; pattern[i] != '\0'; i++) {
@ -2741,7 +2742,7 @@ view_moveto_line_cmd (WView *view)
if (*answer_end == '\0' && errno == 0 && line >= 1) if (*answer_end == '\0' && errno == 0 && line >= 1)
view_moveto (view, line - 1, 0); view_moveto (view, line - 1, 0);
} }
g_free (answer); mhl_mem_free (answer);
view->dirty++; view->dirty++;
view_update (view); view_update (view);
} }
@ -2765,7 +2766,7 @@ view_moveto_addr_cmd (WView *view)
message (D_ERROR, _("Warning"), _(" Invalid address ")); message (D_ERROR, _("Warning"), _(" Invalid address "));
} }
} }
g_free (line); mhl_mem_free (line);
} }
view->dirty++; view->dirty++;
view_update (view); view_update (view);
@ -2790,11 +2791,11 @@ regexp_search (WView *view, int direction)
regexp = input_dialog (_("Search"), _(" Enter regexp:"), MC_HISTORY_VIEW_SEARCH_REGEX, defval); regexp = input_dialog (_("Search"), _(" Enter regexp:"), MC_HISTORY_VIEW_SEARCH_REGEX, defval);
if (regexp == NULL || regexp[0] == '\0') { if (regexp == NULL || regexp[0] == '\0') {
g_free (regexp); mhl_mem_free (regexp);
return; return;
} }
g_free (last_regexp); mhl_mem_free (last_regexp);
view->search_exp = last_regexp = regexp; view->search_exp = last_regexp = regexp;
view->direction = direction; view->direction = direction;
@ -2863,7 +2864,7 @@ view_normal_search_cmd (WView *view)
convert_from_input (exp); convert_from_input (exp);
g_free (last_search_string); mhl_mem_free (last_search_string);
view->search_exp = last_search_string = exp; view->search_exp = last_search_string = exp;
exp = NULL; exp = NULL;
@ -2872,8 +2873,8 @@ view_normal_search_cmd (WView *view)
view->last_search = do_normal_search; view->last_search = do_normal_search;
cleanup: cleanup:
g_free (exp); mhl_mem_free (exp);
g_free (defval); mhl_mem_free (defval);
} }
static void static void

View File

@ -32,9 +32,10 @@
#include <errno.h> #include <errno.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/types.h> #include <sys/types.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "color.h" #include "color.h"
@ -188,7 +189,7 @@ button_callback (Widget *w, widget_msg_t msg, int parm)
return MSG_HANDLED; return MSG_HANDLED;
case WIDGET_DESTROY: case WIDGET_DESTROY:
g_free (b->text); mhl_mem_free (b->text);
return MSG_HANDLED; return MSG_HANDLED;
default: default:
@ -281,7 +282,7 @@ button_get_text (WButton *b)
void void
button_set_text (WButton *b, const char *text) button_set_text (WButton *b, const char *text)
{ {
g_free (b->text); mhl_mem_free (b->text);
b->text = g_strdup (text); b->text = g_strdup (text);
b->widget.cols = button_len (text, b->flags); b->widget.cols = button_len (text, b->flags);
button_scan_hotkey(b); button_scan_hotkey(b);
@ -474,7 +475,7 @@ check_callback (Widget *w, widget_msg_t msg, int parm)
return MSG_HANDLED; return MSG_HANDLED;
case WIDGET_DESTROY: case WIDGET_DESTROY:
g_free (c->text); mhl_mem_free (c->text);
return MSG_HANDLED; return MSG_HANDLED;
default: default:
@ -586,7 +587,7 @@ label_callback (Widget *w, widget_msg_t msg, int parm)
} }
case WIDGET_DESTROY: case WIDGET_DESTROY:
g_free (l->text); mhl_mem_free (l->text);
return MSG_HANDLED; return MSG_HANDLED;
default: default:
@ -602,7 +603,7 @@ label_set_text (WLabel *label, const char *text)
if (label->text && text && !strcmp (label->text, text)) if (label->text && text && !strcmp (label->text, text))
return; /* Flickering is not nice */ return; /* Flickering is not nice */
g_free (label->text); mhl_mem_free (label->text);
if (text){ if (text){
label->text = g_strdup (text); label->text = g_strdup (text);
@ -878,7 +879,7 @@ history_get (const char *input_name)
hist = list_append_unique (hist, g_strdup (this_entry)); hist = list_append_unique (hist, g_strdup (this_entry));
} }
g_free (profile); mhl_mem_free (profile);
/* return pointer to the last entry in the list */ /* return pointer to the last entry in the list */
hist = g_list_last (hist); hist = g_list_last (hist);
@ -911,7 +912,7 @@ history_put (const char *input_name, GList *h)
/* Make sure the history is only readable by the user */ /* Make sure the history is only readable by the user */
if (chmod (profile, S_IRUSR | S_IWUSR) == -1 && errno != ENOENT) { if (chmod (profile, S_IRUSR | S_IWUSR) == -1 && errno != ENOENT) {
g_free (profile); mhl_mem_free (profile);
return; return;
} }
@ -940,7 +941,7 @@ history_put (const char *input_name, GList *h)
} }
} }
g_free (profile); mhl_mem_free (profile);
} }
/* }}} history saving and loading */ /* }}} history saving and loading */
@ -1051,7 +1052,7 @@ static void do_show_hist (WInput * in)
r = show_hist (in->history, in->widget.x, in->widget.y); r = show_hist (in->history, in->widget.x, in->widget.y);
if (r) { if (r) {
assign_text (in, r); assign_text (in, r);
g_free (r); mhl_mem_free (r);
} }
} }
@ -1072,13 +1073,13 @@ input_destroy (WInput *in)
history_put (in->history_name, in->history); history_put (in->history_name, in->history);
in->history = g_list_first (in->history); in->history = g_list_first (in->history);
g_list_foreach (in->history, (GFunc) g_free, NULL); g_list_foreach (in->history, (GFunc) mhl_mem_free, NULL);
g_list_free (in->history); g_list_free (in->history);
} }
g_free (in->buffer); mhl_mem_free (in->buffer);
free_completions (in); free_completions (in);
g_free (in->history_name); mhl_mem_free (in->history_name);
} }
void void
@ -1299,7 +1300,7 @@ copy_region (WInput *in, int x_first, int x_last)
if (last == first) if (last == first)
return; return;
g_free (kill_buffer); mhl_mem_free (kill_buffer);
kill_buffer = g_strndup(in->buffer+first,last-first); kill_buffer = g_strndup(in->buffer+first,last-first);
} }
@ -1380,7 +1381,7 @@ yank (WInput *in)
static void static void
kill_line (WInput *in) kill_line (WInput *in)
{ {
g_free (kill_buffer); mhl_mem_free (kill_buffer);
kill_buffer = g_strdup (&in->buffer [in->point]); kill_buffer = g_strdup (&in->buffer [in->point]);
in->buffer [in->point] = 0; in->buffer [in->point] = 0;
} }
@ -1389,7 +1390,7 @@ void
assign_text (WInput *in, const char *text) assign_text (WInput *in, const char *text)
{ {
free_completions (in); free_completions (in);
g_free (in->buffer); mhl_mem_free (in->buffer);
in->buffer = g_strdup (text); /* was in->buffer->text */ in->buffer = g_strdup (text); /* was in->buffer->text */
in->current_max_len = strlen (in->buffer) + 1; in->current_max_len = strlen (in->buffer) + 1;
in->point = strlen (in->buffer); in->point = strlen (in->buffer);
@ -1857,8 +1858,8 @@ listbox_remove_list (WListbox *l)
while (l->count--) { while (l->count--) {
q = p->next; q = p->next;
g_free (p->text); mhl_mem_free (p->text);
g_free (p); mhl_mem_free (p);
p = q; p = q;
} }
l->pos = l->count = 0; l->pos = l->count = 0;
@ -1899,8 +1900,8 @@ listbox_remove_current (WListbox *l, int force)
l->list = l->top = l->current = 0; l->list = l->top = l->current = 0;
} }
g_free (p->text); mhl_mem_free (p->text);
g_free (p); mhl_mem_free (p);
} }
/* Makes *e the selected entry (sets current and pos) */ /* Makes *e the selected entry (sets current and pos) */
@ -2022,8 +2023,8 @@ listbox_destroy (WListbox *l)
for (i = 0; i < l->count; i++){ for (i = 0; i < l->count; i++){
n = p->next; n = p->next;
g_free (p->text); mhl_mem_free (p->text);
g_free (p); mhl_mem_free (p);
p = n; p = n;
} }
} }
@ -2338,7 +2339,7 @@ buttonbar_callback (Widget *w, widget_msg_t msg, int parm)
case WIDGET_DESTROY: case WIDGET_DESTROY:
for (i = 0; i < 10; i++) for (i = 0; i < 10; i++)
g_free (bb->labels[i].text); mhl_mem_free (bb->labels[i].text);
return MSG_HANDLED; return MSG_HANDLED;
default: default:
@ -2385,7 +2386,7 @@ buttonbar_new (int visible)
static void static void
set_label_text (WButtonBar * bb, int index, const char *text) set_label_text (WButtonBar * bb, int index, const char *text)
{ {
g_free (bb->labels[index - 1].text); mhl_mem_free (bb->labels[index - 1].text);
bb->labels[index - 1].text = g_strdup (text); bb->labels[index - 1].text = g_strdup (text);
} }
@ -2484,7 +2485,7 @@ groupbox_callback (Widget *w, widget_msg_t msg, int parm)
return MSG_HANDLED; return MSG_HANDLED;
case WIDGET_DESTROY: case WIDGET_DESTROY:
g_free (g->title); mhl_mem_free (g->title);
return MSG_HANDLED; return MSG_HANDLED;
default: default:
@ -2507,7 +2508,7 @@ groupbox_new (int x, int y, int width, int height, const char *title)
char *t; char *t;
t = g_strstrip (g_strdup (title)); t = g_strstrip (g_strdup (title));
g->title = g_strconcat (" ", t, " ", (char *) NULL); g->title = g_strconcat (" ", t, " ", (char *) NULL);
g_free (t); mhl_mem_free (t);
} }
return g; return g;

View File

@ -29,6 +29,8 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "global.h" #include "global.h"
#include "tty.h" #include "tty.h"
#include "color.h" /* dialog_colors */ #include "color.h" /* dialog_colors */
@ -87,7 +89,7 @@ int run_listbox (Listbox *l)
else else
val = l->list->pos; val = l->list->pos;
destroy_dlg (l->dlg); destroy_dlg (l->dlg);
g_free (l); mhl_mem_free (l);
return val; return val;
} }
@ -207,7 +209,7 @@ do_create_message (int flags, const char *title, const char *text)
query_dialog (title, p, flags, 0); query_dialog (title, p, flags, 0);
d = last_query_dlg; d = last_query_dlg;
init_dlg (d); init_dlg (d);
g_free (p); mhl_mem_free (p);
return d; return d;
} }
@ -229,7 +231,7 @@ create_message (int flags, const char *title, const char *text, ...)
va_end (args); va_end (args);
d = do_create_message (flags, title, p); d = do_create_message (flags, title, p);
g_free (p); mhl_mem_free (p);
return d; return d;
} }
@ -259,7 +261,7 @@ bg_message (int dummy, int *flags, char *title, const char *text)
(void) dummy; (void) dummy;
title = g_strconcat (_("Background process:"), " ", title, (char *) NULL); title = g_strconcat (_("Background process:"), " ", title, (char *) NULL);
fg_message (*flags, title, text); fg_message (*flags, title, text);
g_free (title); mhl_mem_free (title);
} }
#endif /* WITH_BACKGROUND */ #endif /* WITH_BACKGROUND */
@ -286,7 +288,7 @@ message (int flags, const char *title, const char *text, ...)
#endif /* WITH_BACKGROUND */ #endif /* WITH_BACKGROUND */
fg_message (flags, title, p); fg_message (flags, title, p);
g_free (p); mhl_mem_free (p);
} }
@ -413,7 +415,7 @@ quick_dialog_skip (QuickDialog *qd, int nskip)
} }
return_val = dd->ret_value; return_val = dd->ret_value;
destroy_dlg (dd); destroy_dlg (dd);
g_free (widgets); mhl_mem_free (widgets);
return return_val; return return_val;
} }
@ -514,7 +516,7 @@ fg_input_dialog_help (const char *header, const char *text, const char *help,
Quick_input.widgets = quick_widgets; Quick_input.widgets = quick_widgets;
ret = quick_dialog (&Quick_input); ret = quick_dialog (&Quick_input);
g_free (p_text); mhl_mem_free (p_text);
if (ret != B_CANCEL) { if (ret != B_CANCEL) {
return my_str; return my_str;
@ -561,7 +563,7 @@ input_expand_dialog (const char *header, const char *text,
result = input_dialog (header, text, history_name, def_text); result = input_dialog (header, text, history_name, def_text);
if (result) { if (result) {
expanded = tilde_expand (result); expanded = tilde_expand (result);
g_free (result); mhl_mem_free (result);
return expanded; return expanded;
} }
return result; return result;

View File

@ -35,9 +35,10 @@ typedef int dummy; /* C99 forbids empty compilation unit */
#else #else
#include <setjmp.h> #include <setjmp.h>
#include <X11/Xlib.h> #include <X11/Xlib.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#ifdef HAVE_GMODULE #ifdef HAVE_GMODULE
@ -132,7 +133,7 @@ static gboolean x11_available(void)
if (x11_module == NULL) if (x11_module == NULL)
x11_module = g_module_open ("libX11.so.6", G_MODULE_BIND_LAZY); x11_module = g_module_open ("libX11.so.6", G_MODULE_BIND_LAZY);
g_free (x11_module_fname); mhl_mem_free (x11_module_fname);
if (x11_module == NULL) if (x11_module == NULL)
return FALSE; return FALSE;

View File

@ -19,8 +19,11 @@
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
#include <config.h> #include <config.h>
#include <errno.h> #include <errno.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -143,7 +146,7 @@ static void cpio_free_archive(struct vfs_class *me, struct vfs_s_super *super)
super->u.arch.fd = -1; super->u.arch.fd = -1;
for (l = super->u.arch.deferred; l; l = lnext) { for (l = super->u.arch.deferred; l; l = lnext) {
lnext = l->next; lnext = l->next;
g_free (l); mhl_mem_free (l);
} }
super->u.arch.deferred = NULL; super->u.arch.deferred = NULL;
} }
@ -174,10 +177,10 @@ cpio_open_cpio_file (struct vfs_class *me, struct vfs_s_super *super,
s = g_strconcat (name, decompress_extension (type), (char *) NULL); s = g_strconcat (name, decompress_extension (type), (char *) NULL);
if ((fd = mc_open (s, O_RDONLY)) == -1) { if ((fd = mc_open (s, O_RDONLY)) == -1) {
message (D_ERROR, MSG_ERROR, _("Cannot open cpio archive\n%s"), s); message (D_ERROR, MSG_ERROR, _("Cannot open cpio archive\n%s"), s);
g_free (s); mhl_mem_free (s);
return -1; return -1;
} }
g_free (s); mhl_mem_free (s);
} }
super->u.arch.fd = fd; super->u.arch.fd = fd;
@ -290,7 +293,7 @@ static ssize_t cpio_read_bin_head(struct vfs_class *me, struct vfs_s_super *supe
} }
name = g_malloc(u.buf.c_namesize); name = g_malloc(u.buf.c_namesize);
if((len = mc_read(super->u.arch.fd, name, u.buf.c_namesize)) < u.buf.c_namesize) { if((len = mc_read(super->u.arch.fd, name, u.buf.c_namesize)) < u.buf.c_namesize) {
g_free(name); mhl_mem_free(name);
return STATUS_EOF; return STATUS_EOF;
} }
name[u.buf.c_namesize - 1] = '\0'; name[u.buf.c_namesize - 1] = '\0';
@ -298,7 +301,7 @@ static ssize_t cpio_read_bin_head(struct vfs_class *me, struct vfs_s_super *supe
cpio_skip_padding(super); cpio_skip_padding(super);
if(!strcmp("TRAILER!!!", name)) { /* We got to the last record */ if(!strcmp("TRAILER!!!", name)) { /* We got to the last record */
g_free(name); mhl_mem_free(name);
return STATUS_TRAIL; return STATUS_TRAIL;
} }
@ -349,7 +352,7 @@ static ssize_t cpio_read_oldc_head(struct vfs_class *me, struct vfs_s_super *sup
name = g_malloc(hd.c_namesize); name = g_malloc(hd.c_namesize);
if((len = mc_read(super->u.arch.fd, name, hd.c_namesize)) == -1 || if((len = mc_read(super->u.arch.fd, name, hd.c_namesize)) == -1 ||
(unsigned long) len < hd.c_namesize) { (unsigned long) len < hd.c_namesize) {
g_free (name); mhl_mem_free (name);
return STATUS_EOF; return STATUS_EOF;
} }
name[hd.c_namesize - 1] = '\0'; name[hd.c_namesize - 1] = '\0';
@ -357,7 +360,7 @@ static ssize_t cpio_read_oldc_head(struct vfs_class *me, struct vfs_s_super *sup
cpio_skip_padding(super); cpio_skip_padding(super);
if(!strcmp("TRAILER!!!", name)) { /* We got to the last record */ if(!strcmp("TRAILER!!!", name)) { /* We got to the last record */
g_free(name); mhl_mem_free(name);
return STATUS_TRAIL; return STATUS_TRAIL;
} }
@ -414,7 +417,7 @@ static ssize_t cpio_read_crc_head(struct vfs_class *me, struct vfs_s_super *supe
name = g_malloc(hd.c_namesize); name = g_malloc(hd.c_namesize);
if((len = mc_read (super->u.arch.fd, name, hd.c_namesize)) == -1 || if((len = mc_read (super->u.arch.fd, name, hd.c_namesize)) == -1 ||
(unsigned long) len < hd.c_namesize) { (unsigned long) len < hd.c_namesize) {
g_free (name); mhl_mem_free (name);
return STATUS_EOF; return STATUS_EOF;
} }
name[hd.c_namesize - 1] = '\0'; name[hd.c_namesize - 1] = '\0';
@ -422,7 +425,7 @@ static ssize_t cpio_read_crc_head(struct vfs_class *me, struct vfs_s_super *supe
cpio_skip_padding(super); cpio_skip_padding(super);
if(!strcmp("TRAILER!!!", name)) { /* We got to the last record */ if(!strcmp("TRAILER!!!", name)) { /* We got to the last record */
g_free(name); mhl_mem_free(name);
return STATUS_TRAIL; return STATUS_TRAIL;
} }
@ -545,7 +548,7 @@ cpio_create_entry (struct vfs_class *me, struct vfs_s_super *super,
if (mc_read (super->u.arch.fd, inode->linkname, st->st_size) if (mc_read (super->u.arch.fd, inode->linkname, st->st_size)
< st->st_size) { < st->st_size) {
inode->linkname[0] = 0; inode->linkname[0] = 0;
g_free (name); mhl_mem_free (name);
return STATUS_EOF; return STATUS_EOF;
} }
inode->linkname[st->st_size] = 0; /* Linkname stored without terminating \0 !!! */ inode->linkname[st->st_size] = 0; /* Linkname stored without terminating \0 !!! */
@ -557,7 +560,7 @@ cpio_create_entry (struct vfs_class *me, struct vfs_s_super *super,
} /* !entry */ } /* !entry */
g_free (name); mhl_mem_free (name);
return STATUS_OK; return STATUS_OK;
} }

View File

@ -25,8 +25,11 @@
* archive/site is simply "". Beware. */ * archive/site is simply "". Beware. */
#include <config.h> #include <config.h>
#include <errno.h> #include <errno.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -95,14 +98,14 @@ vfs_s_free_inode (struct vfs_class *me, struct vfs_s_inode *ino)
} }
CALL (free_inode) (me, ino); CALL (free_inode) (me, ino);
g_free (ino->linkname); mhl_mem_free (ino->linkname);
if (ino->localname){ if (ino->localname){
unlink (ino->localname); unlink (ino->localname);
g_free(ino->localname); mhl_mem_free(ino->localname);
} }
total_inodes--; total_inodes--;
ino->super->ino_usage--; ino->super->ino_usage--;
g_free(ino); mhl_mem_free(ino);
} else ino->st.st_nlink--; } else ino->st.st_nlink--;
} }
@ -115,7 +118,7 @@ vfs_s_free_entry (struct vfs_class *me, struct vfs_s_entry *ent)
ent->next->prevp = ent->prevp; ent->next->prevp = ent->prevp;
} }
g_free (ent->name); mhl_mem_free (ent->name);
ent->name = NULL; ent->name = NULL;
if (ent->ino){ if (ent->ino){
@ -125,7 +128,7 @@ vfs_s_free_entry (struct vfs_class *me, struct vfs_s_entry *ent)
} }
total_entries--; total_entries--;
g_free(ent); mhl_mem_free(ent);
} }
void void
@ -227,14 +230,14 @@ vfs_s_resolve_symlink (struct vfs_class *me, struct vfs_s_entry *entry,
if (fullpath) { if (fullpath) {
fullname = g_strconcat (fullpath, "/", linkname, NULL); fullname = g_strconcat (fullpath, "/", linkname, NULL);
linkname = fullname; linkname = fullname;
g_free (fullpath); mhl_mem_free (fullpath);
} }
} }
target = target =
(MEDATA->find_entry) (me, entry->dir->super->root, linkname, (MEDATA->find_entry) (me, entry->dir->super->root, linkname,
follow - 1, 0); follow - 1, 0);
g_free (fullname); mhl_mem_free (fullname);
return target; return target;
} }
@ -258,7 +261,7 @@ vfs_s_find_entry_tree (struct vfs_class *me, struct vfs_s_inode *root,
path++; path++;
if (!path[0]) { if (!path[0]) {
g_free (pathref); mhl_mem_free (pathref);
return ent; return ent;
} }
@ -289,7 +292,7 @@ vfs_s_find_entry_tree (struct vfs_class *me, struct vfs_s_inode *root,
root = ent->ino; root = ent->ino;
} }
cleanup: cleanup:
g_free (pathref); mhl_mem_free (pathref);
return NULL; return NULL;
} }
@ -336,7 +339,7 @@ vfs_s_find_entry_linear (struct vfs_class *me, struct vfs_s_inode *root,
if (save) if (save)
*save = PATH_SEP; *save = PATH_SEP;
retval = vfs_s_find_entry_tree (me, ino, name, follow, flags); retval = vfs_s_find_entry_tree (me, ino, name, follow, flags);
g_free (path); mhl_mem_free (path);
return retval; return retval;
} }
@ -361,7 +364,7 @@ vfs_s_find_entry_linear (struct vfs_class *me, struct vfs_s_inode *root,
ent = vfs_s_new_entry (me, path, ino); ent = vfs_s_new_entry (me, path, ino);
if ((MEDATA->dir_load) (me, ino, path) == -1) { if ((MEDATA->dir_load) (me, ino, path) == -1) {
vfs_s_free_entry (me, ent); vfs_s_free_entry (me, ent);
g_free (path); mhl_mem_free (path);
return NULL; return NULL;
} }
vfs_s_insert_entry (me, root, ent); vfs_s_insert_entry (me, root, ent);
@ -375,11 +378,11 @@ vfs_s_find_entry_linear (struct vfs_class *me, struct vfs_s_inode *root,
#if 0 #if 0
if (!vfs_s_resolve_symlink (me, ent, follow)) { if (!vfs_s_resolve_symlink (me, ent, follow)) {
g_free (path); mhl_mem_free (path);
return NULL; return NULL;
} }
#endif #endif
g_free (path); mhl_mem_free (path);
return ent; return ent;
} }
@ -446,8 +449,8 @@ vfs_s_free_super (struct vfs_class *me, struct vfs_s_super *super)
} }
CALL (free_archive) (me, super); CALL (free_archive) (me, super);
g_free (super->name); mhl_mem_free (super->name);
g_free(super); mhl_mem_free(super);
} }
@ -521,7 +524,7 @@ vfs_s_get_path (struct vfs_class *me, const char *inname,
buf = g_strdup (inname); buf = g_strdup (inname);
retval = g_strdup (vfs_s_get_path_mangle (me, buf, archive, flags)); retval = g_strdup (vfs_s_get_path_mangle (me, buf, archive, flags));
g_free (buf); mhl_mem_free (buf);
return retval; return retval;
} }
@ -549,7 +552,7 @@ vfs_s_fullpath (struct vfs_class *me, struct vfs_s_inode *ino)
if (ino == ino->super->root) if (ino == ino->super->root)
break; break;
newpath = g_strconcat (ino->ent->name, "/", path, (char *) NULL); newpath = g_strconcat (ino->ent->name, "/", path, (char *) NULL);
g_free (path); mhl_mem_free (path);
path = newpath; path = newpath;
} }
return path; return path;
@ -587,7 +590,7 @@ vfs_s_inode_from_path (struct vfs_class *me, const char *name, int flags)
flags & FL_FOLLOW ? LINK_FOLLOW : flags & FL_FOLLOW ? LINK_FOLLOW :
LINK_NO_FOLLOW, LINK_NO_FOLLOW,
FL_DIR | (flags & ~FL_FOLLOW)); FL_DIR | (flags & ~FL_FOLLOW));
g_free (q); mhl_mem_free (q);
return ino; return ino;
} }
@ -648,7 +651,7 @@ vfs_s_closedir (void *data)
struct vfs_s_inode *dir = info->dir; struct vfs_s_inode *dir = info->dir;
vfs_s_free_inode (dir->super->me, dir); vfs_s_free_inode (dir->super->me, dir);
g_free (data); mhl_mem_free (data);
return 0; return 0;
} }
@ -731,7 +734,7 @@ vfs_s_open (struct vfs_class *me, const char *file, int flags, int mode)
return NULL; return NULL;
ino = vfs_s_find_inode (me, super, q, LINK_FOLLOW, FL_NONE); ino = vfs_s_find_inode (me, super, q, LINK_FOLLOW, FL_NONE);
if (ino && ((flags & (O_CREAT | O_EXCL)) == (O_CREAT | O_EXCL))) { if (ino && ((flags & (O_CREAT | O_EXCL)) == (O_CREAT | O_EXCL))) {
g_free (q); mhl_mem_free (q);
ERRNOR (EEXIST, NULL); ERRNOR (EEXIST, NULL);
} }
if (!ino) { if (!ino) {
@ -742,7 +745,7 @@ vfs_s_open (struct vfs_class *me, const char *file, int flags, int mode)
/* If the filesystem is read-only, disable file creation */ /* If the filesystem is read-only, disable file creation */
if (!(flags & O_CREAT) || !(me->write)) { if (!(flags & O_CREAT) || !(me->write)) {
g_free (q); mhl_mem_free (q);
return NULL; return NULL;
} }
@ -756,14 +759,14 @@ vfs_s_open (struct vfs_class *me, const char *file, int flags, int mode)
vfs_s_insert_entry (me, dir, ent); vfs_s_insert_entry (me, dir, ent);
tmp_handle = vfs_mkstemps (&ino->localname, me->name, name); tmp_handle = vfs_mkstemps (&ino->localname, me->name, name);
if (tmp_handle == -1) { if (tmp_handle == -1) {
g_free (q); mhl_mem_free (q);
return NULL; return NULL;
} }
close (tmp_handle); close (tmp_handle);
was_changed = 1; was_changed = 1;
} }
g_free (q); mhl_mem_free (q);
if (S_ISDIR (ino->st.st_mode)) if (S_ISDIR (ino->st.st_mode))
ERRNOR (EISDIR, NULL); ERRNOR (EISDIR, NULL);
@ -782,14 +785,14 @@ vfs_s_open (struct vfs_class *me, const char *file, int flags, int mode)
} }
} else if ((MEDATA->fh_open) } else if ((MEDATA->fh_open)
&& (MEDATA->fh_open (me, fh, flags, mode))) { && (MEDATA->fh_open (me, fh, flags, mode))) {
g_free (fh); mhl_mem_free (fh);
return NULL; return NULL;
} }
if (fh->ino->localname) { if (fh->ino->localname) {
fh->handle = open (fh->ino->localname, NO_LINEAR (flags), mode); fh->handle = open (fh->ino->localname, NO_LINEAR (flags), mode);
if (fh->handle == -1) { if (fh->handle == -1) {
g_free (fh); mhl_mem_free (fh);
ERRNOR (errno, NULL); ERRNOR (errno, NULL);
} }
} }
@ -898,7 +901,7 @@ vfs_s_close (void *fh)
res = -1; res = -1;
else { else {
res = MEDATA->file_store (me, fh, s, FH->ino->localname); res = MEDATA->file_store (me, fh, s, FH->ino->localname);
g_free (s); mhl_mem_free (s);
} }
vfs_s_invalidate (me, FH_SUPER); vfs_s_invalidate (me, FH_SUPER);
} }
@ -906,7 +909,7 @@ vfs_s_close (void *fh)
close (FH->handle); close (FH->handle);
vfs_s_free_inode (me, FH->ino); vfs_s_free_inode (me, FH->ino);
g_free (fh); mhl_mem_free (fh);
return res; return res;
} }
@ -992,7 +995,7 @@ vfs_s_retrieve_file (struct vfs_class *me, struct vfs_s_inode *ino)
close (handle); close (handle);
unlink (ino->localname); unlink (ino->localname);
error_4: error_4:
g_free (ino->localname); mhl_mem_free (ino->localname);
ino->localname = NULL; ino->localname = NULL;
return -1; return -1;
} }
@ -1008,7 +1011,7 @@ vfs_s_fill_names (struct vfs_class *me, fill_names_f func)
while (a){ while (a){
name = g_strconcat ( a->name, "#", me->prefix, "/", /* a->current_dir->name, */ NULL); name = g_strconcat ( a->name, "#", me->prefix, "/", /* a->current_dir->name, */ NULL);
(*func)(name); (*func)(name);
g_free (name); mhl_mem_free (name);
a = a->next; a = a->next;
} }
} }
@ -1092,7 +1095,7 @@ vfs_s_getid (struct vfs_class *me, const char *path)
if (!(p = vfs_s_get_path (me, path, &archive, FL_NO_OPEN))) if (!(p = vfs_s_get_path (me, path, &archive, FL_NO_OPEN)))
return NULL; return NULL;
g_free(p); mhl_mem_free(p);
return (vfsid) archive; return (vfsid) archive;
} }

View File

@ -35,6 +35,9 @@
#include <sys/wait.h> #include <sys/wait.h>
#endif #endif
#include <errno.h> #include <errno.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -122,7 +125,7 @@ extfs_fill_names (struct vfs_class *me, fill_names_f func)
g_strconcat (a->name ? a->name : "", "#", g_strconcat (a->name ? a->name : "", "#",
extfs_prefixes[a->fstype], (char *) NULL); extfs_prefixes[a->fstype], (char *) NULL);
(*func) (name); (*func) (name);
g_free (name); mhl_mem_free (name);
a = a->next; a = a->next;
} }
} }
@ -215,10 +218,10 @@ static void extfs_free_archive (struct archive *archive)
mc_stat (archive->local_name, &my); mc_stat (archive->local_name, &my);
mc_ungetlocalcopy (archive->name, archive->local_name, mc_ungetlocalcopy (archive->name, archive->local_name,
archive->local_stat.st_mtime != my.st_mtime); archive->local_stat.st_mtime != my.st_mtime);
g_free(archive->local_name); mhl_mem_free(archive->local_name);
} }
g_free (archive->name); mhl_mem_free (archive->name);
g_free (archive); mhl_mem_free (archive);
} }
static FILE * static FILE *
@ -250,16 +253,16 @@ extfs_open_archive (int fstype, const char *name, struct archive **pparc)
cmd = cmd =
g_strconcat (mc_extfsdir, extfs_prefixes[fstype], " list ", g_strconcat (mc_extfsdir, extfs_prefixes[fstype], " list ",
local_name ? local_name : tmp, (char *) NULL); local_name ? local_name : tmp, (char *) NULL);
g_free (tmp); mhl_mem_free (tmp);
g_free (mc_extfsdir); mhl_mem_free (mc_extfsdir);
open_error_pipe (); open_error_pipe ();
result = popen (cmd, "r"); result = popen (cmd, "r");
g_free (cmd); mhl_mem_free (cmd);
if (result == NULL) { if (result == NULL) {
close_error_pipe (D_ERROR, NULL); close_error_pipe (D_ERROR, NULL);
if (local_name) { if (local_name) {
mc_ungetlocalcopy (name, local_name, 0); mc_ungetlocalcopy (name, local_name, 0);
g_free(local_name); mhl_mem_free(local_name);
} }
return NULL; return NULL;
} }
@ -352,7 +355,7 @@ extfs_read_archive (int fstype, const char *name, struct archive **pparc)
0); 0);
if (pent == NULL) { if (pent == NULL) {
/* FIXME: Should clean everything one day */ /* FIXME: Should clean everything one day */
g_free (buffer); mhl_mem_free (buffer);
pclose (extfsd); pclose (extfsd);
close_error_pipe (D_ERROR, _("Inconsistent extfs archive")); close_error_pipe (D_ERROR, _("Inconsistent extfs archive"));
return -1; return -1;
@ -371,7 +374,7 @@ extfs_read_archive (int fstype, const char *name, struct archive **pparc)
current_link_name, 0, 0); current_link_name, 0, 0);
if (pent == NULL) { if (pent == NULL) {
/* FIXME: Should clean everything one day */ /* FIXME: Should clean everything one day */
g_free (buffer); mhl_mem_free (buffer);
pclose (extfsd); pclose (extfsd);
close_error_pipe (D_ERROR, close_error_pipe (D_ERROR,
_("Inconsistent extfs archive")); _("Inconsistent extfs archive"));
@ -416,11 +419,11 @@ extfs_read_archive (int fstype, const char *name, struct archive **pparc)
} }
} }
read_extfs_continue: read_extfs_continue:
g_free (current_file_name); mhl_mem_free (current_file_name);
g_free (current_link_name); mhl_mem_free (current_link_name);
} }
} }
g_free (buffer); mhl_mem_free (buffer);
/* Check if extfs 'list' returned 0 */ /* Check if extfs 'list' returned 0 */
if (pclose (extfsd) != 0) { if (pclose (extfsd) != 0) {
@ -495,7 +498,7 @@ extfs_get_path (struct vfs_class *me, const char *inname, struct archive **archi
char *res2 = NULL; char *res2 = NULL;
if (res) if (res)
res2 = g_strdup (res); res2 = g_strdup (res);
g_free (buf); mhl_mem_free (buf);
return res2; return res2;
} }
@ -529,7 +532,7 @@ static char *extfs_get_path_from_entry (struct entry *entry)
strcat (localpath, "/"); strcat (localpath, "/");
p = head; p = head;
head = head->next; head = head->next;
g_free (p); mhl_mem_free (p);
} }
return (localpath); return (localpath);
} }
@ -564,7 +567,7 @@ extfs_resolve_symlinks_int (struct entry *entry,
looping->entry = entry; looping->entry = entry;
looping->next = list; looping->next = list;
pent = extfs_find_entry_int (entry->dir, entry->inode->linkname, looping, 0, 0); pent = extfs_find_entry_int (entry->dir, entry->inode->linkname, looping, 0, 0);
g_free (looping); mhl_mem_free (looping);
if (pent == NULL) if (pent == NULL)
my_errno = ENOENT; my_errno = ENOENT;
return pent; return pent;
@ -617,7 +620,7 @@ extfs_cmd (const char *extfs_cmd, struct archive *archive,
file = extfs_get_path_from_entry (entry); file = extfs_get_path_from_entry (entry);
quoted_file = name_quote (file, 0); quoted_file = name_quote (file, 0);
g_free (file); mhl_mem_free (file);
archive_name = name_quote (extfs_get_archive_name (archive), 0); archive_name = name_quote (extfs_get_archive_name (archive), 0);
quoted_localname = name_quote (localname, 0); quoted_localname = name_quote (localname, 0);
@ -625,14 +628,14 @@ extfs_cmd (const char *extfs_cmd, struct archive *archive,
cmd = g_strconcat (mc_extfsdir, extfs_prefixes[archive->fstype], cmd = g_strconcat (mc_extfsdir, extfs_prefixes[archive->fstype],
extfs_cmd, archive_name, " ", quoted_file, " ", extfs_cmd, archive_name, " ", quoted_file, " ",
quoted_localname, (char *) NULL); quoted_localname, (char *) NULL);
g_free (quoted_file); mhl_mem_free (quoted_file);
g_free (quoted_localname); mhl_mem_free (quoted_localname);
g_free (mc_extfsdir); mhl_mem_free (mc_extfsdir);
g_free (archive_name); mhl_mem_free (archive_name);
open_error_pipe (); open_error_pipe ();
retval = my_system (EXECUTE_AS_SHELL, shell, cmd); retval = my_system (EXECUTE_AS_SHELL, shell, cmd);
g_free (cmd); mhl_mem_free (cmd);
close_error_pipe (D_ERROR, NULL); close_error_pipe (D_ERROR, NULL);
return retval; return retval;
} }
@ -647,17 +650,17 @@ extfs_run (struct vfs_class *me, const char *file)
if ((p = extfs_get_path (me, file, &archive, 0)) == NULL) if ((p = extfs_get_path (me, file, &archive, 0)) == NULL)
return; return;
q = name_quote (p, 0); q = name_quote (p, 0);
g_free (p); mhl_mem_free (p);
archive_name = name_quote (extfs_get_archive_name (archive), 0); archive_name = name_quote (extfs_get_archive_name (archive), 0);
mc_extfsdir = concat_dir_and_file (mc_home, "extfs" PATH_SEP_STR); mc_extfsdir = concat_dir_and_file (mc_home, "extfs" PATH_SEP_STR);
cmd = g_strconcat (mc_extfsdir, extfs_prefixes[archive->fstype], cmd = g_strconcat (mc_extfsdir, extfs_prefixes[archive->fstype],
" run ", archive_name, " ", q, (char *) NULL); " run ", archive_name, " ", q, (char *) NULL);
g_free (mc_extfsdir); mhl_mem_free (mc_extfsdir);
g_free (archive_name); mhl_mem_free (archive_name);
g_free (q); mhl_mem_free (q);
shell_execute (cmd, 0); shell_execute (cmd, 0);
g_free (cmd); mhl_mem_free (cmd);
} }
static void * static void *
@ -679,7 +682,7 @@ extfs_open (struct vfs_class *me, const char *file, int flags, int mode)
created = (entry != NULL); created = (entry != NULL);
} }
g_free (q); mhl_mem_free (q);
if (entry == NULL) if (entry == NULL)
return NULL; return NULL;
if ((entry = extfs_resolve_symlinks (entry)) == NULL) if ((entry = extfs_resolve_symlinks (entry)) == NULL)
@ -762,7 +765,7 @@ extfs_close (void *data)
if (!file->archive->fd_usage) if (!file->archive->fd_usage)
vfs_stamp_create (&vfs_extfs_ops, file->archive); vfs_stamp_create (&vfs_extfs_ops, file->archive);
g_free (data); mhl_mem_free (data);
if (errno_code) if (errno_code)
ERRNOR (EIO, -1); ERRNOR (EIO, -1);
return 0; return 0;
@ -878,7 +881,7 @@ static void * extfs_opendir (struct vfs_class *me, const char *dirname)
if ((q = extfs_get_path (me, dirname, &archive, 0)) == NULL) if ((q = extfs_get_path (me, dirname, &archive, 0)) == NULL)
return NULL; return NULL;
entry = extfs_find_entry (archive->root_entry, q, 0, 0); entry = extfs_find_entry (archive->root_entry, q, 0, 0);
g_free (q); mhl_mem_free (q);
if (entry == NULL) if (entry == NULL)
return NULL; return NULL;
if ((entry = extfs_resolve_symlinks (entry)) == NULL) if ((entry = extfs_resolve_symlinks (entry)) == NULL)
@ -910,7 +913,7 @@ static void * extfs_readdir(void *data)
static int extfs_closedir (void *data) static int extfs_closedir (void *data)
{ {
g_free (data); mhl_mem_free (data);
return 0; return 0;
} }
@ -957,7 +960,7 @@ extfs_internal_stat (struct vfs_class *me, const char *path, struct stat *buf,
extfs_stat_move (buf, entry->inode); extfs_stat_move (buf, entry->inode);
result = 0; result = 0;
cleanup: cleanup:
g_free (path2); mhl_mem_free (path2);
return result; return result;
} }
@ -1004,7 +1007,7 @@ extfs_readlink (struct vfs_class *me, const char *path, char *buf, size_t size)
/* readlink() does not append a NUL character to buf */ /* readlink() does not append a NUL character to buf */
memcpy (buf, entry->inode->linkname, result = len); memcpy (buf, entry->inode->linkname, result = len);
cleanup: cleanup:
g_free (mpath); mhl_mem_free (mpath);
return result; return result;
} }
@ -1049,7 +1052,7 @@ static int extfs_unlink (struct vfs_class *me, const char *file)
extfs_remove_entry (entry); extfs_remove_entry (entry);
result = 0; result = 0;
cleanup: cleanup:
g_free (mpath); mhl_mem_free (mpath);
return result; return result;
} }
@ -1086,7 +1089,7 @@ static int extfs_mkdir (struct vfs_class *me, const char *path, mode_t mode)
} }
result = 0; result = 0;
cleanup: cleanup:
g_free (mpath); mhl_mem_free (mpath);
return result; return result;
} }
@ -1116,7 +1119,7 @@ static int extfs_rmdir (struct vfs_class *me, const char *path)
extfs_remove_entry (entry); extfs_remove_entry (entry);
result = 0; result = 0;
cleanup: cleanup:
g_free (mpath); mhl_mem_free (mpath);
return result; return result;
} }
@ -1131,7 +1134,7 @@ extfs_chdir (struct vfs_class *me, const char *path)
if ((q = extfs_get_path (me, path, &archive, 0)) == NULL) if ((q = extfs_get_path (me, path, &archive, 0)) == NULL)
return -1; return -1;
entry = extfs_find_entry (archive->root_entry, q, 0, 0); entry = extfs_find_entry (archive->root_entry, q, 0, 0);
g_free (q); mhl_mem_free (q);
if (!entry) if (!entry)
return -1; return -1;
entry = extfs_resolve_symlinks (entry); entry = extfs_resolve_symlinks (entry);
@ -1156,7 +1159,7 @@ extfs_getid (struct vfs_class *me, const char *path)
if (!(p = extfs_get_path (me, path, &archive, 1))) if (!(p = extfs_get_path (me, path, &archive, 1)))
return NULL; return NULL;
g_free (p); mhl_mem_free (p);
return (vfsid) archive; return (vfsid) archive;
} }
@ -1198,12 +1201,12 @@ static void extfs_remove_entry (struct entry *e)
unlink (e->inode->local_filename); unlink (e->inode->local_filename);
free (e->inode->local_filename); free (e->inode->local_filename);
} }
g_free (e->inode->linkname); mhl_mem_free (e->inode->linkname);
g_free (e->inode); mhl_mem_free (e->inode);
} }
g_free (e->name); mhl_mem_free (e->name);
g_free (e); mhl_mem_free (e);
} }
static void extfs_free_entry (struct entry *e) static void extfs_free_entry (struct entry *e)
@ -1220,13 +1223,13 @@ static void extfs_free_entry (struct entry *e)
unlink (e->inode->local_filename); unlink (e->inode->local_filename);
free (e->inode->local_filename); free (e->inode->local_filename);
} }
g_free (e->inode->linkname); mhl_mem_free (e->inode->linkname);
g_free (e->inode); mhl_mem_free (e->inode);
} }
if (e->next_in_dir != NULL) if (e->next_in_dir != NULL)
extfs_free_entry (e->next_in_dir); extfs_free_entry (e->next_in_dir);
g_free (e->name); mhl_mem_free (e->name);
g_free (e); mhl_mem_free (e);
} }
static void extfs_free (vfsid id) static void extfs_free (vfsid id)
@ -1303,7 +1306,7 @@ static int extfs_init (struct vfs_class *me)
* appear on screen. */ * appear on screen. */
if (!cfg) { if (!cfg) {
fprintf (stderr, _("Warning: file %s not found\n"), mc_extfsini); fprintf (stderr, _("Warning: file %s not found\n"), mc_extfsini);
g_free (mc_extfsini); mhl_mem_free (mc_extfsini);
return 0; return 0;
} }
@ -1319,7 +1322,7 @@ static int extfs_init (struct vfs_class *me)
fprintf(stderr, "Warning: You need to update your %s file.\n", fprintf(stderr, "Warning: You need to update your %s file.\n",
mc_extfsini); mc_extfsini);
fclose(cfg); fclose(cfg);
g_free (mc_extfsini); mhl_mem_free (mc_extfsini);
return 0; return 0;
} }
if (*key == '#' || *key == '\n') if (*key == '#' || *key == '\n')
@ -1339,7 +1342,7 @@ static int extfs_init (struct vfs_class *me)
extfs_prefixes [extfs_no++] = g_strdup (key); extfs_prefixes [extfs_no++] = g_strdup (key);
} }
fclose(cfg); fclose(cfg);
g_free (mc_extfsini); mhl_mem_free (mc_extfsini);
return 1; return 1;
} }
@ -1368,7 +1371,7 @@ static void extfs_done (struct vfs_class *me)
} }
for (i = 0; i < extfs_no; i++ ) for (i = 0; i < extfs_no; i++ )
g_free (extfs_prefixes [i]); mhl_mem_free (extfs_prefixes [i]);
extfs_no = 0; extfs_no = 0;
} }

View File

@ -144,7 +144,7 @@ fish_command (struct vfs_class *me, struct vfs_s_super *super,
enable_interrupt_key (); enable_interrupt_key ();
status = write (SUP.sockw, str, strlen (str)); status = write (SUP.sockw, str, strlen (str));
g_free (str); mhl_mem_free (str);
disable_interrupt_key (); disable_interrupt_key ();
if (status < 0) if (status < 0)
@ -168,10 +168,10 @@ fish_free_archive (struct vfs_class *me, struct vfs_s_super *super)
close (SUP.sockr); close (SUP.sockr);
SUP.sockw = SUP.sockr = -1; SUP.sockw = SUP.sockr = -1;
} }
g_free (SUP.host); mhl_mem_free (SUP.host);
g_free (SUP.user); mhl_mem_free (SUP.user);
g_free (SUP.cwdir); mhl_mem_free (SUP.cwdir);
g_free (SUP.password); mhl_mem_free (SUP.password);
} }
static void static void
@ -251,7 +251,7 @@ fish_open_archive_int (struct vfs_class *me, struct vfs_s_super *super)
p = g_strconcat (_(" fish: Password required for "), p = g_strconcat (_(" fish: Password required for "),
SUP.user, " ", (char *) NULL); SUP.user, " ", (char *) NULL);
op = vfs_get_password (p); op = vfs_get_password (p);
g_free (p); mhl_mem_free (p);
if (op == NULL) if (op == NULL)
ERRNOR (EPERM, -1); ERRNOR (EPERM, -1);
SUP.password = op; SUP.password = op;
@ -314,7 +314,7 @@ fish_open_archive (struct vfs_class *me, struct vfs_s_super *super,
p = vfs_split_url (strchr (op, ':') + 1, &host, &user, &flags, p = vfs_split_url (strchr (op, ':') + 1, &host, &user, &flags,
&password, 0, URL_NOSLASH); &password, 0, URL_NOSLASH);
g_free (p); mhl_mem_free (p);
SUP.host = host; SUP.host = host;
SUP.user = user; SUP.user = user;
@ -341,12 +341,12 @@ fish_archive_same (struct vfs_class *me, struct vfs_s_super *super,
op = vfs_split_url (strchr (op, ':') + 1, &host, &user, &flags, 0, 0, op = vfs_split_url (strchr (op, ':') + 1, &host, &user, &flags, 0, 0,
URL_NOSLASH); URL_NOSLASH);
g_free (op); mhl_mem_free (op);
flags = ((strcmp (host, SUP.host) == 0) flags = ((strcmp (host, SUP.host) == 0)
&& (strcmp (user, SUP.user) == 0) && (flags == SUP.flags)); && (strcmp (user, SUP.user) == 0) && (flags == SUP.flags));
g_free (host); mhl_mem_free (host);
g_free (user); mhl_mem_free (user);
return flags; return flags;
} }
@ -585,7 +585,7 @@ fish_dir_load(struct vfs_class *me, struct vfs_s_inode *dir, char *remote_path)
vfs_s_free_entry (me, ent); vfs_s_free_entry (me, ent);
reply_code = fish_decode_reply(buffer + 4, 0); reply_code = fish_decode_reply(buffer + 4, 0);
if (reply_code == COMPLETE) { if (reply_code == COMPLETE) {
g_free (SUP.cwdir); mhl_mem_free (SUP.cwdir);
SUP.cwdir = g_strdup (remote_path); SUP.cwdir = g_strdup (remote_path);
print_vfs_message (_("%s: done."), me->name); print_vfs_message (_("%s: done."), me->name);
return 0; return 0;
@ -771,7 +771,7 @@ fish_linear_start (struct vfs_class *me, struct vfs_s_fh *fh, off_t offset)
"echo '### 500'\n" "echo '### 500'\n"
"fi\n", "fi\n",
quoted_name, quoted_name, quoted_name, quoted_name ); quoted_name, quoted_name, quoted_name, quoted_name );
g_free (quoted_name); mhl_mem_free (quoted_name);
if (offset != PRELIM) ERRNOR (E_REMOTE, 0); if (offset != PRELIM) ERRNOR (E_REMOTE, 0);
fh->linear = LS_LINEAR_OPEN; fh->linear = LS_LINEAR_OPEN;
fh->u.fish.got = 0; fh->u.fish.got = 0;
@ -883,14 +883,14 @@ fish_send_command(struct vfs_class *me, struct vfs_s_super *super, const char *c
char *rpath, *mpath = g_strdup (path); \ char *rpath, *mpath = g_strdup (path); \
struct vfs_s_super *super; \ struct vfs_s_super *super; \
if (!(crpath = vfs_s_get_path_mangle (me, mpath, &super, 0))) { \ if (!(crpath = vfs_s_get_path_mangle (me, mpath, &super, 0))) { \
g_free (mpath); \ mhl_mem_free (mpath); \
return -1; \ return -1; \
} \ } \
rpath = mhl_shell_escape_dup(crpath); \ rpath = mhl_shell_escape_dup(crpath); \
g_free (mpath); mhl_mem_free (mpath);
#define POSTFIX(flags) \ #define POSTFIX(flags) \
g_free (rpath); \ mhl_mem_free (rpath); \
return fish_send_command(me, super, buf, flags); return fish_send_command(me, super, buf, flags);
static int static int
@ -913,18 +913,18 @@ static int fish_##name (struct vfs_class *me, const char *path1, const char *pat
char *rpath1, *rpath2, *mpath1, *mpath2; \ char *rpath1, *rpath2, *mpath1, *mpath2; \
struct vfs_s_super *super1, *super2; \ struct vfs_s_super *super1, *super2; \
if (!(crpath1 = vfs_s_get_path_mangle (me, mpath1 = g_strdup(path1), &super1, 0))) { \ if (!(crpath1 = vfs_s_get_path_mangle (me, mpath1 = g_strdup(path1), &super1, 0))) { \
g_free (mpath1); \ mhl_mem_free (mpath1); \
return -1; \ return -1; \
} \ } \
if (!(crpath2 = vfs_s_get_path_mangle (me, mpath2 = g_strdup(path2), &super2, 0))) { \ if (!(crpath2 = vfs_s_get_path_mangle (me, mpath2 = g_strdup(path2), &super2, 0))) { \
g_free (mpath1); \ mhl_mem_free (mpath1); \
g_free (mpath2); \ mhl_mem_free (mpath2); \
return -1; \ return -1; \
} \ } \
rpath1 = mhl_shell_escape_dup (crpath1); \ rpath1 = mhl_shell_escape_dup (crpath1); \
g_free (mpath1); \ mhl_mem_free (mpath1); \
rpath2 = mhl_shell_escape_dup (crpath2); \ rpath2 = mhl_shell_escape_dup (crpath2); \
g_free (mpath2); \ mhl_mem_free (mpath2); \
g_snprintf(buf, sizeof(buf), string "\n", rpath1, rpath2, rpath1, rpath2); \ g_snprintf(buf, sizeof(buf), string "\n", rpath1, rpath2, rpath1, rpath2); \
mhl_mem_free (rpath1); \ mhl_mem_free (rpath1); \
mhl_mem_free (rpath2); \ mhl_mem_free (rpath2); \
@ -1078,7 +1078,7 @@ fish_fill_names (struct vfs_class *me, fill_names_f func)
name = g_strconcat ("/#sh:", SUP.user, "@", SUP.host, flags, name = g_strconcat ("/#sh:", SUP.user, "@", SUP.host, flags,
"/", SUP.cwdir, (char *) NULL); "/", SUP.cwdir, (char *) NULL);
(*func)(name); (*func)(name);
g_free (name); mhl_mem_free (name);
super = super->next; super = super->next;
} }
} }

View File

@ -45,7 +45,7 @@ What to do with this?
if (f || !strncmp( remote_path, "/~/", 3 )) { if (f || !strncmp( remote_path, "/~/", 3 )) {
char *s; char *s;
s = concat_dir_and_file( qhome (*bucket), remote_path +3-f ); s = concat_dir_and_file( qhome (*bucket), remote_path +3-f );
g_free (remote_path); mhl_mem_free (remote_path);
remote_path = s; remote_path = s;
} }
} }
@ -56,6 +56,7 @@ What to do with this?
/* Namespace pollution: horrible */ /* Namespace pollution: horrible */
#include <config.h> #include <config.h>
#include <sys/types.h> /* POSIX-required by sys/socket.h and netdb.h */ #include <sys/types.h> /* POSIX-required by sys/socket.h and netdb.h */
#include <netdb.h> /* struct hostent */ #include <netdb.h> /* struct hostent */
#include <sys/socket.h> /* AF_INET */ #include <sys/socket.h> /* AF_INET */
@ -69,6 +70,8 @@ What to do with this?
#include <errno.h> #include <errno.h>
#include <ctype.h> #include <ctype.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -244,14 +247,14 @@ ftpfs_split_url(char *path, char **host, char **user, int *port, char **pass)
/* If user is different, remove password */ /* If user is different, remove password */
if (new_user && strcmp (*user, new_user)) { if (new_user && strcmp (*user, new_user)) {
g_free (*pass); mhl_mem_free (*pass);
*pass = NULL; *pass = NULL;
} }
g_free (new_user); mhl_mem_free (new_user);
} }
g_free (p); mhl_mem_free (p);
} }
/* Returns a reply code, check /usr/include/arpa/ftp.h for possible values */ /* Returns a reply code, check /usr/include/arpa/ftp.h for possible values */
@ -308,7 +311,7 @@ ftpfs_reconnect (struct vfs_class *me, struct vfs_s_super *super)
if (!cwdir) if (!cwdir)
return 1; return 1;
sock = ftpfs_chdir_internal (me, super, cwdir); sock = ftpfs_chdir_internal (me, super, cwdir);
g_free (cwdir); mhl_mem_free (cwdir);
return sock == COMPLETE; return sock == COMPLETE;
} }
SUP.cwdir = cwdir; SUP.cwdir = cwdir;
@ -362,7 +365,7 @@ ftpfs_command (struct vfs_class *me, struct vfs_s_super *super, int wait_reply,
} }
got_sigpipe = 1; got_sigpipe = 1;
} }
g_free (cmdstr); mhl_mem_free (cmdstr);
disable_interrupt_key (); disable_interrupt_key ();
return TRANSIENT; return TRANSIENT;
} }
@ -386,10 +389,10 @@ ftpfs_command (struct vfs_class *me, struct vfs_s_super *super, int wait_reply,
} }
} }
retry = 0; retry = 0;
g_free (cmdstr); mhl_mem_free (cmdstr);
return status; return status;
} }
g_free (cmdstr); mhl_mem_free (cmdstr);
return COMPLETE; return COMPLETE;
} }
@ -401,10 +404,10 @@ ftpfs_free_archive (struct vfs_class *me, struct vfs_s_super *super)
ftpfs_command(me, super, NONE, "QUIT"); ftpfs_command(me, super, NONE, "QUIT");
close(SUP.sock); close(SUP.sock);
} }
g_free (SUP.host); mhl_mem_free (SUP.host);
g_free (SUP.user); mhl_mem_free (SUP.user);
g_free (SUP.cwdir); mhl_mem_free (SUP.cwdir);
g_free (SUP.password); mhl_mem_free (SUP.password);
} }
/* some defines only used by ftpfs_changetype */ /* some defines only used by ftpfs_changetype */
@ -455,7 +458,7 @@ ftpfs_login_server (struct vfs_class *me, struct vfs_s_super *super,
p = g_strconcat (_(" FTP: Password required for "), SUP.user, " ", p = g_strconcat (_(" FTP: Password required for "), SUP.user, " ",
NULL); NULL);
op = vfs_get_password (p); op = vfs_get_password (p);
g_free (p); mhl_mem_free (p);
if (op == NULL) if (op == NULL)
ERRNOR (EPERM, 0); ERRNOR (EPERM, 0);
SUP.password = g_strdup (op); SUP.password = g_strdup (op);
@ -501,13 +504,13 @@ ftpfs_login_server (struct vfs_class *me, struct vfs_s_super *super,
("FTP: Account required for user %s"), ("FTP: Account required for user %s"),
SUP.user); SUP.user);
op = input_dialog (p, _("Account:"), MC_HISTORY_FTPFS_ACCOUNT, ""); op = input_dialog (p, _("Account:"), MC_HISTORY_FTPFS_ACCOUNT, "");
g_free (p); mhl_mem_free (p);
if (op == NULL) if (op == NULL)
ERRNOR (EPERM, 0); ERRNOR (EPERM, 0);
print_vfs_message (_("ftpfs: sending user account")); print_vfs_message (_("ftpfs: sending user account"));
code = code =
ftpfs_command (me, super, WAIT_REPLY, "ACCT %s", op); ftpfs_command (me, super, WAIT_REPLY, "ACCT %s", op);
g_free (op); mhl_mem_free (op);
} }
if (code != COMPLETE) if (code != COMPLETE)
break; break;
@ -516,7 +519,7 @@ ftpfs_login_server (struct vfs_class *me, struct vfs_s_super *super,
case COMPLETE: case COMPLETE:
print_vfs_message (_("ftpfs: logged in")); print_vfs_message (_("ftpfs: logged in"));
wipe_password (pass); wipe_password (pass);
g_free (name); mhl_mem_free (name);
return 1; return 1;
default: default:
@ -532,7 +535,7 @@ ftpfs_login_server (struct vfs_class *me, struct vfs_s_super *super,
SUP.user); SUP.user);
login_fail: login_fail:
wipe_password (pass); wipe_password (pass);
g_free (name); mhl_mem_free (name);
ERRNOR (EPERM, 0); ERRNOR (EPERM, 0);
} }
@ -582,7 +585,7 @@ ftpfs_load_no_proxy_list (void)
fclose (npf); fclose (npf);
} }
g_free (mc_file); mhl_mem_free (mc_file);
} }
/* Return 1 if FTP proxy should be used for this host, 0 otherwise */ /* Return 1 if FTP proxy should be used for this host, 0 otherwise */
@ -634,8 +637,8 @@ ftpfs_get_proxy_host_and_port (const char *proxy, char **host, int *port)
dir = dir =
vfs_split_url (proxy, host, &user, port, 0, FTP_COMMAND_PORT, vfs_split_url (proxy, host, &user, port, 0, FTP_COMMAND_PORT,
URL_ALLOW_ANON); URL_ALLOW_ANON);
g_free (user); mhl_mem_free (user);
g_free (dir); mhl_mem_free (dir);
} }
static int static int
@ -678,7 +681,7 @@ ftpfs_open_socket (struct vfs_class *me, struct vfs_s_super *super)
print_vfs_message (_("ftpfs: Invalid host address.")); print_vfs_message (_("ftpfs: Invalid host address."));
ftpfs_errno = EINVAL; ftpfs_errno = EINVAL;
if (free_host) if (free_host)
g_free (host); mhl_mem_free (host);
return -1; return -1;
} }
server_address.sin_family = hp->h_addrtype; server_address.sin_family = hp->h_addrtype;
@ -694,13 +697,13 @@ ftpfs_open_socket (struct vfs_class *me, struct vfs_s_super *super)
disable_interrupt_key(); disable_interrupt_key();
ftpfs_errno = errno; ftpfs_errno = errno;
if (free_host) if (free_host)
g_free (host); mhl_mem_free (host);
return -1; return -1;
} }
print_vfs_message (_("ftpfs: making connection to %s"), host); print_vfs_message (_("ftpfs: making connection to %s"), host);
if (free_host) if (free_host)
g_free (host); mhl_mem_free (host);
if (connect (my_socket, (struct sockaddr *) &server_address, if (connect (my_socket, (struct sockaddr *) &server_address,
sizeof (server_address)) < 0){ sizeof (server_address)) < 0){
@ -815,8 +818,8 @@ ftpfs_archive_same (struct vfs_class *me, struct vfs_s_super *super,
port = ((strcmp (host, SUP.host) == 0) port = ((strcmp (host, SUP.host) == 0)
&& (strcmp (user, SUP.user) == 0) && (port == SUP.port)); && (strcmp (user, SUP.user) == 0) && (port == SUP.port));
g_free (host); mhl_mem_free (host);
g_free (user); mhl_mem_free (user);
return port; return port;
} }
@ -967,7 +970,7 @@ ftpfs_open_data_connection (struct vfs_class *me, struct vfs_s_super *super, con
j = ftpfs_command (me, super, WAIT_REPLY, "%s /%s", cmd, j = ftpfs_command (me, super, WAIT_REPLY, "%s /%s", cmd,
/* WarFtpD can't STORE //filename */ /* WarFtpD can't STORE //filename */
(*remote_path == '/') ? remote_path + 1 : remote_path); (*remote_path == '/') ? remote_path + 1 : remote_path);
g_free (remote_path); mhl_mem_free (remote_path);
} else } else
j = ftpfs_command (me, super, WAIT_REPLY, "%s", cmd); j = ftpfs_command (me, super, WAIT_REPLY, "%s", cmd);
if (j != PRELIM) if (j != PRELIM)
@ -1153,7 +1156,7 @@ resolve_symlink_with_ls_options(struct vfs_class *me, struct vfs_s_super *super,
vfs_die("This code should be commented out\n"); vfs_die("This code should be commented out\n");
if (vfs_parse_ls_lga (buffer, &s, &filename, NULL)) { if (vfs_parse_ls_lga (buffer, &s, &filename, NULL)) {
int r = strcmp(fe->name, filename); int r = strcmp(fe->name, filename);
g_free(filename); mhl_mem_free(filename);
if (r == 0) { if (r == 0) {
if (S_ISLNK (s.st_mode)) { if (S_ISLNK (s.st_mode)) {
/* This server doesn't understand LIST -lLa */ /* This server doesn't understand LIST -lLa */
@ -1234,7 +1237,7 @@ ftpfs_dir_load (struct vfs_class *me, struct vfs_s_inode *dir, char *remote_path
sock = sock =
ftpfs_open_data_connection (me, super, "LIST -la", path, TYPE_ASCII, ftpfs_open_data_connection (me, super, "LIST -la", path, TYPE_ASCII,
0); 0);
g_free (path); mhl_mem_free (path);
} }
if (sock == -1) if (sock == -1)
@ -1407,7 +1410,7 @@ ftpfs_linear_start (struct vfs_class *me, struct vfs_s_fh *fh, off_t offset)
if (!name) if (!name)
return 0; return 0;
FH_SOCK = ftpfs_open_data_connection(me, FH_SUPER, "RETR", name, TYPE_BINARY, offset); FH_SOCK = ftpfs_open_data_connection(me, FH_SUPER, "RETR", name, TYPE_BINARY, offset);
g_free (name); mhl_mem_free (name);
if (FH_SOCK == -1) if (FH_SOCK == -1)
ERRNOR (EACCES, 0); ERRNOR (EACCES, 0);
fh->linear = LS_LINEAR_OPEN; fh->linear = LS_LINEAR_OPEN;
@ -1483,23 +1486,23 @@ ftpfs_send_command(struct vfs_class *me, const char *filename, const char *cmd,
int flush_directory_cache = (flags & OPT_FLUSH); int flush_directory_cache = (flags & OPT_FLUSH);
if (!(rpath = vfs_s_get_path_mangle(me, mpath, &super, 0))) { if (!(rpath = vfs_s_get_path_mangle(me, mpath, &super, 0))) {
g_free(mpath); mhl_mem_free(mpath);
return -1; return -1;
} }
p = ftpfs_translate_path (me, super, rpath); p = ftpfs_translate_path (me, super, rpath);
r = ftpfs_command (me, super, WAIT_REPLY, cmd, p); r = ftpfs_command (me, super, WAIT_REPLY, cmd, p);
g_free (p); mhl_mem_free (p);
vfs_stamp_create (&vfs_ftpfs_ops, super); vfs_stamp_create (&vfs_ftpfs_ops, super);
if (flags & OPT_IGNORE_ERROR) if (flags & OPT_IGNORE_ERROR)
r = COMPLETE; r = COMPLETE;
if (r != COMPLETE) { if (r != COMPLETE) {
me->verrno = EPERM; me->verrno = EPERM;
g_free (mpath); mhl_mem_free (mpath);
return -1; return -1;
} }
if (flush_directory_cache) if (flush_directory_cache)
vfs_s_invalidate(me, super); vfs_s_invalidate(me, super);
g_free(mpath); mhl_mem_free(mpath);
return 0; return 0;
} }
@ -1575,12 +1578,12 @@ ftpfs_chdir_internal (struct vfs_class *me, struct vfs_s_super *super, const cha
p = ftpfs_translate_path (me, super, remote_path); p = ftpfs_translate_path (me, super, remote_path);
r = ftpfs_command (me, super, WAIT_REPLY, "CWD /%s", p); r = ftpfs_command (me, super, WAIT_REPLY, "CWD /%s", p);
g_free (p); mhl_mem_free (p);
if (r != COMPLETE) { if (r != COMPLETE) {
ftpfs_errno = EIO; ftpfs_errno = EIO;
} else { } else {
g_free(SUP.cwdir); mhl_mem_free(SUP.cwdir);
SUP.cwdir = g_strdup (remote_path); SUP.cwdir = g_strdup (remote_path);
SUP.cwd_deferred = 0; SUP.cwd_deferred = 0;
} }
@ -1643,7 +1646,7 @@ ftpfs_fh_open (struct vfs_class *me, struct vfs_s_fh *fh, int flags,
ftpfs_open_data_connection (me, fh->ino->super, ftpfs_open_data_connection (me, fh->ino->super,
(flags & O_APPEND) ? "APPE" : (flags & O_APPEND) ? "APPE" :
"STOR", name, TYPE_BINARY, 0); "STOR", name, TYPE_BINARY, 0);
g_free (name); mhl_mem_free (name);
if (fh->handle < 0) if (fh->handle < 0)
return -1; return -1;
@ -1655,7 +1658,7 @@ ftpfs_fh_open (struct vfs_class *me, struct vfs_s_fh *fh, int flags,
if (fh->ino->localname) { if (fh->ino->localname) {
unlink (fh->ino->localname); unlink (fh->ino->localname);
g_free (fh->ino->localname); mhl_mem_free (fh->ino->localname);
fh->ino->localname = NULL; fh->ino->localname = NULL;
} }
return 0; return 0;
@ -1694,12 +1697,12 @@ ftpfs_done (struct vfs_class *me)
while (no_proxy) { while (no_proxy) {
np = no_proxy->next; np = no_proxy->next;
g_free (no_proxy->domain); mhl_mem_free (no_proxy->domain);
g_free (no_proxy); mhl_mem_free (no_proxy);
no_proxy = np; no_proxy = np;
} }
g_free (ftpfs_anonymous_passwd); mhl_mem_free (ftpfs_anonymous_passwd);
g_free (ftpfs_proxy_host); mhl_mem_free (ftpfs_proxy_host);
} }
static void static void
@ -1711,7 +1714,7 @@ ftpfs_fill_names (struct vfs_class *me, fill_names_f func)
while (super){ while (super){
name = g_strconcat ("/#ftp:", SUP.user, "@", SUP.host, "/", SUP.cwdir, (char *) NULL); name = g_strconcat ("/#ftp:", SUP.user, "@", SUP.host, "/", SUP.cwdir, (char *) NULL);
(*func)(name); (*func)(name);
g_free (name); mhl_mem_free (name);
super = super->next; super = super->next;
} }
} }
@ -1889,7 +1892,7 @@ static int ftpfs_netrc_lookup (const char *host, char **login, char **pass)
netrcname = concat_dir_and_file (home_dir, ".netrc"); netrcname = concat_dir_and_file (home_dir, ".netrc");
netrcp = netrc = load_file (netrcname); netrcp = netrc = load_file (netrcname);
if (netrc == NULL) { if (netrc == NULL) {
g_free (netrcname); mhl_mem_free (netrcname);
return 0; return 0;
} }
@ -1964,8 +1967,8 @@ static int ftpfs_netrc_lookup (const char *host, char **login, char **pass)
break; break;
} }
g_free (netrc); mhl_mem_free (netrc);
g_free (netrcname); mhl_mem_free (netrcname);
rupp = g_new (struct rupcache, 1); rupp = g_new (struct rupcache, 1);
rupp->host = g_strdup (host); rupp->host = g_strdup (host);

View File

@ -31,6 +31,8 @@
#include <signal.h> #include <signal.h>
#include <ctype.h> /* is_digit() */ #include <ctype.h> /* is_digit() */
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -107,7 +109,7 @@ vfs_rmstamp (struct vfs_class *v, vfsid id)
} else { } else {
st1->next = stamp->next; st1->next = stamp->next;
} }
g_free (stamp); mhl_mem_free (stamp);
return; return;
} }
@ -126,7 +128,7 @@ vfs_getid (struct vfs_class *vclass, const char *dir)
if (vclass->getid) if (vclass->getid)
id = (*vclass->getid) (vclass, dir1); id = (*vclass->getid) (vclass, dir1);
g_free (dir1); mhl_mem_free (dir1);
return id; return id;
} }
@ -295,7 +297,7 @@ vfs_gc_done (void)
if (stamp->v->free) if (stamp->v->free)
(*stamp->v->free) (stamp->id); (*stamp->v->free) (stamp->id);
st = stamp->next; st = stamp->next;
g_free (stamp); mhl_mem_free (stamp);
stamp = st; stamp = st;
} }

View File

@ -5,6 +5,7 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
@ -68,7 +69,7 @@ local_close (void *data)
return -1; return -1;
fd = *(int *) data; fd = *(int *) data;
g_free (data); mhl_mem_free (data);
return close (fd); return close (fd);
} }
@ -109,7 +110,7 @@ local_closedir (void *data)
int i; int i;
i = closedir (* (DIR **) data); i = closedir (* (DIR **) data);
g_free (data); mhl_mem_free (data);
return i; return i;
} }

View File

@ -112,7 +112,7 @@ mcfs_fill_names (struct vfs_class *me, fill_names_f func)
name = g_strconcat ("/#mc:", mcfs_connections[i].user, name = g_strconcat ("/#mc:", mcfs_connections[i].user,
"@", mcfs_connections[i].host, (char *) NULL); "@", mcfs_connections[i].host, (char *) NULL);
(*func) (name); (*func) (name);
g_free (name); mhl_mem_free (name);
} }
} }
@ -390,11 +390,11 @@ mcfs_get_path (mcfs_connection **mc, const char *path)
if ((remote_path = if ((remote_path =
mcfs_get_host_and_username (path, &host, &user, &port, &pass))) mcfs_get_host_and_username (path, &host, &user, &port, &pass)))
if (!(*mc = mcfs_open_link (host, user, &port, pass))) { if (!(*mc = mcfs_open_link (host, user, &port, pass))) {
g_free (remote_path); mhl_mem_free (remote_path);
remote_path = NULL; remote_path = NULL;
} }
g_free (host); mhl_mem_free (host);
g_free (user); mhl_mem_free (user);
if (pass) if (pass)
wipe_password (pass); wipe_password (pass);
@ -408,7 +408,7 @@ mcfs_get_path (mcfs_connection **mc, const char *path)
char *s; char *s;
s = concat_dir_and_file (mcfs_gethome (*mc), s = concat_dir_and_file (mcfs_gethome (*mc),
remote_path + 3 - f); remote_path + 3 - f);
g_free (remote_path); mhl_mem_free (remote_path);
remote_path = s; remote_path = s;
} }
} }
@ -442,14 +442,14 @@ mcfs_rpc_two_paths (int command, const char *s1, const char *s2)
return -1; return -1;
if ((r2 = mcfs_get_path (&mc, s2)) == 0) { if ((r2 = mcfs_get_path (&mc, s2)) == 0) {
g_free (r1); mhl_mem_free (r1);
return -1; return -1;
} }
rpc_send (mc->sock, rpc_send (mc->sock,
RPC_INT, command, RPC_STRING, r1, RPC_STRING, r2, RPC_END); RPC_INT, command, RPC_STRING, r1, RPC_STRING, r2, RPC_END);
g_free (r1); mhl_mem_free (r1);
g_free (r2); mhl_mem_free (r2);
return mcfs_handle_simple_error (mc->sock, 0); return mcfs_handle_simple_error (mc->sock, 0);
} }
@ -465,7 +465,7 @@ mcfs_rpc_path (int command, const char *path)
rpc_send (mc->sock, rpc_send (mc->sock,
RPC_INT, command, RPC_STRING, remote_file, RPC_END); RPC_INT, command, RPC_STRING, remote_file, RPC_END);
g_free (remote_file); mhl_mem_free (remote_file);
return mcfs_handle_simple_error (mc->sock, 0); return mcfs_handle_simple_error (mc->sock, 0);
} }
@ -482,7 +482,7 @@ mcfs_rpc_path_int (int command, const char *path, int data)
RPC_INT, command, RPC_INT, command,
RPC_STRING, remote_file, RPC_INT, data, RPC_END); RPC_STRING, remote_file, RPC_INT, data, RPC_END);
g_free (remote_file); mhl_mem_free (remote_file);
return mcfs_handle_simple_error (mc->sock, 0); return mcfs_handle_simple_error (mc->sock, 0);
} }
@ -499,7 +499,7 @@ mcfs_rpc_path_int_int (int command, const char *path, int n1, int n2)
RPC_INT, command, RPC_INT, command,
RPC_STRING, remote_file, RPC_INT, n1, RPC_INT, n2, RPC_END); RPC_STRING, remote_file, RPC_INT, n1, RPC_INT, n2, RPC_END);
g_free (remote_file); mhl_mem_free (remote_file);
return mcfs_handle_simple_error (mc->sock, 0); return mcfs_handle_simple_error (mc->sock, 0);
} }
@ -535,7 +535,7 @@ mcfs_open (struct vfs_class *me, const char *file, int flags, int mode)
rpc_send (mc->sock, RPC_INT, MC_OPEN, RPC_STRING, remote_file, RPC_INT, rpc_send (mc->sock, RPC_INT, MC_OPEN, RPC_STRING, remote_file, RPC_INT,
flags, RPC_INT, mode, RPC_END); flags, RPC_INT, mode, RPC_END);
g_free (remote_file); mhl_mem_free (remote_file);
if (0 == if (0 ==
rpc_get (mc->sock, RPC_INT, &result, RPC_INT, &error_num, RPC_END)) rpc_get (mc->sock, RPC_INT, &result, RPC_INT, &error_num, RPC_END))
@ -617,7 +617,7 @@ mcfs_close (void *data)
mcfs_is_error (result, error); mcfs_is_error (result, error);
g_free (data); mhl_mem_free (data);
return result; return result;
} }
@ -659,7 +659,7 @@ mcfs_opendir (struct vfs_class *me, const char *dirname)
rpc_send (mc->sock, RPC_INT, MC_OPENDIR, RPC_STRING, remote_dir, rpc_send (mc->sock, RPC_INT, MC_OPENDIR, RPC_STRING, remote_dir,
RPC_END); RPC_END);
g_free (remote_dir); mhl_mem_free (remote_dir);
if (0 == if (0 ==
rpc_get (mc->sock, RPC_INT, &result, RPC_INT, &error_num, RPC_END)) rpc_get (mc->sock, RPC_INT, &result, RPC_INT, &error_num, RPC_END))
@ -742,8 +742,8 @@ mcfs_free_dir (dir_entry *de)
if (!de) if (!de)
return; return;
mcfs_free_dir (de->next); mcfs_free_dir (de->next);
g_free (de->text); mhl_mem_free (de->text);
g_free (de); mhl_mem_free (de);
} }
static union vfs_dirent mcfs_readdir_data; static union vfs_dirent mcfs_readdir_data;
@ -793,10 +793,10 @@ mcfs_closedir (void *info)
for (p = mcfs_info->entries; p;) { for (p = mcfs_info->entries; p;) {
q = p; q = p;
p = p->next; p = p->next;
g_free (q->text); mhl_mem_free (q->text);
g_free (q); mhl_mem_free (q);
} }
g_free (info); mhl_mem_free (info);
return 0; return 0;
} }
@ -824,7 +824,7 @@ mcfs_get_time (mcfs_connection *mc)
rpc_get (sock, RPC_STRING, &buf, RPC_END); rpc_get (sock, RPC_STRING, &buf, RPC_END);
sscanf (buf, "%lx", &tm); sscanf (buf, "%lx", &tm);
g_free (buf); mhl_mem_free (buf);
return (time_t) tm; return (time_t) tm;
} }
@ -877,7 +877,7 @@ mcfs_stat_cmd (int cmd, const char *path, struct stat *buf)
return -1; return -1;
rpc_send (mc->sock, RPC_INT, cmd, RPC_STRING, remote_file, RPC_END); rpc_send (mc->sock, RPC_INT, cmd, RPC_STRING, remote_file, RPC_END);
g_free (remote_file); mhl_mem_free (remote_file);
if (!rpc_get (mc->sock, RPC_INT, &status, RPC_INT, &error, RPC_END)) if (!rpc_get (mc->sock, RPC_INT, &status, RPC_INT, &error, RPC_END))
return mcfs_set_error (-1, errno); return mcfs_set_error (-1, errno);
@ -984,7 +984,7 @@ mcfs_utime (struct vfs_class *me, const char *path, struct utimbuf *times)
status = mcfs_handle_simple_error (mc->sock, 0); status = mcfs_handle_simple_error (mc->sock, 0);
} }
g_free (file); mhl_mem_free (file);
return (status); return (status);
} }
@ -1003,7 +1003,7 @@ mcfs_readlink (struct vfs_class *me, const char *path, char *buf, size_t size)
rpc_send (mc->sock, RPC_INT, MC_READLINK, RPC_STRING, remote_file, rpc_send (mc->sock, RPC_INT, MC_READLINK, RPC_STRING, remote_file,
RPC_END); RPC_END);
g_free (remote_file); mhl_mem_free (remote_file);
if (!rpc_get (mc->sock, RPC_INT, &status, RPC_INT, &error, RPC_END)) if (!rpc_get (mc->sock, RPC_INT, &status, RPC_INT, &error, RPC_END))
return mcfs_set_error (-1, EIO); return mcfs_set_error (-1, EIO);
@ -1018,7 +1018,7 @@ mcfs_readlink (struct vfs_class *me, const char *path, char *buf, size_t size)
size = len; size = len;
/* readlink() does not append a NUL character to buf */ /* readlink() does not append a NUL character to buf */
memcpy (buf, stat_str, size); memcpy (buf, stat_str, size);
g_free (stat_str); mhl_mem_free (stat_str);
return size; return size;
} }
@ -1060,7 +1060,7 @@ mcfs_chdir (struct vfs_class *me, const char *path)
rpc_send (mc->sock, RPC_INT, MC_CHDIR, RPC_STRING, remote_dir, rpc_send (mc->sock, RPC_INT, MC_CHDIR, RPC_STRING, remote_dir,
RPC_END); RPC_END);
g_free (remote_dir); mhl_mem_free (remote_dir);
if (!rpc_get (mc->sock, RPC_INT, &status, RPC_INT, &error, RPC_END)) if (!rpc_get (mc->sock, RPC_INT, &status, RPC_INT, &error, RPC_END))
return mcfs_set_error (-1, EIO); return mcfs_set_error (-1, EIO);
@ -1136,8 +1136,8 @@ mcfs_forget (const char *path)
if ((p = if ((p =
mcfs_get_host_and_username (path, &host, &user, &port, mcfs_get_host_and_username (path, &host, &user, &port,
&pass)) == 0) { &pass)) == 0) {
g_free (host); mhl_mem_free (host);
g_free (user); mhl_mem_free (user);
if (pass) if (pass)
wipe_password (pass); wipe_password (pass);
return; return;
@ -1155,9 +1155,9 @@ mcfs_forget (const char *path)
mcfs_open_tcp_link (host, user, &port, pass, &vers); mcfs_open_tcp_link (host, user, &port, pass, &vers);
} }
} }
g_free (p); mhl_mem_free (p);
g_free (host); mhl_mem_free (host);
g_free (user); mhl_mem_free (user);
if (pass) if (pass)
wipe_password (pass); wipe_password (pass);
} }
@ -1213,9 +1213,9 @@ init_mcfs (void)
static void static void
mcfs_free_bucket (int bucket) mcfs_free_bucket (int bucket)
{ {
g_free (mcfs_connections[bucket].host); mhl_mem_free (mcfs_connections[bucket].host);
g_free (mcfs_connections[bucket].user); mhl_mem_free (mcfs_connections[bucket].user);
g_free (mcfs_connections[bucket].home); mhl_mem_free (mcfs_connections[bucket].home);
/* Set all the fields to zero */ /* Set all the fields to zero */
mcfs_connections[bucket].host = mcfs_connections[bucket].host =

View File

@ -124,10 +124,6 @@
# define INADDR_NONE (0xffffffffU) # define INADDR_NONE (0xffffffffU)
#endif #endif
/* replacement for g_free() from glib */
#undef g_free
#define g_free(x) do {if (x) free (x);} while (0)
/* We don't care about SIGPIPE */ /* We don't care about SIGPIPE */
int got_sigpipe = 0; int got_sigpipe = 0;
@ -214,7 +210,7 @@ do_open (void)
handle = open (arg, flags, mode); handle = open (arg, flags, mode);
send_status (handle, errno); send_status (handle, errno);
g_free (arg); mhl_mem_free (arg);
} }
static void static void
@ -241,7 +237,7 @@ do_read (void)
send_status (n, 0); send_status (n, 0);
rpc_send (msock, RPC_BLOCK, n, data, RPC_END); rpc_send (msock, RPC_BLOCK, n, data, RPC_END);
g_free (data); mhl_mem_free (data);
} }
static void static void
@ -381,7 +377,7 @@ do_lstat (void)
send_status (n, errno); send_status (n, errno);
if (n >= 0) if (n >= 0)
send_stat_info (&st); send_stat_info (&st);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -413,7 +409,7 @@ do_stat (void)
send_status (n, errno); send_status (n, errno);
if (n >= 0) if (n >= 0)
send_stat_info (&st); send_stat_info (&st);
g_free (file); mhl_mem_free (file);
} }
/* }}} */ /* }}} */
@ -433,7 +429,7 @@ close_handle (int handle)
mcfs_DIR.used--; mcfs_DIR.used--;
if (mcfs_DIR.dirs[handle]) if (mcfs_DIR.dirs[handle])
closedir (mcfs_DIR.dirs[handle]); closedir (mcfs_DIR.dirs[handle]);
g_free (mcfs_DIR.names[handle]); mhl_mem_free (mcfs_DIR.names[handle]);
mcfs_DIR.dirs[handle] = 0; mcfs_DIR.dirs[handle] = 0;
mcfs_DIR.names[handle] = 0; mcfs_DIR.names[handle] = 0;
} }
@ -449,7 +445,7 @@ do_opendir (void)
if (mcfs_DIR.used == OPENDIR_HANDLES) { if (mcfs_DIR.used == OPENDIR_HANDLES) {
send_status (-1, ENFILE); /* Error */ send_status (-1, ENFILE); /* Error */
g_free (arg); mhl_mem_free (arg);
return; return;
} }
@ -463,7 +459,7 @@ do_opendir (void)
if (handle == -1) { if (handle == -1) {
send_status (-1, EMFILE); send_status (-1, EMFILE);
g_free (arg); mhl_mem_free (arg);
if (!inetd_started) if (!inetd_started)
fprintf (stderr, fprintf (stderr,
"OOPS! you have found a bug in mc - do_opendir()!\n"); "OOPS! you have found a bug in mc - do_opendir()!\n");
@ -483,7 +479,7 @@ do_opendir (void)
} else { } else {
send_status (-1, errno); send_status (-1, errno);
g_free (arg); mhl_mem_free (arg);
} }
} }
@ -518,7 +514,7 @@ do_readdir (void)
snprintf (fname, fname_len, "%s/%s", mcfs_DIR.names[handle], snprintf (fname, fname_len, "%s/%s", mcfs_DIR.names[handle],
dirent->d_name); dirent->d_name);
n = lstat (fname, &st); n = lstat (fname, &st);
g_free (fname); mhl_mem_free (fname);
send_status (n, errno); send_status (n, errno);
if (n >= 0) if (n >= 0)
send_stat_info (&st); send_stat_info (&st);
@ -549,7 +545,7 @@ do_chdir (void)
status = chdir (file); status = chdir (file);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -562,7 +558,7 @@ do_rmdir (void)
status = rmdir (file); status = rmdir (file);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -575,7 +571,7 @@ do_mkdir (void)
status = mkdir (file, mode); status = mkdir (file, mode);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -589,7 +585,7 @@ do_mknod (void)
status = mknod (file, mode, dev); status = mknod (file, mode, dev);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -606,7 +602,7 @@ do_readlink (void)
buffer[n] = 0; buffer[n] = 0;
rpc_send (msock, RPC_STRING, buffer, RPC_END); rpc_send (msock, RPC_STRING, buffer, RPC_END);
} }
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -618,7 +614,7 @@ do_unlink (void)
rpc_get (msock, RPC_STRING, &file, RPC_END); rpc_get (msock, RPC_STRING, &file, RPC_END);
status = unlink (file); status = unlink (file);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -630,8 +626,8 @@ do_rename (void)
rpc_get (msock, RPC_STRING, &f1, RPC_STRING, &f2, RPC_END); rpc_get (msock, RPC_STRING, &f1, RPC_STRING, &f2, RPC_END);
status = rename (f1, f2); status = rename (f1, f2);
send_status (status, errno); send_status (status, errno);
g_free (f1); mhl_mem_free (f1);
g_free (f2); mhl_mem_free (f2);
} }
static void static void
@ -643,8 +639,8 @@ do_symlink (void)
rpc_get (msock, RPC_STRING, &f1, RPC_STRING, &f2, RPC_END); rpc_get (msock, RPC_STRING, &f1, RPC_STRING, &f2, RPC_END);
status = symlink (f1, f2); status = symlink (f1, f2);
send_status (status, errno); send_status (status, errno);
g_free (f1); mhl_mem_free (f1);
g_free (f2); mhl_mem_free (f2);
} }
static void static void
@ -656,8 +652,8 @@ do_link (void)
rpc_get (msock, RPC_STRING, &f1, RPC_STRING, &f2, RPC_END); rpc_get (msock, RPC_STRING, &f1, RPC_STRING, &f2, RPC_END);
status = link (f1, f2); status = link (f1, f2);
send_status (status, errno); send_status (status, errno);
g_free (f1); mhl_mem_free (f1);
g_free (f2); mhl_mem_free (f2);
} }
@ -686,7 +682,7 @@ do_chmod (void)
rpc_get (msock, RPC_STRING, &file, RPC_INT, &mode, RPC_END); rpc_get (msock, RPC_STRING, &file, RPC_INT, &mode, RPC_END);
status = chmod (file, mode); status = chmod (file, mode);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -699,7 +695,7 @@ do_chown (void)
RPC_END); RPC_END);
status = chown (file, owner, group); status = chown (file, owner, group);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void
@ -720,13 +716,13 @@ do_utime (void)
if (verbose) if (verbose)
printf ("Got a = %s, m = %s, comp a = %ld, m = %ld\n", as, ms, printf ("Got a = %s, m = %s, comp a = %ld, m = %ld\n", as, ms,
atime, mtime); atime, mtime);
g_free (as); mhl_mem_free (as);
g_free (ms); mhl_mem_free (ms);
times.actime = (time_t) atime; times.actime = (time_t) atime;
times.modtime = (time_t) mtime; times.modtime = (time_t) mtime;
status = utime (file, &times); status = utime (file, &times);
send_status (status, errno); send_status (status, errno);
g_free (file); mhl_mem_free (file);
} }
static void static void

View File

@ -34,6 +34,8 @@
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -80,7 +82,7 @@ sfs_vfmake (struct vfs_class *me, const char *name, char *cache)
vfs_die ("This cannot happen... Hopefully.\n"); vfs_die ("This cannot happen... Hopefully.\n");
if (!(sfs_flags[w] & F_1) && strcmp (pname, "/")) { if (!(sfs_flags[w] & F_1) && strcmp (pname, "/")) {
g_free (pname); mhl_mem_free (pname);
return -1; return -1;
} }
@ -88,19 +90,19 @@ sfs_vfmake (struct vfs_class *me, const char *name, char *cache)
if (!(sfs_flags[w] & F_NOLOCALCOPY)) { if (!(sfs_flags[w] & F_NOLOCALCOPY)) {
s = mc_getlocalcopy (pname); s = mc_getlocalcopy (pname);
if (!s) { if (!s) {
g_free (pname); mhl_mem_free (pname);
return -1; return -1;
} }
pqname = name_quote (s, 0); pqname = name_quote (s, 0);
g_free (s); mhl_mem_free (s);
} else { } else {
pqname = name_quote (pname, 0); pqname = name_quote (pname, 0);
} }
g_free (pname); mhl_mem_free (pname);
#define COPY_CHAR \ #define COPY_CHAR \
if ((size_t) (t-pad) > sizeof(pad)) { \ if ((size_t) (t-pad) > sizeof(pad)) { \
g_free (pqname); \ mhl_mem_free (pqname); \
return -1; \ return -1; \
} \ } \
else \ else \
@ -108,7 +110,7 @@ sfs_vfmake (struct vfs_class *me, const char *name, char *cache)
#define COPY_STRING(a) \ #define COPY_STRING(a) \
if ((t-pad)+strlen(a)>sizeof(pad)) { \ if ((t-pad)+strlen(a)>sizeof(pad)) { \
g_free (pqname); \ mhl_mem_free (pqname); \
return -1; \ return -1; \
} else { \ } else { \
strcpy (t, a); \ strcpy (t, a); \
@ -144,7 +146,7 @@ sfs_vfmake (struct vfs_class *me, const char *name, char *cache)
} }
} }
g_free (pqname); mhl_mem_free (pqname);
open_error_pipe (); open_error_pipe ();
if (my_system (EXECUTE_AS_SHELL, "/bin/sh", pad)) { if (my_system (EXECUTE_AS_SHELL, "/bin/sh", pad)) {
close_error_pipe (D_ERROR, NULL); close_error_pipe (D_ERROR, NULL);
@ -191,7 +193,7 @@ sfs_redirect (struct vfs_class *me, const char *name)
} }
unlink (cache); unlink (cache);
g_free (cache); mhl_mem_free (cache);
return "/I_MUST_NOT_EXIST"; return "/I_MUST_NOT_EXIST";
} }
@ -285,9 +287,9 @@ static void sfs_free (vfsid id)
else else
head = cur->next; head = cur->next;
g_free (cur->cache); mhl_mem_free (cur->cache);
g_free (cur->name); mhl_mem_free (cur->name);
g_free (cur); mhl_mem_free (cur);
} }
static void sfs_fill_names (struct vfs_class *me, fill_names_f func) static void sfs_fill_names (struct vfs_class *me, fill_names_f func)
@ -341,10 +343,10 @@ static int sfs_init (struct vfs_class *me)
if (!cfg){ if (!cfg){
fprintf (stderr, _("Warning: file %s not found\n"), mc_sfsini); fprintf (stderr, _("Warning: file %s not found\n"), mc_sfsini);
g_free (mc_sfsini); mhl_mem_free (mc_sfsini);
return 0; return 0;
} }
g_free (mc_sfsini); mhl_mem_free (mc_sfsini);
sfs_no = 0; sfs_no = 0;
while (sfs_no < MAXFS && fgets (key, sizeof (key), cfg)) { while (sfs_no < MAXFS && fgets (key, sizeof (key), cfg)) {
@ -406,8 +408,8 @@ sfs_done (struct vfs_class *me)
(void) me; (void) me;
for (i = 0; i < sfs_no; i++){ for (i = 0; i < sfs_no; i++){
g_free (sfs_prefix [i]); mhl_mem_free (sfs_prefix [i]);
g_free (sfs_command [i]); mhl_mem_free (sfs_command [i]);
sfs_prefix [i] = sfs_command [i] = NULL; sfs_prefix [i] = sfs_command [i] = NULL;
} }
sfs_no = 0; sfs_no = 0;

View File

@ -112,7 +112,7 @@ static GSList *auth_list;
static inline char * static inline char *
free_after (char *result, char *string_to_free) free_after (char *result, char *string_to_free)
{ {
g_free(string_to_free); mhl_mem_free(string_to_free);
return result; return result;
} }
@ -120,10 +120,10 @@ free_after (char *result, char *string_to_free)
static void static void
smbfs_auth_free (struct smb_authinfo const *a) smbfs_auth_free (struct smb_authinfo const *a)
{ {
g_free (a->host); mhl_mem_free (a->host);
g_free (a->share); mhl_mem_free (a->share);
g_free (a->domain); mhl_mem_free (a->domain);
g_free (a->user); mhl_mem_free (a->user);
wipe_password (a->password); wipe_password (a->password);
} }
@ -197,8 +197,8 @@ smbfs_auth_remove (const char *host, const char *share)
list = g_slist_find_custom (auth_list, list = g_slist_find_custom (auth_list,
&data, &data,
smbfs_auth_cmp_host_and_share); smbfs_auth_cmp_host_and_share);
g_free (data.host); mhl_mem_free (data.host);
g_free (data.share); mhl_mem_free (data.share);
if (!list) if (!list)
return; return;
auth = list->data; auth = list->data;
@ -219,9 +219,9 @@ smbfs_bucket_set_authinfo (smbfs_connection *bucket,
GSList *list; GSList *list;
if (domain && user && pass) { if (domain && user && pass) {
g_free (bucket->domain); mhl_mem_free (bucket->domain);
g_free (bucket->user); mhl_mem_free (bucket->user);
g_free (bucket->password); mhl_mem_free (bucket->password);
bucket->domain = g_strdup (domain); bucket->domain = g_strdup (domain);
bucket->user = g_strdup (user); bucket->user = g_strdup (user);
bucket->password = g_strdup (pass); bucket->password = g_strdup (pass);
@ -256,9 +256,9 @@ smbfs_bucket_set_authinfo (smbfs_connection *bucket,
(domain ? domain : lp_workgroup ()), (domain ? domain : lp_workgroup ()),
user); user);
if (auth) { if (auth) {
g_free (bucket->domain); mhl_mem_free (bucket->domain);
g_free (bucket->user); mhl_mem_free (bucket->user);
g_free (bucket->password); mhl_mem_free (bucket->password);
bucket->domain = g_strdup (auth->domain); bucket->domain = g_strdup (auth->domain);
bucket->user = g_strdup (auth->user); bucket->user = g_strdup (auth->user);
bucket->password = g_strdup (auth->password); bucket->password = g_strdup (auth->password);
@ -357,7 +357,7 @@ smbfs_fill_names (struct vfs_class *me, fill_names_f func)
"/", smbfs_connections[i].service, "/", smbfs_connections[i].service,
NULL); NULL);
(*func)(path); (*func)(path);
g_free (path); mhl_mem_free (path);
} }
} }
} }
@ -606,10 +606,10 @@ smbfs_reconnect(smbfs_connection *conn, int *retries)
if (!(conn->cli = smbfs_do_connect(host, conn->service))) { if (!(conn->cli = smbfs_do_connect(host, conn->service))) {
message (D_ERROR, MSG_ERROR, message (D_ERROR, MSG_ERROR,
_(" reconnect to %s failed\n "), conn->host); _(" reconnect to %s failed\n "), conn->host);
g_free(host); mhl_mem_free(host);
return False; return False;
} }
g_free(host); mhl_mem_free(host);
if (++(*retries) == 2) if (++(*retries) == 2)
return False; return False;
return True; return True;
@ -777,12 +777,12 @@ smbfs_loaddir (opendir_info *smbfs_info)
smbfs_loaddir_helper, NULL) < 0) { smbfs_loaddir_helper, NULL) < 0) {
/* cli_list returns -1 if directory empty or cannot read socket */ /* cli_list returns -1 if directory empty or cannot read socket */
my_errno = cli_error (smbfs_info->conn->cli, NULL, &err, NULL); my_errno = cli_error (smbfs_info->conn->cli, NULL, &err, NULL);
g_free (my_dirname); mhl_mem_free (my_dirname);
return 0; return 0;
} }
if (*(my_dirname) == 0) if (*(my_dirname) == 0)
smbfs_info->dirname = smbfs_info->conn->service; smbfs_info->dirname = smbfs_info->conn->service;
g_free (my_dirname); mhl_mem_free (my_dirname);
/* do_dskattr(); */ /* do_dskattr(); */
done: done:
@ -799,8 +799,8 @@ smbfs_free_dir (dir_entry *de)
if (!de) return; if (!de) return;
smbfs_free_dir (de->next); smbfs_free_dir (de->next);
g_free (de->text); mhl_mem_free (de->text);
g_free (de); mhl_mem_free (de);
} }
#endif #endif
@ -849,10 +849,10 @@ smbfs_closedir (void *info)
/* for (p = smbfs_info->entries; p;){ /* for (p = smbfs_info->entries; p;){
q = p; q = p;
p = p->next; p = p->next;
g_free (q->text); mhl_mem_free (q->text);
g_free (q); mhl_mem_free (q);
} }
g_free (info); */ mhl_mem_free (info); */
return 0; return 0;
} }
@ -1037,12 +1037,12 @@ smbfs_get_master_browser(char **host)
static void static void
smbfs_free_bucket (smbfs_connection *bucket) smbfs_free_bucket (smbfs_connection *bucket)
{ {
g_free (bucket->host); mhl_mem_free (bucket->host);
g_free (bucket->service); mhl_mem_free (bucket->service);
g_free (bucket->domain); mhl_mem_free (bucket->domain);
g_free (bucket->user); mhl_mem_free (bucket->user);
wipe_password (bucket->password); wipe_password (bucket->password);
g_free (bucket->home); mhl_mem_free (bucket->home);
memset (bucket, 0, sizeof (smbfs_connection)); memset (bucket, 0, sizeof (smbfs_connection));
} }
@ -1148,7 +1148,7 @@ smbfs_open_link (char *host, char *path, const char *user, int *port,
if (!(*host)) { /* if blank host name, browse for servers */ if (!(*host)) { /* if blank host name, browse for servers */
if (!smbfs_get_master_browser (&host)) /* set host to ip of master browser */ if (!smbfs_get_master_browser (&host)) /* set host to ip of master browser */
return 0; /* could not find master browser? */ return 0; /* could not find master browser? */
g_free (host); mhl_mem_free (host);
bucket->host = g_strdup (""); /* blank host means master browser */ bucket->host = g_strdup (""); /* blank host means master browser */
} else } else
bucket->host = g_strdup (host); bucket->host = g_strdup (host);
@ -1195,11 +1195,11 @@ smbfs_get_path (smbfs_connection ** sc, const char *path)
smbfs_get_host_and_username (&path, &host, &user, &port, &pass))) smbfs_get_host_and_username (&path, &host, &user, &port, &pass)))
if ((*sc = if ((*sc =
smbfs_open_link (host, remote_path, user, &port, pass)) == NULL) { smbfs_open_link (host, remote_path, user, &port, pass)) == NULL) {
g_free (remote_path); mhl_mem_free (remote_path);
remote_path = NULL; remote_path = NULL;
} }
g_free (host); mhl_mem_free (host);
g_free (user); mhl_mem_free (user);
if (pass) if (pass)
wipe_password (pass); wipe_password (pass);
@ -1212,7 +1212,7 @@ smbfs_get_path (smbfs_connection ** sc, const char *path)
if (f || !strncmp (remote_path, "/~/", 3)) { if (f || !strncmp (remote_path, "/~/", 3)) {
char *s; char *s;
s = concat_dir_and_file ((*sc)->home, remote_path + 3 - f); s = concat_dir_and_file ((*sc)->home, remote_path + 3 - f);
g_free (remote_path); mhl_mem_free (remote_path);
return s; return s;
} }
} }
@ -1302,7 +1302,7 @@ smbfs_fake_share_stat (const char *server_url, const char *path, struct stat *bu
smbfs_connection *sc; smbfs_connection *sc;
char *p; char *p;
p = smbfs_get_path (&sc, path); p = smbfs_get_path (&sc, path);
g_free (p); mhl_mem_free (p);
if (p) { if (p) {
memset (buf, 0, sizeof (*buf)); memset (buf, 0, sizeof (*buf));
/* show this as dir */ /* show this as dir */
@ -1366,16 +1366,16 @@ smbfs_get_remote_stat (smbfs_connection * sc, const char *path, struct stat *buf
if (cli_list if (cli_list
(sc->cli, mypath, attribute, smbfs_loaddir_helper, single_entry) < 1) { (sc->cli, mypath, attribute, smbfs_loaddir_helper, single_entry) < 1) {
my_errno = ENOENT; my_errno = ENOENT;
g_free (mypath); mhl_mem_free (mypath);
return -1; /* cli_list returns number of files */ return -1; /* cli_list returns number of files */
} }
memcpy (buf, &single_entry->my_stat, sizeof (struct stat)); memcpy (buf, &single_entry->my_stat, sizeof (struct stat));
/* don't free here, use for smbfs_fstat() */ /* don't free here, use for smbfs_fstat() */
/* g_free(single_entry->text); /* mhl_mem_free(single_entry->text);
g_free(single_entry); */ mhl_mem_free(single_entry); */
g_free (mypath); mhl_mem_free (mypath);
return 0; return 0;
} }
@ -1433,11 +1433,11 @@ smbfs_get_stat_info (smbfs_connection * sc, const char *path, struct stat *buf)
memset (buf, 0, sizeof (struct stat)); memset (buf, 0, sizeof (struct stat));
buf->st_mode = (S_IFDIR | S_IRUSR | S_IRGRP | S_IROTH) & myumask; buf->st_mode = (S_IFDIR | S_IRUSR | S_IRGRP | S_IROTH) & myumask;
memcpy (&single_entry->my_stat, buf, sizeof (struct stat)); memcpy (&single_entry->my_stat, buf, sizeof (struct stat));
g_free (mdp); mhl_mem_free (mdp);
DEBUG (1, (" PARENT:found in %s\n", current_info->dirname)); DEBUG (1, (" PARENT:found in %s\n", current_info->dirname));
return 0; return 0;
} }
g_free (mdp); mhl_mem_free (mdp);
} }
/* now try to identify as CURRENT dir? */ /* now try to identify as CURRENT dir? */
{ {
@ -1495,7 +1495,7 @@ smbfs_chdir (struct vfs_class *me, const char *path)
DEBUG (3, ("smbfs_chdir(path:%s)\n", path)); DEBUG (3, ("smbfs_chdir(path:%s)\n", path));
if (!(remote_dir = smbfs_get_path (&sc, path))) if (!(remote_dir = smbfs_get_path (&sc, path)))
return -1; return -1;
g_free (remote_dir); mhl_mem_free (remote_dir);
return 0; return 0;
} }
@ -1514,7 +1514,7 @@ smbfs_loaddir_by_name (struct vfs_class *me, const char *path)
DEBUG(6, ("smbfs_loaddir_by_name(%s)\n", mypath)); DEBUG(6, ("smbfs_loaddir_by_name(%s)\n", mypath));
smbfs_chdir(me, mypath); smbfs_chdir(me, mypath);
info = smbfs_opendir (me, mypath); info = smbfs_opendir (me, mypath);
g_free(mypath); mhl_mem_free(mypath);
if (!info) if (!info)
return -1; return -1;
smbfs_readdir(info); smbfs_readdir(info);
@ -1592,7 +1592,7 @@ smbfs_stat (struct vfs_class * me, const char *path, struct stat *buf)
DEBUG (1, ("smbfs_stat: showing server as directory\n")); DEBUG (1, ("smbfs_stat: showing server as directory\n"));
memset (buf, 0, sizeof (struct stat)); memset (buf, 0, sizeof (struct stat));
buf->st_mode = (S_IFDIR | S_IRUSR | S_IRGRP | S_IROTH) & myumask; buf->st_mode = (S_IFDIR | S_IRUSR | S_IRGRP | S_IROTH) & myumask;
g_free (service); mhl_mem_free (service);
return 0; return 0;
} }
} }
@ -1613,12 +1613,12 @@ smbfs_stat (struct vfs_class * me, const char *path, struct stat *buf)
if (strncmp (p, pp, strlen (p)) != 0) { if (strncmp (p, pp, strlen (p)) != 0) {
DEBUG (6, ("desired '%s' is not loaded, we have '%s'\n", p, pp)); DEBUG (6, ("desired '%s' is not loaded, we have '%s'\n", p, pp));
if (smbfs_loaddir_by_name (me, path) < 0) { if (smbfs_loaddir_by_name (me, path) < 0) {
g_free (service); mhl_mem_free (service);
return -1; return -1;
} }
DEBUG (6, ("loaded dir: '%s'\n", current_info->dirname)); DEBUG (6, ("loaded dir: '%s'\n", current_info->dirname));
} }
g_free (service); mhl_mem_free (service);
/* stat dirs & files under shares now */ /* stat dirs & files under shares now */
return smbfs_get_stat_info (sc, path, buf); return smbfs_get_stat_info (sc, path, buf);
} }
@ -1680,17 +1680,17 @@ smbfs_mkdir (struct vfs_class * me, const char *path, mode_t mode)
DEBUG (3, ("smbfs_mkdir(path:%s, mode:%d)\n", path, (int) mode)); DEBUG (3, ("smbfs_mkdir(path:%s, mode:%d)\n", path, (int) mode));
if ((remote_file = smbfs_get_path (&sc, path)) == 0) if ((remote_file = smbfs_get_path (&sc, path)) == 0)
return -1; return -1;
g_free (remote_file); mhl_mem_free (remote_file);
cpath = smbfs_convert_path (path, FALSE); cpath = smbfs_convert_path (path, FALSE);
if (!cli_mkdir (sc->cli, cpath)) { if (!cli_mkdir (sc->cli, cpath)) {
my_errno = cli_error (sc->cli, NULL, &err, NULL); my_errno = cli_error (sc->cli, NULL, &err, NULL);
message (D_ERROR, MSG_ERROR, _(" Error %s creating directory %s "), message (D_ERROR, MSG_ERROR, _(" Error %s creating directory %s "),
cli_errstr (sc->cli), CNV_LANG (cpath)); cli_errstr (sc->cli), CNV_LANG (cpath));
g_free (cpath); mhl_mem_free (cpath);
return -1; return -1;
} }
g_free (cpath); mhl_mem_free (cpath);
return 0; return 0;
} }
@ -1706,18 +1706,18 @@ smbfs_rmdir (struct vfs_class *me, const char *path)
DEBUG(3, ("smbfs_rmdir(path:%s)\n", path)); DEBUG(3, ("smbfs_rmdir(path:%s)\n", path));
if ((remote_file = smbfs_get_path (&sc, path)) == 0) if ((remote_file = smbfs_get_path (&sc, path)) == 0)
return -1; return -1;
g_free (remote_file); mhl_mem_free (remote_file);
cpath = smbfs_convert_path (path, FALSE); cpath = smbfs_convert_path (path, FALSE);
if (!cli_rmdir(sc->cli, cpath)) { if (!cli_rmdir(sc->cli, cpath)) {
my_errno = cli_error(sc->cli, NULL, &err, NULL); my_errno = cli_error(sc->cli, NULL, &err, NULL);
message (D_ERROR, MSG_ERROR, _(" Error %s removing directory %s "), message (D_ERROR, MSG_ERROR, _(" Error %s removing directory %s "),
cli_errstr(sc->cli), CNV_LANG(cpath)); cli_errstr(sc->cli), CNV_LANG(cpath));
g_free (cpath); mhl_mem_free (cpath);
return -1; return -1;
} }
g_free (cpath); mhl_mem_free (cpath);
return 0; return 0;
} }
@ -1757,7 +1757,7 @@ smbfs_forget (const char *path)
path += 2; path += 2;
if ((p = smbfs_get_host_and_username (&path, &host, &user, &port, NULL))) { if ((p = smbfs_get_host_and_username (&path, &host, &user, &port, NULL))) {
g_free (p); mhl_mem_free (p);
for (i = 0; i < SMBFS_MAX_CONNECTIONS; i++) { for (i = 0; i < SMBFS_MAX_CONNECTIONS; i++) {
if (smbfs_connections[i].cli if (smbfs_connections[i].cli
&& (strcmp (host, smbfs_connections[i].host) == 0) && (strcmp (host, smbfs_connections[i].host) == 0)
@ -1773,8 +1773,8 @@ smbfs_forget (const char *path)
} }
} }
} }
g_free (host); mhl_mem_free (host);
g_free (user); mhl_mem_free (user);
} }
static int static int
@ -1871,9 +1871,9 @@ smbfs_open (struct vfs_class *me, const char *file, int flags, int mode)
ret = smbfs_open_readwrite (remote_handle, remote_file, flags, mode); ret = smbfs_open_readwrite (remote_handle, remote_file, flags, mode);
g_free (remote_file); mhl_mem_free (remote_file);
if (!ret) if (!ret)
g_free (remote_handle); mhl_mem_free (remote_handle);
return ret; return ret;
} }
@ -1894,10 +1894,10 @@ smbfs_unlink (struct vfs_class *me, const char *path)
if (!cli_unlink(sc->cli, remote_file)) { if (!cli_unlink(sc->cli, remote_file)) {
message (D_ERROR, MSG_ERROR, _(" %s removing remote file %s "), message (D_ERROR, MSG_ERROR, _(" %s removing remote file %s "),
cli_errstr(sc->cli), CNV_LANG(remote_file)); cli_errstr(sc->cli), CNV_LANG(remote_file));
g_free (remote_file); mhl_mem_free (remote_file);
return -1; return -1;
} }
g_free (remote_file); mhl_mem_free (remote_file);
return 0; return 0;
} }
@ -1914,7 +1914,7 @@ smbfs_rename (struct vfs_class *me, const char *a, const char *b)
return -1; return -1;
if ((rb = smbfs_get_path (&sc, b)) == 0) { if ((rb = smbfs_get_path (&sc, b)) == 0) {
g_free (ra); mhl_mem_free (ra);
return -1; return -1;
} }
@ -1923,8 +1923,8 @@ smbfs_rename (struct vfs_class *me, const char *a, const char *b)
retval = cli_rename(sc->cli, ra, rb); retval = cli_rename(sc->cli, ra, rb);
g_free (ra); mhl_mem_free (ra);
g_free (rb); mhl_mem_free (rb);
if (!retval) { if (!retval) {
message (D_ERROR, MSG_ERROR, _(" %s renaming files\n"), message (D_ERROR, MSG_ERROR, _(" %s renaming files\n"),

View File

@ -31,6 +31,8 @@
#include <sys/mknod.h> #include <sys/mknod.h>
#endif #endif
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -242,7 +244,7 @@ tar_open_archive_int (struct vfs_class *me, const char *name,
result = mc_open (s, O_RDONLY); result = mc_open (s, O_RDONLY);
if (result == -1) if (result == -1)
message (D_ERROR, MSG_ERROR, _("Cannot open tar archive\n%s"), s); message (D_ERROR, MSG_ERROR, _("Cannot open tar archive\n%s"), s);
g_free (s); mhl_mem_free (s);
if (result == -1) if (result == -1)
ERRNOR (ENOENT, -1); ERRNOR (ENOENT, -1);
} }
@ -490,13 +492,13 @@ tar_read_header (struct vfs_class *me, struct vfs_s_super *archive,
longp = ((header->header.linkflag == LF_LONGNAME) longp = ((header->header.linkflag == LF_LONGNAME)
? &next_long_name : &next_long_link); ? &next_long_name : &next_long_link);
g_free (*longp); mhl_mem_free (*longp);
bp = *longp = g_malloc (*h_size + 1); bp = *longp = g_malloc (*h_size + 1);
for (size = *h_size; size > 0; size -= written) { for (size = *h_size; size > 0; size -= written) {
data = tar_get_next_record (archive, tard)->charptr; data = tar_get_next_record (archive, tard)->charptr;
if (data == NULL) { if (data == NULL) {
g_free (*longp); mhl_mem_free (*longp);
*longp = NULL; *longp = NULL;
message (D_ERROR, MSG_ERROR, message (D_ERROR, MSG_ERROR,
_("Unexpected EOF on archive file")); _("Unexpected EOF on archive file"));
@ -511,7 +513,7 @@ tar_read_header (struct vfs_class *me, struct vfs_s_super *archive,
} }
if (bp - *longp == MC_MAXPATHLEN && bp[-1] != '\0') { if (bp - *longp == MC_MAXPATHLEN && bp[-1] != '\0') {
g_free (*longp); mhl_mem_free (*longp);
*longp = NULL; *longp = NULL;
message (D_ERROR, MSG_ERROR, _("Inconsistent tar archive")); message (D_ERROR, MSG_ERROR, _("Inconsistent tar archive"));
return STATUS_BADCHECKSUM; return STATUS_BADCHECKSUM;
@ -556,8 +558,8 @@ tar_read_header (struct vfs_class *me, struct vfs_s_super *archive,
PREFIX_SIZE); PREFIX_SIZE);
current_file_name = g_strconcat (temp_prefix, PATH_SEP_STR, current_file_name = g_strconcat (temp_prefix, PATH_SEP_STR,
temp_name, (char *) NULL); temp_name, (char *) NULL);
g_free (temp_name); mhl_mem_free (temp_name);
g_free (temp_prefix); mhl_mem_free (temp_prefix);
} }
break; break;
case TAR_GNU: case TAR_GNU:
@ -601,7 +603,7 @@ tar_read_header (struct vfs_class *me, struct vfs_s_super *archive,
} else { } else {
entry = vfs_s_new_entry (me, p, inode); entry = vfs_s_new_entry (me, p, inode);
vfs_s_insert_entry (me, parent, entry); vfs_s_insert_entry (me, parent, entry);
g_free (current_link_name); mhl_mem_free (current_link_name);
goto done; goto done;
} }
} }
@ -613,12 +615,12 @@ tar_read_header (struct vfs_class *me, struct vfs_s_super *archive,
if (*current_link_name) { if (*current_link_name) {
inode->linkname = current_link_name; inode->linkname = current_link_name;
} else if (current_link_name != next_long_link) { } else if (current_link_name != next_long_link) {
g_free (current_link_name); mhl_mem_free (current_link_name);
} }
entry = vfs_s_new_entry (me, p, inode); entry = vfs_s_new_entry (me, p, inode);
vfs_s_insert_entry (me, parent, entry); vfs_s_insert_entry (me, parent, entry);
g_free (current_file_name); mhl_mem_free (current_file_name);
done: done:
next_long_link = next_long_name = NULL; next_long_link = next_long_name = NULL;

View File

@ -35,8 +35,8 @@
*/ */
#include <config.h> #include <config.h>
#include <errno.h>
#include <errno.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
@ -51,6 +51,8 @@
#include <ext2fs/ext2fs.h> #include <ext2fs/ext2fs.h>
#include <ctype.h> #include <ctype.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -98,11 +100,11 @@ undelfs_shutdown (void)
if (fs) if (fs)
ext2fs_close (fs); ext2fs_close (fs);
fs = NULL; fs = NULL;
g_free (ext2_fname); mhl_mem_free (ext2_fname);
ext2_fname = NULL; ext2_fname = NULL;
g_free (delarray); mhl_mem_free (delarray);
delarray = NULL; delarray = NULL;
g_free (block_buf); mhl_mem_free (block_buf);
block_buf = NULL; block_buf = NULL;
} }
@ -143,7 +145,7 @@ undelfs_get_path (const char *dirname, char **fsname, char **file)
*file = g_strdup (p+1); *file = g_strdup (p+1);
tmp = g_strndup (dirname, p - dirname); tmp = g_strndup (dirname, p - dirname);
*fsname = g_strconcat ("/dev/", tmp, (char *) NULL); *fsname = g_strconcat ("/dev/", tmp, (char *) NULL);
g_free (tmp); mhl_mem_free (tmp);
return; return;
} }
p--; p--;
@ -273,10 +275,10 @@ undelfs_loaddel (void)
error_out: error_out:
ext2fs_close_inode_scan (scan); ext2fs_close_inode_scan (scan);
free_block_buf: free_block_buf:
g_free (block_buf); mhl_mem_free (block_buf);
block_buf = NULL; block_buf = NULL;
free_delarray: free_delarray:
g_free (delarray); mhl_mem_free (delarray);
delarray = NULL; delarray = NULL;
return 0; return 0;
} }
@ -298,7 +300,7 @@ com_err (const char *whoami, long err_code, const char *fmt, ...)
message (D_ERROR, _(" Ext2lib error "), " %s (%s: %ld) ", str, whoami, message (D_ERROR, _(" Ext2lib error "), " %s (%s: %ld) ", str, whoami,
err_code); err_code);
g_free (str); mhl_mem_free (str);
} }
static void * static void *
@ -311,7 +313,7 @@ undelfs_opendir (struct vfs_class *me, const char *dirname)
return 0; return 0;
/* We don't use the file name */ /* We don't use the file name */
g_free (f); mhl_mem_free (f);
if (!ext2_fname || strcmp (ext2_fname, file)){ if (!ext2_fname || strcmp (ext2_fname, file)){
undelfs_shutdown (); undelfs_shutdown ();
@ -319,7 +321,7 @@ undelfs_opendir (struct vfs_class *me, const char *dirname)
} else { } else {
/* To avoid expensive re-scannings */ /* To avoid expensive re-scannings */
readdir_ptr = READDIR_PTR_INIT; readdir_ptr = READDIR_PTR_INIT;
g_free (file); mhl_mem_free (file);
return fs; return fs;
} }
@ -415,8 +417,8 @@ undelfs_open (struct vfs_class *me, const char *fname, int flags, int mode)
if (!ext2_fname || strcmp (ext2_fname, file)) { if (!ext2_fname || strcmp (ext2_fname, file)) {
message (D_ERROR, undelfserr, message (D_ERROR, undelfserr,
_(" You have to chdir to extract files first ")); _(" You have to chdir to extract files first "));
g_free (file); mhl_mem_free (file);
g_free (f); mhl_mem_free (f);
return 0; return 0;
} }
inode = atol (f); inode = atol (f);
@ -429,15 +431,15 @@ undelfs_open (struct vfs_class *me, const char *fname, int flags, int mode)
/* Found: setup all the structures needed by read */ /* Found: setup all the structures needed by read */
p = (undelfs_file *) g_try_malloc (((gsize) sizeof (undelfs_file))); p = (undelfs_file *) g_try_malloc (((gsize) sizeof (undelfs_file)));
if (!p) { if (!p) {
g_free (file); mhl_mem_free (file);
g_free (f); mhl_mem_free (f);
return 0; return 0;
} }
p->buf = g_try_malloc (fs->blocksize); p->buf = g_try_malloc (fs->blocksize);
if (!p->buf) { if (!p->buf) {
g_free (p); mhl_mem_free (p);
g_free (file); mhl_mem_free (file);
g_free (f); mhl_mem_free (f);
return 0; return 0;
} }
p->inode = inode; p->inode = inode;
@ -447,8 +449,8 @@ undelfs_open (struct vfs_class *me, const char *fname, int flags, int mode)
p->pos = 0; p->pos = 0;
p->size = delarray[i].size; p->size = delarray[i].size;
} }
g_free (file); mhl_mem_free (file);
g_free (f); mhl_mem_free (f);
undelfs_usage++; undelfs_usage++;
return p; return p;
} }
@ -457,8 +459,8 @@ static int
undelfs_close (void *vfs_info) undelfs_close (void *vfs_info)
{ {
undelfs_file *p = vfs_info; undelfs_file *p = vfs_info;
g_free (p->buf); mhl_mem_free (p->buf);
g_free (p); mhl_mem_free (p);
undelfs_usage--; undelfs_usage--;
return 0; return 0;
} }
@ -592,20 +594,20 @@ undelfs_lstat (struct vfs_class *me, const char *path, struct stat *buf)
f = "sda1" f ="401:1" f = "sda1" f ="401:1"
If the first char in f is no digit -> return error */ If the first char in f is no digit -> return error */
if (!isdigit (*f)) { if (!isdigit (*f)) {
g_free (file); mhl_mem_free (file);
g_free (f); mhl_mem_free (f);
return -1; return -1;
} }
if (!ext2_fname || strcmp (ext2_fname, file)){ if (!ext2_fname || strcmp (ext2_fname, file)){
message (D_ERROR, undelfserr, _(" You have to chdir to extract files first ")); message (D_ERROR, undelfserr, _(" You have to chdir to extract files first "));
g_free (file); mhl_mem_free (file);
g_free (f); mhl_mem_free (f);
return 0; return 0;
} }
inode_index = undelfs_getindex (f); inode_index = undelfs_getindex (f);
g_free (file); mhl_mem_free (file);
g_free (f); mhl_mem_free (f);
if (inode_index == -1) if (inode_index == -1)
return -1; return -1;
@ -638,13 +640,13 @@ undelfs_chdir(struct vfs_class *me, const char *path)
/* our vfs, but that is left as an excercise for the reader */ /* our vfs, but that is left as an excercise for the reader */
if ((fd = open (file, O_RDONLY)) == -1){ if ((fd = open (file, O_RDONLY)) == -1){
message (D_ERROR, undelfserr, _(" Cannot open file %s "), file); message (D_ERROR, undelfserr, _(" Cannot open file %s "), file);
g_free (f); mhl_mem_free (f);
g_free (file); mhl_mem_free (file);
return -1; return -1;
} }
close (fd); close (fd);
g_free (f); mhl_mem_free (f);
g_free (file); mhl_mem_free (file);
return 0; return 0;
} }
@ -664,8 +666,8 @@ undelfs_getid (struct vfs_class *me, const char *path)
if (!fsname) if (!fsname)
return NULL; return NULL;
g_free (fname); mhl_mem_free (fname);
g_free (fsname); mhl_mem_free (fsname);
return (vfsid) fs; return (vfsid) fs;
} }

View File

@ -19,8 +19,11 @@
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
#include <config.h> #include <config.h>
#include <ctype.h> #include <ctype.h>
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -133,7 +136,7 @@ vfs_split_url (const char *path, char **host, char **user, int *port,
if (host) if (host)
*host = g_strdup (rest); *host = g_strdup (rest);
g_free (pcopy); mhl_mem_free (pcopy);
return retval; return retval;
} }
#endif /* USE_NETCODE */ #endif /* USE_NETCODE */
@ -238,7 +241,7 @@ vfs_mkstemps (char **pname, const char *prefix, const char *basename)
*q = 0; *q = 0;
fd = mc_mkstemps (pname, prefix, suffix); fd = mc_mkstemps (pname, prefix, suffix);
g_free (suffix); mhl_mem_free (suffix);
return fd; return fd;
} }
@ -869,7 +872,7 @@ vfs_parse_ls_lga (const char *p, struct stat *s, char **filename,
t[p] = 0; t[p] = 0;
} }
g_free (p_copy); mhl_mem_free (p_copy);
return 1; return 1;
error: error:
@ -884,7 +887,7 @@ vfs_parse_ls_lga (const char *p, struct stat *s, char **filename,
_("More parsing errors will be ignored.")); _("More parsing errors will be ignored."));
} }
g_free (p_copy); mhl_mem_free (p_copy);
return 0; return 0;
} }

View File

@ -38,6 +38,8 @@
#include <signal.h> #include <signal.h>
#include <ctype.h> /* is_digit() */ #include <ctype.h> /* is_digit() */
#include <mhl/memory.h>
#include "../src/global.h" #include "../src/global.h"
#include "../src/tty.h" /* enable/disable interrupt key */ #include "../src/tty.h" /* enable/disable interrupt key */
#include "../src/wtools.h" /* message() */ #include "../src/wtools.h" /* message() */
@ -220,7 +222,7 @@ path_magic (const char *path)
/* /*
* Splits path '/p1#op/inpath' into inpath,op; returns which vfs it is. * Splits path '/p1#op/inpath' into inpath,op; returns which vfs it is.
* What is left in path is p1. You still want to g_free(path), you DON'T * What is left in path is p1. You still want to mhl_mem_free(path), you DON'T
* want to free neither *inpath nor *op * want to free neither *inpath nor *op
*/ */
struct vfs_class * struct vfs_class *
@ -301,7 +303,7 @@ vfs_get_class (const char *pathname)
char *path = g_strdup (pathname); char *path = g_strdup (pathname);
vfs = _vfs_get_class (path); vfs = _vfs_get_class (path);
g_free (path); mhl_mem_free (path);
if (!vfs) if (!vfs)
vfs = localfs_class; vfs = localfs_class;
@ -335,13 +337,13 @@ mc_open (const char *filename, int flags, ...)
mode = 0; mode = 0;
if (!vfs->open) { if (!vfs->open) {
g_free (file); mhl_mem_free (file);
errno = -EOPNOTSUPP; errno = -EOPNOTSUPP;
return -1; return -1;
} }
info = (*vfs->open) (vfs, file, flags, mode); /* open must be supported */ info = (*vfs->open) (vfs, file, flags, mode); /* open must be supported */
g_free (file); mhl_mem_free (file);
if (!info){ if (!info){
errno = ferrno (vfs); errno = ferrno (vfs);
return -1; return -1;
@ -359,7 +361,7 @@ int mc_##name inarg \
char *mpath = vfs_canon (path); \ char *mpath = vfs_canon (path); \
vfs = vfs_get_class (mpath); \ vfs = vfs_get_class (mpath); \
result = vfs->name ? (*vfs->name)callarg : -1; \ result = vfs->name ? (*vfs->name)callarg : -1; \
g_free (mpath); \ mhl_mem_free (mpath); \
if (result == -1) \ if (result == -1) \
errno = vfs->name ? ferrno (vfs) : E_NOTSUPP; \ errno = vfs->name ? ferrno (vfs) : E_NOTSUPP; \
return result; \ return result; \
@ -404,13 +406,13 @@ int mc_##name (const char *fname1, const char *fname2) \
name2 = vfs_canon (fname2); \ name2 = vfs_canon (fname2); \
if (vfs != vfs_get_class (name2)){ \ if (vfs != vfs_get_class (name2)){ \
errno = EXDEV; \ errno = EXDEV; \
g_free (name1); \ mhl_mem_free (name1); \
g_free (name2); \ mhl_mem_free (name2); \
return -1; \ return -1; \
} \ } \
result = vfs->name ? (*vfs->name)(vfs, name1, name2) : -1; \ result = vfs->name ? (*vfs->name)(vfs, name1, name2) : -1; \
g_free (name1); \ mhl_mem_free (name1); \
g_free (name2); \ mhl_mem_free (name2); \
if (result == -1) \ if (result == -1) \
errno = vfs->name ? ferrno (vfs) : E_NOTSUPP; \ errno = vfs->name ? ferrno (vfs) : E_NOTSUPP; \
return result; \ return result; \
@ -441,7 +443,7 @@ mc_setctl (const char *path, int ctlop, void *arg)
mpath = vfs_canon (path); mpath = vfs_canon (path);
vfs = vfs_get_class (mpath); vfs = vfs_get_class (mpath);
result = vfs->setctl ? (*vfs->setctl)(vfs, mpath, ctlop, arg) : 0; result = vfs->setctl ? (*vfs->setctl)(vfs, mpath, ctlop, arg) : 0;
g_free (mpath); mhl_mem_free (mpath);
return result; return result;
} }
@ -480,7 +482,7 @@ mc_opendir (const char *dirname)
vfs = vfs_get_class (dname); vfs = vfs_get_class (dname);
info = vfs->opendir ? (*vfs->opendir)(vfs, dname) : NULL; info = vfs->opendir ? (*vfs->opendir)(vfs, dname) : NULL;
g_free (dname); mhl_mem_free (dname);
if (!info){ if (!info){
errno = vfs->opendir ? ferrno (vfs) : E_NOTSUPP; errno = vfs->opendir ? ferrno (vfs) : E_NOTSUPP;
return NULL; return NULL;
@ -521,7 +523,7 @@ mc_closedir (DIR *dirp)
result = vfs->closedir ? (*vfs->closedir)(vfs_info (handle)) : -1; result = vfs->closedir ? (*vfs->closedir)(vfs_info (handle)) : -1;
vfs_free_handle (handle); vfs_free_handle (handle);
g_free (dirp); mhl_mem_free (dirp);
return result; return result;
} }
@ -531,7 +533,7 @@ int mc_stat (const char *filename, struct stat *buf) {
char *path; char *path;
path = vfs_canon (filename); vfs = vfs_get_class (path); path = vfs_canon (filename); vfs = vfs_get_class (path);
result = vfs->stat ? (*vfs->stat) (vfs, path, buf) : -1; result = vfs->stat ? (*vfs->stat) (vfs, path, buf) : -1;
g_free (path); mhl_mem_free (path);
if (result == -1) if (result == -1)
errno = vfs->name ? ferrno (vfs) : E_NOTSUPP; errno = vfs->name ? ferrno (vfs) : E_NOTSUPP;
return result; return result;
@ -543,7 +545,7 @@ int mc_lstat (const char *filename, struct stat *buf) {
char *path; char *path;
path = vfs_canon (filename); vfs = vfs_get_class (path); path = vfs_canon (filename); vfs = vfs_get_class (path);
result = vfs->lstat ? (*vfs->lstat) (vfs, path, buf) : -1; result = vfs->lstat ? (*vfs->lstat) (vfs, path, buf) : -1;
g_free (path); mhl_mem_free (path);
if (result == -1) if (result == -1)
errno = vfs->name ? ferrno (vfs) : E_NOTSUPP; errno = vfs->name ? ferrno (vfs) : E_NOTSUPP;
return result; return result;
@ -582,11 +584,11 @@ _vfs_get_cwd (void)
|| mc_stat (current_dir, &my_stat2) || mc_stat (current_dir, &my_stat2)
|| my_stat.st_ino != my_stat2.st_ino || my_stat.st_ino != my_stat2.st_ino
|| my_stat.st_dev != my_stat2.st_dev) { || my_stat.st_dev != my_stat2.st_dev) {
g_free (current_dir); mhl_mem_free (current_dir);
current_dir = p; current_dir = p;
return p; return p;
} /* Otherwise we return current_dir below */ } /* Otherwise we return current_dir below */
g_free (p); mhl_mem_free (p);
} }
return current_dir; return current_dir;
} }
@ -659,7 +661,7 @@ vfs_canon (const char *path)
local = concat_dir_and_file (current_dir, path); local = concat_dir_and_file (current_dir, path);
result = vfs_canon (local); result = vfs_canon (local);
g_free (local); mhl_mem_free (local);
return result; return result;
} }
@ -689,7 +691,7 @@ mc_chdir (const char *path)
new_dir = vfs_canon (path); new_dir = vfs_canon (path);
new_vfs = vfs_get_class (new_dir); new_vfs = vfs_get_class (new_dir);
if (!new_vfs->chdir) { if (!new_vfs->chdir) {
g_free (new_dir); mhl_mem_free (new_dir);
return -1; return -1;
} }
@ -697,7 +699,7 @@ mc_chdir (const char *path)
if (result == -1) { if (result == -1) {
errno = ferrno (new_vfs); errno = ferrno (new_vfs);
g_free (new_dir); mhl_mem_free (new_dir);
return -1; return -1;
} }
@ -705,7 +707,7 @@ mc_chdir (const char *path)
old_vfs = current_vfs; old_vfs = current_vfs;
/* Actually change directory */ /* Actually change directory */
g_free (current_dir); mhl_mem_free (current_dir);
current_dir = new_dir; current_dir = new_dir;
current_vfs = new_vfs; current_vfs = new_vfs;
@ -739,7 +741,7 @@ vfs_file_class_flags (const char *filename)
fname = vfs_canon (filename); fname = vfs_canon (filename);
vfs = vfs_get_class (fname); vfs = vfs_get_class (fname);
g_free (fname); mhl_mem_free (fname);
return vfs->flags; return vfs->flags;
} }
@ -784,7 +786,7 @@ mc_def_getlocalcopy (const char *filename)
close (fdout); close (fdout);
if (fdin != -1) if (fdin != -1)
mc_close (fdin); mc_close (fdin);
g_free (tmp); mhl_mem_free (tmp);
return NULL; return NULL;
} }
@ -797,7 +799,7 @@ mc_getlocalcopy (const char *pathname)
result = vfs->getlocalcopy ? (*vfs->getlocalcopy)(vfs, path) : result = vfs->getlocalcopy ? (*vfs->getlocalcopy)(vfs, path) :
mc_def_getlocalcopy (path); mc_def_getlocalcopy (path);
g_free (path); mhl_mem_free (path);
if (!result) if (!result)
errno = ferrno (vfs); errno = ferrno (vfs);
return result; return result;
@ -860,7 +862,7 @@ mc_ungetlocalcopy (const char *pathname, const char *local, int has_changed)
return_value = vfs->ungetlocalcopy ? return_value = vfs->ungetlocalcopy ?
(*vfs->ungetlocalcopy)(vfs, path, local, has_changed) : (*vfs->ungetlocalcopy)(vfs, path, local, has_changed) :
mc_def_ungetlocalcopy (vfs, path, local, has_changed); mc_def_ungetlocalcopy (vfs, path, local, has_changed);
g_free (path); mhl_mem_free (path);
return return_value; return return_value;
} }
@ -904,7 +906,7 @@ vfs_shut (void)
vfs_gc_done (); vfs_gc_done ();
g_free (current_dir); mhl_mem_free (current_dir);
for (vfs = vfs_list; vfs; vfs = vfs->next) for (vfs = vfs_list; vfs; vfs = vfs->next)
if (vfs->done) if (vfs->done)