Implement missing data types for calendar and schedule (#474)

* Added the SpecialEvent struct for the Exception_Schedule property of Schedule, encode/decode/same functions, unit tests, and integrated into bacapp functions.

* Added the CalendarEntry struct for the Date_List property of Calendar and the SpecialEvent struct, encode/decode functions, unit tests, and integrated into bacapp functions.

* Added the DateRange struct for the Effective_Period property of Schedule, encode/decode functions, unit tests, and integrated into bacapp functions.

---------

Co-authored-by: Steve Karg <skarg@users.sourceforge.net>
This commit is contained in:
Ondřej Hruška
2024-02-01 17:57:46 +01:00
committed by GitHub
parent 7ad82f19a0
commit 340bd09561
120 changed files with 2003 additions and 124 deletions
+71
View File
@@ -0,0 +1,71 @@
/**
* @file
* @brief API for BACnetSpecialEvent complex data type encode and decode
* @author Ondřej Hruška <ondra@ondrovo.com>
* @author Steve Karg <skarg@users.sourceforge.net>
* @date August 2023
* @section LICENSE
*
* SPDX-License-Identifier: MIT
*/
#ifndef BACNET_SPECIAL_EVENT_H
#define BACNET_SPECIAL_EVENT_H
#include <stdint.h>
#include <stdbool.h>
#include "bacnet/bacnet_stack_exports.h"
#include "bacnet/bactimevalue.h"
#include "bacnet/calendar_entry.h"
#include "bacnet/dailyschedule.h"
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
typedef enum BACnet_SpecialEventPeriod_Tags {
BACNET_SPECIAL_EVENT_PERIOD_CALENDAR_ENTRY = 0,
BACNET_SPECIAL_EVENT_PERIOD_CALENDAR_REFERENCE = 1
} BACNET_SPECIAL_EVENT_PERIOD_TAG;
typedef struct BACnet_Special_Event {
BACNET_SPECIAL_EVENT_PERIOD_TAG periodTag;
union {
BACNET_CALENDAR_ENTRY calendarEntry;
BACNET_OBJECT_ID calendarReference;
} period;
/* We reuse the daily schedule struct and its encoding/decoding - it's identical */
BACNET_DAILY_SCHEDULE timeValues;
uint8_t priority;
} BACNET_SPECIAL_EVENT;
/** Decode Special Event */
BACNET_STACK_EXPORT
int bacnet_special_event_decode(
uint8_t * apdu,
int max_apdu_len,
BACNET_SPECIAL_EVENT * value);
/** Encode Special Event */
BACNET_STACK_EXPORT
int bacnet_special_event_encode(
uint8_t * apdu,
BACNET_SPECIAL_EVENT * value);
BACNET_STACK_EXPORT
int bacnet_special_event_context_encode(
uint8_t *apdu, uint8_t tag_number, BACNET_SPECIAL_EVENT *value);
BACNET_STACK_EXPORT
int bacnet_special_event_context_decode(
uint8_t *apdu, int max_apdu_len, uint8_t tag_number,
BACNET_SPECIAL_EVENT *value);
BACNET_STACK_EXPORT
bool bacnet_special_event_same(
BACNET_SPECIAL_EVENT *value1, BACNET_SPECIAL_EVENT *value2);
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* BACNET_SPECIAL_EVENT_H */