This commit is contained in:
猗露 2025-01-30 02:12:58 +00:00 committed by GitHub
commit 81f7628385
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
5 changed files with 22 additions and 1 deletions

View file

@ -1153,12 +1153,14 @@ module Iter_ = struct
let bench_to_array n = let bench_to_array n =
let iter () = Iter.to_array Iter.(1 -- n) let iter () = Iter.to_array Iter.(1 -- n)
and gen () = Gen.to_array Gen.(1 -- n) and gen () = Gen.to_array Gen.(1 -- n)
and oseq () = OSeq.to_array OSeq.(1 -- n) in and oseq () = OSeq.to_array OSeq.(1 -- n)
and of_iter () = CCArray.of_iter Iter.(1 -- n) in
B.throughputN 3 ~repeat B.throughputN 3 ~repeat
[ [
"iter.to_array", iter, (); "iter.to_array", iter, ();
"gen.to_array", gen, (); "gen.to_array", gen, ();
"oseq.to_array", oseq, (); "oseq.to_array", oseq, ();
"ccarray.of_iter", of_iter, ();
] ]
let bench_cons n = let bench_cons n =

View file

@ -466,6 +466,12 @@ let to_seq a =
let to_iter a k = iter k a let to_iter a k = iter k a
let of_iter (i : 'a iter) : 'a array =
let open CCVector in
let vec = create () in
i (push vec);
to_array vec
let to_gen a = let to_gen a =
let k = ref 0 in let k = ref 0 in
fun () -> fun () ->

View file

@ -240,6 +240,11 @@ val to_iter : 'a t -> 'a iter
in modification of the iterator. in modification of the iterator.
@since 2.8 *) @since 2.8 *)
val of_iter : 'a iter -> 'a t
(** [of_iter iter] builds a array from a given [iter].
In the result, elements appear in the same order as they did in the source [iter].
@since NEXT_RELEASE *)
val to_seq : 'a t -> 'a Seq.t val to_seq : 'a t -> 'a Seq.t
(** [to_seq a] returns a [Seq.t] of the elements of an array [a]. (** [to_seq a] returns a [Seq.t] of the elements of an array [a].
The input array [a] is shared with the sequence and modification of it will result The input array [a] is shared with the sequence and modification of it will result

View file

@ -248,6 +248,11 @@ val to_iter : 'a t -> 'a iter
in modification of the iterator. in modification of the iterator.
@since 2.8 *) @since 2.8 *)
val of_iter : 'a iter -> 'a t
(** [of_iter iter] builds a array from a given [iter].
In the result, elements appear in the same order as they did in the source [iter].
@since NEXT_RELEASE *)
val to_seq : 'a t -> 'a Seq.t val to_seq : 'a t -> 'a Seq.t
(** [to_seq a] returns a [Seq.t] of the elements of an array [a]. (** [to_seq a] returns a [Seq.t] of the elements of an array [a].
The input array [a] is shared with the sequence and modification of it will result The input array [a] is shared with the sequence and modification of it will result

View file

@ -309,3 +309,6 @@ q ~count:300 arr_arbitrary (fun a ->
Array.sort CCInt.compare a1; Array.sort CCInt.compare a1;
sort_generic (module IA) ~cmp:CCInt.compare a2; sort_generic (module IA) ~cmp:CCInt.compare a2;
a1 = a2) a1 = a2)
;;
q Q.(array int) (fun a -> of_iter (to_iter a) = a)