Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mysticatea/eaw

The Node.js module to calculate the width of east Asian characters.
https://github.com/mysticatea/eaw

east-asian-characters eastasianwidth javascript node nodejs npm npm-module npm-package text unicode web

Last synced: 3 months ago
JSON representation

The Node.js module to calculate the width of east Asian characters.

Awesome Lists containing this project

README

        

# eaw

[![npm version](https://img.shields.io/npm/v/eaw.svg)](https://www.npmjs.com/package/eaw)
[![Downloads/month](https://img.shields.io/npm/dm/eaw.svg)](http://www.npmtrends.com/eaw)
[![Build Status](https://travis-ci.org/mysticatea/eaw.svg?branch=master)](https://travis-ci.org/mysticatea/eaw)
[![Coverage Status](https://codecov.io/gh/mysticatea/eaw/branch/master/graph/badge.svg)](https://codecov.io/gh/mysticatea/eaw)
[![Dependency Status](https://david-dm.org/mysticatea/eaw.svg)](https://david-dm.org/mysticatea/eaw)

The Node.js module to calculate the width of east Asian characters. (based on Unicode 9.0.0)

The script of this module is generated with [EastAsianWidth.txt] that Unicode Character Database provides.

- The generator script is [./scripts/generate.js].
- The generated script is [./lib/is-narrow-character.js].

The generator script is used to **maintain** this module as following to latest Unicode.

## πŸ’Ώ Installation

This module can be installed by [npm].

$ npm install --save eaw

- It requires Node.js `>=4.0.0`.
- It can be used in browsers by [browserify]-like tools.

## πŸ“– Usage

### CLI

This module provides a CLI command: `eaw`

The command calculates the width of east Asian characters for each line.

```
Usage: eaw [OPTIONS]

It calculates the width of given east Asian characters.
It reads the characters from stdin or `--text` option.

OPTIONS:
-s, --split ... It splits the given text by LF to make the
width of each line shorter than the given
number.
-t, --text ...... The characters that eaw processes instead of
stdin.

Example:
$ eaw --text "hello, δΈ–η•Œ"
11
$ cat hello.txt | eaw
11
$ cat hello.txt | eaw --split 4
hell
o,
δΈ–η•Œ
```

### Node.js

This module provides Node.js module.

```js
const eaw = require("eaw")

console.log(eaw.isNarrowCharacter("A")) // β†’ true
console.log(eaw.isNarrowCharacter("あ")) // β†’ false
console.log(eaw.getWidth("A")) // β†’ 1
console.log(eaw.getWidth("あ")) // β†’ 2
console.log(eaw.getWidth("hello, δΈ–η•Œ")) // β†’ 11
console.log(eaw.getWidth(["hello, δΈ–η•Œ", "🌟❀"])) // β†’ [11, 4]
console.log(eaw.split("hello, δΈ–η•Œ", 4)) // β†’ ["hell", "o, ", "δΈ–η•Œ"]
console.log(eaw.split(["hello, δΈ–η•Œ", "πŸŒŸβ€πŸ‘"], 4)) // β†’ ["hell", "o, ", "δΈ–η•Œ", "🌟❀", "πŸ‘"]

process.stdin
.pipe(eaw.createWidthStream())
.pipe(process.stdout)

process.stdin
.pipe(eaw.createSplitStream(4))
.pipe(process.stdout)
```

> eaw.isNarrowCharacter(character: string): boolean

It checks whether the given character is a narrow character or not.

This function checks the first code point if the argument has 2 or more characters.

> eaw.getWidth(characters: string, widthOfWideCharacters?: number = 2): number

> eaw.getWidth(characters: string[], widthOfWideCharacters?: number = 2): number[]

> eaw.getWidth(characters: Iterable<string>, widthOfWideCharacters?: number = 2): Iterable<number>

It returns the total width of the given characters.

> eaw.split(characters: string, maxPerLine: number, widthOfWideCharacters?: number = 2): string[]

> eaw.split(characters: string[], maxPerLine: number, widthOfWideCharacters?: number = 2): string[]

> eaw.split(characters: Iterable<string>, maxPerLine: number, widthOfWideCharacters?: number = 2): Iterable<string>

It splits the given characters to make the width of each line shorter than the given number.

> eaw.createWidthStream(widthOfWideCharacters?: number = 2): [stream.Transform]

It returns the transform stream to calculate the width of each line.

> eaw.createSplitStream(maxPerLine: number, widthOfWideCharacters?: number = 2): [stream.Transform]

It returns the transform stream to split the given characters to make the width of each line shorter than the given number.

## πŸ“° Changelog

See [GitHub Releases]

## πŸ’ͺ Contributing

Welcom your contributing!

Please use GitHub's issues/PRs.

### Development tools

- `npm test` runs tests.
- `npm run build` generates the script from [EastAsianWidth.txt].
- `npm run clean` removes the coverage result of the last `npm test` command.
- `npm run coverage` opens the coverage of the last `npm test` command by browsers.
- `npm run lint` runs [ESLint].
- `npm run watch` runs tests for each file change.

[EastAsianWidth.txt]: http://www.unicode.org/Public/UCD/latest/ucd/EastAsianWidth.txt
[./scripts/generate.js]: ./scripts/generate.js
[./lib/is-narrow-character.js]: ./lib/is-narrow-character.js
[npm]: https://www.npmjs.com/
[browserify]: http://browserify.org/
[stream.Transform]: https://nodejs.org/api/stream.html#stream_class_stream_transform
[GitHub Releases]: https://github.com/mysticatea/eaw/releases
[ESLint]: http://eslint.org/