| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705 |
- /*$file${.::calc2.c} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
- /*
- * Model: calc2.qm
- * File: ${.::calc2.c}
- *
- * This code has been generated by QM 5.2.4 <www.state-machine.com/qm>.
- * DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
- *
- * SPDX-License-Identifier: GPL-3.0-or-later
- *
- * This generated code is open source software: you can redistribute it under
- * the terms of the GNU General Public License as published by the Free
- * Software Foundation.
- *
- * This code 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.
- *
- * NOTE:
- * Alternatively, this generated code may be distributed under the terms
- * of Quantum Leaps commercial licenses, which expressly supersede the GNU
- * General Public License and are specifically designed for licensees
- * interested in retaining the proprietary status of their code.
- *
- * Contact information:
- * <www.state-machine.com/licensing>
- * <info@state-machine.com>
- */
- /*$endhead${.::calc2.c} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
- #include "qpc.h" /* QP/C */
- #include "bsp.h" /* board support package */
- #include "calc2.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} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
- /*${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, void const * const par);
- 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_operand(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_final(Calc * const me, QEvt const * const e);
- /*$enddecl${SMs::Calc} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
- /*$skip${QP_VERSION} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
- /* Check for the minimum required QP version */
- #if (QP_VERSION < 700U) || (QP_VERSION != ((QP_RELEASE^4294967295U) % 0x3E8U))
- #error qpc version 7.0.0 or higher required
- #endif
- /*$endskip${QP_VERSION} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
- /*$define${SMs::the_calc} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
- /*${SMs::the_calc} .........................................................*/
- QHsm * const the_calc = &Calc_inst.super;
- /*$enddef${SMs::the_calc} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
- /*$define${SMs::Calc_ctor} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
- /*${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} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
- /*${SMs::Calc} .............................................................*/
- Calc Calc_inst;
- /*${SMs::Calc::eval} .......................................................*/
- static bool Calc_eval(Calc * const me,
- double op,
- uint8_t oper)
- {
- double result;
- if (me->oper1 == KEY_NULL) { /* no op1 yet */
- me->op1 = op;
- me->oper1 = oper;
- result = me->op1;
- }
- else 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, void const * const par) {
- /*${SMs::Calc::SM::initial} */
- (void)par; /* 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_;
- }
- /*${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->oper1 = KEY_NULL;
- 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::operand} ............................................*/
- static QState Calc_operand(Calc * const me, QEvt const * const e) {
- QState status_;
- switch (e->sig) {
- /*${SMs::Calc::SM::on::operand} */
- case Q_ENTRY_SIG: {
- BSP_message("operand1-ENTRY;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand} */
- case Q_EXIT_SIG: {
- BSP_message("operand1-EXIT;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::CE} */
- case CE_SIG: {
- BSP_clear();
- status_ = Q_TRAN(&Calc_ready);
- break;
- }
- /*${SMs::Calc::SM::on::operand::EQUALS} */
- case EQUALS_SIG: {
- /*${SMs::Calc::SM::on::operand::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::operand::EQUALS::[else]} */
- else {
- status_ = Q_TRAN(&Calc_error);
- }
- break;
- }
- /*${SMs::Calc::SM::on::operand::OPER} */
- case OPER_SIG: {
- /*${SMs::Calc::SM::on::operand::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::operand::OPER::[else]} */
- else {
- status_ = Q_TRAN(&Calc_error);
- }
- break;
- }
- default: {
- status_ = Q_SUPER(&Calc_on);
- break;
- }
- }
- return status_;
- }
- /*${SMs::Calc::SM::on::operand::zero1} .....................................*/
- static QState Calc_zero1(Calc * const me, QEvt const * const e) {
- QState status_;
- switch (e->sig) {
- /*${SMs::Calc::SM::on::operand::zero1} */
- case Q_ENTRY_SIG: {
- BSP_message("zero1-ENTRY;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::zero1} */
- case Q_EXIT_SIG: {
- BSP_message("zero1-EXIT;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::zero1::DIGIT_0} */
- case DIGIT_0_SIG: {
- ;
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::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::operand::zero1::POINT} */
- case POINT_SIG: {
- BSP_insert((int)'0');
- BSP_insert((int)'.');
- status_ = Q_TRAN(&Calc_frac1);
- break;
- }
- default: {
- status_ = Q_SUPER(&Calc_operand);
- break;
- }
- }
- return status_;
- }
- /*${SMs::Calc::SM::on::operand::int1} ......................................*/
- static QState Calc_int1(Calc * const me, QEvt const * const e) {
- QState status_;
- switch (e->sig) {
- /*${SMs::Calc::SM::on::operand::int1} */
- case Q_ENTRY_SIG: {
- BSP_message("int1-ENTRY;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::int1} */
- case Q_EXIT_SIG: {
- BSP_message("int1-EXIT;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::int1::POINT} */
- case POINT_SIG: {
- BSP_insert((int)'.');
- status_ = Q_TRAN(&Calc_frac1);
- break;
- }
- /*${SMs::Calc::SM::on::operand::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_operand);
- break;
- }
- }
- return status_;
- }
- /*${SMs::Calc::SM::on::operand::frac1} .....................................*/
- static QState Calc_frac1(Calc * const me, QEvt const * const e) {
- QState status_;
- switch (e->sig) {
- /*${SMs::Calc::SM::on::operand::frac1} */
- case Q_ENTRY_SIG: {
- BSP_message("frac1-ENTRY;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::frac1} */
- case Q_EXIT_SIG: {
- BSP_message("frac1-EXIT;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::frac1::POINT} */
- case POINT_SIG: {
- ;
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::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_operand);
- break;
- }
- }
- return status_;
- }
- /*${SMs::Calc::SM::on::operand::negated1} ..................................*/
- static QState Calc_negated1(Calc * const me, QEvt const * const e) {
- QState status_;
- switch (e->sig) {
- /*${SMs::Calc::SM::on::operand::negated1} */
- case Q_ENTRY_SIG: {
- BSP_message("negated1-ENTRY;");
- BSP_negate();
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::negated1} */
- case Q_EXIT_SIG: {
- BSP_message("negated1-EXIT;");
- status_ = Q_HANDLED();
- break;
- }
- /*${SMs::Calc::SM::on::operand::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::operand::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::operand::negated1::POINT} */
- case POINT_SIG: {
- BSP_insert(Q_EVT_CAST(CalcEvt)->key_code);
- status_ = Q_TRAN(&Calc_frac1);
- break;
- }
- /*${SMs::Calc::SM::on::operand::negated1::OPER} */
- case OPER_SIG: {
- /*${SMs::Calc::SM::on::operand::negated1::OPER::[e->key=='-']} */
- if (Q_EVT_CAST(CalcEvt)->key_code == KEY_MINUS) {
- ;
- status_ = Q_HANDLED();
- }
- /*${SMs::Calc::SM::on::operand::negated1::OPER::[else]} */
- else {
- status_ = Q_HANDLED();
- }
- break;
- }
- default: {
- status_ = Q_SUPER(&Calc_operand);
- 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_zero1);
- 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_int1);
- break;
- }
- /*${SMs::Calc::SM::on::opEntered::POINT} */
- case POINT_SIG: {
- BSP_clear();
- BSP_insert((int)'0');
- BSP_insert((int)'.');
- status_ = Q_TRAN(&Calc_frac1);
- 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_negated1);
- }
- /*${SMs::Calc::SM::on::opEntered::OPER::[else]} */
- else {
- status_ = Q_HANDLED();
- }
- break;
- }
- default: {
- status_ = Q_SUPER(&Calc_on);
- 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} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
|