mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-05 11:04:42 +03:00
replaced g_free() by mhl_mem_free()
This commit is contained in:
parent
8bc0e27a54
commit
15d7d47c15
@ -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
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
50
edit/edit.c
50
edit/edit.c
@ -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);
|
||||||
}
|
}
|
||||||
|
126
edit/editcmd.c
126
edit/editcmd.c
@ -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);
|
||||||
|
@ -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 */
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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))) {
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
@ -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 ();
|
||||||
|
@ -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 ();
|
||||||
|
25
src/boxes.c
25
src/boxes.c
@ -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);
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
77
src/cmd.c
77
src/cmd.c
@ -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);
|
||||||
|
10
src/color.c
10
src/color.c
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
10
src/dialog.c
10
src/dialog.c
@ -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 ();
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
43
src/ext.c
43
src/ext.c
@ -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;
|
||||||
}
|
}
|
||||||
|
68
src/file.c
68
src/file.c
@ -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) {
|
||||||
|
@ -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)
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
69
src/find.c
69
src/find.c
@ -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;
|
||||||
|
|
||||||
|
11
src/help.c
11
src/help.c
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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 ()
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
|
@ -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 ();
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
41
src/main.c
41
src/main.c
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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 *
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
61
src/screen.c
61
src/screen.c
@ -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);
|
||||||
}
|
}
|
||||||
|
29
src/setup.c
29
src/setup.c
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
20
src/tree.c
20
src/tree.c
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
38
src/user.c
38
src/user.c
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
73
src/util.c
73
src/util.c
@ -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 *
|
||||||
|
@ -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);
|
||||||
|
67
src/view.c
67
src/view.c
@ -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
|
||||||
|
53
src/widget.c
53
src/widget.c
@ -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;
|
||||||
|
18
src/wtools.c
18
src/wtools.c
@ -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;
|
||||||
|
@ -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;
|
||||||
|
25
vfs/cpio.c
25
vfs/cpio.c
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
103
vfs/extfs.c
103
vfs/extfs.c
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
42
vfs/fish.c
42
vfs/fish.c
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
93
vfs/ftpfs.c
93
vfs/ftpfs.c
@ -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);
|
||||||
|
8
vfs/gc.c
8
vfs/gc.c
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
66
vfs/mcfs.c
66
vfs/mcfs.c
@ -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 =
|
||||||
|
56
vfs/mcserv.c
56
vfs/mcserv.c
@ -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, ×);
|
status = utime (file, ×);
|
||||||
send_status (status, errno);
|
send_status (status, errno);
|
||||||
g_free (file);
|
mhl_mem_free (file);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
32
vfs/sfs.c
32
vfs/sfs.c
@ -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;
|
||||||
|
122
vfs/smbfs.c
122
vfs/smbfs.c
@ -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"),
|
||||||
|
20
vfs/tar.c
20
vfs/tar.c
@ -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;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
52
vfs/vfs.c
52
vfs/vfs.c
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user