diff options
author | Olliver Schinagl <o.schinagl@ultimaker.com> | 2015-07-06 05:49:50 (GMT) |
---|---|---|
committer | Olliver Schinagl <o.schinagl@ultimaker.com> | 2015-07-06 12:07:31 (GMT) |
commit | 0ab6f4f9f4c2af88e4bbd10b0e11b1516577d319 (patch) | |
tree | be0e67637b190e5c930f93a80a343f8e0d5c8b44 /src/procedures.h | |
parent | f217213dccab10e8af0953f48a7671855326c871 (diff) | |
download | eulogium-master.zip eulogium-master.tar.gz eulogium-master.tar.bz2 |
Diffstat (limited to 'src/procedures.h')
-rw-r--r-- | src/procedures.h | 95 |
1 files changed, 86 insertions, 9 deletions
diff --git a/src/procedures.h b/src/procedures.h index 79e23eb..08ce1d6 100644 --- a/src/procedures.h +++ b/src/procedures.h @@ -1,5 +1,5 @@ /* - * eulogium_procedures, available procedures + * procedures, available procedures * * Copyright (c) 2015 Ultimaker B.V. * Author: Olliver Schinagl <o.schinagl@ultimaker.com> @@ -7,23 +7,100 @@ * SPDX-License-Identifier: AGPL-3.0+ */ -#ifndef _EULOGIUM_PROCEDURES_H -#define _EULOGIUM_PROCEDURES_H +#ifndef _PROCEDURES_H +#define _PROCEDURES_H #include <Eina.h> #include <Eldbus.h> #include <stdint.h> -#include "print_data.h" +enum procedure_status { + PROC_READY, + PROC_ACTIVE, + PROC_FINISHED, +}; + +enum procedure_key { + PROC_NONE, + PROC_BED_HOME, + PROC_BED_LEVEL, + PROC_HOTEND_SWITCH, + PROC_HOTEND_LEVEL, + PROC_PRINT, + PROC_BED_HEATUP, + PROC_HOTEND_HEATUP_0, + PROC_HOTEND_HEATUP_1, + PROC_PRINT_SPEED, + PROC_FAN_SPEED, + PROC_FLOW_RATE, + PROC_LAST, /* sentinel */ +}; + +enum steps { + PROC_RUN_PRE_PRINT_SETUP, + STEP_PRINTING, + PROC_POST_PRINT, + PROC_WAIT_FOR_CLEANUP, + STEP_HEATING, + STEP_SPEEDING, + STEP_FLOWING, + STEP_HOMEING, +}; + +struct procedure_step { + const char *key; + const enum steps step; +}; + +enum msgs { + PROC_MSG_PRINTER_CLEANED, +}; + +struct procedure_msg { + const char *key; + const enum msgs msg; +}; + +enum meta_type { + PROC_META_NONE, + PROC_META_PRINT, + PROC_META_DIAL, +}; struct procedure_data { - char *key; - uint_fast16_t keylen; + const char *key; + enum procedure_status status; + const char *sig; + const char *para; /* TODO va_list to go with sig? */ Eina_Bool available; Eina_Bool executable; + void (*parser)(void *data, const void *key, Eldbus_Message_Iter *variant); + void *meta; /* TODO every proc. has meta data, some needs to be periodically updated (print_data), others on signal changes */ + const struct procedure_msg *msgs; + const struct procedure_step *_steps; /* TODO optional? maybe we don't even have to know the list */ + struct procedure_step *step_active; }; -struct procedure_data *procedures_init(void); -Eldbus_Pending *procedure_start_print(Eldbus_Proxy *proxy, struct print_data *print); +struct eulogium_data; /* XXX remove later when struct eulogium gets refactored. */ + +struct procedure_data *procedures_init(Eldbus_Proxy *proxy); +void procedure_meta_getall(void); +const struct procedure_data *procedure_get(const char *key); +const struct procedure_step *procedure_step_get(const struct procedure_data *proc, const char *key); +void procedure_process_step(struct eulogium_data *eulogium, struct procedure_data *procedure); +Eldbus_Pending *procedure_message(const struct procedure_data *proc, const struct procedure_msg *msg); + +struct print_data; /* XXX only here until print_start gets simplified */ +Eldbus_Pending *procedure_print_start(const struct print_data *print); +Eldbus_Pending *procedure_print_printer_cleaned(void); +Eldbus_Pending *procedure_print_progress_get(struct procedure_data *procedure); + +void *procedure_meta_get(struct procedure_data *procedure); +void procedure_meta_set(struct procedure_data *procedure, void *data); + +Eldbus_Pending *procedure_metadata_get(enum procedure_key proc_key); +Eldbus_Pending *procedure_target_set(const enum procedure_key proc_key); + +void procedures_shutdown(void); -#endif /* _EULOGIUM_PRIVATE_H */ +#endif /* _PROCEDURES_H */ |