quick modifier parser macro
This commit is contained in:
parent
f9841267ec
commit
2d5291c07b
4 changed files with 67 additions and 3 deletions
|
@ -1,4 +1,4 @@
|
|||
use bng_macros::{ModifierParser, SlopeModifierParser};
|
||||
use bng_macros::{ModifierParser, QuickModifierParser, SlopeModifierParser};
|
||||
use fasteval::Instruction;
|
||||
|
||||
mod lex;
|
||||
|
@ -22,6 +22,7 @@ pub(super) enum Modifier {
|
|||
Tempo(u16),
|
||||
}
|
||||
|
||||
#[derive(QuickModifierParser)]
|
||||
pub(super) enum QuickModifier {
|
||||
Volume(bool),
|
||||
Octave(bool),
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
use super::{Atom, Modifier, SlopeModifier, WrapperKind};
|
||||
use super::{Atom, Modifier, QuickModifier, SlopeModifier, WrapperKind};
|
||||
|
||||
pub(super) mod lexer;
|
||||
|
||||
|
@ -13,6 +13,10 @@ impl WrappingTokens {
|
|||
const SQUARE_BRACKETS: (char, char) = ('[', ']');
|
||||
const BRACKETS: (char, char) = ('{', '}');
|
||||
const SEMICOLON_COMMA: (char, char) = (';', ',');
|
||||
const PLUS_MINUS: (char, char) = ('+', '-');
|
||||
const RIGHT_LEFT: (char, char) = ('>', '<');
|
||||
const SLASH_BACKSLASH: (char, char) = ('/', '\\');
|
||||
const QUOTE_DEG: (char, char) = ('\'', '°');
|
||||
}
|
||||
|
||||
pub(super) trait Token<T> {
|
||||
|
@ -30,6 +34,17 @@ impl Token<(char, char)> for WrapperKind {
|
|||
}
|
||||
}
|
||||
|
||||
impl Token<(char, char)> for QuickModifier {
|
||||
fn token(self) -> (char, char) {
|
||||
match self {
|
||||
Self::Volume(_) => WrappingTokens::PLUS_MINUS,
|
||||
Self::Octave(_) => WrappingTokens::RIGHT_LEFT,
|
||||
Self::Length(_) => WrappingTokens::SLASH_BACKSLASH,
|
||||
Self::Pizz(_) => WrappingTokens::QUOTE_DEG,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl Token<char> for Modifier {
|
||||
fn token(self) -> char {
|
||||
match self {
|
||||
|
|
|
@ -1,4 +1,6 @@
|
|||
use nom::IResult;
|
||||
use nom::{branch::alt, character::complete::char, combinator::value, IResult, Parser};
|
||||
|
||||
use crate::bng::score::QuickModifier;
|
||||
|
||||
pub(crate) trait Parse: Sized {
|
||||
fn parse(input: &str) -> IResult<&str, Self>;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue