2021-03-18 22:44:05 +01:00
|
|
|
/* Reflow Oven Controller
|
|
|
|
*
|
|
|
|
* Copyright (C) 2021 Mario Hüttel <mario.huettel@gmx.net>
|
|
|
|
*
|
|
|
|
* This file is part of the Reflow Oven Controller Project.
|
|
|
|
*
|
|
|
|
* The reflow oven controller is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* The Reflow Oven Control Firmware 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.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with the reflow oven controller project.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __CONFIG_PARSER_TEMP_PROFILE_PARSER_H__
|
|
|
|
#define __CONFIG_PARSER_TEMP_PROFILE_PARSER_H__
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2021-05-15 21:58:00 +02:00
|
|
|
#include <linklist-lib/singly-linked-list.h>
|
2021-03-18 22:44:05 +01:00
|
|
|
|
|
|
|
enum pl_command_type {
|
|
|
|
PL_PID_CONF = 0,
|
|
|
|
PL_SET_TEMP,
|
|
|
|
PL_SET_RAMP,
|
|
|
|
PL_WAIT_FOR_TEMP,
|
|
|
|
PL_WAIT_FOR_TIME,
|
|
|
|
PL_LOUDSPEAKER_SET,
|
|
|
|
PL_OFF,
|
|
|
|
_PL_NUM_CMDS,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum pl_ret_val {
|
|
|
|
PL_RET_SUCCESS = 0,
|
|
|
|
PL_RET_DISK_ERR,
|
|
|
|
PL_RET_PARAM_ERR,
|
|
|
|
PL_RET_LIST_FULL,
|
|
|
|
PL_RET_SCRIPT_ERR,
|
|
|
|
};
|
|
|
|
|
2021-03-19 16:58:14 +01:00
|
|
|
#define PROFILE_LANG_MAX_NUM_ARGS (8)
|
2021-03-18 22:44:05 +01:00
|
|
|
|
|
|
|
struct pl_command {
|
|
|
|
enum pl_command_type cmd;
|
2021-03-19 16:58:14 +01:00
|
|
|
float params[PROFILE_LANG_MAX_NUM_ARGS];
|
2021-03-18 22:44:05 +01:00
|
|
|
};
|
|
|
|
|
2021-05-15 21:58:00 +02:00
|
|
|
/**
|
|
|
|
* @brief Parse a temperature profile from file and generate the command list
|
|
|
|
*
|
|
|
|
* Commands are parsed into the list given by \p command_list. If \p max_len is reached,
|
|
|
|
* the function returns with @ref PL_RET_LIST_FULL
|
|
|
|
*
|
|
|
|
* In any case, the command list not cleared afterwards. The user has to clear the command list manually
|
|
|
|
* using @ref temp_profile_free_command_list.
|
|
|
|
*
|
|
|
|
* @param filename File to parse
|
|
|
|
* @param[in, out] command_list Command list to output @ref pl_command elements in.
|
|
|
|
* @param max_len maximum number of commands.
|
|
|
|
* @param cmds_parsed Number of parsed commands
|
|
|
|
* @return
|
|
|
|
*/
|
2021-03-18 22:44:05 +01:00
|
|
|
enum pl_ret_val temp_profile_parse_from_file(const char *filename,
|
2021-05-15 21:58:00 +02:00
|
|
|
SlList **command_list,
|
|
|
|
uint32_t max_len,
|
2021-03-18 22:44:05 +01:00
|
|
|
uint32_t *cmds_parsed);
|
|
|
|
|
2021-05-15 21:58:00 +02:00
|
|
|
/**
|
|
|
|
* @brief Fully free a comamnd list including hte sotred command structures.
|
|
|
|
*
|
|
|
|
* \p list's destination is set to NULL to indicate the empty list.
|
|
|
|
*
|
|
|
|
* @param[in, out] list Pointer to list.
|
|
|
|
*/
|
|
|
|
void temp_profile_free_command_list(SlList **list);
|
|
|
|
|
2021-03-18 22:44:05 +01:00
|
|
|
#endif /* __CONFIG_PARSER_TEMP_PROFILE_PARSER_H__ */
|