diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/exceptions.c | 35 | ||||
| -rw-r--r-- | lib/hash.c | 2 | ||||
| -rw-r--r-- | lib/parser.c | 20 | ||||
| -rw-r--r-- | lib/pile.c | 35 | ||||
| -rw-r--r-- | lib/polynom.c | 2 | ||||
| -rw-r--r-- | lib/scalaires.c | 2 | 
6 files changed, 67 insertions, 29 deletions
| diff --git a/lib/exceptions.c b/lib/exceptions.c index 0fc363e..e59013b 100644 --- a/lib/exceptions.c +++ b/lib/exceptions.c @@ -13,6 +13,7 @@  #define _(x) x  #endif  #include "exceptions.h" +#include "pile.h"  char *contexts[128];  int clevel = 0; @@ -23,7 +24,7 @@ char *Estrdup(char *o)  	if (o) {  		if (!(r = strdup(o))) { -			exception(1, _("Out of memory.")); +			exception(2, _("Out of memory."));  		}  	} else {  		return NULL; @@ -37,7 +38,7 @@ void *Emalloc(size_t s)  	if (s) {  		if (!(r = malloc(s))) { -			exception(1, _("Out of memory.")); +			exception(2, _("Out of memory."));  		}  	} else {  		return NULL; @@ -48,7 +49,7 @@ void *Emalloc(size_t s)  void pushcontext(char *c)  {  	if (clevel == 128) { -		exception(1, _("Too much error contexts during pushcontext().")); +		exception(2, _("Too much error contexts during pushcontext()."));  	}  	contexts[clevel++] = Estrdup(c);  #ifdef DEBUG @@ -59,7 +60,7 @@ void pushcontext(char *c)  void popcontext(void)  {  	if (clevel == 0) { -		exception(1, _("Error context empty, but popcontext() called.")); +		exception(2, _("Error context empty, but popcontext() called."));  	}  	free(contexts[--clevel]);  } @@ -71,14 +72,24 @@ void flushcontext(void)  	}  } -void exception(int level, char *msg) +/* exception avec level=1 pour une erreur non fatale avec vidage de la pile sinon  +pour toutre valeur de level erreur avec terminaison du programme */ + +void exception(int level, char *msg)   {  	int i; - -	fprintf(stderr, "Error detected. Showing context.\n"); -	for (i = 0; i < clevel; i++) { -		fprintf(stderr, " (%i) - %s\n", i, contexts[i]); -	} -	fprintf(stderr, "  Error description: %s\n", msg); -	exit(level); +	switch (level) { +	case 1: +		fprintf(stderr, "  Error description: %s\n", msg); +		flush_pile(); +		break; +	default: +		fprintf(stderr, "Error detected. Showing context.\n"); +		for (i = 0; i < clevel; i++) { +			fprintf(stderr, " (%i) - %s\n", i, contexts[i]); +		} +		fprintf(stderr, "  Error description: %s\n", msg); +		exit(1); +		break; +	}	  } @@ -24,7 +24,7 @@ static int FonctionHachage(char *clef)  	unsigned int i;  	if (!clef) { -		exception(1, _("Internal error into hashing")); +		exception(2, _("Internal error into hashing"));  	}  	for (i = 0; i < strlen(CHAINEHACHAGE); i++) { diff --git a/lib/parser.c b/lib/parser.c index 60e3dca..6d608b4 100644 --- a/lib/parser.c +++ b/lib/parser.c @@ -96,7 +96,7 @@ static void push_op(op_t op)  	if (pileop_pos != PILEOP_MAX)  		pile_operators[pileop_pos++] = op;  	else -		exception(-1, _("Too many nested operators in expression.\n")); +		exception(2, _("Too many nested operators in expression.\n"));  } @@ -127,7 +127,7 @@ static void push_call(int call)  	if (pilecall_pos != PILECALL_MAX)  		pile_nestedcall[pilecall_pos++] = call;  	else -		exception(-1, _("Too many nested functions calls in expression.\n")); +		exception(2, _("Too many nested functions calls in expression.\n"));  }  /* Cette fonction lit un "mot" sur la chaine line et renvoit le nouveau pointeur */ @@ -204,9 +204,9 @@ void parse_line(char *line)  			}  			if (get_pri(buffer[0]) == -1) {  				if (got_unary) { -					exception(-1, _("Invalid unary operator")); +					exception(1, _("Invalid unary operator"));  				} else { -					exception(-1, _("Invalid binary operator")); +					exception(1, _("Invalid binary operator"));  				}  			}  			while (get_pri(get_last_op()) >= get_pri(buffer[0]) @@ -232,7 +232,7 @@ void parse_line(char *line)  				while (pileop_pos) {  					op = pop_op();  					if (op == '(') -						exception(-1, _("Parse error: too much left parenthesis")); +						exception(1, _("Parse error: too much left parenthesis"));  					act_pile(get_func(op));  				}  				popcontext(); @@ -242,12 +242,12 @@ void parse_line(char *line)  				/* Fin de parenthese (Appel de fonction ou expression mathématique) */  				while (1) {  					if (!pileop_pos) -						exception(-1, _("Parse error: too much right parenthesis")); +						exception(1, _("Parse error: too much right parenthesis"));  					op = pop_op();  					if (((op & 127) == '('))  						break;  					if (((op & 127) == '[')) -						exception(-1, _("Parse error: enclosure mismatch")); +						exception(1, _("Parse error: enclosure mismatch"));  					act_pile(get_func(op));  				}  				if (op == '(') { @@ -261,12 +261,12 @@ void parse_line(char *line)  				/* Fin d'opérateur de décalage */  				while (1) {  					if (!pileop_pos) -						exception(-1, _("Parse error: too much right parenthesis")); +						exception(1, _("Parse error: too much right parenthesis"));  					op = pop_op();  					if (((op & 127) == '['))  						break;  					if (((op & 127) == '(')) -						exception(-1, _("Parse error: enclosure mismatch")); +						exception(1, _("Parse error: enclosure mismatch"));  					act_pile(get_func(op));  				}  				act_pile(get_func(op)); @@ -285,7 +285,7 @@ void parse_line(char *line)  			if (!get_last_call())  				increment_call();  		} else if (buffer[0]) { -			exception(-1, _("Invalid character")); +			exception(1, _("Invalid character"));  		}  		popcontext();  	} @@ -73,7 +73,7 @@ void push_pile_poly(polynome poly)  		pile[pile_ptr].poly = poly;  		pile_ptr++;  	} else { -		exception(1, _("push_pile_poly: Stack Overflow")); +		exception(2, _("push_pile_poly: Stack Overflow"));  	}  } @@ -85,7 +85,7 @@ void push_pile_int(int val)  		pile[pile_ptr].val = val;  		pile_ptr++;  	} else { -		exception(1, _("push_pile_int: Stack Overflow")); +		exception(2, _("push_pile_int: Stack Overflow"));  	} @@ -98,7 +98,7 @@ void push_pile_string(char *st)  		pile[pile_ptr].label = Estrdup(st);  		pile_ptr++;  	} else { -		exception(1, _("push_pile_string: Stack Overflow")); +		exception(2, _("push_pile_string: Stack Overflow"));  	} @@ -112,11 +112,38 @@ pile_elem pop_pile(unsigned int count)  		pile_ptr -= count;  	} else {  		sprintf(buf, _("pop_pile: Can't pop %u elements"), count); -		exception(1, buf); +		exception(2, buf);  	}  	return pile[pile_ptr];  } +void flush_pile(void) +{ +	int i; + +	if (pile_ptr) { +		for (i = 0; i <= pile_ptr - 1; i++) { +			switch (pile[i].type) { +			case T_INT: +				break; +			case T_STRING: +				free(pile[i].label); +				break; +			case T_POLY: +				ply_destruct(pile[i].poly); +				break; +			} +		} +	} +	pile_ptr=0; +} + + + + + + +  char *affichage_level_1(void)  {  	char *result = NULL; diff --git a/lib/polynom.c b/lib/polynom.c index a50d0cb..241c2da 100644 --- a/lib/polynom.c +++ b/lib/polynom.c @@ -288,7 +288,7 @@ char *ply_affichage(polynome poly)  		if (count < BUFSIZ)  			strcat(buf, temp);  		else -			exception(1, _("ply_affichage: strcat error, not enoug space in buffer")); +			exception(2, _("ply_affichage: strcat error, not enoug space in buffer"));  		poly = poly->suiv;  	}  	return Estrdup(buf); diff --git a/lib/scalaires.c b/lib/scalaires.c index a58b627..ab97084 100644 --- a/lib/scalaires.c +++ b/lib/scalaires.c @@ -109,7 +109,7 @@ rationnel rat_multiplication(rationnel rat1, rationnel rat2)  rationnel rat_division(rationnel rat1, rationnel rat2)  {				/* division */  	if (!rat2.num) -		exception(1,_("division by zero")); +		exception(2,_("division by zero"));  	return rat_constr(rat1.num * rat2.denom, rat1.denom * rat2.num);  } | 
