From: Alan Schmitt <alan.schmitt@polytechnique.org>
To: "lwn" <lwn@lwn.net>, "cwn" <cwn@lists.idyll.org>, caml-list@inria.fr
Subject: [Caml-list] Attn: Development Editor, Latest OCaml Weekly News
Date: Tue, 20 Sep 2022 16:01:25 +0200 [thread overview]
Message-ID: <875yhirvpm.fsf@m4x.org> (raw)
[-- Attachment #1: Type: text/plain, Size: 22079 bytes --]
Hello
Here is the latest OCaml Weekly News, for the week of September 13 to
20, 2022.
Table of Contents
─────────────────
Sandmark Nightly Service now reports Instructions Retired along with Time
Outreachy December 2022
Unicode 15.0.0 update for Uucd, Uucp, Uunf and Uuseg
OUPS meetup september 2022 (french only)
strymonas v2: library for highest-performance stream processing
OCaml Community Code of Conduct
Use OCaml to interact with Neovim
What will be required to transpile OCaml to Lua?
OBazl Toolsuite - tools for building OCaml with Bazel
Old CWN
Sandmark Nightly Service now reports Instructions Retired along with Time
═════════════════════════════════════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/sandmark-nightly-service-now-reports-instructions-retired-along-with-time/10475/1>
Shakthi Kannan announced
────────────────────────
Sandmark Nightly is a service for the OCaml compiler developers that
helps benchmark the development branches of the compiler on the large
set of Sandmark benchmarks on tuned machines and reports the results
in an interactive UI. Currently, Sandmark nightly reported many
metrics including running time. But running time is a notoriously
noisy metric on modern architectures due to the effects of modern OS,
arch and micro-arch optimisations. There could be swings of 50% in
either directions when the directory in which the program is run
changes.
While we run Sandmark benchmarks on tuned machines, we still see
impact of noise on the real time measurements. To this end, we
introduce a new metric into Sandmark nightly that in addition to real
time, would help interpret the results accounting for the noise. We
now report “instructions retired” for Sandmark runs. Instructions
retired report the number of instructions executed by the program
during its run and hence is shielded from the noise that affects real
time measurements. Of course, the same number of instructions may be
discharged at different rates by the processor due to
instruction-level parallelism and hence, the instructions discharged
metric should be used in conjunction with real time measurements. For
example, if a new compiler feature adds 2 instructions to the prolog
of the function, then the instructions retired metric should inform
you how many new instructions are actually executed on top of the
baseline.
The instructions retired metric is collected from `perf' command. We
also have other useful metrics from perf such as page faults,
branches, branch misses, cache misses at various levels of the
hierarchy, etc. We will add graphs to report these going forward.
Enjoy the new feature, and as ever, report issues and bugs to
[Sandmark Issues].
The web service is available at <https://sandmark.tarides.com> and you
can select the `Perfstat Output' radio button on the left panel as
shown below.
<https://global.discourse-cdn.com/standard11/uploads/ocaml/original/2X/5/5f9d3d8d87ba6821e8f41f027ce7a6b0074ec95a.png>
After selecting the variants and a baseline for comparison, you can
view the normalised `instructions per cycle' change as illustrated
below:
<https://global.discourse-cdn.com/standard11/uploads/ocaml/original/2X/1/1baf673b1246eb3505f8603a260ee4f22f32fb85.png>
You can also request for your development branches to be added to the
Sandmark Nightly Service at the [sandmark-nightly-config] repository
for the nightly runs.
[Sandmark Issues] <https://github.com/ocaml-bench/sandmark/issues>
[sandmark-nightly-config]
<https://github.com/ocaml-bench/sandmark-nightly-config>
References
╌╌╌╌╌╌╌╌╌╌
1. Run perfstat with Sandmark nightly service. [Sandmark PR #394]
2. Add webpage with perfstat output from Sandmark. [Sandmark-nightly
PR #81]
3. perfstat.ipynb. [Sandmark perfstat Jupyter notebook]
[Sandmark PR #394] <https://github.com/ocaml-bench/sandmark/pull/394>
[Sandmark-nightly PR #81]
<https://github.com/ocaml-bench/sandmark-nightly/pull/81>
[Sandmark perfstat Jupyter notebook]
<https://github.com/ocaml-bench/sandmark/blob/main/notebooks/perfstat/perfstat.ipynb>
Outreachy December 2022
═══════════════════════
Archive:
<https://discuss.ocaml.org/t/outreachy-december-2022/10336/18>
Patrick Ferris said
───────────────────
Just a reminder the deadline for mentor signup is in 9 days, the same
day as
<https://discuss.ocaml.org/t/outreachy-summer-22-closing-commemoration-session-on-23rd-sept/10450>
:camel:
Unicode 15.0.0 update for Uucd, Uucp, Uunf and Uuseg
════════════════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/ann-unicode-15-0-0-update-for-uucd-uucp-uunf-and-uuseg/10485/1>
Daniel Bünzli announced
───────────────────────
Unicode 15.0.0 was released on the 13th of september. It adds 4489 new
characters to the standard.
Given the increasing contributions from the South Asian subcontinent
to OCaml we are glad this includes support for the 42 (sic) characters
of the [Nag Mundari script]. For information about the other
additions, see the [announcement page].
Accordingly the libraries mentioned at the end of this message had to
be updated. Consult the individual release notes for details. Both
Uucd and Uucp are incompatible releases sinces new script and block
enumerants had to be added.
Note that starting from Unicode 16.0.0 – that is in a year – these
libraries will be changed to use the UTF decoders of the standard
library rather than rely on Uutf. They will thus only be available for
OCaml >= 4.14.
The OCaml tips of the [minimal Unicode introduction], which you should
read if Unicode still puzzles you, have been updated to mention the
new standard library UTF decoders.
Also, the `ucharinfo' tool distributed with `uucp'[^1] can now also
lookup characters by matching substrings in their Unicode name or name
aliases.
Best,
Daniel
A big thanks for funding from the [OCaml Software Foundation] and from
my [faithful donators].
• Uucd 15.0.0 Unicode character database decoder for OCaml.
<http://erratique.ch/software/uucd>
• Uucp 15.0.0 Unicode character properties for OCaml.
<http://erratique.ch/software/uucp>
• Uunf 15.0.0 Unicode text normalization for OCaml.
<http://erratique.ch/software/uunf>
• Uuseg 15.0.0 Unicode text segmentation for OCaml.
<http://erratique.ch/software/uuseg>
[^1]: It’s a depopt you’ll need `opam install cmdliner uutf uunf uucp'
to install it.
[Nag Mundari script]
<https://unicode.org/charts/PDF/Unicode-15.0/U150-1E4D0.pdf>
[announcement page]
<https://blog.unicode.org/2022/09/announcing-unicode-standard-version-150.html>
[minimal Unicode introduction]
<https://erratique.ch/software/uucp/doc/unicode.html>
[OCaml Software Foundation] <http://ocaml-sf.org/>
[faithful donators] <https://github.com/sponsors/dbuenzli>
OUPS meetup september 2022 (french only)
════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/oups-meetup-september-2022-french-only/10492/1>
zapashcanon announced
─────────────────────
(this is in french only as the talks will be in french it’s probably
not relevant for english speakers)
Le prochain OUPS aura lieu le *jeudi 29 septembre* 2022. Le
rendez-vous est fixé à *19h* au *4 place Jussieu (salle à préciser)*,
75005 Paris.
*[L’inscription est obligatoire]* pour pouvoir accéder au meetup !
Les exposés seront également retransmis en ligne sur le [galène du
OUPS].
Toutes les informations sont disponibles sur le [site du OUPS].
*Programme :*
*COBOL 101 – Émilien Lemaire*
COBOL est un langage très ancien et est assez éloigné de ceux que nous
manipulons tous les jours. Malgré cela il reste l’un des plus utilisés
dans le monde.
Durant cette présentation je vais donc vous introduire au langage,
voir comment sont écrit les programmes, comment les variables
sont-elles déclarées et comment les manipuler. Je vais aussi vous
présenter quelques features “intéressantes” du langage, dont certaines
sont inattendues.
*OCaml Multicore – Florian Angeletti*
*Opam-bin: Opam et paquets binaires – Fabrice Le Fessant*
L’utilisation d’un gestionnaire de paquets sources comme Opam n’est
pas toujours optimale en temps, car l’outil passe beaucoup de temps à
recompiler des paquets, dèjà compilés dans le passé ou par d’autres
utilisateurs. Le plugin Opam-bin répond à ce problème en permettant de
créer à la volée des paquets binaires, qui seront réutilisés à
l’avenir et peuvent être partagés avec d’autres utilisateurs. L’exposé
montre son utilisation et comment il fonctionne.
Les présentations seront suivies par des discussions libres. Les
pizzas seront offertes par la fondation OCaml ! :pizza:
[L’inscription est obligatoire]
<https://www.meetup.com/fr-FR/ocaml-paris/events/288520108/>
[galène du OUPS] <https://galene.irill.org/group/oups/>
[site du OUPS] <https://oups.frama.io/>
strymonas v2: library for highest-performance stream processing
═══════════════════════════════════════════════════════════════
Archive:
<https://sympa.inria.fr/sympa/arc/caml-list/2022-09/msg00004.html>
Oleg announced
──────────────
As has just been announced at the OCAML 2022 workshop, the new,
re-written version of strymonas library is now available at
<https://strymonas.github.io>
Strymonas is the stream processing library that achieves the highest
performance of existing OCaml streaming libraries, attaining the speed
and memory efficiency of hand-written state machines. It supports
finite and infinite streams with the familiar declarative interface,
of any combination of map, filter, take(while), drop(while), zip,
flatmap combinators and tupling. Experienced users may use the
lower-level interface of stateful streams and implement accumulating
maps, compression and windowing. The library is based on assured code
generation (at present, of OCaml and C) and guarantees in all cases
complete fusion.
Compared with the original strymonas (POPL 2017), the new version is
completely re-written and:
• Generates not only OCaml but also C (which needs no OCaml run-time
and vectorizable)
• Has Core + code-generation Backends architecture: MetaOCaml is
needed only for the OCaml backend and benchmarks; the Core and the C
generation backend are pure OCaml. More backends can be easily
added.
• The complete fusion is now achieved in all cases
• Supports both user-friendly and familiar declarative combinators,
and low-level core of stafeful streams (which can be used together)
• Core streams support streams over tuples, records and even abstract
data types
• Fusion is now performed as normalization-by-evaluation
The paper <https://strymonas.github.io/docs/ocaml-22.pdf> and the
OCAML 2022 talk (soon to be available on YouTube’s SIGPLAN
channel, among all other talks of the ICFP 2022 event) give
more details. The github repo contains the complete code of
the library, examples and all benchmarks.
OCaml Community Code of Conduct
═══════════════════════════════
Archive:
<https://discuss.ocaml.org/t/ocaml-community-code-of-conduct/10494/1>
Sudha Parimala announced
────────────────────────
Hello all! On behalf of the OCaml CoC committee, I’d like to present
the proposed Code of Conduct for the OCaml community. We hope this is
a step towards ensuring a friendly and inclusive community for
everyone.
The CoC text, based on Contributor Covenant can be found [here].
[here]
<https://gist.github.com/Sudha247/ed049de0fd91d26f43777fb11ac0453f>
The committee
╌╌╌╌╌╌╌╌╌╌╌╌╌
The current committee consists of the following people:
• Louis Roché ( @Khady, Ahrefs)
• Marcello Seri ( @mseri, University of Groningen)
• Raja Boujbel ( @rjbou, OCamlPro)
• Simon Cruanes ( @c-cube, Imandara Software)
• Sonja Heinze (@pitag, Tarides)
Scope
╌╌╌╌╌
The spaces within the scope of the committee at the moment are:
• discuss.ocaml.org
• OCaml mailing list
• OCaml IRC
• OCaml GitHub organisation
Timeline
╌╌╌╌╌╌╌╌
The committee has discussed on the CoC text. We’d be happy to hear any
feedback from the community. If all goes well, the CoC will be
enforced roughly a month from now. We’ll keep this thread updated with
any developments.
Role of OCaml Software foundation
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
While this effort is endorsed by the OCaml Software Foundation,
they’re not directly involved with the committee’s operation or
decisions by the committee on the enforcement, and this would remain
the same in future.
Onboarding more projects
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
The committee is open to onboarding more projects under the umbrella
of this CoC.
We see two ways to go forward:
(1) Projects adopt the CoC text and the project maintainers do the
moderation work themselves.
(2) Projects adopt the CoC text and the committee would also act as
arbitrers for violation reports submitted to them.
Ideally we could do a combination of both. Smaller projects could
possibly adopt the latter and take help from the committee for
enforcement, while bigger projects with capacity to do the moderation
themselves can adopt the CoC text. The decision to accept projects
into the umbrella lies with the committee.
We’re keen to hear any thoughts or suggestions for improvement. If
you’re interested to adopt this CoC for your OCaml project, please
don’t hesitate to post here or contact me (write to me at sudharg247
[at] gmail [dot] com or DM here) or any of the committee members (DM
here).
Use OCaml to interact with Neovim
═════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/what-will-be-required-to-transpile-ocaml-to-lua/10493/10>
Deep in this thread, Dani Dickstein said
────────────────────────────────────────
For the Neovim-specific use case, you may want to take a look at
[vcaml], which lets you write OCaml programs that interact with Neovim
over msgpack RPC. Do note though that while the library as-is should
provide you with the functionality you need, it is under active
development so the API may change (improve) in significant ways
between releases.
[vcaml] <https://opam.ocaml.org/packages/vcaml/>
What will be required to transpile OCaml to Lua?
════════════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/what-will-be-required-to-transpile-ocaml-to-lua/10493/14>
Deep in this thread, David Jeffrey said
───────────────────────────────────────
Doesn’t necessarily help much, but a while ago I wrote a
proof-of-concept ML-style language (using OCaml, of course) that
transpiled to Lua - <https://github.com/merle-lang/luml> (I was mostly
thinking about targeting game engines… I did enough to implement
Tetris and then gave up on it).
The module that emits Lua source code was pretty simple:
<https://github.com/merle-lang/luml/blob/master/lib/compile.ml> - I
did thinking about trying to target byte code but it seemed tricky due
to different Lua versions, I think.
OBazl Toolsuite - tools for building OCaml with Bazel
═════════════════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/obazl-toolsuite-tools-for-building-ocaml-with-bazel/10021/10>
Continuing this thread, james woodyatt asked and Gregg Reynolds replied
───────────────────────────────────────────────────────────────────────
Any chance we might see a `conf-bazel' package added to
OPAM so a package can depend on a compatible version of
Bazel being installed on the host?
I’ve put a lot of work into seamless OPAM integration, but only in one
direction: make it easy to use OPAM resources in a Bazel build
program. I have not put much thought into integrating Bazel itself
into the OPAM ecosystem. For example publishing a Bazel-enabled
package to OPAM. It looks like writing such a conf-bazel package would
be pretty easy, but I’m not sure it would do us much good at the
moment. What specific use cases do you have in mind?
There are two ways to integrate Bazel and OPAM. One is to
automatically generate BUILD.bazel files for OPAM packages. Then Bazel
would build everything, eliminating the need for the OPAM engine. This
is the strategy followed by rust (tool: cargo_raze, evidently now
supplanted by crate_universe) and go (tool: gazelle). Unfortunately a
complete solution along these lines is not feasible for OCaml, since
source files do not carry enough information to support inference to a
build program, and OPAM packages may use a variety of build languages
(Dune, Makefiles, OMake, etc.). On the other hand, Dune seems to be
the most widely used build engine by a considerable margin, and the
Dune language is easy to parse (if not so easy to interpret), so I’m
working on a conversion tool that automatically converts Dune files to
BUILD.bazel files.
The other strategy is to rely on OPAM to build dependencies and then
“import” the built artifacts into Bazel. OBazl defines an
`opam_import' rule for this purpose, and a tool that bazelizes OPAM
switches, generating an OBazl ’coswitch’. The mapping from OPAM
package name to Bazel label is straightforward: ’yojson’ to
`@yojson//lib/yojson', ’lwt.unix’ to `@lwt//lib/unix', etc.
So in practice OBazl supports a hybrid approach. Use Bazel to build
your code, but import pre-built OPAM dependencies. To do that you run
the opam conversion tool to generate a ’coswitch’ which defines a
local Bazel repo for each OPAM package, and configure your
WORKSPACE.bazel to import those repos. Write your BUILD.bazel files
using opam labels as above. If your project already uses dune, you can
run the dune conversion tool to generate your BUILD.bazel files, which
in some cases will need some tweaking, since some Dune stanzas lack
sufficient information for conversion, and in others the conversion
code needs complicated logic that I haven’t gotten around to writing,
or that does not seem worth the bother.
The OPAM “import” conversion tool is fairly stable. It converts the
META files in OPAM into BUILD.bazel files, which include dependency
information. So when you depend on an `opam_import' target you get its
entire dependency graph.
The Dune migration tool is another matter. Reverse-engineering the
Dune language is a non-trivial task, lemme tell ya. The good news is
that after what seems like eons of work the end is in sight. I’ve been
running it against a semi-random set of projects (js_of_ocaml,
ocaml-protoc, some ppx libs, etc.) and working through the quirks
inch-by-inch. Rule stanzas are a real PITA, can I just say that? In
any case, it looks like I should have an alpha release with
documentation and some case studies within a week or so. I hope. At
the very least I’ll convert my dev configuration into something usable
by others so you can follow along if you want.
Old CWN
═══════
If you happen to miss a CWN, you can [send me a message] and I’ll mail
it to you, or go take a look at [the archive] or the [RSS feed of the
archives].
If you also wish to receive it every week by mail, you may subscribe
[online].
[Alan Schmitt]
[send me a message] <mailto:alan.schmitt@polytechnique.org>
[the archive] <https://alan.petitepomme.net/cwn/>
[RSS feed of the archives] <https://alan.petitepomme.net/cwn/cwn.rss>
[online] <http://lists.idyll.org/listinfo/caml-news-weekly/>
[Alan Schmitt] <https://alan.petitepomme.net/>
[-- Attachment #2: Type: text/html, Size: 34041 bytes --]
next reply other threads:[~2022-09-20 14:01 UTC|newest]
Thread overview: 236+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-09-20 14:01 Alan Schmitt [this message]
-- strict thread matches above, loose matches on Subject: below --
2025-04-15 9:51 Alan Schmitt
2025-04-08 13:14 Alan Schmitt
2025-04-01 9:12 Alan Schmitt
2025-03-25 8:06 Alan Schmitt
2025-03-18 10:18 Alan Schmitt
2025-03-11 15:00 Alan Schmitt
2025-03-04 14:01 Alan Schmitt
2025-02-25 10:36 Alan Schmitt
2025-02-18 14:33 Alan Schmitt
2025-02-11 7:17 Alan Schmitt
2025-02-04 12:05 Alan Schmitt
2025-01-28 13:24 Alan Schmitt
2025-01-21 15:47 Alan Schmitt
2025-01-14 8:20 Alan Schmitt
2025-01-07 17:26 Alan Schmitt
2024-12-31 8:03 Alan Schmitt
2024-12-24 8:55 Alan Schmitt
2024-12-17 13:05 Alan Schmitt
2024-12-10 13:48 Alan Schmitt
2024-12-03 14:44 Alan Schmitt
2024-11-26 8:30 Alan Schmitt
2024-11-19 6:52 Alan Schmitt
2024-11-12 15:00 Alan Schmitt
2024-11-05 13:22 Alan Schmitt
2024-10-29 13:30 Alan Schmitt
2024-10-22 12:42 Alan Schmitt
2024-10-15 13:31 Alan Schmitt
2024-10-08 10:56 Alan Schmitt
2024-10-01 13:37 Alan Schmitt
2024-09-24 13:18 Alan Schmitt
2024-09-17 14:02 Alan Schmitt
2024-09-10 13:55 Alan Schmitt
2024-09-03 8:24 Alan Schmitt
2024-08-27 9:02 Alan Schmitt
2024-08-20 9:29 Alan Schmitt
2024-08-13 13:21 Alan Schmitt
2024-08-06 9:00 Alan Schmitt
2024-07-30 13:26 Alan Schmitt
2024-07-23 13:30 Alan Schmitt
2024-07-16 6:24 Alan Schmitt
2024-07-09 9:19 Alan Schmitt
2024-07-02 7:30 Alan Schmitt
2024-06-25 13:58 Alan Schmitt
2024-06-18 13:05 Alan Schmitt
2024-06-11 15:04 Alan Schmitt
2024-06-04 13:26 Alan Schmitt
2024-05-28 9:07 Alan Schmitt
2024-05-21 13:07 Alan Schmitt
2024-05-14 13:25 Alan Schmitt
2024-05-07 7:30 Alan Schmitt
2024-04-30 7:22 Alan Schmitt
2024-04-23 12:17 Alan Schmitt
2024-04-16 12:00 Alan Schmitt
2024-04-09 9:15 Alan Schmitt
2024-04-02 14:31 Alan Schmitt
2024-03-26 6:32 Alan Schmitt
2024-03-19 15:09 Alan Schmitt
2024-03-12 10:31 Alan Schmitt
2024-03-05 14:50 Alan Schmitt
2024-02-27 13:53 Alan Schmitt
2024-02-20 9:12 Alan Schmitt
2024-02-13 8:42 Alan Schmitt
2024-02-06 15:14 Alan Schmitt
2024-01-30 14:16 Alan Schmitt
2024-01-23 9:45 Alan Schmitt
2024-01-16 10:01 Alan Schmitt
2024-01-09 13:40 Alan Schmitt
2024-01-02 8:59 Alan Schmitt
2023-12-26 10:12 Alan Schmitt
2023-12-19 10:10 Alan Schmitt
2023-12-12 10:20 Alan Schmitt
2023-12-05 10:13 Alan Schmitt
2023-11-28 9:09 Alan Schmitt
2023-11-21 7:47 Alan Schmitt
2023-11-14 13:42 Alan Schmitt
2023-11-07 10:31 Alan Schmitt
2023-10-31 10:43 Alan Schmitt
2023-10-24 9:17 Alan Schmitt
2023-10-17 7:46 Alan Schmitt
2023-10-10 7:48 Alan Schmitt
2023-10-03 13:00 Alan Schmitt
2023-09-19 8:54 Alan Schmitt
2023-09-12 13:21 Alan Schmitt
2023-09-05 9:00 Alan Schmitt
2023-08-29 13:04 Alan Schmitt
2023-08-22 9:20 Alan Schmitt
2023-08-15 16:33 Alan Schmitt
2023-08-08 8:53 Alan Schmitt
2023-08-01 7:13 Alan Schmitt
2023-07-25 8:45 Alan Schmitt
2023-07-11 8:45 Alan Schmitt
2023-07-04 9:18 Alan Schmitt
2023-06-27 8:38 Alan Schmitt
2023-06-20 9:52 Alan Schmitt
2023-06-13 7:09 Alan Schmitt
2023-06-06 14:22 Alan Schmitt
2023-05-30 15:43 Alan Schmitt
2023-05-23 9:41 Alan Schmitt
2023-05-16 13:05 Alan Schmitt
2023-05-09 11:49 Alan Schmitt
2023-05-02 8:01 Alan Schmitt
2023-04-25 9:25 Alan Schmitt
2023-04-18 8:50 Alan Schmitt
2023-04-11 12:41 Alan Schmitt
2023-04-04 8:45 Alan Schmitt
2023-03-28 7:21 Alan Schmitt
2023-03-21 10:07 Alan Schmitt
2023-03-14 9:52 Alan Schmitt
2023-03-07 9:02 Alan Schmitt
2023-02-28 14:38 Alan Schmitt
2023-02-21 10:19 Alan Schmitt
2023-02-14 8:12 Alan Schmitt
2023-02-07 8:16 Alan Schmitt
2023-01-31 6:44 Alan Schmitt
2023-01-24 8:57 Alan Schmitt
2023-01-17 8:37 Alan Schmitt
2022-11-29 14:53 Alan Schmitt
2022-09-27 7:17 Alan Schmitt
2022-09-13 8:40 Alan Schmitt
2022-08-23 8:06 Alan Schmitt
2022-08-16 8:51 Alan Schmitt
2022-08-09 8:02 Alan Schmitt
2022-08-02 9:51 Alan Schmitt
2022-07-26 17:54 Alan Schmitt
2022-07-19 8:58 Alan Schmitt
2022-07-12 7:59 Alan Schmitt
2022-07-05 7:42 Alan Schmitt
2022-06-28 7:37 Alan Schmitt
2022-06-21 8:06 Alan Schmitt
2022-06-14 9:29 Alan Schmitt
2022-06-07 10:15 Alan Schmitt
2022-05-31 12:29 Alan Schmitt
2022-05-24 8:04 Alan Schmitt
2022-05-17 7:12 Alan Schmitt
2022-05-10 12:30 Alan Schmitt
2022-05-03 9:11 Alan Schmitt
2022-04-26 6:44 Alan Schmitt
2022-04-19 5:34 Alan Schmitt
2022-04-12 8:10 Alan Schmitt
2022-04-05 11:50 Alan Schmitt
2022-03-29 7:42 Alan Schmitt
2022-03-22 13:01 Alan Schmitt
2022-03-15 9:59 Alan Schmitt
2022-03-01 13:54 Alan Schmitt
2022-02-22 12:43 Alan Schmitt
2022-02-08 13:16 Alan Schmitt
2022-02-01 13:00 Alan Schmitt
2022-01-25 12:44 Alan Schmitt
2022-01-11 8:20 Alan Schmitt
2022-01-04 7:56 Alan Schmitt
2021-12-28 8:59 Alan Schmitt
2021-12-21 9:11 Alan Schmitt
2021-12-14 11:02 Alan Schmitt
2021-11-30 10:51 Alan Schmitt
2021-11-16 8:41 Alan Schmitt
2021-11-09 10:08 Alan Schmitt
2021-11-02 8:50 Alan Schmitt
2021-10-19 8:23 Alan Schmitt
2021-09-28 6:37 Alan Schmitt
2021-09-21 9:09 Alan Schmitt
2021-09-07 13:23 Alan Schmitt
2021-08-24 13:44 Alan Schmitt
2021-08-17 6:24 Alan Schmitt
2021-08-10 16:47 Alan Schmitt
2021-07-27 8:54 Alan Schmitt
2021-07-20 12:58 Alan Schmitt
2021-07-06 12:33 Alan Schmitt
2021-06-29 12:24 Alan Schmitt
2021-06-22 9:04 Alan Schmitt
2021-06-01 9:23 Alan Schmitt
2021-05-25 7:30 Alan Schmitt
2021-05-11 14:47 Alan Schmitt
2021-05-04 8:57 Alan Schmitt
2021-04-27 14:26 Alan Schmitt
2021-04-20 9:07 Alan Schmitt
2021-04-06 9:42 Alan Schmitt
2021-03-30 14:55 Alan Schmitt
2021-03-23 9:05 Alan Schmitt
2021-03-16 10:31 Alan Schmitt
2021-03-09 10:58 Alan Schmitt
2021-02-23 9:51 Alan Schmitt
2021-02-16 13:53 Alan Schmitt
2021-02-02 13:56 Alan Schmitt
2021-01-26 13:25 Alan Schmitt
2021-01-19 14:28 Alan Schmitt
2021-01-12 9:47 Alan Schmitt
2021-01-05 11:22 Alan Schmitt
2020-12-29 9:59 Alan Schmitt
2020-12-22 8:48 Alan Schmitt
2020-12-15 9:51 Alan Schmitt
2020-12-01 8:54 Alan Schmitt
2020-11-03 15:15 Alan Schmitt
2020-10-27 8:43 Alan Schmitt
2020-10-20 8:15 Alan Schmitt
2020-10-06 7:22 Alan Schmitt
2020-09-29 7:02 Alan Schmitt
2020-09-22 7:27 Alan Schmitt
2020-09-08 13:11 Alan Schmitt
2020-09-01 7:55 Alan Schmitt
2020-08-18 7:25 Alan Schmitt
2020-07-28 16:57 Alan Schmitt
2020-07-21 14:42 Alan Schmitt
2020-07-14 9:54 Alan Schmitt
2020-07-07 10:04 Alan Schmitt
2020-06-30 7:00 Alan Schmitt
2020-06-16 8:36 Alan Schmitt
2020-06-09 8:28 Alan Schmitt
2020-05-19 9:52 Alan Schmitt
2020-05-12 7:45 Alan Schmitt
2020-05-05 7:45 Alan Schmitt
2020-04-28 12:44 Alan Schmitt
2020-04-21 8:58 Alan Schmitt
2020-04-14 7:28 Alan Schmitt
2020-04-07 7:51 Alan Schmitt
2020-03-31 9:54 Alan Schmitt
2020-03-24 9:31 Alan Schmitt
2020-03-17 11:04 Alan Schmitt
2020-03-10 14:28 Alan Schmitt
2020-03-03 8:00 Alan Schmitt
2020-02-25 8:51 Alan Schmitt
2020-02-18 8:18 Alan Schmitt
2020-02-04 8:47 Alan Schmitt
2020-01-28 10:53 Alan Schmitt
2020-01-21 14:08 Alan Schmitt
2020-01-14 14:16 Alan Schmitt
2020-01-07 13:43 Alan Schmitt
2019-12-31 9:18 Alan Schmitt
2019-12-17 8:52 Alan Schmitt
2019-12-10 8:21 Alan Schmitt
2019-12-03 15:42 Alan Schmitt
2019-11-26 8:33 Alan Schmitt
2019-11-12 13:21 Alan Schmitt
2019-11-05 6:55 Alan Schmitt
2019-10-15 7:28 Alan Schmitt
2019-09-03 7:35 Alan Schmitt
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=875yhirvpm.fsf@m4x.org \
--to=alan.schmitt@polytechnique.org \
--cc=caml-list@inria.fr \
--cc=cwn@lists.idyll.org \
--cc=lwn@lwn.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox