abCalc/ops/abCOpSl.c

45 lines
654 B
C

/*
abCOpSl.c
By: Jeremy Rand
*/
#include <stdio.h>
#include "abCOpSl.h"
#include "abCOp.h"
#include "abCError.h"
#include "abCExpr.h"
#include "abCExprInt.h"
#include "abCStack.h"
#define OP_NAME "SL"
static void slExecute(void);
void abCalcOpSlInit(void)
{
abCalcOpRegister(OP_NAME, slExecute);
}
void slExecute(void)
{
abCalcExpr result;
AB_CALC_OP_ONE_ARG(OP_NAME);
if (expr->type != abCalcExprTypeInt) {
abCalcRaiseError(abCalcBadArgTypeError, OP_NAME);
return;
}
abCalcExprIntSet(&result, (expr->u.integer << 1));
abCalcStackExprPop(NULL);
abCalcStackExprPush(&result);
}