rbuffer_t

概述

Read Buffer。用于数据解包。

示例:

  1. uint8_t buff[128];
  2. wbuffer_t wbuffer;
  3. rbuffer_t rbuffer;
  4. const char* str = NULL;
  5. wbuffer_init(&wbuffer, buff, sizeof(buff));
  6. wbuffer_write_string(&wbuffer, "hello awtk");
  7. rbuffer_init(&rbuffer, wbuffer.data, wbuffer.cursor);
  8. rbuffer_read_string(&rbuffer, &str);

函数

函数名称 说明
rbuffer_has_more 判断是否还有数据可读。
rbuffer_init 初始rbuffer对象。
rbuffer_peek_uint16 读取uint16数据,但不改变cursor的位置。
rbuffer_peek_uint32 读取uint32数据,但不改变cursor的位置。
rbuffer_peek_uint8 读取uint8数据,但不改变cursor的位置。
rbuffer_read_binary 读取指定长度的二进制数据。
rbuffer_read_float 读取float数据。
rbuffer_read_string 读取字符串。
rbuffer_read_uint16 读取uint16数据。
rbuffer_read_uint32 读取uint32数据。
rbuffer_read_uint8 读取uint8数据。
rbuffer_skip 跳过指定的长度。

属性

属性名称 类型 说明
capacity uint32_t 缓存区最大容量。
cursor uint32_t 当前读取位置。
data uint8_t* 缓存区。

rbuffer_has_more 函数


  • 函数功能:

判断是否还有数据可读。

  • 函数原型:
  1. bool_t rbuffer_has_more (rbuffer_t* rbuffer);
  • 参数说明:
参数 类型 说明
返回值 bool_t 返回TRUE表示还有数据可读,否则表示无数据可读。
rbuffer rbuffer_t* rbuffer对象。

rbuffer_init 函数


  • 函数功能:

初始rbuffer对象。

  • 函数原型:
  1. rbuffer_t* rbuffer_init (rbuffer_t* rbuffer, uint8_t* data, uint16_t capacity);
  • 参数说明:
参数 类型 说明
返回值 rbuffer_t* rbuffer对象本身。
rbuffer rbuffer_t* rbuffer对象。
data uint8_t* 缓冲区。
capacity uint16_t 缓冲区的容量。

rbuffer_peek_uint16 函数


  • 函数功能:

读取uint16数据,但不改变cursor的位置。

  • 函数原型:
  1. ret_t rbuffer_peek_uint16 (rbuffer_t* rbuffer, uint16_t* value);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
value uint16_t* 读取的数据。

rbuffer_peek_uint32 函数


  • 函数功能:

读取uint32数据,但不改变cursor的位置。

  • 函数原型:
  1. ret_t rbuffer_peek_uint32 (rbuffer_t* rbuffer, uint32_t* value);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
value uint32_t* 读取的数据。

rbuffer_peek_uint8 函数


  • 函数功能:

读取uint8数据,但不改变cursor的位置。

  • 函数原型:
  1. ret_t rbuffer_peek_uint8 (rbuffer_t* rbuffer, uint8_t* value);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
value uint8_t* 读取的数据。

rbuffer_read_binary 函数


  • 函数功能:

读取指定长度的二进制数据。

  • 函数原型:
  1. ret_t rbuffer_read_binary (rbuffer_t* rbuffer, void* data, uint32_t size);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
data void* 读取的数据。
size uint32_t 读取的数据长度。

rbuffer_read_float 函数


  • 函数功能:

读取float数据。

  • 函数原型:
  1. ret_t rbuffer_read_float (rbuffer_t* rbuffer, float_t* value);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
value float_t* 读取的数据。

rbuffer_read_string 函数


  • 函数功能:

读取字符串。

  • 函数原型:
  1. ret_t rbuffer_read_string (rbuffer_t* rbuffer, char** str);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
str char** 用于返回字符串。

rbuffer_read_uint16 函数


  • 函数功能:

读取uint16数据。

  • 函数原型:
  1. ret_t rbuffer_read_uint16 (rbuffer_t* rbuffer, uint16_t* value);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
value uint16_t* 读取的数据。

rbuffer_read_uint32 函数


  • 函数功能:

读取uint32数据。

  • 函数原型:
  1. ret_t rbuffer_read_uint32 (rbuffer_t* rbuffer, uint32_t* value);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
value uint32_t* 读取的数据。

rbuffer_read_uint8 函数


  • 函数功能:

读取uint8数据。

  • 函数原型:
  1. ret_t rbuffer_read_uint8 (rbuffer_t* rbuffer, uint8_t* value);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
value uint8_t* 读取的数据。

rbuffer_skip 函数


  • 函数功能:

跳过指定的长度。

  • 函数原型:
  1. ret_t rbuffer_skip (rbuffer_t* rbuffer, int32_t offset);
  • 参数说明:
参数 类型 说明
返回值 ret_t 返回RET_OK表示成功,否则表示失败。
rbuffer rbuffer_t* rbuffer对象。
offset int32_t 跳过的偏移量,正数往前负数往回跳。

capacity 属性


缓存区最大容量。

  • 类型:uint32_t
特性 是否支持
可直接读取
可直接修改

cursor 属性


当前读取位置。

  • 类型:uint32_t
特性 是否支持
可直接读取
可直接修改

data 属性


缓存区。

  • 类型:uint8_t*
特性 是否支持
可直接读取
可直接修改