Gazebo_simulation-Frontend/node_modules/str2buf/README.md
2020-12-21 10:29:31 -05:00

54 lines
1.4 KiB
Markdown

# str2buf [![NPM](https://img.shields.io/npm/v/str2buf.svg)](https://npmjs.com/package/str2buf) [![Build](https://travis-ci.org/kevlened/str2buf.svg?branch=master)](https://travis-ci.org/kevlened/str2buf)
isomorphic string <=> buffer in 198 bytes
## Install
`npm install str2buf`
## Usage
You must provide strings where each character is represented by a single byte (also known as the binary string format). For example, the output of a `atob` operation or any ASCII string would be allowed.
```javascript
const str2buf = require('str2buf')
str2buf.toUint8Array('hello')
// new Uint8Array([104,101,108,108,111])
str2buf.fromUint8Array(new Uint8Array([104,101,108,108,111]))
// 'hello'
str2buf.toBuffer('hello')
// ArrayBuffer
str2buf.fromBuffer(new Uint8Array([104,101,108,108,111]).buffer)
// 'hello'
```
## Can it be smaller?
If you use ES6 imports with a bundler that supports tree-shaking, yes!
```javascript
import { fromUint8Array } from 'str2buf'
```
#### Perf profile
```
⏱ browser performance on 1000 arrays or strings of size 25003:
str2buf.fromUint8Array: 245.842ms
str2buf.toUint8Array: 165.240ms
str2buf.fromBuffer: 234.920ms
str2buf.toBuffer: 160.021ms
⏱ node performance on 1000 arrays or strings of size 25003:
str2buf.fromUint8Array: 20.213ms
str2buf.toUint8Array: 15.655ms
str2buf.fromBuffer: 32.880ms
str2buf.toBuffer: 21.514ms
```
## License
MIT