awtk/docs/fscript_rbuffer.md
2021-01-14 09:23:11 +08:00

242 lines
3.6 KiB
Markdown

## 读缓冲区扩展函数
rbuffer 有以下属性:
* data 缓冲区的指针
* cursor 当前读的位置
* capacity 最大容量
### 1.rbuffer\_create
> 创建 rbuffer 对象。
----------------------------
#### 原型
```js
rbuffer_create(str) => object
rbuffer_create(binary) => object
rbuffer_create(data, size) => object
```
### 2.rbuffer\_skip
> 跳过指定长度的数据。
----------------------------
#### 原型
```js
rbuffer_skip(rbuffer, size) => bool
```
### 3.rbuffer\_rewind
> 重置读取指针到 0。
----------------------------
#### 原型
```js
rbuffer_rewind(rbuffer) => bool
```
### 4.rbuffer\_read\_uint8
> 读取 uint8_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_uint8(rbuffer) => uint8_t
```
### 5.rbuffer\_read\_uint16
> 读取 uint16_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_uint16(rbuffer) => uint16_t
```
### 6.rbuffer\_read\_uint32
> 读取 uint32_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_uint32(rbuffer) => uint32_t
```
### 7.rbuffer\_read\_uint64
> 读取 uint64_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_uint64(rbuffer) => uint64_t
```
### 8.rbuffer\_read\_int8
> 读取 int8_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_int8(rbuffer) => int8_t
```
### 9.rbuffer\_read\_int16
> 读取 int16_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_int16(rbuffer) => int16_t
```
### 10.rbuffer\_read\_int32
> 读取 int32_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_int32(rbuffer) => int32_t
```
### 11.rbuffer\_read\_int64
> 读取 int64_t 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_int64(rbuffer) => int64_t
```
### 12.rbuffer\_read\_float
> 读取 float 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_float(rbuffer) => float
```
### 13.rbuffer\_read\_double
> 读取 double 类型的数据。
----------------------------
#### 原型
```js
rbuffer_read_double(rbuffer) => double
```
### 14.rbuffer\_read\_string
> 读取指定长度的字符串。
----------------------------
#### 原型
```js
rbuffer_read_string(rbuffer, size) => str
```
### 15.rbuffer\_read\_binary
> 读取指定长度的二进制数据。
----------------------------
#### 原型
```js
rbuffer_read_binary(rbuffer, size) => binary
```
### 16.rbuffer\_get\_data
> 获取 buffer 的指针。
----------------------------
#### 原型
```js
rbuffer_get_data(rbuffer) => pointer
```
### 17.rbuffer\_get\_cursor
> 获取 buffer 当前的读取位置。
----------------------------
#### 原型
```js
rbuffer_get_cursor(rbuffer) => uint32_t
```
### 18.rbuffer\_get\_capacity
> 获取 buffer 的容量。
----------------------------
#### 原型
```js
rbuffer_get_capacity(rbuffer) => uint32_t
```
### 更多示例
```js
...
b=rbuffer_create(wbuffer_get_data(a), wbuffer_get_cursor(a))
assert(rbuffer_get_cursor(b)==0)
assert(rbuffer_read_int8(b)== -10)
assert(rbuffer_get_cursor(b)==1)
assert(rbuffer_read_int16(b)==-1122)
assert(rbuffer_get_cursor(b)==3)
assert(rbuffer_read_int32(b)==-11223344)
assert(rbuffer_get_cursor(b)==7)
assert(rbuffer_read_int64(b)==-1122334455667788)
assert(rbuffer_get_cursor(b)==15)
assert(rbuffer_read_string(b)=="hello")
assert(rbuffer_get_cursor(b)==21)
c = rbuffer_read_binary(b, 6)
assert(rbuffer_get_cursor(b)==27)
wbuffer_rewind(a)
assert(wbuffer_get_cursor(a)==0)
wbuffer_write_binary(a, c)
assert(wbuffer_get_cursor(a)==6)
unset(a)
unset(b)
```