decancer npm crates.io npm downloads crates.io downloads code style: prettier Build Status license BLAZINGLY FAST!!!

A tiny package that removes common unicode confusables/homoglyphs from strings.

Installation

Rust (v1.64 or later)

In your Cargo.toml:

toml decancer = "1.6.3"

JavaScript (Node.js v16 or later)

In your shell:

console $ npm install decancer

In your code:

js const decancer = require('decancer')

JavaScript (Deno v1.28 or later)

In your code:

ts import decancer from 'npm:decancer'

JavaScript (Bun)

In your shell:

console $ bun install decancer

In your code:

js const decancer = require('decancer')

JavaScript (Browser)

In your code:

```html

```

C/C++

Download precompiled binaries

Building from source

Prerequisites:

console $ git clone https://github.com/null8626/decancer.git --depth 1 $ cd decancer/bindings/native $ cargo build --release

And the binary files should be generated in the target/release directory.

Examples

note: cured output will always be in lowercase.

Rust

```rust let cured = decancer::cure("vοΌ₯ⓑ𝔂 π”½π•ŒΕ‡β„•ο½™ ţ乇𝕏𝓣");

// cured here is a decancer::CuredString struct wrapping over the cured string // for comparison purposes, it's more recommended to use the methods provided by the decancer::CuredString struct.

asserteq!(cured, "very funny text"); assert!(cured.startswith("very")); assert!(cured.contains("funny")); assert!(cured.ends_with("text"));

let outputstr = cured.into_str(); // retrieve the String inside and consume the struct. ```

JavaScript (Node.js/Deno/Bun)

```js const cured = decancer('vοΌ₯ⓑ𝔂 π”½π•ŒΕ‡β„•ο½™ ţ乇𝕏𝓣')

// cured here is a CuredString object wrapping over the cured string // for comparison purposes, it's more recommended to use the methods provided by the CuredString class.

if (cured.contains('funny')) { console.log('found the funny') }

if ( cured.equals('very funny text') && cured.startsWith('very') && cured.endsWith('text') ) { console.log('it works!') }

console.log(cured.toString()) // => 'very funny text' ```

JavaScript (Browser)

```html Decancerer!!! (tm)