2 stable releases
2.0.0 | Jul 23, 2022 |
---|---|
1.0.0 | Jul 23, 2022 |
#1633 in Cryptography
363 downloads per month
10KB
131 lines
Features
- ROT encryption & decryption
- Exhaustive testing
Usage
use nrot::{rot, rot_letter, Mode};
fn encrypt(input: String) {
let rotation = 13;
let input_length = input.len();
let input_bytes = input.as_bytes();
if input_length == 1 {
let byte_result = rot_letter(Mode::Encrypt, input_bytes[0], rotation);
println!("{}", String::from_utf8_lossy(&[byte_result]))
} else {
let bytes_result = rot(Mode::Encrypt, input_bytes, rotation);
println!("{}", String::from_utf8_lossy(&bytes_result))
};
}
fn decrypt(input: String) {
let rotation = 13;
let input_length = input.len();
let input_bytes = input.as_bytes();
if input_length == 1 {
let byte_result = rot_letter(Mode::Decrypt, input_bytes[0], rotation);
println!("{}", String::from_utf8_lossy(&[byte_result]))
} else {
let bytes_result = rot(Mode::Decrypt, input_bytes, rotation);
println!("{}", String::from_utf8_lossy(&bytes_result))
};
}
fn main() {
let input = "Hello, world!".to_string();
encrypt(input);
let input = "Uryyb, jbeyq!".to_string();
decrypt(input);
}
To learn more, see other examples.
Credits
- ROT13 implementation is inspired by Cameron Phillips's ROT13
- Noto Emoji