diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/hash.c | 3 | ||||
-rw-r--r-- | lib/pile.c | 4 | ||||
-rw-r--r-- | lib/polynom.c | 9 | ||||
-rw-r--r-- | lib/scalaires.c | 7 |
4 files changed, 14 insertions, 9 deletions
@@ -9,6 +9,7 @@ #include <string.h> #include "hash.h" #include "exceptions.h" +#include "polynom.h" #ifdef HAVE_CONFIG_H #include "config.h" #else @@ -149,7 +150,7 @@ _TypeVariable NomVarToVar(char *Nom, _TableauVariable t, char *trouve) void AfficheListe(_ListeChaine l) { while (l != NULL) { - fprintf(stderr, "%s\n", l->Elem.NomVar); + fprintf(stderr, "%s: %s\n", l->Elem.NomVar, ply_affichage(l->Elem.Variable)); l = l->Suivant; } } @@ -150,6 +150,7 @@ void act_pile(int func) { pile_elem operande1, operande2; char buf[50]; + char valid; sprintf(buf, _("Calling act_pile(%i)"), func); pushcontext(buf); @@ -269,6 +270,9 @@ void act_pile(int func) operande2 = pop_pile(1); if ((operande1.type == T_POLY) && (operande2.type == T_STRING)) { if (operande2.label) { + NomVarToVar(operande2.label, variables, &valid); + if (valid) + SupprimerDansTab(&variables,operande2.label); InsererVarDansTab(&variables, CreerElement(operande2.label, (void *) operande1.poly)); free(operande2.label); } else { diff --git a/lib/polynom.c b/lib/polynom.c index 9dc2517..a50d0cb 100644 --- a/lib/polynom.c +++ b/lib/polynom.c @@ -3,15 +3,14 @@ * Operations sur les polynomes * */ - -#include "polynom.h" -#include "scalaires.h" -#include "exceptions.h" -#include "main.h" #include <stdio.h> #include <math.h> #include <stdlib.h> #include <string.h> +#include "polynom.h" +#include "scalaires.h" +#include "exceptions.h" +#include "main.h" #ifdef HAVE_CONFIG_H #include "config.h" #else diff --git a/lib/scalaires.c b/lib/scalaires.c index 7a97866..a58b627 100644 --- a/lib/scalaires.c +++ b/lib/scalaires.c @@ -3,10 +3,9 @@ * Operations sur les scalaires ( rationnels ) * */ - +#include <math.h> #include "scalaires.h" #include "exceptions.h" -#include <math.h> #ifdef HAVE_CONFIG_H #include "config.h" #else @@ -109,6 +108,8 @@ rationnel rat_multiplication(rationnel rat1, rationnel rat2) rationnel rat_division(rationnel rat1, rationnel rat2) { /* division */ - + if (!rat2.num) + exception(1,_("division by zero")); return rat_constr(rat1.num * rat2.denom, rat1.denom * rat2.num); + } |