Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/malept/t12r

Transliterator: Ruby I18n.transliterate speedup written in Rust
https://github.com/malept/t12r

gem i18n ruby rust transliterator

Last synced: 16 days ago
JSON representation

Transliterator: Ruby I18n.transliterate speedup written in Rust

Awesome Lists containing this project

README

        

# T12r

[![Build Status](https://travis-ci.org/data-axle/t12r.svg?branch=master)](https://travis-ci.org/data-axle/t12r)

T12r (or Transliterator) is a speedup and enhancement for the [`i18n` gem](https://rubygems.org/gems/i18n)'s
`I18n.transliterate` method, using a Rust-based native extension. It supports more characters
out-of-the-box.

## Requirements

* Ruby ≥ 2.4
* [Rust](http://www.rust-lang.org/) (if you build from source)

If you're using t12r on macOS without Rust installed, please note that the prebuilt binaries are built
with the following xcode versions:

* macOS 10.13: xcode 10.1
* macOS 10.14: xcode 10.2

Since they are built on Travis CI, prebuilt macOS binaries may require libgmp (`brew install gmp`
or equivalent).

## Usage

To speed up existing calls to `I18n.transliterate`, add this `gem` line to your `Gemfile`, after you
declare `gem 'i18n'`:

```ruby
gem 't12r', require: 't12r/i18n_monkeypatch'
```

To only use `T12r.transliterate` directly, omit the `require` argument.

### Example

```ruby
> T12r.transliterate('…yes?')
=> '...yes?'
> T12r.transliterate('Input string…', ' ' => '-')
=> 'Input-string...'
```

# Legal

This project is copyrighted by Infogroup, under the terms of the Apache License (version 2.0). See
`LICENSE` for details.