446 lines
14 KiB
C++
Raw Normal View History

2012-08-14 18:00:48 -04:00
//////////////////////////////////////////////////////////////////////////////
// Model: pelican.qm
2013-10-10 20:01:51 -04:00
// File: ./pelican.cpp
2012-08-14 18:00:48 -04:00
//
2013-10-10 20:01:51 -04:00
// This code has been generated by QM tool (see state-machine.com/qm).
// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
2012-08-14 18:00:48 -04:00
//
2013-10-10 20:01:51 -04:00
// 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.
2012-08-14 18:00:48 -04:00
//////////////////////////////////////////////////////////////////////////////
2013-10-10 20:01:51 -04:00
// @(/3/1) ...................................................................
2012-08-14 18:00:48 -04:00
#include "qp_port.h"
#include "bsp.h"
#include "pelican.h"
namespace PELICAN {
Q_DEFINE_THIS_FILE
enum PelicanTimeouts { // various timeouts in ticks
CARS_GREEN_MIN_TOUT = BSP_TICKS_PER_SEC * 8, // min green for cars
CARS_YELLOW_TOUT = BSP_TICKS_PER_SEC * 3, // yellow for cars
PEDS_WALK_TOUT = BSP_TICKS_PER_SEC * 3, // walking time for peds
PEDS_FLASH_TOUT = BSP_TICKS_PER_SEC / 5, // flashing timeout for peds
PEDS_FLASH_NUM = 5*2, // number of flashes for peds
OFF_FLASH_TOUT = BSP_TICKS_PER_SEC / 2 // flashing timeout when off
};
// Pelican class -------------------------------------------------------------
2013-10-10 20:01:51 -04:00
// @(/2/0) ...................................................................
class Pelican : public QP::GuiQActive {
2012-08-14 18:00:48 -04:00
private:
QP::QTimeEvt m_timeout;
uint8_t m_flashCtr;
public:
2013-10-10 20:01:51 -04:00
Pelican()
: GuiQActive(Q_STATE_CAST(&Pelican::initial)),
m_timeout(TIMEOUT_SIG)
2012-08-14 18:00:48 -04:00
{
2013-10-10 20:01:51 -04:00
// empty
2012-08-14 18:00:48 -04:00
}
protected:
static QP::QState initial(Pelican * const me, QP::QEvt const * const e);
static QP::QState operational(Pelican * const me, QP::QEvt const * const e);
static QP::QState carsEnabled(Pelican * const me, QP::QEvt const * const e);
static QP::QState carsGreen(Pelican * const me, QP::QEvt const * const e);
static QP::QState carsGreenNoPed(Pelican * const me, QP::QEvt const * const e);
static QP::QState carsGreenInt(Pelican * const me, QP::QEvt const * const e);
static QP::QState carsGreenPedWait(Pelican * const me, QP::QEvt const * const e);
static QP::QState carsYellow(Pelican * const me, QP::QEvt const * const e);
static QP::QState pedsEnabled(Pelican * const me, QP::QEvt const * const e);
static QP::QState pedsWalk(Pelican * const me, QP::QEvt const * const e);
static QP::QState pedsFlash(Pelican * const me, QP::QEvt const * const e);
static QP::QState offline(Pelican * const me, QP::QEvt const * const e);
};
2013-10-10 20:01:51 -04:00
2012-08-14 18:00:48 -04:00
// Local objects -------------------------------------------------------------
static Pelican l_Pelican; // the single instance of Pelican active object
// Global objects ------------------------------------------------------------
QP::QActive * const AO_Pelican = &l_Pelican; // the opaque pointer
// Pelican class definition --------------------------------------------------
2013-10-10 20:01:51 -04:00
// @(/2/0) ...................................................................
2012-08-14 18:00:48 -04:00
2013-10-10 20:01:51 -04:00
// @(/2/0/3) .................................................................
// @(/2/0/3/0)
2012-08-14 18:00:48 -04:00
QP::QState Pelican::initial(Pelican * const me, QP::QEvt const * const e) {
me->subscribe(PEDS_WAITING_SIG);
me->subscribe(TERMINATE_SIG);
QS_OBJ_DICTIONARY(&l_Pelican);
QS_OBJ_DICTIONARY(&l_Pelican.m_timeout);
QS_FUN_DICTIONARY(&QP::QHsm::top);
QS_FUN_DICTIONARY(&Pelican::initial);
QS_FUN_DICTIONARY(&Pelican::offline);
QS_FUN_DICTIONARY(&Pelican::operational);
QS_FUN_DICTIONARY(&Pelican::carsEnabled);
QS_FUN_DICTIONARY(&Pelican::carsGreen);
QS_FUN_DICTIONARY(&Pelican::carsGreenNoPed);
QS_FUN_DICTIONARY(&Pelican::carsGreenPedWait);
QS_FUN_DICTIONARY(&Pelican::carsGreenInt);
QS_FUN_DICTIONARY(&Pelican::carsYellow);
QS_FUN_DICTIONARY(&Pelican::pedsEnabled);
QS_FUN_DICTIONARY(&Pelican::pedsWalk);
QS_FUN_DICTIONARY(&Pelican::pedsFlash);
QS_SIG_DICTIONARY(PEDS_WAITING_SIG, (void *)0); // global signals
QS_SIG_DICTIONARY(ON_SIG, (void *)0);
QS_SIG_DICTIONARY(OFF_SIG, (void *)0);
QS_SIG_DICTIONARY(TIMEOUT_SIG, &l_Pelican); // just for Pelican
return Q_TRAN(&Pelican::operational);
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1) ...............................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::operational(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_signalCars(CARS_RED);
BSP_signalPeds(PEDS_DONT_WALK);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/0)
2012-08-14 18:00:48 -04:00
case Q_INIT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsEnabled);
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/1)
2012-08-14 18:00:48 -04:00
case OFF_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::offline);
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/2)
2012-08-14 18:00:48 -04:00
case TERMINATE_SIG: {
BSP_terminate(0);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&QHsm::top);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3) .............................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::carsEnabled(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3)
2012-08-14 18:00:48 -04:00
case Q_EXIT_SIG: {
BSP_signalCars(CARS_RED);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/0)
2012-08-14 18:00:48 -04:00
case Q_INIT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsGreen);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::operational);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1) ...........................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::carsGreen(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_signalCars(CARS_GREEN);
me->m_timeout.postIn(me, CARS_GREEN_MIN_TOUT);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1)
2012-08-14 18:00:48 -04:00
case Q_EXIT_SIG: {
(void)me->m_timeout.disarm();
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/0)
2012-08-14 18:00:48 -04:00
case Q_INIT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsGreenNoPed);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::carsEnabled);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/1) .........................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::carsGreenNoPed(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/1)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_showState("carsGreenNoPed");
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/1/0)
2012-08-14 18:00:48 -04:00
case PEDS_WAITING_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsGreenPedWait);
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/1/1)
2012-08-14 18:00:48 -04:00
case TIMEOUT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsGreenInt);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::carsGreen);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/2) .........................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::carsGreenInt(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/2)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_showState("carsGreenInt");
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/2/0)
2012-08-14 18:00:48 -04:00
case PEDS_WAITING_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsYellow);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::carsGreen);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/3) .........................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::carsGreenPedWait(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/3)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_showState("carsGreenPedWait");
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/1/3/0)
2012-08-14 18:00:48 -04:00
case TIMEOUT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsYellow);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::carsGreen);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/2) ...........................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::carsYellow(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/2)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_showState("carsYellow");
BSP_signalCars(CARS_YELLOW);
me->m_timeout.postIn(me, CARS_YELLOW_TOUT);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/2)
2012-08-14 18:00:48 -04:00
case Q_EXIT_SIG: {
(void)me->m_timeout.disarm();
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/3/2/0)
2012-08-14 18:00:48 -04:00
case TIMEOUT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::pedsEnabled);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::carsEnabled);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4) .............................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::pedsEnabled(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4)
2012-08-14 18:00:48 -04:00
case Q_EXIT_SIG: {
BSP_signalPeds(PEDS_DONT_WALK);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/0)
2012-08-14 18:00:48 -04:00
case Q_INIT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::pedsWalk);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::operational);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/1) ...........................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::pedsWalk(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/1)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_showState("pedsWalk");
BSP_signalPeds(PEDS_WALK);
me->m_timeout.postIn(me, PEDS_WALK_TOUT);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/1)
2012-08-14 18:00:48 -04:00
case Q_EXIT_SIG: {
(void)me->m_timeout.disarm();
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/1/0)
2012-08-14 18:00:48 -04:00
case TIMEOUT_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::pedsFlash);
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::pedsEnabled);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2) ...........................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::pedsFlash(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_showState("pedsFlash");
me->m_timeout.postIn(me, PEDS_FLASH_TOUT);
me->m_flashCtr = PEDS_FLASH_NUM*2 + 1;
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2)
2012-08-14 18:00:48 -04:00
case Q_EXIT_SIG: {
(void)me->m_timeout.disarm();
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2/0)
2012-08-14 18:00:48 -04:00
case TIMEOUT_SIG: {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2/0/0)
2012-08-14 18:00:48 -04:00
if (me->m_flashCtr != 0U) {
--me->m_flashCtr;
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2/0/0/0)
2012-08-14 18:00:48 -04:00
if ((me->m_flashCtr & 1U) == 0U) {
BSP_signalPeds(PEDS_DONT_WALK);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2/0/0/1)
2012-08-14 18:00:48 -04:00
else {
BSP_signalPeds(PEDS_BLANK);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
}
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/1/4/2/0/1)
2012-08-14 18:00:48 -04:00
else {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::carsEnabled);
2012-08-14 18:00:48 -04:00
}
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&Pelican::pedsEnabled);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2) ...............................................................
2012-08-14 18:00:48 -04:00
QP::QState Pelican::offline(Pelican * const me, QP::QEvt const * const e) {
2013-10-10 20:01:51 -04:00
QP::QState status_;
2012-08-14 18:00:48 -04:00
switch (e->sig) {
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2)
2012-08-14 18:00:48 -04:00
case Q_ENTRY_SIG: {
BSP_showState("offline");
me->m_timeout.postEvery(me, OFF_FLASH_TOUT);
me->m_flashCtr = 0U;
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2)
2012-08-14 18:00:48 -04:00
case Q_EXIT_SIG: {
(void)me->m_timeout.disarm();
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2/0)
2012-08-14 18:00:48 -04:00
case TIMEOUT_SIG: {
me->m_flashCtr ^= 1U;
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2/0/0)
2012-08-14 18:00:48 -04:00
if ((me->m_flashCtr & 1U) == 0U) {
BSP_signalCars(CARS_RED);
BSP_signalPeds(PEDS_DONT_WALK);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2/0/1)
2012-08-14 18:00:48 -04:00
else {
BSP_signalCars(CARS_BLANK);
BSP_signalPeds(PEDS_BLANK);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
}
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2/1)
2012-08-14 18:00:48 -04:00
case ON_SIG: {
2013-10-10 20:01:51 -04:00
status_ = Q_TRAN(&Pelican::operational);
2012-08-14 18:00:48 -04:00
break;
}
2013-10-10 20:01:51 -04:00
// @(/2/0/3/2/2)
2012-08-14 18:00:48 -04:00
case TERMINATE_SIG: {
BSP_terminate(0);
2013-10-10 20:01:51 -04:00
status_ = Q_HANDLED();
2012-08-14 18:00:48 -04:00
break;
}
default: {
2013-10-10 20:01:51 -04:00
status_ = Q_SUPER(&QHsm::top);
2012-08-14 18:00:48 -04:00
break;
}
}
2013-10-10 20:01:51 -04:00
return status_;
2012-08-14 18:00:48 -04:00
}
} // namespace PELICAN