replaced GString stuff by static buffers

This commit is contained in:
Enrico Weigelt, metux IT service 2009-01-31 21:55:51 +01:00
parent a1b47185c9
commit f235b1976e
4 changed files with 36 additions and 39 deletions

View File

@ -1,6 +1,7 @@
2009-01-31 Enrico Weigelt, metux ITS <weigelt@metux.de> 2009-01-31 Enrico Weigelt, metux ITS <weigelt@metux.de>
* replaced buggy concat_dir_and_file() by mhl_str_dir_plus_file() (in mhl/string.h) * replaced buggy concat_dir_and_file() by mhl_str_dir_plus_file() (in mhl/string.h)
* replaced GString stuff by static buffers
2009-01-30 Enrico Weigelt, metux ITS <weigelt@metux.de> 2009-01-30 Enrico Weigelt, metux ITS <weigelt@metux.de>

View File

@ -151,10 +151,9 @@ edit_load_file_fast (WEdit *edit, const char *filename)
buf2 = edit->curs2 >> S_EDIT_BUF_SIZE; buf2 = edit->curs2 >> S_EDIT_BUF_SIZE;
if ((file = mc_open (filename, O_RDONLY | O_BINARY)) == -1) { if ((file = mc_open (filename, O_RDONLY | O_BINARY)) == -1) {
GString *errmsg = g_string_new(NULL); char errmsg[8192];
g_string_sprintf(errmsg, _(" Cannot open %s for reading "), filename); snprintf(errmsg, sizeof(errmsg), _(" Cannot open %s for reading "), filename);
edit_error_dialog (_("Error"), get_sys_error (errmsg->str)); edit_error_dialog (_("Error"), get_sys_error (errmsg));
g_string_free (errmsg, TRUE);
return 1; return 1;
} }
@ -273,18 +272,16 @@ edit_insert_file (WEdit *edit, const char *filename)
edit_insert_stream (edit, f); edit_insert_stream (edit, f);
edit_cursor_move (edit, current - edit->curs1); edit_cursor_move (edit, current - edit->curs1);
if (pclose (f) > 0) { if (pclose (f) > 0) {
GString *errmsg = g_string_new (NULL); char errmsg[8192];
g_string_sprintf (errmsg, _(" Error reading from pipe: %s "), p); snprintf(errmsg, sizeof(errmsg), _(" Error reading from pipe: %s "), p);
edit_error_dialog (_("Error"), errmsg->str); edit_error_dialog (_("Error"), errmsg);
g_string_free (errmsg, TRUE);
g_free (p); g_free (p);
return 0; return 0;
} }
} else { } else {
GString *errmsg = g_string_new (NULL); char errmsg[8192];
g_string_sprintf (errmsg, _(" Cannot open pipe for reading: %s "), p); snprintf(errmsg, sizeof(errmsg), _(" Cannot open pipe for reading: %s "), p);
edit_error_dialog (_("Error"), errmsg->str); edit_error_dialog (_("Error"), errmsg);
g_string_free (errmsg, TRUE);
g_free (p); g_free (p);
return 0; return 0;
} }
@ -314,7 +311,8 @@ static int
check_file_access (WEdit *edit, const char *filename, struct stat *st) check_file_access (WEdit *edit, const char *filename, struct stat *st)
{ {
int file; int file;
GString *errmsg = (GString *) 0; char errmsg[8192];
errmsg[0] = 0;
/* Try opening an existing file */ /* Try opening an existing file */
file = mc_open (filename, O_NONBLOCK | O_RDONLY | O_BINARY, 0666); file = mc_open (filename, O_NONBLOCK | O_RDONLY | O_BINARY, 0666);
@ -329,8 +327,7 @@ check_file_access (WEdit *edit, const char *filename, struct stat *st)
O_NONBLOCK | O_RDONLY | O_BINARY | O_CREAT | O_EXCL, O_NONBLOCK | O_RDONLY | O_BINARY | O_CREAT | O_EXCL,
0666); 0666);
if (file < 0) { if (file < 0) {
g_string_sprintf (errmsg = g_string_new (NULL), snprintf (errmsg, sizeof(errmsg), _(" Cannot open %s for reading "), filename);
_(" Cannot open %s for reading "), filename);
goto cleanup; goto cleanup;
} else { } else {
/* New file, delete it if it's not modified or saved */ /* New file, delete it if it's not modified or saved */
@ -340,15 +337,13 @@ check_file_access (WEdit *edit, const char *filename, struct stat *st)
/* Check what we have opened */ /* Check what we have opened */
if (mc_fstat (file, st) < 0) { if (mc_fstat (file, st) < 0) {
g_string_sprintf (errmsg = g_string_new (NULL), snprintf (errmsg, sizeof(errmsg), _(" Cannot get size/permissions for %s "), filename);
_(" Cannot get size/permissions for %s "), filename);
goto cleanup; goto cleanup;
} }
/* We want to open regular files only */ /* We want to open regular files only */
if (!S_ISREG (st->st_mode)) { if (!S_ISREG (st->st_mode)) {
g_string_sprintf (errmsg = g_string_new (NULL), snprintf (errmsg, sizeof(errmsg), _(" %s is not a regular file "), filename);
_(" %s is not a regular file "), filename);
goto cleanup; goto cleanup;
} }
@ -361,16 +356,14 @@ check_file_access (WEdit *edit, const char *filename, struct stat *st)
} }
if (st->st_size >= SIZE_LIMIT) { if (st->st_size >= SIZE_LIMIT) {
g_string_sprintf (errmsg = g_string_new (NULL), snprintf (errmsg, sizeof(errmsg), _(" File %s is too large "), filename);
_(" File %s is too large "), filename);
goto cleanup; goto cleanup;
} }
cleanup: cleanup:
(void) mc_close (file); (void) mc_close (file);
if (errmsg) { if (errmsg[0]) {
edit_error_dialog (_("Error"), errmsg->str); edit_error_dialog (_("Error"), errmsg);
g_string_free (errmsg, TRUE);
return 1; return 1;
} }
return 0; return 0;

View File

@ -1235,14 +1235,16 @@ edit_replace_prompt (WEdit * edit, char *replace_text, int xpos, int ypos)
0, 0, 0, 0, 0}, 0, 0, 0, 0, 0},
NULL_QuickWidget}; NULL_QuickWidget};
GString *label_text = g_string_new (_(" Replace with: ")); const char* label_nls = _(" Replace with: ");
if (*replace_text) { char label_text[8192];
size_t label_len; if (*replace_text)
label_len = label_text->len; {
g_string_append (label_text, replace_text); size_t label_len = strlen(label_nls);
convert_to_display (label_text->str + label_len); snprintf(label_text, sizeof(label_text), "%s%s", label_nls, replace_text);
convert_to_display((&label_text)+label_len);
} }
quick_widgets[5].text = label_text->str;
quick_widgets[5].text = label_text;
{ {
int retval; int retval;
@ -1261,7 +1263,6 @@ edit_replace_prompt (WEdit * edit, char *replace_text, int xpos, int ypos)
Quick_input.ypos = ypos; Quick_input.ypos = ypos;
retval = quick_dialog (&Quick_input); retval = quick_dialog (&Quick_input);
g_string_free (label_text, TRUE);
return retval; return retval;
} }
} }

View File

@ -506,10 +506,14 @@ void edit_get_syntax_color (WEdit * edit, long byte_index, int *color)
*/ */
static int read_one_line (char **line, FILE * f) static int read_one_line (char **line, FILE * f)
{ {
GString *p = g_string_new (""); char buffer[8192];
int c, r = 0; int index = 0, c, r = 0;
buffer[0] = 0;
for (;;) { for (;;) {
if (index >= (sizeof(buffer)-1))
break;
c = fgetc (f); c = fgetc (f);
if (c == EOF) { if (c == EOF) {
if (ferror (f)) { if (ferror (f)) {
@ -531,13 +535,11 @@ static int read_one_line (char **line, FILE * f)
if (c == '\n') if (c == '\n')
break; break;
g_string_append_c (p, c); buffer[index] = c;
index++;
} }
if (r != 0) { if (r != 0) {
*line = p->str; *line = mhl_str_dup(buffer);
g_string_free (p, FALSE);
} else {
g_string_free (p, TRUE);
} }
return r; return r;
} }