diff --git a/parser/src/emitter.rs b/parser/src/emitter.rs index ad7882f..10f43ab 100644 --- a/parser/src/emitter.rs +++ b/parser/src/emitter.rs @@ -301,11 +301,12 @@ fn need_quotes(string: &str) -> bool { string == "" || need_quotes_spaces(string) || string.starts_with(|character: char| match character { - ':' | '&' | '*' | '?' | '|' | '-' | '<' | '>' | '=' | '!' | '%' | '@' => true, + '&' | '*' | '?' | '|' | '-' | '<' | '>' | '=' | '!' | '%' | '@' => true, _ => false, }) || string.contains(|character: char| match character { - '{' + ':' + | '{' | '}' | '[' | ']' diff --git a/parser/tests/test_round_trip.rs b/parser/tests/test_round_trip.rs new file mode 100644 index 0000000..bfa9602 --- /dev/null +++ b/parser/tests/test_round_trip.rs @@ -0,0 +1,23 @@ +extern crate yaml_rust; + +use yaml_rust::{Yaml, YamlEmitter, YamlLoader}; + +fn test_round_trip(original: &Yaml) { + let mut out = String::new(); + YamlEmitter::new(&mut out).dump(original).unwrap(); + let documents = YamlLoader::load_from_str(&out).unwrap(); + assert_eq!(documents.len(), 1); + assert_eq!(documents[0], *original); +} + +#[test] +fn test_escape_character() { + let y = Yaml::String("\x1b".to_owned()); + test_round_trip(&y); +} + +#[test] +fn test_colon_in_string() { + let y = Yaml::String("x: %".to_owned()); + test_round_trip(&y); +}