2 releases
0.1.2 | Nov 23, 2024 |
---|---|
0.1.1 | Nov 20, 2024 |
0.1.0 |
|
#577 in Parser implementations
404 downloads per month
12KB
157 lines
Morse Code Parser
Morse Code Parser — це бібліотека та CLI-інструмент для парсингу, валідації та декодування тексту, закодованого у код Морзе. Реалізовано на мові програмування Rust із використанням граматики Pest.
📜 Опис проєкту
Проєкт демонструє створення граматик для парсингу текстових форматів та реалізацію повного циклу обробки даних:
- Парсинг коду Морзе: Перетворення закодованого тексту у внутрішнє представлення.
- Декодування: Перетворення закодованого тексту у зрозумілий текст (літери A-Z, цифри 0-9).
- Валідація: Перевірка введення на наявність помилок або недопустимих символів.
🚀 Основні функції
- Парсинг: Перевірка структури коду Морзе відповідно до граматики у
grammar.pest
. - Декодування: Конвертація закодованого тексту у зрозумілий текст.
- Валідація: Аналіз введення для перевірки допустимості.
🛠️ Встановлення та запуск
Клонування репозиторію
git clone https://github.com/eyexzy/morse_code_parser.git
cd morse_code_parser
Збірка проєкту
cargo build
Запуск CLI
cargo run -- "... --- ..."
Тестування
cargo test
🔧 Приклади використання
Парсинг та декодування
use morse_code_parser::{parse_morse_code, decode_morse, validate_input};
fn main() {
let input = "... --- ... / - .... .. ... / .. ... / - . ... -";
// Перевірка валідності
if validate_input(input) {
println!("Valid Morse code input!");
}
// Парсинг
parse_morse_code(input).expect("Failed to parse Morse code!");
// Декодування
let decoded = decode_morse(input).expect("Failed to decode Morse code!");
println!("Decoded text: {}", decoded);
}
Приклад результату:
Valid Morse code input!
Parsed structure: ...
Decoded text: SOS THIS IS TEST
📜 Граматика коду Морзе
Файл grammar.pest
:
WHITESPACE = _{ " " | "\t" | "\n" }
morse_char = { "." | "-" }
morse_letter = @{ morse_char+ }
morse_word = { morse_letter ~ (" " ~ morse_letter)* }
morse_code = { morse_word ~ (WHITESPACE* ~ "/" ~ WHITESPACE* ~ morse_word)* }
morse_code_with_spaces = { WHITESPACE* ~ morse_code ~ WHITESPACE* }
📊 Тестове покриття
Проєкт має понад 50 тестів, що перевіряють:
- Парсинг: Вхідні дані різної структури.
- Декодування: Валідні, невідомі та некоректні символи.
- Валідацію: Допустимість введення.
- Крайні випадки: Пусті рядки, великі блоки тексту, невалідні дані.
Для запуску тестів:
cargo test
🔗 Посилання
📝 Ліцензія
Проєкт доступний під ліцензією MIT. Деталі можна знайти у файлі LICENSE.
Dependencies
~4MB
~74K SLoC