-
Notifications
You must be signed in to change notification settings - Fork 412
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feature: add KiB,MiB,GiB and TiB values (#8618)
We make these the default printed values when displaying bytes. However the dune lang decoder can understand binary and decimal byte units. We also expand the test suite to account for parsing and displaying these values. Signed-off-by: Ali Caglayan <alizter@gmail.com>
- Loading branch information
Showing
8 changed files
with
180 additions
and
21 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
- `dune cache trim` now accepts binary byte units: `KiB`, `MiB`, etc. (#8618, @Alizter) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,8 @@ | ||
(** Conversion table for byte suffixes and their corresponding [Int64.t] values. | ||
The first element of the tuple is a list of possible suffixes for the second | ||
element of the tuple which is the value. There are some static checks done | ||
on this table ensuring it is ordered and well-formed.*) | ||
(** Conversion table for decimal byte suffixes and their corresponding [Int64.t] values. | ||
The first element of the tuple is a list of possible suffixes for the second element | ||
of the tuple which is the value. There are some static checks done on this table | ||
ensuring it is ordered and well-formed.*) | ||
val conversion_table : (string list * Int64.t) list | ||
|
||
(** [pp n] pretty-prints [n] as a decimal byte suffix. *) | ||
val pp : Int64.t -> string |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
(library | ||
(name dune_sexp_tests) | ||
(inline_tests) | ||
(libraries | ||
dune_tests_common | ||
stdune | ||
dune_sexp | ||
;; This is because of the (implicit_transitive_deps false) | ||
;; in dune-project | ||
ppx_expect.config | ||
ppx_expect.config_types | ||
ppx_expect.common | ||
base | ||
ppx_inline_test.config) | ||
(preprocess | ||
(pps ppx_expect))) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
open Stdune | ||
|
||
let () = Dune_tests_common.init () | ||
|
||
(* Testing the parsing of byte values *) | ||
let parse_bytes value = | ||
Dune_sexp.Ast.atom_or_quoted_string Loc.none value | ||
|> Dune_sexp.Decoder.parse Dune_sexp.Decoder.bytes_unit Univ_map.empty | ||
;; | ||
|
||
let rec long_power (l : int64) (n : int) : int64 = | ||
if n = 0 then 1L else Int64.mul l @@ long_power l (n - 1) | ||
;; | ||
|
||
let parse_and_assert ?check value = | ||
let value = parse_bytes value in | ||
(match check with | ||
| None -> () | ||
| Some check -> assert (value = check)); | ||
value | ||
;; | ||
|
||
let test_bytes ?check value = parse_and_assert ?check value |> Printf.printf "%#Ld\n" | ||
|
||
(* Hack to insert underscores for hex values. Digits must only be 0-9 *) | ||
let test_bytes_hex ?check value = | ||
match parse_and_assert ?check value |> sprintf "%Lx" |> Int.of_string with | ||
| Some x -> x |> Printf.sprintf "0x%#d\n" |> print_endline | ||
| None -> print_endline "hex value must not have letters" | ||
;; | ||
|
||
(* Test parsing of integers. *) | ||
|
||
let%expect_test "parsing no suffix" = | ||
try test_bytes "100" with | ||
| exn -> | ||
User_message.print (User_message.make [ Exn.pp exn ]); | ||
[%expect | ||
{| | ||
File "<none>", line 1, characters 0-0: | ||
Error: missing suffix, use one of B, kB, KiB, MB, MiB, GB, GiB, TB, TiB |}] | ||
;; | ||
|
||
(* Test all suffixes. We print binary units in hex to better see output. *) | ||
|
||
let%expect_test "parsing B suffix" = | ||
test_bytes "1B" ~check:(long_power 1024L 0); | ||
[%expect {| 1 |}] | ||
;; | ||
|
||
let%expect_test "parsing kB suffix" = | ||
test_bytes "1kB" ~check:(long_power 1000L 1); | ||
[%expect {| 1_000 |}] | ||
;; | ||
|
||
let%expect_test "parsing KiB suffix" = | ||
test_bytes_hex "1KiB" ~check:(long_power 1024L 1); | ||
[%expect {| 0x400 |}] | ||
;; | ||
|
||
let%expect_test "parsing MB suffix" = | ||
test_bytes "1MB" ~check:(long_power 1000L 2); | ||
[%expect {| 1_000_000 |}] | ||
;; | ||
|
||
let%expect_test "parsing MiB suffix" = | ||
test_bytes_hex "1MiB" ~check:(long_power 1024L 2); | ||
[%expect {| 0x100_000 |}] | ||
;; | ||
|
||
let%expect_test "parsing GB suffix" = | ||
test_bytes "1GB" ~check:(long_power 1000L 3); | ||
[%expect {| 1_000_000_000 |}] | ||
;; | ||
|
||
let%expect_test "parsing GiB suffix" = | ||
test_bytes_hex "1GiB" ~check:(long_power 1024L 3); | ||
[%expect {| 0x40_000_000 |}] | ||
;; | ||
|
||
let%expect_test "parsing TB suffix" = | ||
test_bytes "1TB" ~check:(long_power 1000L 4); | ||
[%expect {| 1_000_000_000_000 |}] | ||
;; | ||
|
||
let%expect_test "parsing TiB suffix" = | ||
test_bytes_hex "1TiB" ~check:(long_power 1024L 4); | ||
[%expect {| 0x10_000_000_000 |}] | ||
;; |