#![allow(dead_code)]
#![allow(unused_variables)]
#![allow(non_snake_case)]
#![allow(non_camel_case_types)]
#![allow(unused_parens)]
#![allow(unused_mut)]
#![allow(unused_assignments)]
#![allow(unused_doc_comments)]
#![allow(unused_imports)]
use std::str::Chars;
pub struct Lextoken<AT:Default> {
pub sym: String, pub value: AT, }
impl<AT:Default> Lextoken<AT>
{
pub fn new(name:String, val:AT) -> Lextoken<AT>
{
Lextoken {
sym : name,
value : val,
}
}}
pub trait Lexer<AT:Default>
{
fn nextsym(&mut self) -> Option<Lextoken<AT>>;
fn linenum(&self) -> usize { 0 } fn column(&self) -> usize { 0 }
fn current_line(&self) -> String { String::from("")
}
}
pub struct charlexer<'t>
{
pub chars: Chars<'t>,
index: usize,
}
impl<'t> charlexer<'t>
{
pub fn new<'u:'t>(input:&'u str) -> charlexer<'u>
{ charlexer {chars:input.chars(), index:0} }
}
impl<'t, AT:Default> Lexer<AT> for charlexer<'t>
{
fn nextsym(&mut self) -> Option<Lextoken<AT>>
{
let mut res = None;
let mut stop = false;
while !stop
{
res=match self.chars.next() {
None => {stop=true; None},
Some(c) => {
self.index+=1;
if c.is_whitespace() {None}
else {stop=true; Some(Lextoken::new(c.to_string(),AT::default()))}
},
} } res
} fn linenum(&self) -> usize { 1 }
fn column(&self) -> usize { self.index }
fn current_line(&self) -> String
{
self.chars.clone().collect()
}
}