LibJuno 0.42.0
LibJuno is a lightweight C99 library designed specifically for embedded systems.
Loading...
Searching...
No Matches
sm_api.h
Go to the documentation of this file.
1/*
2 MIT License
3
4 Copyright (c) 2025 Robin A. Onsay
5
6 Permission is hereby granted, free of charge, to any person obtaining
7 a copy of this software and associated documentation files
8 (the "Software"), to deal in the Software without restriction,
9 including without limitation the rights to use, copy, modify, merge,
10 publish, distribute, sublicense, and/or sell copies of the Software,
11 and to permit persons to whom the Software is furnished to do so,
12 subject to the following conditions:
13
14 The above copyright notice and this permission notice shall be
15 included in all copies or substantial portions of the Software.
16*/
17
27#ifndef JUNO_SM_API_H
28#define JUNO_SM_API_H
29#include "juno/macros.h"
30#include "juno/status.h"
31#include "juno/module.h"
32#include "juno/types.h"
33#include <stdbool.h>
34#include <stddef.h>
35#ifdef __cplusplus
36extern "C"
37{
38#endif
39
40typedef struct JUNO_SM_ROOT_TAG JUNO_SM_ROOT_T;
42
43JUNO_MODULE_DECLARE(JUNO_SM_STATE_T);
45typedef struct JUNO_SM_STATE_ROOT_TAG JUNO_SM_STATE_ROOT_T;
46
48JUNO_MODULE_RESULT(JUNO_SM_RESULT_STATE_ROOT_T, JUNO_SM_STATE_ROOT_T *);
49JUNO_MODULE_RESULT(JUNO_SM_RESULT_STATE_T, JUNO_SM_STATE_T *);
50JUNO_MODULE_OPTION(JUNO_SM_OPTION_STATE_ROOT_T, JUNO_SM_STATE_ROOT_T *);
51JUNO_MODULE_OPTION(JUNO_SM_OPTION_STATE_T, JUNO_SM_STATE_T *);
52JUNO_MODULE_RESULT(JUNO_SM_RESULT_OPTION_STATE_ROOT_T, JUNO_SM_OPTION_STATE_ROOT_T);
53JUNO_MODULE_RESULT(JUNO_SM_RESULT_OPTION_STATE_T, JUNO_SM_OPTION_STATE_T);
54
56struct JUNO_SM_STATE_ROOT_TAG JUNO_MODULE_ROOT(JUNO_SM_STATE_API_T,
57 JUNO_SM_T *ptSm;
58 JUNO_SM_OPTION_STATE_T tOptionNextState;
59);
60
62{
64 JUNO_STATUS_T (*StateAction)(JUNO_SM_STATE_T *ptJunoSm);
66 JUNO_RESULT_BOOL_T (*ShouldExit)(JUNO_SM_STATE_T *ptJunoSm);
68 JUNO_STATUS_T (*ResetState)(JUNO_SM_STATE_T *ptJunoSm);
69};
70
71struct JUNO_SM_ROOT_TAG JUNO_MODULE_ROOT(void,
73 JUNO_SM_STATE_T *ptCurrentState;
74);
75
78{
79 JUNO_ASSERT_EXISTS(ptSmRoot);
80 JUNO_ASSERT_EXISTS(ptSmRoot->ptCurrentState);
82}
83
85{
86 JUNO_ASSERT_EXISTS(ptSmState);
87 JUNO_ASSERT_EXISTS(ptSmState->ptApi && ptSmState->ptSm);
88 if(ptSmState->tOptionNextState.bIsSome)
89 {
90 JUNO_ASSERT_EXISTS(ptSmState->tOptionNextState.tSome);
91 }
93}
94
95static inline JUNO_STATUS_T JunoSm_StateInit(JUNO_SM_ROOT_T *ptSm, JUNO_SM_STATE_ROOT_T *ptStateRoot, JUNO_SM_STATE_ROOT_T *ptNextState, const JUNO_SM_STATE_API_T *ptStateApi, JUNO_FAILURE_HANDLER_T pfcnFailureHandler, JUNO_USER_DATA_T *pvFailureUserData)
96{
97 JUNO_ASSERT_EXISTS(ptStateRoot && ptStateApi && ptSm);
98 ptStateRoot->ptSm = (JUNO_SM_T *) ptSm;
99 ptStateRoot->_pfcnFailureHandler = pfcnFailureHandler;
100 ptStateRoot->_pvFailureUserData = pvFailureUserData;
101 ptStateRoot->ptApi = ptStateApi;
102 if(ptNextState)
103 {
104 ptStateRoot->tOptionNextState.bIsSome = true;
105 ptStateRoot->tOptionNextState.tSome = (JUNO_SM_STATE_T *) ptNextState;
106 }
107 return JunoSm_StateVerify(ptStateRoot);
108}
109
110static inline JUNO_STATUS_T JunoSm_Init(JUNO_SM_ROOT_T *ptSmRoot, JUNO_SM_STATE_ROOT_T *ptStartState, JUNO_FAILURE_HANDLER_T pfcnFailureHandler, JUNO_USER_DATA_T *pvFailureUserData)
111{
112 JUNO_ASSERT_EXISTS(ptSmRoot);
113 ptSmRoot->ptCurrentState = (JUNO_SM_STATE_T *) ptStartState;
114 ptSmRoot->_pfcnFailureHandler = pfcnFailureHandler;
115 ptSmRoot->_pvFailureUserData = pvFailureUserData;
116 JUNO_STATUS_T tStatus = JunoSm_Verify(ptSmRoot);
117 JUNO_ASSERT_SUCCESS(tStatus, return tStatus);
118 return tStatus;
119}
120
121static inline JUNO_SM_RESULT_STATE_T JunoSm_GetCurrentState(JUNO_SM_ROOT_T *ptSmRoot)
122{
123 JUNO_SM_RESULT_STATE_T tResult = {JUNO_STATUS_ERR, NULL};
124 tResult.tStatus = JunoSm_Verify(ptSmRoot);
125 JUNO_ASSERT_SUCCESS(tResult.tStatus, return tResult);
126 tResult.tStatus = JUNO_STATUS_SUCCESS;
127 tResult.tOk = ptSmRoot->ptCurrentState;
128 return tResult;
129}
130
131static inline JUNO_SM_RESULT_OPTION_STATE_T JunoSm_TransitionState(JUNO_SM_ROOT_T *ptSmRoot)
132{
133 JUNO_SM_RESULT_OPTION_STATE_T tResult = {JUNO_STATUS_ERR, {}};
134 tResult.tStatus = JunoSm_Verify(ptSmRoot);
135 JUNO_ASSERT_SUCCESS(tResult.tStatus, return tResult);
136 tResult.tStatus = JUNO_STATUS_SUCCESS;
137 JUNO_SM_STATE_ROOT_T *ptCurrentStateRoot = (JUNO_SM_STATE_ROOT_T*) ptSmRoot->ptCurrentState;
138 if(ptCurrentStateRoot->tOptionNextState.bIsSome)
139 {
140 ptSmRoot->ptCurrentState = ptCurrentStateRoot->tOptionNextState.tSome;
141 tResult.tOk.bIsSome = true;
142 tResult.tOk.tSome = ptSmRoot->ptCurrentState;
143 }
144 else
145 {
146 tResult.tOk.bIsSome = false;
147 tResult.tOk.tSome = NULL;
148 }
149 return tResult;
150}
151
152#ifdef __cplusplus
153}
154#endif
155#endif // JUNO_SM_API_H
#define JUNO_ASSERT_EXISTS(ptr)
Definition macros.h:28
#define JUNO_ASSERT_SUCCESS(tStatus, failOp)
Definition macros.h:52
#define JUNO_MODULE_DECLARE(NAME_T)
Definition module.h:102
#define JUNO_MODULE_RESULT(NAME_T, OK_T)
Defines a result type combining a status and a success payload.
Definition module.h:223
#define JUNO_MODULE_ROOT(API_T,...)
Definition module.h:182
#define JUNO_MODULE_OPTION(NAME_T, SOME_T)
Defines an option type combining a flag to indicate some and a success payload.
Definition module.h:242
static JUNO_STATUS_T JunoSm_StateVerify(JUNO_SM_STATE_ROOT_T *ptSmState)
Definition sm_api.h:84
static JUNO_STATUS_T JunoSm_Init(JUNO_SM_ROOT_T *ptSmRoot, JUNO_SM_STATE_ROOT_T *ptStartState, JUNO_FAILURE_HANDLER_T pfcnFailureHandler, JUNO_USER_DATA_T *pvFailureUserData)
Definition sm_api.h:110
struct JUNO_SM_STATE_ROOT_TAG JUNO_SM_STATE_ROOT_T
Definition sm_api.h:45
static JUNO_STATUS_T JunoSm_StateInit(JUNO_SM_ROOT_T *ptSm, JUNO_SM_STATE_ROOT_T *ptStateRoot, JUNO_SM_STATE_ROOT_T *ptNextState, const JUNO_SM_STATE_API_T *ptStateApi, JUNO_FAILURE_HANDLER_T pfcnFailureHandler, JUNO_USER_DATA_T *pvFailureUserData)
Definition sm_api.h:95
static JUNO_SM_RESULT_OPTION_STATE_T JunoSm_TransitionState(JUNO_SM_ROOT_T *ptSmRoot)
Definition sm_api.h:131
static JUNO_STATUS_T JunoSm_Verify(JUNO_SM_ROOT_T *ptSmRoot)
Verify if this is a valid state machine.
Definition sm_api.h:77
static JUNO_SM_RESULT_STATE_T JunoSm_GetCurrentState(JUNO_SM_ROOT_T *ptSmRoot)
Definition sm_api.h:121
struct JUNO_SM_ROOT_TAG JUNO_SM_ROOT_T
Definition sm_api.h:40
#define JUNO_STATUS_ERR
Definition status.h:25
void(* JUNO_FAILURE_HANDLER_T)(JUNO_STATUS_T tStatus, const char *pcCustomMessage, JUNO_USER_DATA_T *pvUserData)
Definition status.h:43
int32_t JUNO_STATUS_T
Definition status.h:23
#define JUNO_STATUS_SUCCESS
Definition status.h:24
void JUNO_USER_DATA_T
Definition status.h:42
Definition sm_api.h:62
JUNO_RESULT_BOOL_T(* ShouldExit)(JUNO_SM_STATE_T *ptJunoSm)
Returns a bool result whether the current state should exit.
Definition sm_api.h:66
JUNO_STATUS_T(* StateAction)(JUNO_SM_STATE_T *ptJunoSm)
The action that should be executed in this state.
Definition sm_api.h:64
JUNO_STATUS_T(* ResetState)(JUNO_SM_STATE_T *ptJunoSm)
Reset the state.
Definition sm_api.h:68