Skip to content

Latest commit

 

History

History
57 lines (41 loc) · 1.73 KB

README.md

File metadata and controls

57 lines (41 loc) · 1.73 KB

ripmors

ripmors is a Rust library for encoding and decoding International Morse code and several variants.

It is fast:

  • Encoding ASCII text to Morse code: 1.5 GiB/s
  • Encoding Unicode text to Morse code: 730 MiB/s
  • Decoding Morse code: 570 MiB/s
$ echo 'Hello, World!' | ripmors
.... . .-.. .-.. --- --..-- / .-- --- .-. .-.. -.. -.-.--
$ echo '-- --- .-. ... . / -.-. --- -.. .' | ripmors -d
MORSE CODE

Documentation

If you want to uwu-encode instead, use this project instead.

Usage

Or, in Rust:

use ripmors::{decode_string, encode_string, to_standard};

assert_eq!(encode_string("Hello, World!"), ".... . .-.. .-.. --- --..-- / .-- --- .-. .-.. -.. -.-.--");
assert_eq!(decode_string(b"-- --- .-. ... . / -.-. --- -.. .", to_standard), "MORSE CODE");

In addition to the standard International Morse Code and its Latin extensions, the following variants are supported:

$ echo 'モールスふごう' | ripmors
-..-. .--.- -.--. ---.- --.. ---- .. ..-
$ echo '-..-. .--.- -.--. ---.- --.. ---- .. ..-' | ripmors -d japanese
モールスフコ゛ウ

Or, in Rust:

use ripmors::{decode_string, encode_string, to_japanese};

assert_eq!(encode_string("モールスふごう"), "-..-. .--.- -.--. ---.- --.. ---- .. ..-");
assert_eq!(decode_string(b"-..-. .--.- -.--. ---.- --.. ---- .. ..-", to_japanese), "モールスフコ゛ウ");