From 16c7608bcfb876866abd62b65276951ee2a81b54 Mon Sep 17 00:00:00 2001 From: Benedikt Peetz Date: Thu, 9 May 2024 13:20:13 +0200 Subject: feat(pkgs/lf-make-map): Add de-serialization to lf mappings --- sys/nixpkgs/pkgs/lf-make-map/src/mapping/mod.rs | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) (limited to 'sys/nixpkgs/pkgs/lf-make-map/src/mapping/mod.rs') diff --git a/sys/nixpkgs/pkgs/lf-make-map/src/mapping/mod.rs b/sys/nixpkgs/pkgs/lf-make-map/src/mapping/mod.rs index 129e9673..114fdca0 100644 --- a/sys/nixpkgs/pkgs/lf-make-map/src/mapping/mod.rs +++ b/sys/nixpkgs/pkgs/lf-make-map/src/mapping/mod.rs @@ -5,7 +5,6 @@ use std::{ use log::debug; -pub mod error; pub mod map_tree; #[derive(Clone, Debug, Eq)] @@ -77,7 +76,6 @@ impl MapKey { generated_chars }; - assert_eq!(added_chars.len(), new_resolution,); let part_path = self.part_path.clone(); let output: Vec = added_chars @@ -101,6 +99,15 @@ impl MapKey { fn make(pat: char, part: &str, number_of_chars: usize) -> String { let mut acc = String::new(); + if !part.split(pat).all(|part| part.len() > 0) { + panic!( + "\ +Can't turn this path '{}' to a mapping. +This should not happen, please report the bug!", + part + ) + } + let mut last_working = None; for i in 0..number_of_chars { for str in part.split(pat) { @@ -123,9 +130,9 @@ impl MapKey { acc } - let value = if part.contains('_') { + let value = if part.contains('_') && !part.starts_with('_') && !part.ends_with('_') { make('_', part, number_of_chars) - } else if part.contains('-') { + } else if part.contains('-') && !part.starts_with('-') && !part.ends_with('-') { make('-', part, number_of_chars) } else { part.chars().take(number_of_chars).collect::() @@ -134,7 +141,7 @@ impl MapKey { assert_eq!( value.len(), number_of_chars, - "'{}' is not {}", + "'{}' does not have expected length of: {}", value, number_of_chars ); -- cgit 1.4.1