mirror of
https://codeberg.org/unspeaker/tengri.git
synced 2025-12-06 11:46:42 +01:00
parent
c8827b43c3
commit
91dc77cfea
16 changed files with 931 additions and 823 deletions
|
|
@ -1,111 +0,0 @@
|
|||
use crate::*;
|
||||
|
||||
#[cfg(test)] mod test_token_iter {
|
||||
use crate::*;
|
||||
//use proptest::prelude::*;
|
||||
#[test] fn test_iters () {
|
||||
let mut iter = crate::SourceIter::new(&":foo :bar");
|
||||
let _ = iter.next();
|
||||
}
|
||||
#[test] const fn test_const_iters () {
|
||||
let iter = crate::SourceConstIter::new(&":foo :bar");
|
||||
let _ = iter.next();
|
||||
}
|
||||
#[test] fn test_num () {
|
||||
let _digit = to_digit('0');
|
||||
let _digit = to_digit('x');
|
||||
let _number = to_number(&"123");
|
||||
let _number = to_number(&"12asdf3");
|
||||
}
|
||||
//proptest! {
|
||||
//#[test] fn proptest_source_iter (
|
||||
//source in "\\PC*"
|
||||
//) {
|
||||
//let mut iter = crate::SourceIter::new(&source);
|
||||
////let _ = iter.next();
|
||||
//}
|
||||
//#[test] fn proptest_token_iter (
|
||||
//source in "\\PC*"
|
||||
//) {
|
||||
//let mut iter = crate::TokenIter::new(&source);
|
||||
////let _ = iter.next();
|
||||
//}
|
||||
//}
|
||||
}
|
||||
|
||||
//#[cfg(test)] mod test_token_prop {
|
||||
//use crate::{CstToken, CstMeta, Value::*};
|
||||
//use proptest::prelude::*;
|
||||
//proptest! {
|
||||
//#[test] fn test_token_prop (
|
||||
//source in "\\PC*",
|
||||
//start in usize::MIN..usize::MAX,
|
||||
//length in usize::MIN..usize::MAX,
|
||||
//) {
|
||||
//let token = CstToken(Nil, CstMeta { source: &source, start, length });
|
||||
//let _ = token.slice();
|
||||
//}
|
||||
//}
|
||||
//}
|
||||
|
||||
#[cfg(test)] #[test] fn test_token () -> Result<(), Box<dyn std::error::Error>> {
|
||||
use crate::Value::*;
|
||||
let source = ":f00";
|
||||
let mut token = CstToken(Sym(":"), CstMeta { source, start: 0, length: 1 });
|
||||
token = token.grow_sym();
|
||||
assert_eq!(token, CstToken(Sym(":f"), CstMeta { source, start: 0, length: 2, }));
|
||||
token = token.grow_sym();
|
||||
assert_eq!(token, CstToken(Sym(":f0"), CstMeta { source, start: 0, length: 3, }));
|
||||
token = token.grow_sym();
|
||||
assert_eq!(token, CstToken(Sym(":f00"), CstMeta { source, start: 0, length: 4, }));
|
||||
|
||||
assert_eq!(None,
|
||||
SourceIter::new("").next());
|
||||
assert_eq!(None,
|
||||
SourceIter::new(" \n \r \t ").next());
|
||||
assert_eq!(&Num(7),
|
||||
SourceIter::new("7").next().unwrap().0.value());
|
||||
assert_eq!(&Num(100),
|
||||
SourceIter::new(" 100 ").next().unwrap().0.value());
|
||||
assert_eq!(&Err(Unexpected('a')),
|
||||
SourceIter::new(" 9a ").next().unwrap().0.value());
|
||||
assert_eq!(&Sym(":123foo"),
|
||||
SourceIter::new(" :123foo ").next().unwrap().0.value());
|
||||
assert_eq!(&Sym("@bar456"),
|
||||
SourceIter::new(" \r\r\r\n\n\n@bar456\t\t\t\t\t\t").next().unwrap().0.value());
|
||||
assert_eq!(&Key("foo123"),
|
||||
SourceIter::new("foo123").next().unwrap().0.value());
|
||||
assert_eq!(&Key("foo/bar"),
|
||||
SourceIter::new("foo/bar").next().unwrap().0.value());
|
||||
assert_eq!(&Str("foo/bar"),
|
||||
SourceIter::new("\"foo/bar\"").next().unwrap().0.value());
|
||||
assert_eq!(&Str("foo/bar"),
|
||||
SourceIter::new(" \"foo/bar\" ").next().unwrap().0.value());
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
//#[cfg(test)] #[test] fn test_examples () -> Result<(), DslError> {
|
||||
//// Let's pretend to render some view.
|
||||
//let source = include_str!("../../tek/src/view_arranger.edn");
|
||||
//// The token iterator allows you to get the tokens represented by the source text.
|
||||
//let mut view = TokenIter(source);
|
||||
//// The token iterator wraps a const token+source iterator.
|
||||
//assert_eq!(view.0.0, source);
|
||||
//let mut expr = view.peek();
|
||||
//assert_eq!(view.0.0, source);
|
||||
//assert_eq!(expr, Some(Token {
|
||||
//source, start: 0, length: source.len() - 1, value: Exp(0, SourceIter::new(&source[1..]))
|
||||
//}));
|
||||
////panic!("{view:?}");
|
||||
////panic!("{:#?}", expr);
|
||||
////for example in [
|
||||
////include_str!("../../tui/examples/edn01.edn"),
|
||||
////include_str!("../../tui/examples/edn02.edn"),
|
||||
////] {
|
||||
//////let items = Dsl::read_all(example)?;
|
||||
//////panic!("{layout:?}");
|
||||
//////let content = <dyn ViewContext<::tengri_engine::tui::Tui>>::from(&layout);
|
||||
////}
|
||||
//Ok(())
|
||||
//}
|
||||
Loading…
Add table
Add a link
Reference in a new issue