mirror of
https://github.com/QuantumLeaps/qpc.git
synced 2025-01-28 07:03:10 +08:00
891 lines
28 KiB
C
891 lines
28 KiB
C
/*.$file${.::calc1.c} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
|
|
/*
|
|
* Model: calc1.qm
|
|
* File: ${.::calc1.c}
|
|
*
|
|
* This code has been generated by QM 4.6.0 <www.state-machine.com/qm/>.
|
|
* DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
|
|
*
|
|
* This program is open source software: you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License as published
|
|
* by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* for more details.
|
|
*/
|
|
/*.$endhead${.::calc1.c} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
|
|
#include "qpc.h" /* QP/C */
|
|
#include "bsp.h" /* board support package */
|
|
#include "calc1.h" /* application */
|
|
|
|
Q_DEFINE_THIS_FILE
|
|
|
|
#define KEY_NULL '\0'
|
|
#define KEY_PLUS '+'
|
|
#define KEY_MINUS '-'
|
|
#define KEY_MULT '*'
|
|
#define KEY_DIVIDE '/'
|
|
|
|
/*.$declare${SMs::Calc} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
|
|
/*.${SMs::Calc} ............................................................*/
|
|
typedef struct Calc {
|
|
/* protected: */
|
|
QHsm super;
|
|
|
|
/* public: */
|
|
|
|
/* private: */
|
|
double op1;
|
|
double op2;
|
|
uint8_t oper1;
|
|
uint8_t oper2;
|
|
} Calc;
|
|
|
|
/* private: */
|
|
|
|
/* guard function to evaluate the current expression
|
|
* taking into account the precedence of operands.
|
|
* return: true if evaluation successfull
|
|
* false when error encountered
|
|
*/
|
|
static bool Calc_eval(Calc * const me, double op, uint8_t oper);
|
|
extern Calc Calc_inst;
|
|
|
|
/* protected: */
|
|
static QState Calc_initial(Calc * const me, QEvt const * const e);
|
|
static QState Calc_on(Calc * const me, QEvt const * const e);
|
|
|
|
/* Error state after evaluation of an expression.
|
|
This state can be exited only throgh the inherited C (Clear) event.
|
|
*/
|
|
static QState Calc_error(Calc * const me, QEvt const * const e);
|
|
static QState Calc_ready(Calc * const me, QEvt const * const e);
|
|
static QState Calc_result(Calc * const me, QEvt const * const e);
|
|
static QState Calc_begin(Calc * const me, QEvt const * const e);
|
|
static QState Calc_operand1(Calc * const me, QEvt const * const e);
|
|
static QState Calc_zero1(Calc * const me, QEvt const * const e);
|
|
static QState Calc_int1(Calc * const me, QEvt const * const e);
|
|
static QState Calc_frac1(Calc * const me, QEvt const * const e);
|
|
static QState Calc_negated1(Calc * const me, QEvt const * const e);
|
|
static QState Calc_opEntered(Calc * const me, QEvt const * const e);
|
|
static QState Calc_operand2(Calc * const me, QEvt const * const e);
|
|
static QState Calc_zero2(Calc * const me, QEvt const * const e);
|
|
static QState Calc_int2(Calc * const me, QEvt const * const e);
|
|
static QState Calc_frac2(Calc * const me, QEvt const * const e);
|
|
static QState Calc_negated2(Calc * const me, QEvt const * const e);
|
|
static QState Calc_final(Calc * const me, QEvt const * const e);
|
|
/*.$enddecl${SMs::Calc} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
|
|
|
|
/*.$skip${QP_VERSION} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
|
|
/*. Check for the minimum required QP version */
|
|
#if (QP_VERSION < 650U) || (QP_VERSION != ((QP_RELEASE^4294967295U) % 0x3E8U))
|
|
#error qpc version 6.5.0 or higher required
|
|
#endif
|
|
/*.$endskip${QP_VERSION} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
|
|
/*.$define${SMs::the_calc} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
|
|
/*.${SMs::the_calc} ........................................................*/
|
|
QHsm * const the_calc = &Calc_inst.super;
|
|
/*.$enddef${SMs::the_calc} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
|
|
/*.$define${SMs::Calc_ctor} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
|
|
/*.${SMs::Calc_ctor} .......................................................*/
|
|
void Calc_ctor(void) {
|
|
Calc *me = &Calc_inst;
|
|
QHsm_ctor(&me->super, Q_STATE_CAST(&Calc_initial));
|
|
}
|
|
/*.$enddef${SMs::Calc_ctor} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
|
|
/*.$define${SMs::Calc} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
|
|
/*.${SMs::Calc} ............................................................*/
|
|
Calc Calc_inst;
|
|
|
|
/* guard function to evaluate the current expression
|
|
* taking into account the precedence of operands.
|
|
* return: true if evaluation successfull
|
|
* false when error encountered
|
|
*/
|
|
/*.${SMs::Calc::eval} ......................................................*/
|
|
static bool Calc_eval(Calc * const me, double op, uint8_t oper) {
|
|
double result;
|
|
if ((oper == KEY_NULL) || (oper == KEY_PLUS) || (oper == KEY_MINUS)) {
|
|
switch (me->oper2) {
|
|
case KEY_MULT: {
|
|
me->op2 *= op;
|
|
break;
|
|
}
|
|
case KEY_DIVIDE: {
|
|
if ((-1e-30 < op) && (op < 1e-30)) {
|
|
BSP_display_error(" Error 0 "); /* divide by zero */
|
|
return false;
|
|
}
|
|
me->op2 /= op;
|
|
break;
|
|
}
|
|
default: { /* no op2 yet */
|
|
me->op2 = op;
|
|
me->oper2 = oper;
|
|
break;
|
|
}
|
|
}
|
|
switch (me->oper1) {
|
|
case KEY_PLUS: {
|
|
me->op1 += me->op2;
|
|
break;
|
|
}
|
|
case KEY_MINUS: {
|
|
me->op1 -= me->op2;
|
|
break;
|
|
}
|
|
case KEY_MULT: {
|
|
me->op1 *= me->op2;
|
|
break;
|
|
}
|
|
case KEY_DIVIDE: {
|
|
if ((-1e-30 < me->op2) && (me->op2 < 1e-30)) {
|
|
BSP_display_error(" Error 0 "); /* divide by zero */
|
|
return false;
|
|
}
|
|
me->op1 /= me->op2;
|
|
break;
|
|
}
|
|
default: {
|
|
Q_ERROR();
|
|
break;
|
|
}
|
|
}
|
|
me->oper1 = oper;
|
|
me->oper2 = KEY_NULL;
|
|
result = me->op1;
|
|
}
|
|
else { /* (oper == KEY_MULT) || (oper == KEY_DIV) */
|
|
switch (me->oper2) {
|
|
case KEY_MULT: {
|
|
me->op2 *= op;
|
|
break;
|
|
}
|
|
case KEY_DIVIDE: {
|
|
if ((-1e-30 < op) && (op < 1e-30)) {
|
|
BSP_display_error(" Error 0 "); /* divide by zero */
|
|
return false;
|
|
}
|
|
me->op2 /= op;
|
|
break;
|
|
}
|
|
default: { /* oper2 not provided yet */
|
|
me->op2 = op;
|
|
break;
|
|
}
|
|
}
|
|
me->oper2 = oper;
|
|
result = me->op2;
|
|
}
|
|
|
|
if ((result < -99999999.0) || (99999999.0 < result)) {
|
|
BSP_display_error(" Error 1 "); /* out of range */
|
|
return false;
|
|
}
|
|
if ((-0.0000001 < result) && (result < 0.0000001)) {
|
|
result = 0.0;
|
|
}
|
|
BSP_display(result);
|
|
|
|
return true;
|
|
}
|
|
|
|
/*.${SMs::Calc::SM} ........................................................*/
|
|
static QState Calc_initial(Calc * const me, QEvt const * const e) {
|
|
/*.${SMs::Calc::SM::initial} */
|
|
(void)e; /* unused parameter */
|
|
return Q_TRAN(&Calc_on);
|
|
}
|
|
/*.${SMs::Calc::SM::on} ....................................................*/
|
|
static QState Calc_on(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("on-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("on-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::initial} */
|
|
case Q_INIT_SIG: {
|
|
BSP_message("on-INIT;");
|
|
BSP_clear();
|
|
status_ = Q_TRAN(&Calc_ready);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::C} */
|
|
case C_SIG: {
|
|
status_ = Q_TRAN(&Calc_on);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::OFF} */
|
|
case OFF_SIG: {
|
|
status_ = Q_TRAN(&Calc_final);
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&QHsm_top);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
|
|
/* Error state after evaluation of an expression.
|
|
This state can be exited only throgh the inherited C (Clear) event.
|
|
*/
|
|
/*.${SMs::Calc::SM::on::error} .............................................*/
|
|
static QState Calc_error(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::error} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("error-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::error} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("error-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_on);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready} .............................................*/
|
|
static QState Calc_ready(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::ready} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("ready-ENTRY;");
|
|
me->oper2 = KEY_NULL;
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("ready-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::initial} */
|
|
case Q_INIT_SIG: {
|
|
BSP_message("ready-INIT;");
|
|
status_ = Q_TRAN(&Calc_begin);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::DIGIT_0} */
|
|
case DIGIT_0_SIG: {
|
|
BSP_clear();
|
|
status_ = Q_TRAN(&Calc_zero1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::DIGIT_1_9} */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_clear();
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_int1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_clear();
|
|
BSP_insert((int)'0');
|
|
BSP_insert((int)'.');
|
|
status_ = Q_TRAN(&Calc_frac1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::OPER} */
|
|
case OPER_SIG: {
|
|
me->op1 = BSP_get_value();
|
|
me->oper1 = Q_EVT_CAST(CalcEvt)->key_code;
|
|
status_ = Q_TRAN(&Calc_opEntered);
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_on);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::result} .....................................*/
|
|
static QState Calc_result(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::ready::result} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("result-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::result} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("result-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_ready);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::begin} ......................................*/
|
|
static QState Calc_begin(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::ready::begin} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("begin-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::begin} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("begin-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::begin::OPER} */
|
|
case OPER_SIG: {
|
|
/*.${SMs::Calc::SM::on::ready::begin::OPER::[e->key=='-']} */
|
|
if (Q_EVT_CAST(CalcEvt)->key_code == KEY_MINUS) {
|
|
status_ = Q_TRAN(&Calc_negated1);
|
|
}
|
|
/*.${SMs::Calc::SM::on::ready::begin::OPER::[else]} */
|
|
else {
|
|
status_ = Q_HANDLED();
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_ready);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1} ..........................................*/
|
|
static QState Calc_operand1(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand1} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("operand1-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("operand1-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::CE} */
|
|
case CE_SIG: {
|
|
BSP_clear();
|
|
status_ = Q_TRAN(&Calc_ready);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::OPER} */
|
|
case OPER_SIG: {
|
|
me->op1 = BSP_get_value();
|
|
me->oper1 = Q_EVT_CAST(CalcEvt)->key_code;
|
|
status_ = Q_TRAN(&Calc_opEntered);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::EQUALS} */
|
|
case EQUALS_SIG: {
|
|
status_ = Q_TRAN(&Calc_result);
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_on);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::zero1} ...................................*/
|
|
static QState Calc_zero1(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand1::zero1} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("zero1-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::zero1} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("zero1-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::zero1::DIGIT_0} */
|
|
case DIGIT_0_SIG: {
|
|
;
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::zero1::DIGIT_1_9} */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_int1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::zero1::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_insert((int)'0');
|
|
BSP_insert((int)'.');
|
|
status_ = Q_TRAN(&Calc_frac1);
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand1);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::int1} ....................................*/
|
|
static QState Calc_int1(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand1::int1} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("int1-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::int1} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("int1-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::int1::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_insert((int)'.');
|
|
status_ = Q_TRAN(&Calc_frac1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::int1::DIGIT_0, DIGIT_1_9} */
|
|
case DIGIT_0_SIG: /* intentionally fall through */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand1);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::frac1} ...................................*/
|
|
static QState Calc_frac1(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand1::frac1} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("frac1-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::frac1} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("frac1-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::frac1::POINT} */
|
|
case POINT_SIG: {
|
|
;
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::frac1::DIGIT_0, DIGIT_1_9} */
|
|
case DIGIT_0_SIG: /* intentionally fall through */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand1);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::negated1} ................................*/
|
|
static QState Calc_negated1(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand1::negated1} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("negated1-ENTRY;");
|
|
BSP_negate();
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::negated1} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("negated1-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::negated1::DIGIT_0} */
|
|
case DIGIT_0_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_zero1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::negated1::DIGIT_1_9} */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_int1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::negated1::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_frac1);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::negated1::OPER} */
|
|
case OPER_SIG: {
|
|
/*.${SMs::Calc::SM::on::operand1::negated1::OPER::[e->key=='-']} */
|
|
if (Q_EVT_CAST(CalcEvt)->key_code == KEY_MINUS) {
|
|
;
|
|
status_ = Q_HANDLED();
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand1::negated1::OPER::[else]} */
|
|
else {
|
|
status_ = Q_HANDLED();
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand1);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::opEntered} .........................................*/
|
|
static QState Calc_opEntered(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::opEntered} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("opEntered-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::opEntered} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("opEntered-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::opEntered::DIGIT_0} */
|
|
case DIGIT_0_SIG: {
|
|
BSP_clear();
|
|
status_ = Q_TRAN(&Calc_zero2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::opEntered::DIGIT_1_9} */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_clear();
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_int2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::opEntered::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_clear();
|
|
BSP_insert((int)'0');
|
|
BSP_insert((int)'.');
|
|
status_ = Q_TRAN(&Calc_frac2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::opEntered::OPER} */
|
|
case OPER_SIG: {
|
|
/*.${SMs::Calc::SM::on::opEntered::OPER::[e->key=='-']} */
|
|
if (Q_EVT_CAST(CalcEvt)->key_code == KEY_MINUS) {
|
|
status_ = Q_TRAN(&Calc_negated2);
|
|
}
|
|
/*.${SMs::Calc::SM::on::opEntered::OPER::[else]} */
|
|
else {
|
|
status_ = Q_HANDLED();
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_on);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2} ..........................................*/
|
|
static QState Calc_operand2(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand2} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("operand2-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("operand2-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::CE} */
|
|
case CE_SIG: {
|
|
BSP_clear();
|
|
status_ = Q_TRAN(&Calc_opEntered);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::EQUALS} */
|
|
case EQUALS_SIG: {
|
|
/*.${SMs::Calc::SM::on::operand2::EQUALS::[Calc_eval(me,BSP_get_value(),KE~} */
|
|
if (Calc_eval(me, BSP_get_value(), KEY_NULL)) {
|
|
status_ = Q_TRAN(&Calc_result);
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::EQUALS::[else]} */
|
|
else {
|
|
status_ = Q_TRAN(&Calc_error);
|
|
}
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::OPER} */
|
|
case OPER_SIG: {
|
|
/*.${SMs::Calc::SM::on::operand2::OPER::[Calc_eval(me,BSP_get_value(),Q_~} */
|
|
if (Calc_eval(me, BSP_get_value(), Q_EVT_CAST(CalcEvt)->key_code)) {
|
|
status_ = Q_TRAN(&Calc_opEntered);
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::OPER::[else]} */
|
|
else {
|
|
status_ = Q_TRAN(&Calc_error);
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_on);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::zero2} ...................................*/
|
|
static QState Calc_zero2(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand2::zero2} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("zero2-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::zero2} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("zero2-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::zero2::DIGIT_0} */
|
|
case DIGIT_0_SIG: {
|
|
;
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::zero2::DIGIT_1_9} */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_int2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::zero2::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_insert((int)'0');
|
|
BSP_insert((int)'.');
|
|
status_ = Q_TRAN(&Calc_frac2);
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand2);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::int2} ....................................*/
|
|
static QState Calc_int2(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand2::int2} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("int2-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::int2} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("int2-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::int2::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_insert((int)'.');
|
|
status_ = Q_TRAN(&Calc_frac2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::int2::DIGIT_0, DIGIT_1_9} */
|
|
case DIGIT_0_SIG: /* intentionally fall through */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand2);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::frac2} ...................................*/
|
|
static QState Calc_frac2(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand2::frac2} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("frac2-ENTRY;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::frac2} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("frac2-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::frac2::POINT} */
|
|
case POINT_SIG: {
|
|
;
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::frac2::DIGIT_0, DIGIT_1_9} */
|
|
case DIGIT_0_SIG: /* intentionally fall through */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand2);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::negated2} ................................*/
|
|
static QState Calc_negated2(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::on::operand2::negated2} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("negated2-ENTRY;");
|
|
BSP_negate();
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::negated2} */
|
|
case Q_EXIT_SIG: {
|
|
BSP_message("negated2-EXIT;");
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::negated2::DIGIT_0} */
|
|
case DIGIT_0_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_zero2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::negated2::DIGIT_1_9} */
|
|
case DIGIT_1_9_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_int2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::negated2::POINT} */
|
|
case POINT_SIG: {
|
|
BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
|
|
status_ = Q_TRAN(&Calc_frac2);
|
|
break;
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::negated2::OPER} */
|
|
case OPER_SIG: {
|
|
/*.${SMs::Calc::SM::on::operand2::negated2::OPER::[e->key=='-']} */
|
|
if (Q_EVT_CAST(CalcEvt)->key_code == KEY_MINUS) {
|
|
;
|
|
status_ = Q_HANDLED();
|
|
}
|
|
/*.${SMs::Calc::SM::on::operand2::negated2::OPER::[else]} */
|
|
else {
|
|
status_ = Q_HANDLED();
|
|
}
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&Calc_operand2);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.${SMs::Calc::SM::final} .................................................*/
|
|
static QState Calc_final(Calc * const me, QEvt const * const e) {
|
|
QState status_;
|
|
switch (e->sig) {
|
|
/*.${SMs::Calc::SM::final} */
|
|
case Q_ENTRY_SIG: {
|
|
BSP_message("final-ENTRY;");
|
|
BSP_exit();
|
|
status_ = Q_HANDLED();
|
|
break;
|
|
}
|
|
default: {
|
|
status_ = Q_SUPER(&QHsm_top);
|
|
break;
|
|
}
|
|
}
|
|
return status_;
|
|
}
|
|
/*.$enddef${SMs::Calc} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
|