1
1

* syntax.c (defines): New static variable for list of defines.

(mc_defines_destroy): New function to release memory of key
pair.
(destroy_defines): New function to destroy list of defines
completely.
(this_try_alloc_color_pair): Use strncpy() instead of unsafe
strcpy().  Use values from list of defines to substitute given
parameters.
(edit_read_syntax_rules): Initialize list of defines and process
new "define" keyword.  Use strncpy() instead of unsafe strcpy().
(edit_free_syntax_rules): Destroy list of defines.
Этот коммит содержится в:
Pavel Roskin 2003-02-25 15:07:53 +00:00
родитель 9c5a3c3b8d
Коммит 0158eaf0f3
2 изменённых файлов: 65 добавлений и 6 удалений

Просмотреть файл

@ -1,3 +1,17 @@
2003-02-25 Andrew V. Samoilov <sav@bcs.zp.ua>
* syntax.c (defines): New static variable for list of defines.
(mc_defines_destroy): New function to release memory of key
pair.
(destroy_defines): New function to destroy list of defines
completely.
(this_try_alloc_color_pair): Use strncpy() instead of unsafe
strcpy(). Use values from list of defines to substitute given
parameters.
(edit_read_syntax_rules): Initialize list of defines and process
new "define" keyword. Use strncpy() instead of unsafe strcpy().
(edit_free_syntax_rules): Destroy list of defines.
2003-02-21 Andrew V. Samoilov <sav@bcs.zp.ua> 2003-02-21 Andrew V. Samoilov <sav@bcs.zp.ua>
* editmenu.c (OptMenuEmacs): Define as OptMenu. * editmenu.c (OptMenuEmacs): Define as OptMenu.

Просмотреть файл

@ -83,6 +83,27 @@ int option_syntax_highlighting = 1;
#define syntax_g_free(x) do {if(x) {g_free(x); (x)=0;}} while (0) #define syntax_g_free(x) do {if(x) {g_free(x); (x)=0;}} while (0)
/* List of defines */
static GTree *defines;
static gint
mc_defines_destroy (gpointer key, gpointer value, gpointer data)
{
g_free (key);
g_free (value);
return FALSE;
}
/* Completely destroys the defines tree */
static void
destroy_defines (void)
{
g_tree_traverse (defines, mc_defines_destroy, G_POST_ORDER, NULL);
g_tree_destroy (defines);
defines = 0;
}
static long compare_word_to_right (WEdit * edit, long i, char *text, char *whole_left, char *whole_right, int line_start) static long compare_word_to_right (WEdit * edit, long i, char *text, char *whole_left, char *whole_right, int line_start)
{ {
unsigned char *p, *q; unsigned char *p, *q;
@ -534,18 +555,24 @@ this_try_alloc_color_pair (char *fg, char *bg)
if (!*fg) if (!*fg)
fg = 0; fg = 0;
if (fg) { if (fg) {
strcpy (f, fg); p = g_tree_lookup (defines, fg);
if (p)
fg = p;
strncpy (f, fg, sizeof (f) - 1);
f[sizeof (f) - 1] = 0;
p = strchr (f, '/'); p = strchr (f, '/');
if (p) if (p)
*p = '\0'; *p = '\0';
fg = f;
} }
if (bg) { if (bg) {
strcpy (b, bg); p = g_tree_lookup (defines, bg);
if (p)
bg = p;
strncpy (b, bg, sizeof (b) - 1);
b[sizeof (b) - 1] = 0;
p = strchr (b, '/'); p = strchr (b, '/');
if (p) if (p)
*p = '\0'; *p = '\0';
bg = b;
} }
return try_alloc_color_pair (fg, bg); return try_alloc_color_pair (fg, bg);
} }
@ -596,6 +623,8 @@ static int edit_read_syntax_rules (WEdit * edit, FILE * f)
r = edit->rules = g_malloc0 (MAX_CONTEXTS * sizeof (struct context_rule *)); r = edit->rules = g_malloc0 (MAX_CONTEXTS * sizeof (struct context_rule *));
defines = g_tree_new ((GCompareFunc) strcmp);
for (;;) { for (;;) {
char **a; char **a;
line++; line++;
@ -705,8 +734,10 @@ static int edit_read_syntax_rules (WEdit * edit, FILE * f)
bg = *a; bg = *a;
if (*a) if (*a)
a++; a++;
strcpy (last_fg, fg ? fg : ""); strncpy (last_fg, fg ? fg : "", sizeof (last_fg) - 1);
strcpy (last_bg, bg ? bg : ""); last_fg[sizeof (last_fg) - 1] = 0;
strncpy (last_bg, bg ? bg : "", sizeof (last_bg) - 1);
last_bg[sizeof (last_bg) - 1] = 0;
c->keyword[0]->color = this_try_alloc_color_pair (fg, bg); c->keyword[0]->color = this_try_alloc_color_pair (fg, bg);
c->keyword[0]->keyword = g_strdup (" "); c->keyword[0]->keyword = g_strdup (" ");
check_not_a; check_not_a;
@ -762,6 +793,18 @@ static int edit_read_syntax_rules (WEdit * edit, FILE * f)
/* do nothing for comment */ /* do nothing for comment */
} else if (!strcmp (args[0], "file")) { } else if (!strcmp (args[0], "file")) {
break; break;
} else if (!strcmp (args[0], "define")) {
gpointer t;
char *key = *a++;
char *value = *a;
if (!key || !value)
break_a;
if ((t = g_tree_lookup (defines, key))){
g_free (t);
t = g_strdup (value);
} else {
g_tree_insert (defines, g_strdup (key), g_strdup (value));
}
} else { /* anything else is an error */ } else { /* anything else is an error */
break_a; break_a;
} }
@ -806,6 +849,8 @@ void edit_free_syntax_rules (WEdit * edit)
return; return;
if (!edit->rules) if (!edit->rules)
return; return;
if (defines)
destroy_defines ();
edit_get_rule (edit, -1); edit_get_rule (edit, -1);
syntax_g_free (edit->syntax_type); syntax_g_free (edit->syntax_type);
edit->syntax_type = 0; edit->syntax_type = 0;