async-ioctl
TypeScript icon, indicating that this package has built-in type declarations

1.0.6 • Public • Published

node-async-ioctl

Asynchronous ioctl for Node.js. Used for node-nbd-client, UNIX-only.

Usage

  • ioctl(fd: number | bigint, request: number | bigint, value: number | bigint | Buffer): Promise<number>
    • meant for ioctl calls returning immediately. Uses the libuv thread pool.
  • ioctl.batch(batch: [fd: number | bigint, request: number | bigint, value: number | bigint | Buffer][]): Promise<number[]>
    • same as ioctl(fd, request, value) except requests can be submitted in batches.
  • ioctl.blocking(fd: number | bigint, request: number | bigint, value: number | bigint | Buffer): Promise<number>
    • meant for ioctl calls blocking until something happens. Uses a dedicated thread so more memory and higher latency.
import { open } from 'fs'
import { ioctl } from 'async-ioctl'

// Get number of rows for current terminal
const rows = await ioctl(process.stdout.fd, 0x2000ab00)

async function getBlockDeviceSize(path: string) {
    const device = await open(path)
    const buffer = Buffer.alloc(8)

    await ioctl(device.fd, 0x2000ab00, buffer)

    return buffer
}

// Buffer argument
const result = await ioctl(device.fd, 0x2000ab00, Buffer.from('test'))
// Buffer argument
const result = await ioctl(device.fd, 0x2000ab00, BigInt('13343554'))

Readme

Keywords

none

Package Sidebar

Install

npm i async-ioctl

Weekly Downloads

3

Version

1.0.6

License

MIT

Unpacked Size

41.1 kB

Total Files

15

Last publish

Collaborators

  • fathyb