2 releases
0.1.1 | Jul 24, 2021 |
---|---|
0.1.0 | Jul 24, 2021 |
#2527 in Encoding
10KB
169 lines
UWU-Codec
I'm sorry.
Motivation
Do you also think hexadecimal byte encoding is boring? Do you want more uwu in your life? This program solves both of your problems. Bytes are encoded into two words according to the following mapping:
nibble | word |
---|---|
0000 | uwu |
0001 | owo |
0010 | umu |
0011 | nya |
0100 | omo |
0101 | o_o |
0110 | q_p |
0111 | u_u |
1000 | o~o |
1001 | UwU |
1010 | OwO |
1011 | UmU |
1100 | OmO |
1101 | O_O |
1110 | U_U |
1111 | Nya |
Usage
Use the uwuencode
and uwudecode
binaries like this:
uwuencode path/to/raw/input path/to/encoded/output
uwudecode path/to/encoded/input path/to/raw/output
You can also use the functions in your project to spice things up:
use uwucodec::encode;
fn main() {
let encoded = encode(&"Hello World".as_bytes());
let decoded = decode(&encoded);
}
License
Apache-2.0
lib.rs
:
This crate provides an encoding from byte to uwu and back. Encode:
use uwucodec::encode;
fn main() {
println!("Hello World in uwu is: {}", encode("Hello World".as_bytes()));
}
Decode:
use uwucodec::decode;
fn main() {
let text = "omo o~o q_p o_o q_p OmO q_p OmO q_p Nya umu uwu o_o u_u q_p Nya u_u umu q_p OmO q_p omo";
println!("{} is {:?}", text, decode(text));
}
Dependencies
~4MB
~69K SLoC