From dea8646b8b98583d15528031138682d1ac9ada85 Mon Sep 17 00:00:00 2001 From: "osboxes.org" Date: Wed, 7 Oct 2015 11:35:49 +0200 Subject: Allow BOM (Byte order mark) in toml --- src/parser.rs | 9 +++++++++ tests/valid.rs | 3 +++ tests/valid/example-bom.toml | 5 +++++ 3 files changed, 17 insertions(+) create mode 100644 tests/valid/example-bom.toml diff --git a/src/parser.rs b/src/parser.rs index 394465f..190454c 100644 --- a/src/parser.rs +++ b/src/parser.rs @@ -190,6 +190,14 @@ impl<'a> Parser<'a> { false } + // Consumes a BOM (Byte Order Mark) if one is next + fn bom(&mut self) -> bool { + match self.peek(0) { + Some((_, '\u{feff}')) => { self.cur.next(); true } + _ => false + } + } + // Consumes whitespace ('\t' and ' ') until another character (or EOF) is // reached. Returns if any whitespace was consumed fn ws(&mut self) -> bool { @@ -234,6 +242,7 @@ impl<'a> Parser<'a> { /// to determine the cause of the parse failure. pub fn parse(&mut self) -> Option { let mut ret = TomlTable { values: BTreeMap::new(), defined: false }; + self.bom(); while self.peek(0).is_some() { self.ws(); if self.newline() { continue } diff --git a/tests/valid.rs b/tests/valid.rs index 568518b..f346781 100644 --- a/tests/valid.rs +++ b/tests/valid.rs @@ -178,3 +178,6 @@ test!(example3, test!(example4, include_str!("valid/example-v0.4.0.toml"), include_str!("valid/example-v0.4.0.json")); +test!(example_bom, + include_str!("valid/example-bom.toml"), + include_str!("valid/example.json")); diff --git a/tests/valid/example-bom.toml b/tests/valid/example-bom.toml new file mode 100644 index 0000000..fb5ac81 --- /dev/null +++ b/tests/valid/example-bom.toml @@ -0,0 +1,5 @@ +best-day-ever = 1987-07-05T17:45:00Z + +[numtheory] +boring = false +perfection = [6, 28, 496] -- cgit v1.2.3