Changed BACnetPropertyStates to support more enumerations. Added apdu size checking on decode. Removed BACnetPropertyStates local enumeration. Increased BACnetPropertyStates codec unit test coverage.
This commit is contained in:
+53
-18
@@ -31,25 +31,8 @@
|
||||
#include "bacnet/bacapp.h"
|
||||
#include "bacnet/timestamp.h"
|
||||
|
||||
typedef enum {
|
||||
BOOLEAN_VALUE,
|
||||
BINARY_VALUE,
|
||||
EVENT_TYPE,
|
||||
POLARITY,
|
||||
PROGRAM_CHANGE,
|
||||
PROGRAM_STATE,
|
||||
REASON_FOR_HALT,
|
||||
RELIABILITY,
|
||||
STATE,
|
||||
SYSTEM_STATUS,
|
||||
UNITS,
|
||||
UNSIGNED_VALUE,
|
||||
LIFE_SAFETY_MODE,
|
||||
LIFE_SAFETY_STATE
|
||||
} BACNET_PROPERTY_STATE_TYPE;
|
||||
|
||||
typedef struct {
|
||||
BACNET_PROPERTY_STATE_TYPE tag;
|
||||
BACNET_PROPERTY_STATES tag;
|
||||
union {
|
||||
bool booleanValue;
|
||||
BACNET_BINARY_PV binaryValue;
|
||||
@@ -65,6 +48,52 @@ typedef struct {
|
||||
BACNET_UNSIGNED_INTEGER unsignedValue;
|
||||
BACNET_LIFE_SAFETY_MODE lifeSafetyMode;
|
||||
BACNET_LIFE_SAFETY_STATE lifeSafetyState;
|
||||
BACNET_RESTART_REASON restartReason;
|
||||
BACNET_DOOR_ALARM_STATE doorAlarmState;
|
||||
BACNET_ACTION action;
|
||||
BACNET_DOOR_SECURED_STATUS doorSecuredStatus;
|
||||
BACNET_DOOR_STATUS doorStatus;
|
||||
BACNET_DOOR_VALUE doorValue;
|
||||
BACNET_FILE_ACCESS_METHOD fileAccessMethod;
|
||||
BACNET_LOCK_STATUS lockStatus;
|
||||
BACNET_LIFE_SAFETY_OPERATION lifeSafetyOperation;
|
||||
BACNET_MAINTENANCE maintenance;
|
||||
BACNET_NODE_TYPE nodeType;
|
||||
BACNET_NOTIFY_TYPE notifyType;
|
||||
BACNET_SECURITY_LEVEL securityLevel;
|
||||
BACNET_SHED_STATE shedState;
|
||||
BACNET_SILENCED_STATE silencedState;
|
||||
BACNET_ACCESS_EVENT accessEvent;
|
||||
BACNET_ACCESS_ZONE_OCCUPANCY_STATE zoneOccupancyState;
|
||||
BACNET_ACCESS_CREDENTIAL_DISABLE_REASON accessCredDisableReason;
|
||||
BACNET_ACCESS_CREDENTIAL_DISABLE accessCredDisable;
|
||||
BACNET_AUTHENTICATION_STATUS authenticationStatus;
|
||||
BACNET_BACKUP_STATE backupState;
|
||||
BACNET_WRITE_STATUS writeStatus;
|
||||
BACNET_LIGHTING_IN_PROGRESS lightingInProgress;
|
||||
BACNET_LIGHTING_OPERATION lightingOperation;
|
||||
BACNET_LIGHTING_TRANSITION lightingTransition;
|
||||
int32_t integerValue;
|
||||
BACNET_BINARY_LIGHTING_PV binaryLightingValue;
|
||||
BACNET_TIMER_STATE timerState;
|
||||
BACNET_TIMER_TRANSITION timerTransition;
|
||||
BACNET_IP_MODE bacnetIPMode;
|
||||
BACNET_PORT_COMMAND networkPortCommand;
|
||||
BACNET_PORT_TYPE networkType;
|
||||
BACNET_PORT_QUALITY networkNumberQuality;
|
||||
BACNET_ESCALATOR_OPERATION_DIRECTION escalatorOperationDirection;
|
||||
BACNET_ESCALATOR_FAULT escalatorFault;
|
||||
BACNET_ESCALATOR_MODE escalatorMode;
|
||||
BACNET_LIFT_CAR_DIRECTION liftCarDirection;
|
||||
BACNET_LIFT_CAR_DOOR_COMMAND liftCarDoorCommand;
|
||||
BACNET_LIFT_CAR_DRIVE_STATUS liftCarDriveStatus;
|
||||
BACNET_LIFT_CAR_MODE liftCarMode;
|
||||
BACNET_LIFT_GROUP_MODE liftGroupMode;
|
||||
BACNET_LIFT_FAULT liftFault;
|
||||
BACNET_PROTOCOL_LEVEL protocolLevel;
|
||||
BACNET_AUDIT_LEVEL auditLevel;
|
||||
BACNET_AUDIT_OPERATION auditOperation;
|
||||
uint32_t extendedValue;
|
||||
} state;
|
||||
} BACNET_PROPERTY_STATE;
|
||||
|
||||
@@ -72,6 +101,12 @@ typedef struct {
|
||||
extern "C" {
|
||||
#endif /* __cplusplus */
|
||||
|
||||
BACNET_STACK_EXPORT
|
||||
int bacapp_property_state_decode(
|
||||
uint8_t *apdu,
|
||||
uint32_t apdu_size,
|
||||
BACNET_PROPERTY_STATE *value);
|
||||
|
||||
BACNET_STACK_EXPORT
|
||||
int bacapp_decode_property_state(
|
||||
uint8_t * apdu,
|
||||
|
||||
Reference in New Issue
Block a user