Skip to content

Move list functions into a dedicated submodule#315

Merged
talex5 merged 2 commits intoocaml-multicore:mainfrom
raphael-proust:move-list-ops-in-dedicated-submodule
Sep 13, 2022
Merged

Move list functions into a dedicated submodule#315
talex5 merged 2 commits intoocaml-multicore:mainfrom
raphael-proust:move-list-ops-in-dedicated-submodule

Conversation

@raphael-proust
Copy link
Copy Markdown
Contributor

As the title says: this PR introduces a submodule of Fiber called List to collect the list-related functions.

  • The name Eio.Fiber.map could suggest mapping fibers.
  • Lists are centrals but Seqs are also becoming important so having List functions unqualified in the main namespace may not be the best.
  • At some point there'll be contributions to add rev_map, mapi, filteri, etc. and the main namespace would get bloated quickly.

Copy link
Copy Markdown
Collaborator

@talex5 talex5 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems reasonable to me.


(** {2 Concurrent list operations} *)

val filter : ?max_fibers:int -> ('a -> bool) -> 'a list -> 'a list
Copy link
Copy Markdown
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would be nice to mark these as deprecated first, with a clue where they went, for one release at least.

Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done

raphael-proust and others added 2 commits September 13, 2022 14:43
Add deprecated versions of the original functions that were moved.
@talex5 talex5 force-pushed the move-list-ops-in-dedicated-submodule branch from 34c1135 to 781e112 Compare September 13, 2022 13:53
Copy link
Copy Markdown
Collaborator

@talex5 talex5 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks! I just rebased and added a bit of text to the odoc.

@talex5 talex5 merged commit 1bb2907 into ocaml-multicore:main Sep 13, 2022
talex5 added a commit to talex5/opam-repository that referenced this pull request Oct 12, 2022
CHANGES:

Changes:

- Update to OCaml 5.0.0~beta1 (@anmonteiro @talex5 ocaml-multicore/eio#346).

- Add API for seekable read/writes (@nojb ocaml-multicore/eio#307).

- Add `Flow.write` (@haesbaert ocaml-multicore/eio#318).
  This provides an optimised alternative to `copy` in the case where you are writing from a buffer.

- Add `Net.with_tcp_connect` (@bikallem ocaml-multicore/eio#302).
  Convenience function for opening a TCP connection.

- Add `Eio.Time.Timeout` (@talex5 ocaml-multicore/eio#320).
  Makes it easier to pass timeouts around.

- Add `Eio_mock.Clock` (@talex5 ocaml-multicore/eio#328).
  Control time in tests.

- Add `Buf_read.take_while1` and `skip_while1` (@bikallem ocaml-multicore/eio#309).
  These fail if no characters match.

- Make the type parameter for `Promise.t` covariant (@anmonteiro ocaml-multicore/eio#300).

- Move list functions into a dedicated submodule (@raphael-proust ocaml-multicore/eio#315).

- Direct implementation of `Flow.source_string` (@c-cube ocaml-multicore/eio#317).
  Slightly faster.

Bug fixes:

- `Condition.broadcast` must interlock as well (@haesbaert ocaml-multicore/eio#324).

- Split the reads into no more than 2^32-1 for luv (@haesbaert @talex5 @EduardoRFS ocaml-multicore/eio#343).
  Luv uses a 32 bit int for buffer sizes and wraps if the value passed is too big.

- eio_luv: allow `Net.connect` to be cancelled (@talex5 @nojb ocaml-multicore/eio#311).

- eio_main: Use dedicated log source (@anmonteiro ocaml-multicore/eio#326).

- linux_eio: fix kernel version number in log message (@talex5 @nojb ocaml-multicore/eio#314).

- Account for stack differences in the socketpair test (issue ocaml-multicore/eio#312) (@haesbaert ocaml-multicore/eio#313).

Documentation:

- Add Best Practices section to README (@talex5 ocaml-multicore/eio#299).

- Documentation improvements (@talex5 ocaml-multicore/eio#295 ocaml-multicore/eio#337).
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants