[Libguestfs] [PATCH 13/27] daemon: Reimplement ‘list_ldm_(volumes|partitions)’ APIs in OCaml.

Pino Toscano ptoscano at redhat.com
Wed Jul 19 13:20:40 UTC 2017


On Friday, 14 July 2017 15:39:21 CEST Richard W.M. Jones wrote:
> +(* All device mapper devices are called /dev/mapper/ldm_vol_*.  XXX We
> + * could tighten this up in future if ldmtool had a way to read these
> + * names back after they have been created.
> + *)
> +let list_ldm_volumes () =
> +  (* If /dev/mapper doesn't exist at all, don't give an error. *)
> +  if not (is_directory "/dev/mapper") then
> +    []
> +  else (
> +    let dir = Sys.readdir "/dev/mapper" in
> +    let dir = Array.to_list dir in
> +    let dir =
> +      List.filter (fun d -> String.is_prefix d "ldm_vol_") dir in
> +    let dir = List.map ((^) "/dev/mapper/") dir in
> +    List.sort compare dir
> +  )
> +
> +(* Same as above but /dev/mapper/ldm_part_*. *)
> +let list_ldm_partitions () =
> +  (* If /dev/mapper doesn't exist at all, don't give an error. *)
> +  if not (is_directory "/dev/mapper") then
> +    []
> +  else (
> +    let dir = Sys.readdir "/dev/mapper" in
> +    let dir = Array.to_list dir in
> +    let dir =
> +      List.filter (fun d -> String.is_prefix d "ldm_part_") dir in
> +    let dir = List.map ((^) "/dev/mapper/") dir in
> +    List.sort compare dir
> +  )

IMHO most of their code can be shared, like done in the C
implementations -- something like the following (untested):

  let get_devices prefix =
    (* If /dev/mapper doesn't exist at all, don't give an error. *)
    if not (is_directory "/dev/mapper") then
      []
    else (
      let dir = Sys.readdir "/dev/mapper" in
      let dir = Array.to_list dir in
      let dir =
        List.filter (fun d -> String.is_prefix d prefix) dir in
      let dir = List.map ((^) "/dev/mapper/") dir in
      List.sort compare dir
    )

  let list_ldm_volumes () =
    get_devices "ldm_vol_"

  let list_ldm_partitions () =
    get_devices "ldm_part_"

-- 
Pino Toscano
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: This is a digitally signed message part.
URL: <http://listman.redhat.com/archives/libguestfs/attachments/20170719/8bab4eaf/attachment.sig>


More information about the Libguestfs mailing list