complete anybase
This commit is contained in:
parent
aa12db5ec7
commit
6c7563455f
3 changed files with 37 additions and 10 deletions
|
@ -70,13 +70,41 @@ pub fn encode(text: String, base: u32, char_length: u32) -> String {
|
||||||
return results;
|
return results;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Decodes catspeak into text using any base up to [`max_base()`]
|
||||||
|
///
|
||||||
|
/// `char_length` is set manually, but the minimum can be generated using [`char_length()`]
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// use cat2text::anybase;
|
||||||
|
/// let text = "meow mewo; mrrp mreow mrrp nyaaaa~ mreow mreow meow nyaaaa~; meow mrow meow mrrp mreow meow mrrp mewo".to_string();
|
||||||
|
/// let base = 10;
|
||||||
|
/// let char_length = anybase::char_length(base);
|
||||||
|
|
||||||
#[test]
|
/// assert_eq!("i love cats", anybase::decode(text, base, char_length));
|
||||||
fn test_anybase_encode() {
|
/// ```
|
||||||
use crate::anybase;
|
pub fn decode(text: String, base: u32, char_length: u32) -> String {
|
||||||
let text = "i love cats".to_string();
|
let catspeak_words: Vec<String> = text.split("; ").map(|item| item.to_string()).collect();
|
||||||
let base = 10;
|
let mut output: String = String::new();
|
||||||
let char_length = anybase::char_length(base);
|
let mut shortened_alphabet = alphabet();
|
||||||
|
shortened_alphabet.truncate(base as usize);
|
||||||
assert_eq!("", anybase::encode(text, base, char_length));
|
for engl_word in catspeak_words {
|
||||||
|
let mut word = String::new();
|
||||||
|
for engl_letter in core::split_every_x(engl_word, char_length as usize) {
|
||||||
|
let char_num = core::cat_to_num(
|
||||||
|
engl_letter
|
||||||
|
.split(" ")
|
||||||
|
.map(|item| item.to_string())
|
||||||
|
.collect(),
|
||||||
|
shortened_alphabet.clone(),
|
||||||
|
char_length,
|
||||||
|
);
|
||||||
|
word += String::from_utf8(vec![(char_num + 96) as u8])
|
||||||
|
.unwrap()
|
||||||
|
.as_str();
|
||||||
|
}
|
||||||
|
word += " ";
|
||||||
|
output += word.as_str();
|
||||||
|
}
|
||||||
|
return output.trim().to_string();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,6 @@ pub fn num_to_cat(num: u32, alphabet: Vec<String>, char_length: u32) -> String {
|
||||||
let base: u32 = alphabet.len() as u32;
|
let base: u32 = alphabet.len() as u32;
|
||||||
|
|
||||||
// base*n*-ifying logic
|
// base*n*-ifying logic
|
||||||
// FIXME: With base 10 this loops 100 times? see `anybase::test_anybase_encode()`
|
|
||||||
let mut nums: Vec<u32> = Vec::new();
|
let mut nums: Vec<u32> = Vec::new();
|
||||||
while (nums.len() as u32) < char_length {
|
while (nums.len() as u32) < char_length {
|
||||||
nums.push((num as u32) % base);
|
nums.push((num as u32) % base);
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#![doc = include_str!("../README.md")]
|
#![doc = include_str!("../README.md")]
|
||||||
//pub mod anybase;
|
pub mod anybase;
|
||||||
pub mod base4;
|
pub mod base4;
|
||||||
pub mod core;
|
pub mod core;
|
||||||
pub mod bytes;
|
pub mod bytes;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue