From fba7778782193f0d0899f82d6b322da59a9044a0 Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Sat, 11 Feb 2017 09:13:28 -0800 Subject: Fix displaying empty arrays Closes #145 --- src/value.rs | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) (limited to 'src/value.rs') diff --git a/src/value.rs b/src/value.rs index 99e6d23..4d56023 100644 --- a/src/value.rs +++ b/src/value.rs @@ -366,21 +366,19 @@ impl ser::Serialize for Value { // Be sure to visit non-tables first (and also non // array-of-tables) as all keys must be emitted first. for (k, v) in t { - if !v.is_array() && !v.is_table() { - map.serialize_key(k)?; - map.serialize_value(v)?; + if !v.is_table() && !v.is_array() || + (v.as_array().map(|a| a.len() == 0).unwrap_or(false)) { + map.serialize_entry(k, v)?; } } for (k, v) in t { - if v.is_array() { - map.serialize_key(k)?; - map.serialize_value(v)?; + if v.as_array().map(|a| a.len() > 0).unwrap_or(false) { + map.serialize_entry(k, v)?; } } for (k, v) in t { if v.is_table() { - map.serialize_key(k)?; - map.serialize_value(v)?; + map.serialize_entry(k, v)?; } } map.end() -- cgit v1.2.3