Feature/add create object service (#476)

Added BACnet CreateObject and DeleteObject services

* refactored codec for BACnetPropertyValue into bacapp module
* added unit tests for BACnetPropertyValue
* refactored COV and Events to use BACnetPropertyValue codec API
* added unit tests for COV
* added overrun safe decoders for tag numbers and boolean context
* added unit tests and codecs for CreateObject and DeleteObject services
* added APDU service handers and senders for CreateObject and DeleteObject services
* added command line apps bacco and bacdo for CreateObject and DeleteObject services
* added CreateObject and DeleteObject service handling in example server app and device object
* added new BACnetRejectReason, Error Class, and BACnetAbortReason enumerations and conversions

---------

Co-authored-by: Steve Karg <skarg@users.sourceforge.net>
This commit is contained in:
Steve Karg
2023-08-28 13:02:35 -05:00
committed by GitHub
parent 8184afea12
commit f61f4300be
60 changed files with 3946 additions and 942 deletions
+40 -2
View File
@@ -77,6 +77,9 @@ BACNET_REJECT_REASON reject_convert_error_code(BACNET_ERROR_CODE error_code)
case ERROR_CODE_REJECT_UNRECOGNIZED_SERVICE:
reject_code = REJECT_REASON_UNRECOGNIZED_SERVICE;
break;
case ERROR_CODE_INVALID_DATA_ENCODING:
reject_code = REJECT_REASON_INVALID_DATA_ENCODING;
break;
case ERROR_CODE_REJECT_PROPRIETARY:
reject_code = REJECT_REASON_PROPRIETARY_FIRST;
break;
@@ -89,6 +92,38 @@ BACNET_REJECT_REASON reject_convert_error_code(BACNET_ERROR_CODE error_code)
return (reject_code);
}
/**
* @brief Determine if a BACnetErrorCode is a BACnetRejectReason
* @param error_code #BACNET_ERROR_CODE enumeration
* @return true if the BACnet Error Code is a BACnet abort reason
*/
bool reject_valid_error_code(BACNET_ERROR_CODE error_code)
{
bool status = false;
switch (error_code) {
case ERROR_CODE_REJECT_OTHER:
case ERROR_CODE_REJECT_BUFFER_OVERFLOW:
case ERROR_CODE_REJECT_INCONSISTENT_PARAMETERS:
case ERROR_CODE_REJECT_INVALID_PARAMETER_DATA_TYPE:
case ERROR_CODE_REJECT_INVALID_TAG:
case ERROR_CODE_REJECT_MISSING_REQUIRED_PARAMETER:
case ERROR_CODE_REJECT_PARAMETER_OUT_OF_RANGE:
case ERROR_CODE_REJECT_TOO_MANY_ARGUMENTS:
case ERROR_CODE_REJECT_UNDEFINED_ENUMERATION:
case ERROR_CODE_REJECT_UNRECOGNIZED_SERVICE:
case ERROR_CODE_INVALID_DATA_ENCODING:
case ERROR_CODE_REJECT_PROPRIETARY:
status = true;
break;
default:
break;
}
return status;
}
/**
* @brief Convert a reject code to BACnet Error code
* @param reject_code - code to be converted
@@ -100,6 +135,9 @@ BACNET_ERROR_CODE reject_convert_to_error_code(BACNET_REJECT_REASON reject_code)
BACNET_ERROR_CODE error_code = ERROR_CODE_REJECT_OTHER;
switch (reject_code) {
case REJECT_REASON_OTHER:
error_code = ERROR_CODE_REJECT_OTHER;
break;
case REJECT_REASON_BUFFER_OVERFLOW:
error_code = ERROR_CODE_REJECT_BUFFER_OVERFLOW;
break;
@@ -127,8 +165,8 @@ BACNET_ERROR_CODE reject_convert_to_error_code(BACNET_REJECT_REASON reject_code)
case REJECT_REASON_UNRECOGNIZED_SERVICE:
error_code = ERROR_CODE_REJECT_UNRECOGNIZED_SERVICE;
break;
case REJECT_REASON_OTHER:
error_code = ERROR_CODE_REJECT_OTHER;
case REJECT_REASON_INVALID_DATA_ENCODING:
error_code = ERROR_CODE_INVALID_DATA_ENCODING;
break;
default:
if ((reject_code >= REJECT_REASON_PROPRIETARY_FIRST) &&