Merge pull request #2458 from Mingun/identifier

Keep aliases always sorted and include aliases in expecting message for field/variant_identifier
This commit is contained in:
David Tolnay
2023-08-05 16:39:14 -07:00
committed by GitHub
4 changed files with 214 additions and 117 deletions
+15 -5
View File
@@ -183,12 +183,20 @@ impl Name {
}
fn deserialize_aliases(&self) -> Vec<String> {
let mut aliases = self.deserialize_aliases.clone();
let main_name = self.deserialize_name();
if !aliases.contains(&main_name) {
aliases.push(main_name);
self.deserialize_aliases.clone()
}
fn correct_aliases(&mut self) {
// `deserialize_aliases` got from a BTreeSet, so it sorted and does not
// contain duplicates.
// We cannot insert main name in `new` because rename_all rules not yet
// applied there.
match self.deserialize_aliases.binary_search(&self.deserialize) {
Ok(_) => {} // element already here
Err(pos) => self
.deserialize_aliases
.insert(pos, self.deserialize.clone()),
}
aliases
}
}
@@ -988,6 +996,7 @@ impl Variant {
if !self.name.deserialize_renamed {
self.name.deserialize = rules.deserialize.apply_to_variant(&self.name.deserialize);
}
self.name.correct_aliases();
}
pub fn rename_all_rules(&self) -> RenameAllRules {
@@ -1327,6 +1336,7 @@ impl Field {
if !self.name.deserialize_renamed {
self.name.deserialize = rules.deserialize.apply_to_field(&self.name.deserialize);
}
self.name.correct_aliases();
}
pub fn skip_serializing(&self) -> bool {