// Generated from CSV.g4 by ANTLR 4.8 #![allow(dead_code)] #![allow(nonstandard_style)] #![allow(unused_imports)] #![allow(unused_variables)] use antlr_rust::atn::ATN; use antlr_rust::atn_deserializer::ATNDeserializer; use antlr_rust::char_stream::CharStream; use antlr_rust::dfa::DFA; use antlr_rust::error_listener::ErrorListener; use antlr_rust::int_stream::IntStream; use antlr_rust::lexer::{BaseLexer, Lexer, LexerRecog}; use antlr_rust::lexer_atn_simulator::{ILexerATNSimulator, LexerATNSimulator}; use antlr_rust::parser_rule_context::{cast, BaseParserRuleContext, ParserRuleContext}; use antlr_rust::recognizer::{Actions, Recognizer}; use antlr_rust::rule_context::{BaseRuleContext, EmptyContext, EmptyCustomRuleContext}; use antlr_rust::token::*; use antlr_rust::token_factory::{CommonTokenFactory, TokenAware, TokenFactory}; use antlr_rust::vocabulary::{Vocabulary, VocabularyImpl}; use antlr_rust::PredictionContextCache; use antlr_rust::TokenSource; use antlr_rust::{lazy_static, Tid, TidAble, TidExt}; use std::cell::RefCell; use std::marker::PhantomData; use std::ops::{Deref, DerefMut}; use std::rc::Rc; use std::sync::Arc; pub const T__0: isize = 1; pub const T__1: isize = 2; pub const T__2: isize = 3; pub const WS: isize = 4; pub const TEXT: isize = 5; pub const STRING: isize = 6; pub const channelNames: [&'static str; 0 + 2] = ["DEFAULT_TOKEN_CHANNEL", "HIDDEN"]; pub const modeNames: [&'static str; 1] = ["DEFAULT_MODE"]; pub const ruleNames: [&'static str; 6] = ["T__0", "T__1", "T__2", "WS", "TEXT", "STRING"]; pub const _LITERAL_NAMES: [Option<&'static str>; 4] = [None, Some("','"), Some("'\r'"), Some("'\n'")]; pub const _SYMBOLIC_NAMES: [Option<&'static str>; 7] = [ None, None, None, None, Some("WS"), Some("TEXT"), Some("STRING"), ]; lazy_static! { static ref _shared_context_cache: Arc = Arc::new(PredictionContextCache::new()); static ref VOCABULARY: Box = Box::new(VocabularyImpl::new( _LITERAL_NAMES.iter(), _SYMBOLIC_NAMES.iter(), None )); } pub type LexerContext<'input> = BaseRuleContext<'input, EmptyCustomRuleContext<'input, LocalTokenFactory<'input>>>; pub type LocalTokenFactory<'input> = antlr_rust::token_factory::ArenaCommonFactory<'input>; type From<'a> = as TokenFactory<'a>>::From; pub struct CSVLexer<'input, Input: CharStream>> { base: BaseLexer<'input, CSVLexerActions, Input, LocalTokenFactory<'input>>, } antlr_rust::tid! { impl<'input,Input> TidAble<'input> for CSVLexer<'input,Input> where Input:CharStream > } impl<'input, Input: CharStream>> Deref for CSVLexer<'input, Input> { type Target = BaseLexer<'input, CSVLexerActions, Input, LocalTokenFactory<'input>>; fn deref(&self) -> &Self::Target { &self.base } } impl<'input, Input: CharStream>> DerefMut for CSVLexer<'input, Input> { fn deref_mut(&mut self) -> &mut Self::Target { &mut self.base } } impl<'input, Input: CharStream>> CSVLexer<'input, Input> { fn get_rule_names(&self) -> &'static [&'static str] { &ruleNames } fn get_literal_names(&self) -> &[Option<&str>] { &_LITERAL_NAMES } fn get_symbolic_names(&self) -> &[Option<&str>] { &_SYMBOLIC_NAMES } fn get_grammar_file_name(&self) -> &'static str { "CSVLexer.g4" } pub fn new_with_token_factory(input: Input, tf: &'input LocalTokenFactory<'input>) -> Self { antlr_rust::recognizer::check_version("0", "3"); Self { base: BaseLexer::new_base_lexer( input, LexerATNSimulator::new_lexer_atnsimulator( _ATN.clone(), _decision_to_DFA.clone(), _shared_context_cache.clone(), ), CSVLexerActions {}, tf, ), } } } impl<'input, Input: CharStream>> CSVLexer<'input, Input> where &'input LocalTokenFactory<'input>: Default, { pub fn new(input: Input) -> Self { CSVLexer::new_with_token_factory(input, <&LocalTokenFactory<'input> as Default>::default()) } } pub struct CSVLexerActions {} impl CSVLexerActions {} impl<'input, Input: CharStream>> Actions<'input, BaseLexer<'input, CSVLexerActions, Input, LocalTokenFactory<'input>>> for CSVLexerActions { } impl<'input, Input: CharStream>> CSVLexer<'input, Input> {} impl<'input, Input: CharStream>> LexerRecog<'input, BaseLexer<'input, CSVLexerActions, Input, LocalTokenFactory<'input>>> for CSVLexerActions { } impl<'input> TokenAware<'input> for CSVLexerActions { type TF = LocalTokenFactory<'input>; } impl<'input, Input: CharStream>> TokenSource<'input> for CSVLexer<'input, Input> { type TF = LocalTokenFactory<'input>; fn next_token(&mut self) -> >::Tok { self.base.next_token() } fn get_line(&self) -> isize { self.base.get_line() } fn get_char_position_in_line(&self) -> isize { self.base.get_char_position_in_line() } fn get_input_stream(&mut self) -> Option<&mut dyn IntStream> { self.base.get_input_stream() } fn get_source_name(&self) -> String { self.base.get_source_name() } fn get_token_factory(&self) -> &'input Self::TF { self.base.get_token_factory() } } lazy_static! { static ref _ATN: Arc = Arc::new(ATNDeserializer::new(None).deserialize(_serializedATN.chars())); static ref _decision_to_DFA: Arc>> = { let mut dfa = Vec::new(); let size = _ATN.decision_to_state.len(); for i in 0..size { dfa.push(DFA::new(_ATN.clone(), _ATN.get_decision_state(i), i as isize).into()) } Arc::new(dfa) }; } const _serializedATN: &'static str = "\x03\u{608b}\u{a72a}\u{8133}\u{b9ed}\u{417c}\u{3be7}\u{7786}\u{5964}\x02\ \x08\x2c\x08\x01\x04\x02\x09\x02\x04\x03\x09\x03\x04\x04\x09\x04\x04\x05\ \x09\x05\x04\x06\x09\x06\x04\x07\x09\x07\x03\x02\x03\x02\x03\x03\x03\x03\ \x03\x04\x03\x04\x03\x05\x06\x05\x17\x0a\x05\x0d\x05\x0e\x05\x18\x03\x05\ \x03\x05\x03\x06\x06\x06\x1e\x0a\x06\x0d\x06\x0e\x06\x1f\x03\x07\x03\x07\ \x03\x07\x03\x07\x07\x07\x26\x0a\x07\x0c\x07\x0e\x07\x29\x0b\x07\x03\x07\ \x03\x07\x02\x02\x08\x03\x03\x05\x04\x07\x05\x09\x06\x0b\x07\x0d\x08\x03\ \x02\x05\x03\x02\x22\x22\x07\x02\x0c\x0c\x0f\x0f\x22\x22\x24\x24\x2e\x2e\ \x03\x02\x24\x24\x02\x2f\x02\x03\x03\x02\x02\x02\x02\x05\x03\x02\x02\x02\ \x02\x07\x03\x02\x02\x02\x02\x09\x03\x02\x02\x02\x02\x0b\x03\x02\x02\x02\ \x02\x0d\x03\x02\x02\x02\x03\x0f\x03\x02\x02\x02\x05\x11\x03\x02\x02\x02\ \x07\x13\x03\x02\x02\x02\x09\x16\x03\x02\x02\x02\x0b\x1d\x03\x02\x02\x02\ \x0d\x21\x03\x02\x02\x02\x0f\x10\x07\x2e\x02\x02\x10\x04\x03\x02\x02\x02\ \x11\x12\x07\x0f\x02\x02\x12\x06\x03\x02\x02\x02\x13\x14\x07\x0c\x02\x02\ \x14\x08\x03\x02\x02\x02\x15\x17\x09\x02\x02\x02\x16\x15\x03\x02\x02\x02\ \x17\x18\x03\x02\x02\x02\x18\x16\x03\x02\x02\x02\x18\x19\x03\x02\x02\x02\ \x19\x1a\x03\x02\x02\x02\x1a\x1b\x08\x05\x02\x02\x1b\x0a\x03\x02\x02\x02\ \x1c\x1e\x0a\x03\x02\x02\x1d\x1c\x03\x02\x02\x02\x1e\x1f\x03\x02\x02\x02\ \x1f\x1d\x03\x02\x02\x02\x1f\x20\x03\x02\x02\x02\x20\x0c\x03\x02\x02\x02\ \x21\x27\x07\x24\x02\x02\x22\x23\x07\x24\x02\x02\x23\x26\x07\x24\x02\x02\ \x24\x26\x0a\x04\x02\x02\x25\x22\x03\x02\x02\x02\x25\x24\x03\x02\x02\x02\ \x26\x29\x03\x02\x02\x02\x27\x25\x03\x02\x02\x02\x27\x28\x03\x02\x02\x02\ \x28\x2a\x03\x02\x02\x02\x29\x27\x03\x02\x02\x02\x2a\x2b\x07\x24\x02\x02\ \x2b\x0e\x03\x02\x02\x02\x07\x02\x18\x1f\x25\x27\x03\x02\x03\x02";