X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdo-if.c;h=1acf84936c0b8b96c1bb16501a7b8dc882b2fa0a;hb=fa489d6ef77150e60c31906ee322bea2901da57f;hp=339710696326035de2bf4ec760a9b05dedfe246f;hpb=bc963dae9be291ea0a7cccf189d13e00d3797cfd;p=pspp-builds.git diff --git a/src/do-if.c b/src/do-if.c index 33971069..1acf8493 100644 --- a/src/do-if.c +++ b/src/do-if.c @@ -14,26 +14,25 @@ You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software - Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA - 02111-1307, USA. */ + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + 02110-1301, USA. */ #include #include "do-ifP.h" -#include +#include "error.h" #include #include "alloc.h" #include "command.h" #include "error.h" -#include "expr.h" +#include "expressions/public.h" #include "lexer.h" #include "str.h" #include "var.h" -#include "debug-print.h" +#include "gettext.h" +#define _(msgid) gettext (msgid) -#if DEBUGGING -#include -#endif +#include "debug-print.h" /* *INDENT-OFF* */ /* Description of DO IF transformations: @@ -155,8 +154,6 @@ cmd_else (void) { struct do_if_trns *t; - lex_match_id ("ELSE"); - /* Check that we're in a pleasing situation. */ if (!ctl_stack || ctl_stack->type != CST_DO_IF) { @@ -198,8 +195,6 @@ cmd_end_if (void) /* List iterator. */ struct do_if_trns *iter; - lex_match_id ("IF"); - /* Check that we're in a pleasing situation. */ if (!ctl_stack || ctl_stack->type != CST_DO_IF) { @@ -252,9 +247,7 @@ parse_do_if (void) struct do_if_trns *t; struct expression *e; - lex_match_id ("IF"); - - e = expr_parse (PXP_BOOLEAN); + e = expr_parse (default_dict, EXPR_BOOLEAN); if (!e) return NULL; if (token != '.') @@ -286,15 +279,15 @@ do_if_trns_proc (struct trns_header * trns, struct ccase * c, int case_num UNUSED) { struct do_if_trns *t = (struct do_if_trns *) trns; - union value bool; + double boolean; - expr_evaluate (t->cond, c, case_num, &bool); - if (bool.f == 1.0) + boolean = expr_evaluate_num (t->cond, c, case_num); + if (boolean == 1.0) { debug_printf ((_("DO IF %d: true\n"), t->h.index)); return -1; } - else if (bool.f == 0.0) + else if (boolean == 0.0) { debug_printf ((_("DO IF %d: false\n"), t->h.index)); return t->false_jump;