* 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.
Этот коммит содержится в:
родитель
9c5a3c3b8d
Коммит
0158eaf0f3
@ -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;
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user