mirror of
https://gitee.com/zlgopen/awtk.git
synced 2024-12-02 03:58:33 +08:00
add tk_size_of_basic_type and refactor
This commit is contained in:
parent
34dd3ce8b4
commit
c41b764899
@ -2,7 +2,7 @@
|
||||
|
||||
2024/03/12
|
||||
* 完善函数 tk\_buffer\_set\_value/tk\_buffer\_get\_value
|
||||
* 导出tk\_skip\_to\_offset
|
||||
* 增加函数 tk\_size\_of\_basic\_type
|
||||
|
||||
2024/03/10
|
||||
* 增加函数tk\_basic\_type\_from\_name
|
||||
|
170
src/tkc/utils.c
170
src/tkc/utils.c
@ -2224,144 +2224,103 @@ ret_t tk_bits_data_to_bytes_data(uint8_t* bits, uint32_t bits_size, uint8_t* byt
|
||||
return RET_OK;
|
||||
}
|
||||
|
||||
uint8_t* tk_skip_to_offset(uint8_t* data, uint32_t size, value_type_t type, int16_t index) {
|
||||
return_value_if_fail(data != NULL, NULL);
|
||||
|
||||
uint32_t tk_size_of_basic_type(value_type_t type) {
|
||||
switch (type) {
|
||||
case VALUE_TYPE_INT8:
|
||||
case VALUE_TYPE_UINT8:
|
||||
case VALUE_TYPE_BOOL: {
|
||||
return_value_if_fail((index + 1) <= size, NULL);
|
||||
return data + index;
|
||||
}
|
||||
case VALUE_TYPE_BOOL:
|
||||
return 1;
|
||||
case VALUE_TYPE_INT16:
|
||||
case VALUE_TYPE_UINT16: {
|
||||
return_value_if_fail((index + 1) * 2 <= size, NULL);
|
||||
return data + index * 2;
|
||||
}
|
||||
case VALUE_TYPE_UINT16:
|
||||
return 2;
|
||||
case VALUE_TYPE_INT32:
|
||||
case VALUE_TYPE_UINT32: {
|
||||
return_value_if_fail((index + 1) * 4 <= size, NULL);
|
||||
return data + index * 4;
|
||||
}
|
||||
case VALUE_TYPE_UINT32:
|
||||
case VALUE_TYPE_FLOAT32:
|
||||
return 4;
|
||||
case VALUE_TYPE_INT64:
|
||||
case VALUE_TYPE_UINT64: {
|
||||
return_value_if_fail((index + 1) * 8 <= size, NULL);
|
||||
return data + index * 8;
|
||||
}
|
||||
case VALUE_TYPE_FLOAT32: {
|
||||
return_value_if_fail((index + 1) * 4 <= size, NULL);
|
||||
return data + index * 4;
|
||||
}
|
||||
case VALUE_TYPE_DOUBLE: {
|
||||
return_value_if_fail((index + 1) * 8 <= size, NULL);
|
||||
return data + index * 8;
|
||||
}
|
||||
case VALUE_TYPE_UINT64:
|
||||
case VALUE_TYPE_DOUBLE:
|
||||
return 8;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
return 0;
|
||||
}
|
||||
|
||||
uint8_t* tk_skip_to_offset(uint8_t* data, uint32_t size, value_type_t type, int16_t index) {
|
||||
uint32_t type_size = tk_size_of_basic_type(type);
|
||||
uint32_t offset = index * type_size;
|
||||
return_value_if_fail(data != NULL && type_size > 0, NULL);
|
||||
return_value_if_fail((offset + type_size) <= size, RET_BAD_PARAMS);
|
||||
|
||||
return data + offset;
|
||||
}
|
||||
|
||||
ret_t tk_buffer_set_value(uint8_t* buffer, uint32_t size, value_type_t type, int16_t offset,
|
||||
int16_t bit_offset, const value_t* value) {
|
||||
uint32_t type_size = tk_size_of_basic_type(type);
|
||||
uint8_t* data = tk_skip_to_offset(buffer, size, type, offset);
|
||||
return_value_if_fail(data != NULL, RET_BAD_PARAMS);
|
||||
|
||||
if (bit_offset >= 0) {
|
||||
return_value_if_fail(bit_offset < type_size * 8, RET_BAD_PARAMS);
|
||||
return bits_stream_set(data, type_size, bit_offset, value_bool(value));
|
||||
}
|
||||
|
||||
switch (type) {
|
||||
case VALUE_TYPE_INT8: {
|
||||
if (bit_offset < 0) {
|
||||
*data = value_int8(value);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 8, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 1, bit_offset, value_int8(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT8: {
|
||||
if (bit_offset < 0) {
|
||||
*data = value_uint8(value);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 8, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 1, bit_offset, value_uint8(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_INT16: {
|
||||
if (bit_offset < 0) {
|
||||
int16_t v = value_int16(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 16, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 2, bit_offset, value_int16(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT16: {
|
||||
if (bit_offset < 0) {
|
||||
uint16_t v = value_uint16(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 16, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 2, bit_offset, value_uint16(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_INT32: {
|
||||
if (bit_offset < 0) {
|
||||
int32_t v = value_int32(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 32, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 4, bit_offset, value_int32(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT32: {
|
||||
if (bit_offset < 0) {
|
||||
uint32_t v = value_uint32(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 32, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 4, bit_offset, value_uint32(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_INT64: {
|
||||
if (bit_offset < 0) {
|
||||
int64_t v = value_int64(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 64, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 8, bit_offset, value_int64(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT64: {
|
||||
if (bit_offset < 0) {
|
||||
uint64_t v = value_uint64(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 64, RET_BAD_PARAMS);
|
||||
bits_stream_set(data, 8, bit_offset, value_uint64(value) != 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_FLOAT32: {
|
||||
assert(bit_offset < 0);
|
||||
float v = value_float32(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_DOUBLE: {
|
||||
assert(bit_offset < 0);
|
||||
double v = value_double(value);
|
||||
memcpy(data, &v, sizeof(v));
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
default: {
|
||||
log_debug("tk_buffer_set_value: not support %d\n", type);
|
||||
return RET_NOT_IMPL;
|
||||
}
|
||||
}
|
||||
|
||||
return RET_OK;
|
||||
@ -2370,119 +2329,80 @@ ret_t tk_buffer_set_value(uint8_t* buffer, uint32_t size, value_type_t type, int
|
||||
ret_t tk_buffer_get_value(uint8_t* buffer, uint32_t size, value_type_t type, int16_t offset,
|
||||
int16_t bit_offset, value_t* value) {
|
||||
bool_t v = FALSE;
|
||||
uint32_t type_size = tk_size_of_basic_type(type);
|
||||
uint8_t* data = tk_skip_to_offset(buffer, size, type, offset);
|
||||
return_value_if_fail(data != NULL, RET_BAD_PARAMS);
|
||||
return_value_if_fail(type_size > 0, RET_BAD_PARAMS);
|
||||
|
||||
if (bit_offset >= 0) {
|
||||
return_value_if_fail(bit_offset < type_size * 8, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, type_size, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
|
||||
return RET_OK;
|
||||
}
|
||||
|
||||
switch (type) {
|
||||
case VALUE_TYPE_INT8: {
|
||||
if (bit_offset < 0) {
|
||||
value_set_int8(value, *data);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 8, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 1, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT8: {
|
||||
if (bit_offset < 0) {
|
||||
value_set_uint8(value, *data);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 8, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 1, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_INT16: {
|
||||
if (bit_offset < 0) {
|
||||
int16_t v = 0;
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_int16(value, v);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 16, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 2, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT16: {
|
||||
if (bit_offset < 0) {
|
||||
value_set_uint16(value, *(uint16_t*)data);
|
||||
uint16_t v = 0;
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_uint16(value, v);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 16, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 2, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_INT32: {
|
||||
if (bit_offset < 0) {
|
||||
int32_t v = 0;
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_int32(value, v);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 32, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 4, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT32: {
|
||||
if (bit_offset < 0) {
|
||||
uint32_t v = 0;
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_uint32(value, v);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 32, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 4, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_INT64: {
|
||||
if (bit_offset < 0) {
|
||||
int64_t v = 0;
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_int64(value, v);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 64, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 8, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_UINT64: {
|
||||
if (bit_offset < 0) {
|
||||
uint64_t v = 0;
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_uint64(value, v);
|
||||
} else {
|
||||
return_value_if_fail(bit_offset < 64, RET_BAD_PARAMS);
|
||||
bits_stream_get(data, 8, bit_offset, &v);
|
||||
value_set_bool(value, v);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_FLOAT32: {
|
||||
float v = 0;
|
||||
assert(bit_offset < 0);
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_float32(value, v);
|
||||
break;
|
||||
}
|
||||
case VALUE_TYPE_DOUBLE: {
|
||||
double v = 0;
|
||||
assert(bit_offset < 0);
|
||||
memcpy(&v, data, sizeof(v));
|
||||
value_set_double(value, v);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
default: {
|
||||
log_debug("tk_buffer_get_value: not support %d\n", type);
|
||||
return RET_NOT_IMPL;
|
||||
}
|
||||
}
|
||||
|
||||
return RET_OK;
|
||||
|
@ -1209,16 +1209,12 @@ ret_t tk_buffer_get_value(uint8_t* buffer, uint32_t size, value_type_t type, int
|
||||
int16_t bit_offset, value_t* value);
|
||||
|
||||
/**
|
||||
* @method tk_skip_to_offset
|
||||
* 跳转到指定的偏移位置。
|
||||
* @param {uint8_t*} data 数据。
|
||||
* @param {uint32_t} size 数据长度。
|
||||
* @method tk_size_of_basic_type
|
||||
* 获取基本类型的大小(字节数)。
|
||||
* @param {value_type_t} type 类型。
|
||||
* @param {int16_t} index 索引。
|
||||
*
|
||||
* @return {uint8_t*} 返回跳转后的位置。
|
||||
* @return {uint32_t} 返回大小。
|
||||
*/
|
||||
uint8_t* tk_skip_to_offset(uint8_t* data, uint32_t size, value_type_t type, int16_t index);
|
||||
uint32_t tk_size_of_basic_type(value_type_t type);
|
||||
|
||||
/**
|
||||
* @method tk_basic_type_from_name
|
||||
|
Loading…
Reference in New Issue
Block a user