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, 13 Sep 2022 10:40:41 +0200 [thread overview]
Message-ID: <87sfkv8y5y.fsf@m4x.org> (raw)
[-- Attachment #1: Type: text/plain, Size: 17186 bytes --]
Hello
Here is the latest OCaml Weekly News, for the week of September 06 to
13, 2022.
Table of Contents
─────────────────
Caqti 1.9.0 and Plans for 2.0.0
Outreachy summer ’22 closing commemoration session on 23rd Sept
MirageOS for B2B SaaS
Tuareg and Caml modes for Emacs: what are the differences?
Engineer position at Imandra (Austin TX/UK)
Acme plumbing rules for OCaml
Other OCaml News
Old CWN
Caqti 1.9.0 and Plans for 2.0.0
═══════════════════════════════
Archive:
<https://discuss.ocaml.org/t/ann-caqti-1-9-0-and-plans-for-2-0-0/10448/1>
Petter A. Urkedal announced
───────────────────────────
First I would like to announce the 1.9.0 minor release, see the
release notes below for details.
There is also ongoing work in the [caqti2 branch] targeted for the
next major release. If someone have an opinion on directions, we can
discuss it here, or in the issue tracker ([meta-issue]), see my brief
notes below.
I will attend parts of the ICFP 2022 virtually next week so there may
be time to discuss over audio.
[caqti2 branch] <https://github.com/paurkedal/ocaml-caqti/tree/caqti2>
[meta-issue] <https://github.com/paurkedal/ocaml-caqti/issues/90>
Release Notes for 1.9.0
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
New features:
• Allow unquoted semicolons in query strings in the new API. There are
corner cases where it is needed, as reported in issue #87, and a
parser which rejects semicolons are still available for loading
schema files statement by statement.
• Add support for MySQL and MariaDB configuration files, as a solution
to issue #86.
• Add a limit to the number of times a database connection is reused
when pooling connections (#94). Thanks to Peter Mondlock for
investigating resource usage server side motivating this addition.
• Provide access to the raw SQLite3 connection handle for the purpose
of defining custom functions (#56).
Fixes:
• Add missing dune dependency on unix (GPR#85 by David Allsopp).
• Documentation fixes (GPR#82, GPR#83, GPR#84 by Reynir Björnsson,
GPR#88 by Jonathan Duarte, and GPR#92 by Jim Tittsler).
Deprecations:
• `Caqti_type.field' was deprecated in favour of `Caqti_type.Field.t'.
Other:
• Replace deprecated core_kernel dependency with core.
Notes on 2.0.0 Development
╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌
The main addition is pgx and mirage support. It is already functional,
but not very useful for production, since it lacks TLS. The trick here
is that PostgreSQL uses STARTTLS, so we can’t use conduit-lwt as-is.
Another thing in progress, but unpublished, is [per-connection
configuration]. Up till now, configuration has only been possible
through the connection URL or behind-the-scene via C libraries (now
also for MariaDB). However, this will no longer be practical for
delivering CA certificates to pgx. Two design issues which you may
have an opinion about:
• Driver specific options can be defined in the `caqti' package or in
`caqti-driver-*' packages. In the former case, the configuration can
be manipulated without depending on specific drivers, but the
downside is that we will pull in dependencies on `x509',
`domain-name', `ipaddr' and possibly `tls' and `sexplib0'.
• My current sketch provides sexp-serialisation, a choice mainly
motivated by the availability of such serialization for client
configuration of `tls', but I hope to find a more generic solution
which allows easy embedding of Caqti configuration in application
configuration independent of which format is used.
An example of how an sexp-formatted configuration might look like:
┌────
│ (connection
│ (pool
│ (max-use-count 20)
│ (max-idle-size 10))
│ (driver postgresql)
│ (endpoints
│ (inet pg1.example.org)
│ (inet pg2.example.org))
│ (target-session-attrs read-write))
└────
where the `(pool ...)' clause is driver-indepnedent and the `(driver
...)' clause determines which DB-specific options are valid. In the
current draft, order does not matter despite this dependency.
(I could also mention plans of wrapping modules, but this will be done
first as a forward-compatible module in parallel to the current
modules preferably at the beginning of a major release cycle. The
reason I haven’t written that main `Caqti' module yet, is that I would
like to take the opportunity to tidy up the namespace to make it
easier for newcomers to discover the main entry points.)
[per-connection configuration]
<https://github.com/paurkedal/ocaml-caqti/issues/89>
Outreachy summer ’22 closing commemoration session on 23rd Sept
═══════════════════════════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/outreachy-summer-22-closing-commemoration-session-on-23rd-sept/10450/1>
Moazzam Moriani announced
─────────────────────────
I, along with Jay, were the two [Outreachy] interns working with the
OCaml :camel: community this summer. I worked on [Multicore
Applications] and Jay on [TopoJSON]. Our internship, of course, was
only made possible because @sudha and @patricoferris generously chose
to volunteer to mentor us–as our respective mentors–throughout the
summer. We are grateful to the both of them :heart:.
Our three-month long Outreachy internship just ended relatively
recently and, personally, I have really enjoyed working on my project
and learning OCaml. So much so that Jay and I would like to share our
experiences with the rest of the community. :sparkles:
To carry forward a tradition established by the [previous Outreachy
cohort], we will host a virtual session that will consist of two short
presentations from the both of us followed by a Q&A. The session will
be on Friday 23rd September 2-3pm CET.
It is open to whoever wishes to join. A recording will be shared later
online as well.
We hope you will join us! :raised_hands:
[Outreachy] <https://www.outreachy.org/>
[Multicore Applications] <https://github.com/ocaml-bench/sandmark>
[TopoJSON] <https://github.com/geocaml/ocaml-topojson>
[previous Outreachy cohort]
<https://discuss.ocaml.org/t/friday-03-04-intern-presentations-open-attendance/9429>
Marcus Rohrmoser asked and Moazzam Moriani replied
──────────────────────────────────────────────────
I suppose you mean CEST i.e.
2022-09-23T14:00:00+02:00/PT1H
Yes I do. Thank you for pointing it out.
MirageOS for B2B SaaS
═════════════════════
Archive: <https://discuss.ocaml.org/t/mirageos-for-b2b-saas/10454/1>
Volodymyr Melnyk asked
──────────────────────
I have an idea to build a SaaS for corporate blogging (like Medium,
but for companies) and I want to try MirageOS as a total platform for
services. I have no production experience with OCaml (only Golang, JS,
Ruby) and have no experience with MirageOS and unikernels (only
Docker, Linux, and a little bit k8s), but I’m very interested in both.
Could you please help me to clarify possible issues with such an
approach?
Also I’m interested about a hosting for MirageOS services. I don’t
like containers and k8s stuff and I prefer dedicated and virtual
servers instead of cloud stuff because I have no resources to pay up
to 5x more for hosting.
Thank you for your help!
Calascibetta Romain replied
───────────────────────────
Thank you for your interest in MirageOS. MirageOS is first and
foremost a framework for creating an application (such as a blog) for
several targets. One of these targets is [Solo5] which allows to
create an entire system which includes everything necessary for OCaml
(its runtime). Thus, one can deploy a MirageOS application on:
• KVM (with the target `hvt')
• [Xen]
• or produce a simple executable taking advantage of [seccomp] (and
thus finely controlling access to the executable).
• we can also mention the experimental target for [Raspberry Pi 4]
The objective of MirageOS is to make the choice of targets transparent
to the application. This means that for a given application, deploying
for KVM or Xen should not be an upstream choice (which would govern
the development of the application) but the last of the choices which
can, of course, be left to third party users.
This reverses the development logic of an application thanks to
abstraction mechanisms (specific to OCaml) (the [functors]) that allow
to get rid of any specialisation to a given system (Solo5, Unix,
Raspberry Pi, etc.).
This is of course the theory and in practice, it works quite well :) .
To take the example of the blog, you can see [Hannes’ blog] or [mine]
which runs on MirageOS (KVM). The latter have a similar architecture:
a unikernel managing TLS certificates and redirecting HTTP connections
to unikernels on a local network ([tlstunnel] or [contruno]) and a
unikernel ([unipi]) that only transmits what appears in a Git
repository via the HTTP protocol (http/1.1 and h2).
Deployment depends of course on what you have. Regarding KVM, you can
follow the tutorials [here] (quite general) and [there]. You can
deploy your unikernels on Google Cloud with this (probably a bit old)
[tutorial]. Finally, a deployment with seccomp is possible, it is a
simple executable.
Of course, most of these unikernels are already available for download
[here] thanks to the excellent work of [robur.io]. It is ensured that
the generated image is reproducible regardless of the context.
There is of course a whole series of unikernels made by the community
that you can mainly find on GitHub. We can talk about several services
like [DNS] or [emails].
I would like to specify that all this is still experimental. We are
gradually reaching the stage where our unikernels are used in
production domains, but it still requires a lot of work and a lot of
skills for such a small team :) . Of course, we are open to everyone’s
participation and we are especially here to help newcomers.
[Solo5] <https://github.com/Solo5/solo5/>
[Xen] <https://xenproject.org/>
[seccomp]
<https://code.google.com/archive/p/seccompsandbox/wikis/overview.wiki>
[Raspberry Pi 4] <https://github.com/dinosaure/gilbraltar/>
[functors] <https://ocaml.org/docs/functors>
[Hannes’ blog] <https://hannes.nqsb.io/>
[mine] <https://blog.osau.re>
[tlstunnel] <https://github.com/roburio/tlstunnel>
[contruno] <https://github.com/dinosaure/contruno>
[unipi] <https://github.com/roburio/unipi>
[here] <https://robur.coop/Projects/Reproducible_builds>
[there] <https://blog.osau.re/articles/blog_requiem.html>
[tutorial]
<https://github.com/aantron/dream/tree/master/example/w-mirage>
[here] <https://builds.robur.coop/>
[robur.io] <https://robur.io/>
[DNS] <https://github.com/roburio/dns-primary-git>
[emails] <https://mirage.io/blog/2022-04-01-Mr-MIME>
Tuareg and Caml modes for Emacs: what are the differences?
══════════════════════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/tuareg-and-caml-modes-for-emacs-what-are-the-differences/10285/12>
Deep in this thread, Tim McGilchrist announced
──────────────────────────────────────────────
I wrote up a longer form version of my setup at
<https://lambdafoo.com/posts/2022-09-07-ocaml-with-emacs-2022.html>
There are still some bits I am not happy with but I have been using it
daily. Also @bbatsov wrote his version at
<https://batsov.com/articles/2022/08/23/setting-up-emacs-for-ocaml-development/>
Engineer position at Imandra (Austin TX/UK)
═══════════════════════════════════════════
Archive:
<https://discuss.ocaml.org/t/engineer-position-at-imandra-austin-tx-uk/10465/1>
Simon Cruanes announced
───────────────────────
[Imandra] is looking for a full time engineer in the UK or in Austin,
Texas.
The job offers can be found [here].Imandra is an AI startup developing
a cloud-native automated reasoning engine for analysis of algorithms
and data. Whether you’re writing mission-critical code or need to
understand the countless complex decisions that a system may make, use
Imandra to ensure the algorithms you create are safe, explainable and
fair. OCaml is the main language used at Imandra.
[Imandra] <https://imandra.ai/>
[here] <https://apply.workable.com/imandra/>
Acme plumbing rules for OCaml
═════════════════════════════
Archive:
<https://discuss.ocaml.org/t/acme-plumbing-rules-for-ocaml/10467/1>
David A. Arroyo announced
─────────────────────────
I am sure that the intersection of OCaml users and [Acme] users is
small, but I have reason to believe it is a non-zero set :) . For
those of you using this spartan editor, here are some plumbing rules
that I use that allow me to right-click on error messages returned by
the OCaml compilers, and jump to the referenced location in acme:
┌────
│ # example: in file "foo/bar.ml", line 155, characters 30-62
│ type is text
│ data matches '.*[Ff]ile "([^"]+)", line ([0-9]+), characters ([0-9]+)-([0-9]+).*'$nl'?'
│ arg isfile $1
│ data set $file
│ attr add addr=$2-#0+#$3,$2-#0+#$4
│ plumb to edit
│ plumb client $editor
│
│ # example: File "tests/dune", line 2, characters 7-22:
│ type is text
│ data matches '.*[Ff]ile "([^"]+)", lines ([0-9]+)-([0-9]+).*'$nl'?'
│ arg isfile $1
│ data set $file
│ attr add addr=$2,$3
│ plumb to edit
│ plumb client $editor
└────
It could probably be extended to search `~/.opam' so you could plumb
errors in files outside of your project, but I do not use opam, so I
haven’t needed to do it.
Here is a short demo of its use: <https://youtu.be/Evl-N0oNNd0>
It’s not in OCaml, but I also wrote
<https://github.com/droyo/acme-autoformat> and put an `OcamlFmt'
script in acme’s $PATH like so:
┌────
│ #!/bin/sh
│ exec /usr/local/bin/acme-autoformat -r '\.mli?$' \
│ -- ocamlformat --name='{{.Basename}}' --enable-outside-detected-project -
└────
This calls `ocamlformat' whenever I Put an .ml[i] file. This is
probably obviated by combining acme-lsp and ocaml-lsp, but these two
bits work well enough that I haven’t felt a need to pursue it.
[Acme] <https://acme.cat-v.org/>
Other OCaml News
════════════════
>From the ocaml.org blog
───────────────────────
Here are links from many OCaml blogs aggregated at [the ocaml.org
blog].
• [Tarides Sponsors Girls Can Code]
• [Introducing the Jane Street Graduate Research Fellowship]
[the ocaml.org blog] <https://ocaml.org/blog/>
[Tarides Sponsors Girls Can Code]
<https://tarides.com/blog/2022-09-06-tarides-sponsors-girls-can-code>
[Introducing the Jane Street Graduate Research Fellowship]
<https://blog.janestreet.com/graduate-research-fellowship/>
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: 27859 bytes --]
next reply other threads:[~2022-09-13 8:40 UTC|newest]
Thread overview: 236+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-09-13 8:40 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-20 14:01 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=87sfkv8y5y.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