2010-02-05 17:39:42 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
struct PSYC_Parser;
|
|
|
|
|
|
|
|
/** @brief initialize a pstate struct
|
|
|
|
*
|
|
|
|
* @param pstate pointer to an allocated
|
|
|
|
* PSYC_Parser struct.
|
|
|
|
*/
|
|
|
|
void PSYC_initState(struct PSYC_Parser* pstate);
|
|
|
|
|
|
|
|
|
2010-01-31 14:27:00 +00:00
|
|
|
/** @brief parses a packet
|
|
|
|
*
|
|
|
|
* This function parses rawdata
|
|
|
|
* and uses the callbacks in PSYC_Parser
|
|
|
|
* to communicate with the caller.
|
|
|
|
*
|
|
|
|
* First the header will be parsed,
|
|
|
|
* after that the stateCallback
|
|
|
|
* (with inEntity set to false)
|
|
|
|
* will be called for each variable.
|
|
|
|
* Then, routingCallback will be called
|
|
|
|
* to find out if further parsing
|
|
|
|
* is desired.
|
|
|
|
* If it returns false, PSYC_parser returns.
|
|
|
|
* If it returns true, parsing continues
|
|
|
|
* to the body.
|
|
|
|
* After the entitystate has been parsed,
|
|
|
|
* stateCallback will be called for each
|
|
|
|
* variable, having inEntity set to true.
|
|
|
|
* Finally, bodyCallback will be called,
|
|
|
|
* containing the method, and its data.
|
|
|
|
*
|
|
|
|
* In case of an parsing error <to continue>
|
|
|
|
*
|
|
|
|
* @param data constant pointer to the
|
|
|
|
* raw data that is to be processed.
|
|
|
|
* @param length the amount of bytes to parse
|
|
|
|
* @param pstate pointer to a preallocated
|
2010-02-05 17:39:42 +00:00
|
|
|
* and initialized (PSYC_initState)
|
|
|
|
* instance of the struct state
|
|
|
|
*
|
2010-01-31 14:27:00 +00:00
|
|
|
*/
|
|
|
|
void PSYC_parse(const uint8_t* data, unsigned int length,
|
|
|
|
struct PSYC_Parser* pstate);
|
|
|
|
|
|
|
|
/** @brief FlagMod */
|
2011-04-22 18:50:59 +00:00
|
|
|
enum PSYC_Operator
|
2010-01-31 14:27:00 +00:00
|
|
|
{
|
2011-04-22 18:50:59 +00:00
|
|
|
// modifier operators
|
|
|
|
ASSIGN = 0x02,
|
|
|
|
AUGMENT = 0x04,
|
|
|
|
DIMINISH = 0x08,
|
|
|
|
SET = 0x10,
|
|
|
|
QUERY = 0x20,
|
2010-02-05 17:39:42 +00:00
|
|
|
};
|
2010-01-31 14:27:00 +00:00
|
|
|
|
|
|
|
struct PSYC_Parser
|
|
|
|
{
|
|
|
|
/** @brief Callback for the states
|
|
|
|
*
|
|
|
|
* This callback will be called to inform
|
|
|
|
* the caller about the states.
|
|
|
|
*
|
|
|
|
* It will be called once for each variable.
|
|
|
|
*
|
|
|
|
* @param pstate pointer to the ParserState
|
|
|
|
* struct for identification
|
|
|
|
* @param name not null terminated c-string,
|
|
|
|
* containing the name of the variable
|
|
|
|
* @param nlength the length of the variable name
|
|
|
|
* @param value not null terminated c-string,
|
|
|
|
* containing the value of the variable
|
|
|
|
* @param vlength the length of the variable value
|
|
|
|
* @param modifers modifer of the variable (see Modifer)
|
|
|
|
* @param inEntity wether this variable is an entity
|
|
|
|
* variable(true) or a routing variable(false) */
|
2010-02-05 17:39:42 +00:00
|
|
|
void (*stateCallback)(struct PSYC_Parser* pstate,
|
2010-01-31 14:27:00 +00:00
|
|
|
const uint8_t *name, const unsigned int nlength,
|
2010-02-05 17:39:42 +00:00
|
|
|
const uint8_t *value, const unsigned int vlength,
|
2011-04-22 20:59:15 +00:00
|
|
|
enum PSYC_Operator oper, char inEntity);
|
2010-01-31 14:27:00 +00:00
|
|
|
|
|
|
|
/** @brief gets called after the routing-header was parsed
|
|
|
|
*
|
2010-02-05 17:39:42 +00:00
|
|
|
* @return if 0, parser will continue to parse
|
2010-01-31 14:27:00 +00:00
|
|
|
* the content part and calls bodyCallback
|
|
|
|
* when finished,
|
2010-02-05 17:39:42 +00:00
|
|
|
* if not 0, parser will stop parsing and
|
2010-01-31 14:27:00 +00:00
|
|
|
* calls contentCallback */
|
2010-02-05 17:39:42 +00:00
|
|
|
char (*routingCallback)(struct PSYC_Parser* pstate);
|
2010-01-31 14:27:00 +00:00
|
|
|
|
|
|
|
/** @brief Body callback, gets called when the body was parsed
|
|
|
|
*
|
|
|
|
* @param pstate pointer to the ParserState struct
|
|
|
|
* for identificiation
|
|
|
|
* @param method not null terminated c-string,
|
|
|
|
* containing the method name
|
|
|
|
* @param mlength the length of the methodname
|
|
|
|
* @param dlength the length of the data
|
|
|
|
* @param data not null terminated c-string,
|
|
|
|
* containing the data section
|
|
|
|
* @param content not null terminated c-string
|
|
|
|
* @param clength length of the content string */
|
2010-02-05 17:39:42 +00:00
|
|
|
void (*bodyCallback)(struct PSYC_Parser* pstate,
|
2010-01-31 14:27:00 +00:00
|
|
|
const uint8_t* method, unsigned int mlength,
|
2010-02-05 17:39:42 +00:00
|
|
|
const uint8_t* data, unsigned int dlength,
|
2010-01-31 14:27:00 +00:00
|
|
|
const uint8_t* content, unsigned int clength);
|
|
|
|
|
|
|
|
/** @brief Error callback, gets called to indicate
|
|
|
|
* an error and the start of an error packet
|
|
|
|
*
|
|
|
|
* If there was an error while parsing the rawdata,
|
|
|
|
* instead of passing the packets data to the callbacks,
|
|
|
|
* an error packet will be passed back, describing the
|
|
|
|
* the error in more detail.
|
|
|
|
*
|
|
|
|
* On error, errorCallback will be called
|
|
|
|
* to report the errortype (in the method),
|
|
|
|
* after that errorStateCallback will be
|
|
|
|
* called to inform about more detailed facts
|
|
|
|
* of the error.
|
|
|
|
*
|
|
|
|
* Any previous state or body callbacks become
|
|
|
|
* invalid and have to be purged.*/
|
2010-02-05 17:39:42 +00:00
|
|
|
void (*errorCallback)(struct PSYC_Parser* pstate,
|
2010-01-31 14:27:00 +00:00
|
|
|
const uint8_t *method, unsigned int mlength);
|
|
|
|
|
|
|
|
/** @brief error state callback
|
|
|
|
*
|
|
|
|
* The parameters are the same as for stateCallback.
|
|
|
|
* The callback will be called once for each
|
|
|
|
* state variable in the error report packet
|
|
|
|
*/
|
2010-02-05 17:39:42 +00:00
|
|
|
void (*errorStateCallback)(struct PSYC_Parser* pstate,
|
2010-01-31 14:27:00 +00:00
|
|
|
const uint8_t *name, const unsigned int nlength,
|
2010-02-05 17:39:42 +00:00
|
|
|
const uint8_t *value, const unsigned int vlength,
|
2011-04-22 20:59:15 +00:00
|
|
|
enum PSYC_Operator oper);
|
2010-02-05 17:39:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*******************************************
|
|
|
|
* The following variables and datatypes *
|
|
|
|
* are being used to remember the *
|
|
|
|
* internal state. You should not *
|
|
|
|
* touch them. *
|
|
|
|
*******************************************/
|
|
|
|
uint8_t glyph;
|
|
|
|
unsigned int contpos; // position inside the content
|
|
|
|
unsigned int mstart,mlength, // position and length of the method
|
|
|
|
dstart,dlength; //
|
|
|
|
|
|
|
|
};
|
2010-01-31 14:27:00 +00:00
|
|
|
|
|
|
|
|