| 1 | use crate::common::is_whitespace_char; |
| 2 | use crate::reader::error::SyntaxError; |
| 3 | use crate::reader::events::XmlEvent; |
| 4 | use crate::reader::lexer::Token; |
| 5 | |
| 6 | use super::{PullParser, Result, State}; |
| 7 | |
| 8 | impl PullParser { |
| 9 | pub fn inside_cdata(&mut self, t: Token) -> Option<Result> { |
| 10 | match t { |
| 11 | Token::CDataEnd => { |
| 12 | let event = if self.config.c.cdata_to_characters { |
| 13 | // start called push_pos, but there will be no event to pop it |
| 14 | if self.buf.is_empty() { |
| 15 | self.next_pos(); |
| 16 | } |
| 17 | None |
| 18 | } else { |
| 19 | let data = self.take_buf(); |
| 20 | Some(Ok(XmlEvent::CData(data))) |
| 21 | }; |
| 22 | self.into_state(State::OutsideTag, event) |
| 23 | }, |
| 24 | |
| 25 | Token::Character(c) if !self.is_valid_xml_char(c) => { |
| 26 | Some(self.error(SyntaxError::InvalidCharacterEntity(c as u32))) |
| 27 | }, |
| 28 | Token::Character(c) => { |
| 29 | if !is_whitespace_char(c) { |
| 30 | self.inside_whitespace = false; |
| 31 | } |
| 32 | self.buf.push(c); |
| 33 | None |
| 34 | }, |
| 35 | _ => { |
| 36 | debug_assert!(false, "unreachable" ); |
| 37 | None |
| 38 | }, |
| 39 | } |
| 40 | } |
| 41 | } |
| 42 | |