From bc48a548e753d6c9108bdecb9d6a711617521c23 Mon Sep 17 00:00:00 2001 From: "Richard W.M. Jones" Date: Sun, 28 Jul 2024 14:49:42 +0100 Subject: [PATCH] v2v: --mac: Allow gw and len fields to be empty Even if these appear in the middle of the list, allow them to be empty. For example this is now permitted whereas previously it was an error: virt-v2v --mac :ip:,,,nameserver Reported-by: Arik Hadas (cherry picked from commit 159fda411d2f75b087106e7293d273ae142c9fbe) --- in-place/in_place.ml | 12 +++++++----- inspector/inspector.ml | 12 +++++++----- v2v/v2v.ml | 12 +++++++----- 3 files changed, 21 insertions(+), 15 deletions(-) diff --git a/in-place/in_place.ml b/in-place/in_place.ml index b74dbc8a..d55f49a0 100644 --- a/in-place/in_place.ml +++ b/in-place/in_place.ml @@ -90,10 +90,10 @@ let rec main () = | "ip" -> (match String.nsplit "," out with | [] -> error (f_"invalid --mac ip option") - | [ip] -> add_static_ip mac ip None None [] - | [ip; gw] -> add_static_ip mac ip (Some gw) None [] + | [ip] -> add_static_ip mac ip "" "" [] + | [ip; gw] -> add_static_ip mac ip gw "" [] | ip :: gw :: len :: nameservers -> - add_static_ip mac ip (Some gw) (Some len) nameservers + add_static_ip mac ip gw len nameservers ) | _ -> assert false and add_static_ip if_mac_addr if_ip_address if_default_gateway @@ -108,12 +108,14 @@ let rec main () = an IP address") what addr in error_unless_ip_addr "ipaddr" if_ip_address; + let if_default_gateway = + match if_default_gateway with "" -> None | gw -> Some gw in Option.iter (error_unless_ip_addr "gw") if_default_gateway; List.iter (error_unless_ip_addr "nameserver") if_nameservers; let if_prefix_length = match if_prefix_length_str with - | None -> None - | Some len -> + | "" -> None + | len -> let len = try int_of_string len with | Failure _ -> error (f_"cannot parse --mac ip prefix length \ diff --git a/inspector/inspector.ml b/inspector/inspector.ml index c79dd687..7c9d2919 100644 --- a/inspector/inspector.ml +++ b/inspector/inspector.ml @@ -97,10 +97,10 @@ let rec main () = | "ip" -> (match String.nsplit "," out with | [] -> error (f_"invalid --mac ip option") - | [ip] -> add_static_ip mac ip None None [] - | [ip; gw] -> add_static_ip mac ip (Some gw) None [] + | [ip] -> add_static_ip mac ip "" "" [] + | [ip; gw] -> add_static_ip mac ip gw "" [] | ip :: gw :: len :: nameservers -> - add_static_ip mac ip (Some gw) (Some len) nameservers + add_static_ip mac ip gw len nameservers ) | _ -> assert false and add_static_ip if_mac_addr if_ip_address if_default_gateway @@ -115,12 +115,14 @@ let rec main () = is an IP address") what addr in error_unless_ip_addr "ipaddr" if_ip_address; + let if_default_gateway = + match if_default_gateway with "" -> None | gw -> Some gw in Option.iter (error_unless_ip_addr "gw") if_default_gateway; List.iter (error_unless_ip_addr "nameserver") if_nameservers; let if_prefix_length = match if_prefix_length_str with - | None -> None - | Some len -> + | "" -> None + | len -> let len = try int_of_string len with | Failure _ -> error (f_"cannot parse --mac ip prefix \ diff --git a/v2v/v2v.ml b/v2v/v2v.ml index 89c08fc5..6d9e3792 100644 --- a/v2v/v2v.ml +++ b/v2v/v2v.ml @@ -109,10 +109,10 @@ let rec main () = | "ip" -> (match String.nsplit "," out with | [] -> error (f_"invalid --mac ip option") - | [ip] -> add_static_ip mac ip None None [] - | [ip; gw] -> add_static_ip mac ip (Some gw) None [] + | [ip] -> add_static_ip mac ip "" "" [] + | [ip; gw] -> add_static_ip mac ip gw "" [] | ip :: gw :: len :: nameservers -> - add_static_ip mac ip (Some gw) (Some len) nameservers + add_static_ip mac ip gw len nameservers ) | _ -> assert false and add_static_ip if_mac_addr if_ip_address if_default_gateway @@ -127,12 +127,14 @@ let rec main () = is an IP address") what addr in error_unless_ip_addr "ipaddr" if_ip_address; + let if_default_gateway = + match if_default_gateway with "" -> None | gw -> Some gw in Option.iter (error_unless_ip_addr "gw") if_default_gateway; List.iter (error_unless_ip_addr "nameserver") if_nameservers; let if_prefix_length = match if_prefix_length_str with - | None -> None - | Some len -> + | "" -> None + | len -> let len = try int_of_string len with | Failure _ -> error (f_"cannot parse --mac ip prefix length field \