diff --git a/Dockerfile b/Dockerfile index 2751f1f5bb..a1ffd68d4a 100644 --- a/Dockerfile +++ b/Dockerfile @@ -43,6 +43,7 @@ COPY --from=build /home/opam/_build/default/src/ocamlorg_web/bin/main.exe /bin/s COPY playground/asset playground/asset RUN git clone https://github.com/ocaml-web/html-compiler-manuals /manual +ADD data/v2 /v2 RUN git config --global --add safe.directory /var/opam-repository @@ -50,7 +51,8 @@ ENV DREAM_VERBOSITY=info \ OCAMLORG_HTTP_PORT=8080 \ OCAMLORG_MANUAL_PATH=/manual \ OCAMLORG_PKG_STATE_PATH=/var/package.state \ - OCAMLORG_REPO_PATH=/var/opam-repository/ + OCAMLORG_REPO_PATH=/var/opam-repository/ \ + OCAMLORG_V2_PATH /v2 EXPOSE 8080 diff --git a/data/conferences/2013-ocaml-users-and-developers-workshop.md b/data/conferences/2013-ocaml-users-and-developers-workshop.md index 6a05ec5170..936963e38d 100644 --- a/data/conferences/2013-ocaml-users-and-developers-workshop.md +++ b/data/conferences/2013-ocaml-users-and-developers-workshop.md @@ -13,37 +13,38 @@ presentations: - title: Accessing and using weather-related data in OCaml authors: - Hezekiah Carty - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/weather-related-data.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/guha.pdf + link: ocaml/2013/proposals/weather-related-data.pdf + slides: ocaml/2013/slides/carty.pdf - title: The Frenetic Network Controller authors: - Nate Foster - Arjun Guha - Frenetic Contributors - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/frenetic.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/guha.pdf + link: ocaml/2013/proposals/frenetic.pdf + slides: ocaml/2013/slides/guha.pdf - title: 'Pfff: PHP Program analysis at Facebook' authors: - Yoann Padioleau link: https://github.com/facebook/pfff/wiki/Main - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/padioleau.pdf + slides: ocaml/2013/slides/padioleau.pdf - title: The design of the wxOCaml library authors: - Fabrice Le Fessant - link: + link: ocaml/2013/proposals/wxocaml.pdf + slides: ocaml/2013/slides/lefessant.pdf - title: 'Goji: an Automated Tool for Building High Level OCaml-JavaScript Interfaces' authors: - Benjamin Canou - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/wxocaml.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/lefessant.pdf + link: ocaml/2013/proposals/goji.pdf + slides: ocaml/2013/slides/canou.pdf - title: 'ctypes: foreign calls in your native language' authors: - Jeremy Yallop - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/ctypes.pdf + link: ocaml/2013/proposals/ctypes.pdf - title: The State of OCaml authors: - Xavier Leroy - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/leroy.pdf + slides: ocaml/2013/slides/leroy.pdf - title: The OCaml Platform v0.1 authors: - Anil Madhavapeddy @@ -53,67 +54,68 @@ presentations: - Philippe Wang - Leo White - Jeremy Yallop - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/platform.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/madhavapeddy.pdf + link: ocaml/2013/proposals/platform.pdf + slides: ocaml/2013/slides/madhavapeddy.pdf - title: Extensions points for OCaml authors: - Leo White - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/white.pdf + slides: ocaml/2013/slides/white.pdf - title: High-Performance GPGPU Programming with OCaml authors: - Mathias Bourgoin - Emmmanuel Chailloux - Jean-Luc Lamotte - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/gpgpu.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/bourgoin.pdf + link: ocaml/2013/proposals/gpgpu.pdf + slides: ocaml/2013/slides/bourgoin.pdf - title: Improving OCaml high level optimisations authors: - Pierre Chambart - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/optimizations.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/chambart.pdf + link: ocaml/2013/proposals/optimizations.pdf + slides: ocaml/2013/slides/chambart.pdf - title: A new implementation of OCaml formats based on GADTs authors: - Benoît Vaugon - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/formats-as-gadts.pdf https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/vaugon.pdf + link: ocaml/2013/proposals/formats-as-gadts.pdf + slides: ocaml/2013/slides/vaugon.pdf - title: Runtime types in OCaml authors: - Grégoire Henry - Jacques Garrigue - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/runtime-types.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/henry.pdf + link: ocaml/2013/proposals/runtime-types.pdf + slides: ocaml/2013/slides/henry.pdf - title: On variance, injectivity, and abstraction authors: - Jacques Garrigue - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/injectivity.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/garrigue.pdf + link: ocaml/2013/proposals/injectivity.pdf + slides: ocaml/2013/slides/garrigue.pdf - title: 'Ocamlot: OCaml Online Testing' authors: - David Sheets - Anil Madhavapeddy - Amir Chaudhry - Thomas Gazagnaire - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/ocamlot.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/sheets.pdf + link: ocaml/2013/proposals/ocamlot.pdf + slides: ocaml/2013/slides/sheets.pdf - title: Merlin, an assistant for editing OCaml code authors: - Frédéric Bour - Thomas Refis - Simon Castellan - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/merlin.pdf + link: ocaml/2013/proposals/merlin.pdf - title: Profiling the Memory Usage of OCaml Applications without Changing their Behavior authors: - Çagdas Bozman - Michel Mauny - Fabrice Le Fessant - Thomas Gazagnaire - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/profiling-memory.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/bozman.pdf + link: ocaml/2013/proposals/profiling-memory.pdf + slides: ocaml/2013/slides/bozman.pdf - title: 'Core bench: micro-benchmarking for OCaml' authors: - Christopher Hardin - James Roshan - link: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/proposals/core-bench.pdf - slides: https://github.com/ocaml/v2.ocaml.org/blob/master/site/meetings/ocaml/2013/slides/james.pdf + link: ocaml/2013/proposals/core-bench.pdf + slides: ocaml/2013/slides/james.pdf organising_committee: [] program_committee: - name: Mark Shinwell diff --git a/data/v2/conferences/ocaml/2013/call.md b/data/v2/conferences/ocaml/2013/call.md new file mode 100644 index 0000000000..4668644b77 --- /dev/null +++ b/data/v2/conferences/ocaml/2013/call.md @@ -0,0 +1,81 @@ + + +``` +============================================================================== + + OCAML 2013 + The OCaml Users and Developers Workshop + http://ocaml.org/meetings/ocaml/2013/ + Boston, Massachusetts, USA + September 24, 2013 + + CALL FOR PRESENTATIONS + + Co-located with ICFP 2013 + Sponsored by SIGPLAN + + Talk Proposal Submission Extended Deadline: + June 18, 2013 (anywhere on earth) + +============================================================================== + +The first occurrence of the OCaml Users and Developers Workshop was +colocated with ICFP 2012, in Copenhagen, following the OCaml Meetings +in Paris in 2010 and 2011. OCaml 2013 will be held on September 24, +2013, in Boston, colocated with ICFP 2013. + +The OCaml Users and Developers Workshop brings together industrial +users of OCaml with academics and hackers who are working on extending +the language, type system and tools. Discussions will focus on the +practical aspects of OCaml programming and the nitty gritty of the +tool-chain and upcoming improvements and changes. Thus, we aim to +solicit talks on all aspects related to improving the use or +development of the language and of its programming environment, +including, for example: + +- compiler developments, new backends, runtime and architectures + +- practical type system improvements, such as (but not exhaustively) + GADTs, first-class modules, generic programming, or dependent types + +- new library or application releases, and their design rationales + +- tool enhancements by commercial consultants + +- prominent industrial uses of OCaml, or deployments in unusual + situations. + +It will be an informal meeting, with an online scribe report of the +meeting, but no formal proceedings. Slides of presentations will be +available online from the workshop homepage. + +To submit a talk, please register a description of the talk (about 2 +pages long) at http://ocaml.org/meetings/ocaml/2013/talks/ providing a +clear statement of what will be brought by the talk: the problems that +are addressed, the technical solutions or methods that are +proposed. If you wish to perform a demo or require any special setup, +we will do our best to accommodate you. + +Schedule +======== + +Abstract Submission (extended) Deadline: June 18, 2013 (anywhere on earth) +Notification to Speakers: Friday, July 7, 2013 +Workshop: Tuesday, September 24, 2013 + +Program Committee +================= + +* Damien Doligez, INRIA Paris-Rocquencourt, France +* Jun Furuse, Standard Chartered Bank, Singapore +* Jacques Le Normand, Google, USA +* Michel Mauny, ENSTA-ParisTech, France (chair) +* Mark Shinwell, Jane Street Europe, UK +* David Walker, Princeton University, USA +* Jeremy Yallop, University of Cambridge, UK +* Sarah Zennou, EADS IW, France + +If you have any questions, please e-mail: +Michel Mauny + +``` diff --git a/data/v2/conferences/ocaml/2013/index.md b/data/v2/conferences/ocaml/2013/index.md new file mode 100644 index 0000000000..49c6cefa61 --- /dev/null +++ b/data/v2/conferences/ocaml/2013/index.md @@ -0,0 +1,67 @@ + + +*Table of contents* + +OCaml 2013 +========== + +**The OCaml Users and Developers Workshop** +Boston (MA, USA), September 24, 2013 +Colocated with [ICFP 2013](http://icfpconference.org/icfp2013/) + +The meeting is an informal community gathering of users of the language, +library authors, and developers, using and extending OCaml in new ways. + +News +---- + +- October 7, 2013: The [final program, with links to papers and + slides](program.html) is available. +- July 11, 2013: The [preliminary program](program.html) is available. +- June 7, 2013: The submission deadline has been extended to June 18, + anywhere on earth. +- May 7, 2013: The [submission + site](https://www.easychair.org/conferences/?conf=ocaml2013) is now + open! Please submit a presentation before June 7. +- May 7, 2013: The [submission + site](https://www.easychair.org/conferences/?conf=ocaml2013) is now + open! Please submit a presentation before June 7 June 18 + (anywhere on earth). +- April 16, 2013: [workshop announcement](call.html). The [submission + site](talks/) should open in the next days. + +Important dates +--------------- + +- June 18, 2013 (anywhere on earth): Extended deadline for submissions +- July 7, 2013: Notification to speakers +- September 24, 2013: Workshop + +Call for presentations +---------------------- + +Please consider submitting a presentation, and/or join us in Boston! See +[here the call for presentations](call.html). + +Program Committee +----------------- + +- Damien Doligez, INRIA Paris-Rocquencourt, France +- Jun Furuse, Standard Chartered Bank, Singapore +- Jacques Le Normand, Google, USA +- Michel Mauny, ENSTA-ParisTech, France (chair) +- Mark Shinwell, Jane Street Europe, UK +- David Walker, Princeton University, USA +- Jeremy Yallop, University of Cambridge, UK +- Sarah Zennou, EADS IW, France + +History +------- + +The [first occurrence of the OCaml Users and Developers +Workshop](http://oud.ocaml.org/2012/) was colocated with [ICFP +2012](http://icfpconference.org/icfp2012/), in Copenhagen, following the +*OCaml User Meetings* in Paris in [2008](../2008/), 2010 and [2011](../2011/) +and in Grenoble in [2009](../2009/). Building on the success of +past events, OCaml 2013 will be held on September 24, 2013, in Boston, +colocated with [ICFP 2013](http://icfpconference.org/icfp2013/). diff --git a/data/v2/conferences/ocaml/2013/program.md b/data/v2/conferences/ocaml/2013/program.md new file mode 100644 index 0000000000..8404a40dc8 --- /dev/null +++ b/data/v2/conferences/ocaml/2013/program.md @@ -0,0 +1,123 @@ + + +OCaml 2013 - Program +-------------------- + +### The OCaml Users and Developers Workshop + +#### Boston (MA, USA), September 24, 2013 + +#### Colocated with ICFP 2013 + +#### 09:00-09:10 - Welcome + +#### 09:10-10:10 - Applications + +Accessing and using weather-related data in OCaml +([paper](proposals/weather-related-data.pdf), +[slides](slides/carty.pdf)), by Hezekiah Carty (MDA Information Systems +LLC, USA) + +The Frenetic Network Controller ([paper](proposals/frenetic.pdf), +[slides](slides/guha.pdf)), by Nate Foster (Cornell University, USA), +Arjun Guha (UMass Amherst, USA) and Frenetic Contributors (The Frenetic +Project, USA) + +Pfff: PHP Program analysis at Facebook +([paper](https://github.com/facebook/pfff/wiki/Main), +[slides](slides/padioleau.pdf)), by Yoann Padioleau (Facebook, USA) + +#### 10:10-10:30 - Break + +#### 10:30-11:30 - Bindings + +The design of the wxOCaml library ([paper](proposals/wxocaml.pdf), +[slides](slides/lefessant.pdf)), by Fabrice Le Fessant (INRIA +Paris-Rocquencourt and OCamlPro SAS, France) + +Goji: an Automated Tool for Building High Level OCaml-JavaScript +Interfaces ([paper](proposals/goji.pdf), [slides](slides/canou.pdf)), by +Benjamin Canou (Université Pierre et Marie Curie, LIP6 UMR 7606, France) + +ctypes: foreign calls in your native language +([paper](proposals/ctypes.pdf)), by Jeremy Yallop (University of +Cambridge, UK) + +#### 11:30-11:50 - Break + +#### 11:50-12:30 - OCaml News + +The State of OCaml (invited, [slides](slides/leroy.pdf)), Xavier Leroy +(INRIA Paris-Rocquencourt, France + +The OCaml Platform v0.1 ([paper](proposals/platform.pdf), +[slides](slides/madhavapeddy.pdf)), by Anil Madhavapeddy (University of +Cambridge, UK), Amir Chaudhry (University of Cambridge, UK), Thomas +Gazagnaire (OCamlPro SAS, France), David Sheets (University of +Cambridge, UK), Philippe Wang (University of Cambridge, UK), Leo White +(University of Cambridge, UK) and Jeremy Yallop (University of +Cambridge, UK) + +#### 12:30-14:00 - Lunch + +#### 14:00-15:00 - Compilation + +Extensions points for OCaml (invited, [slides](slides/white.pdf)), by +Leo White (University of Cambridge, UK) + +High-Performance GPGPU Programming with OCaml +([paper](proposals/gpgpu.pdf), [slides](slides/bourgoin.pdf)), by +Mathias Bourgoin (Université Pierre et Marie Curie, LIP6 UMR 7606, +France), Emmmanuel Chailloux (Université Pierre et Marie Curie, LIP6 UMR +7606, France) and Jean-Luc Lamotte (Université Pierre et Marie Curie, +LIP6 UMR 7606, France) + +Improving OCaml high level optimisations +([paper](proposals/optimizations.pdf), [slides](slides/chambart.pdf)), +by Pierre Chambart (OCamlPro SAS, France) + +#### 15:00-15:20 - Break + +#### 15:20-16:20 - Types + +A new implementation of OCaml formats based on GADTs +([paper](proposals/formats-as-gadts.pdf), [slides](slides/vaugon.pdf)), +by Benoît Vaugon (ENSTA-ParisTech, France) + +Runtime types in OCaml ([paper](proposals/runtime-types.pdf), +[slides](slides/henry.pdf)), by Grégoire Henry (INRIA +Paris-Rocquencourt, France) and Jacques Garrigue (Nagoya University, +Japan) + +On variance, injectivity, and abstraction +([paper](proposals/injectivity.pdf), [slides](slides/garrigue.pdf)), by +Jacques Garrigue (Nagoya University, Japan) + +#### 16:20-16:40 - Break + +#### 16:40-17:40 - Tools + +Ocamlot: OCaml Online Testing ([paper](proposals/ocamlot.pdf), +[slides](slides/sheets.pdf)), by David Sheets (University of Cambridge, +UK), Anil Madhavapeddy (University of Cambridge, UK), Amir Chaudhry +(University of Cambridge, UK) and Thomas Gazagnaire (OCamlPro SAS, +France) + +Merlin, an assistant for editing OCaml code +([paper](proposals/merlin.pdf)), by Frédéric Bour (Université +Paris-Diderot, France), Thomas Refis (Université Paris-Diderot, France) +and Simon Castellan (Université Paris-Diderot, France) + +Profiling the Memory Usage of OCaml Applications without Changing their +Behavior ([paper](proposals/profiling-memory.pdf), +[slides](slides/bozman.pdf)), by Çagdas Bozman (OCamlPro SAS, INRIA +Paris-Rocquencourt and ENSTA-Paristech, France), Michel Mauny +(ENSTA-ParisTech, France), Fabrice Le Fessant (INRIA Paris-Rocquencourt +and OCamlPro SAS, France) and Thomas Gazagnaire (OCamlPro SAS, France) + +Core bench: micro-benchmarking for OCaml +([paper](proposals/core-bench.pdf), [slides](slides/james.pdf)), by +Christopher Hardin (Jane Street Capital, USA) and James Roshan (Jane +Street Capital, USA) + +#### 18:00 - Closing diff --git a/data/v2/conferences/ocaml/2013/proposals/core-bench.pdf b/data/v2/conferences/ocaml/2013/proposals/core-bench.pdf new file mode 100644 index 0000000000..dc30f97944 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/core-bench.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/ctypes.pdf b/data/v2/conferences/ocaml/2013/proposals/ctypes.pdf new file mode 100644 index 0000000000..a823d1c91d Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/ctypes.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/formats-as-gadts.pdf b/data/v2/conferences/ocaml/2013/proposals/formats-as-gadts.pdf new file mode 100644 index 0000000000..1b3ffb83a6 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/formats-as-gadts.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/frenetic.pdf b/data/v2/conferences/ocaml/2013/proposals/frenetic.pdf new file mode 100644 index 0000000000..c82fb222f5 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/frenetic.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/goji.pdf b/data/v2/conferences/ocaml/2013/proposals/goji.pdf new file mode 100644 index 0000000000..53bac26d71 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/goji.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/gpgpu.pdf b/data/v2/conferences/ocaml/2013/proposals/gpgpu.pdf new file mode 100644 index 0000000000..cbc0bcc4dd Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/gpgpu.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/injectivity.pdf b/data/v2/conferences/ocaml/2013/proposals/injectivity.pdf new file mode 100644 index 0000000000..9b9095732d Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/injectivity.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/merlin.pdf b/data/v2/conferences/ocaml/2013/proposals/merlin.pdf new file mode 100644 index 0000000000..5d26738285 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/merlin.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/ocamlot.pdf b/data/v2/conferences/ocaml/2013/proposals/ocamlot.pdf new file mode 100644 index 0000000000..00ba3e235e Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/ocamlot.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/optimizations.pdf b/data/v2/conferences/ocaml/2013/proposals/optimizations.pdf new file mode 100644 index 0000000000..2735b77312 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/optimizations.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/platform.pdf b/data/v2/conferences/ocaml/2013/proposals/platform.pdf new file mode 100644 index 0000000000..3e0b1b4b85 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/platform.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/profiling-memory.pdf b/data/v2/conferences/ocaml/2013/proposals/profiling-memory.pdf new file mode 100644 index 0000000000..7a517290e5 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/profiling-memory.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/runtime-types.pdf b/data/v2/conferences/ocaml/2013/proposals/runtime-types.pdf new file mode 100644 index 0000000000..b8ff3eb063 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/runtime-types.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/weather-related-data.pdf b/data/v2/conferences/ocaml/2013/proposals/weather-related-data.pdf new file mode 100644 index 0000000000..acf78838b9 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/weather-related-data.pdf differ diff --git a/data/v2/conferences/ocaml/2013/proposals/wxocaml.pdf b/data/v2/conferences/ocaml/2013/proposals/wxocaml.pdf new file mode 100644 index 0000000000..3dffc9ed9a Binary files /dev/null and b/data/v2/conferences/ocaml/2013/proposals/wxocaml.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/bourgoin.pdf b/data/v2/conferences/ocaml/2013/slides/bourgoin.pdf new file mode 100644 index 0000000000..fd4f7fe227 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/bourgoin.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/bozman.pdf b/data/v2/conferences/ocaml/2013/slides/bozman.pdf new file mode 100644 index 0000000000..590f3045ea Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/bozman.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/canou.pdf b/data/v2/conferences/ocaml/2013/slides/canou.pdf new file mode 100644 index 0000000000..8d81d93d46 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/canou.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/carty.pdf b/data/v2/conferences/ocaml/2013/slides/carty.pdf new file mode 100644 index 0000000000..ee04687b97 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/carty.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/chambart.pdf b/data/v2/conferences/ocaml/2013/slides/chambart.pdf new file mode 100644 index 0000000000..a171be3322 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/chambart.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/garrigue.pdf b/data/v2/conferences/ocaml/2013/slides/garrigue.pdf new file mode 100644 index 0000000000..077b27b976 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/garrigue.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/guha.pdf b/data/v2/conferences/ocaml/2013/slides/guha.pdf new file mode 100644 index 0000000000..5629bdbe0a Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/guha.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/henry.pdf b/data/v2/conferences/ocaml/2013/slides/henry.pdf new file mode 100644 index 0000000000..d9b8a8d420 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/henry.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/james.pdf b/data/v2/conferences/ocaml/2013/slides/james.pdf new file mode 100644 index 0000000000..8f191f9148 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/james.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/lefessant.pdf b/data/v2/conferences/ocaml/2013/slides/lefessant.pdf new file mode 100644 index 0000000000..fac8c59c87 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/lefessant.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/leroy.pdf b/data/v2/conferences/ocaml/2013/slides/leroy.pdf new file mode 100644 index 0000000000..681a7f3a8c Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/leroy.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/madhavapeddy.pdf b/data/v2/conferences/ocaml/2013/slides/madhavapeddy.pdf new file mode 100644 index 0000000000..489f244f44 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/madhavapeddy.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/padioleau.pdf b/data/v2/conferences/ocaml/2013/slides/padioleau.pdf new file mode 100644 index 0000000000..3ff7330334 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/padioleau.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/sheets.pdf b/data/v2/conferences/ocaml/2013/slides/sheets.pdf new file mode 100644 index 0000000000..fb8b977de8 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/sheets.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/vaugon.pdf b/data/v2/conferences/ocaml/2013/slides/vaugon.pdf new file mode 100644 index 0000000000..56dbd5e646 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/vaugon.pdf differ diff --git a/data/v2/conferences/ocaml/2013/slides/white.pdf b/data/v2/conferences/ocaml/2013/slides/white.pdf new file mode 100644 index 0000000000..20256f1b51 Binary files /dev/null and b/data/v2/conferences/ocaml/2013/slides/white.pdf differ diff --git a/data/v2/conferences/ocaml/2013/talks/index.md b/data/v2/conferences/ocaml/2013/talks/index.md new file mode 100644 index 0000000000..d32ad2d1a6 --- /dev/null +++ b/data/v2/conferences/ocaml/2013/talks/index.md @@ -0,0 +1,3 @@ +OCaml 2013: submissions + + diff --git a/src/ocamlorg_data/data.ml b/src/ocamlorg_data/data.ml index bcaae984b3..57ff89591b 100644 --- a/src/ocamlorg_data/data.ml +++ b/src/ocamlorg_data/data.ml @@ -238,3 +238,5 @@ module Conference = struct let all = Conference.all let get_by_slug slug = List.find_opt (fun x -> String.equal slug x.slug) all end + +module V2 = V2 diff --git a/src/ocamlorg_data/data.mli b/src/ocamlorg_data/data.mli index 655415ad3f..2146d5e1d0 100644 --- a/src/ocamlorg_data/data.mli +++ b/src/ocamlorg_data/data.mli @@ -211,3 +211,7 @@ module Conference : sig val all : t list val get_by_slug : string -> t option end + +module V2 : sig + include module type of V2 +end diff --git a/src/ocamlorg_data/dune b/src/ocamlorg_data/dune index ac90548237..c0b610ecd2 100644 --- a/src/ocamlorg_data/dune +++ b/src/ocamlorg_data/dune @@ -340,3 +340,22 @@ (with-stdout-to %{target} (run %{ood_gen} conferences))))) + +(rule + (target v2.ml) + (deps + (:v2 + (source_tree %{workspace_root}/data/v2))) + (action + (chdir + %{workspace_root}/data/v2 + (with-stdout-to + %{target} + (progn + (echo "let assets = [") + (pipe-stdout + (run find . -type f) + (run cut -b 2-) + (run sed "s/^/\"/") + (run sed "s/$/\";/")) + (echo "]")))))) diff --git a/src/ocamlorg_web/lib/config.ml b/src/ocamlorg_web/lib/config.ml index d8ba90020d..6b31272ae1 100644 --- a/src/ocamlorg_web/lib/config.ml +++ b/src/ocamlorg_web/lib/config.ml @@ -7,3 +7,5 @@ let http_port = env_with_default "OCAMLORG_HTTP_PORT" "8080" |> int_of_string let manual_path = env_with_default "OCAMLORG_MANUAL_PATH" "http-compiler-manuals" + +let v2_path = env_with_default "OCAMLORG_V2_PATH" "data/v2" diff --git a/src/ocamlorg_web/lib/handler.ml b/src/ocamlorg_web/lib/handler.ml index 180586268e..58b9b7c8a7 100644 --- a/src/ocamlorg_web/lib/handler.ml +++ b/src/ocamlorg_web/lib/handler.ml @@ -1414,3 +1414,10 @@ let sitemap _request = Dream.flush stream) let logos _req = Dream.html (Ocamlorg_frontend.logos ()) + +let v2_asset req = + let? path = + try Some (Config.v2_path ^ Dream.target req) with _ -> None + in + let? () = if Sys.file_exists path then Some () else None in + Filename.(Dream.from_filesystem (dirname path) (basename path) req) diff --git a/src/ocamlorg_web/lib/redirection.ml b/src/ocamlorg_web/lib/redirection.ml index e24294c4de..0aeb4966ef 100644 --- a/src/ocamlorg_web/lib/redirection.ml +++ b/src/ocamlorg_web/lib/redirection.ml @@ -1,43 +1,28 @@ open Ocamlorg -let fwd_v2 target = (target, Url.v2 ^ target) - -(* For assets previously hosted on V2, we redirect the requests to - v2.ocaml.org. *) let v2_assets = - [ - "/meetings/ocaml/2013/proposals/core-bench.pdf"; - "/meetings/ocaml/2013/proposals/ctypes.pdf"; - "/meetings/ocaml/2013/proposals/formats-as-gadts.pdf"; - "/meetings/ocaml/2013/proposals/frenetic.pdf"; - "/meetings/ocaml/2013/proposals/goji.pdf"; - "/meetings/ocaml/2013/proposals/gpgpu.pdf"; - "/meetings/ocaml/2013/proposals/injectivity.pdf"; - "/meetings/ocaml/2013/proposals/merlin.pdf"; - "/meetings/ocaml/2013/proposals/ocamlot.pdf"; - "/meetings/ocaml/2013/proposals/optimizations.pdf"; - "/meetings/ocaml/2013/proposals/platform.pdf"; - "/meetings/ocaml/2013/proposals/profiling-memory.pdf"; - "/meetings/ocaml/2013/proposals/runtime-types.pdf"; - "/meetings/ocaml/2013/proposals/weather-related-data.pdf"; - "/meetings/ocaml/2013/proposals/wxocaml.pdf"; - "/meetings/ocaml/2013/slides/bourgoin.pdf"; - "/meetings/ocaml/2013/slides/bozman.pdf"; - "/meetings/ocaml/2013/slides/canou.pdf"; - "/meetings/ocaml/2013/slides/carty.pdf"; - "/meetings/ocaml/2013/slides/chambart.pdf"; - "/meetings/ocaml/2013/slides/garrigue.pdf"; - "/meetings/ocaml/2013/slides/guha.pdf"; - "/meetings/ocaml/2013/slides/henry.pdf"; - "/meetings/ocaml/2013/slides/james.pdf"; - "/meetings/ocaml/2013/slides/lefessant.pdf"; - "/meetings/ocaml/2013/slides/leroy.pdf"; - "/meetings/ocaml/2013/slides/madhavapeddy.pdf"; - "/meetings/ocaml/2013/slides/padioleau.pdf"; - "/meetings/ocaml/2013/slides/sheets.pdf"; - "/meetings/ocaml/2013/slides/vaugon.pdf"; - "/meetings/ocaml/2013/slides/white.pdf"; - ] + let confs = + [ "/conference/"; "/meetings/"; "/meeting/"; "/workshops/"; "/workshop/" ] + in + let redirects confs target source = + let f s = (s ^ source, target) in + List.map f confs + in + let f path = + let open String in + if starts_with ~prefix:"/conferences/" path && ends_with ~suffix:".pdf" path + then redirects confs path (sub path 13 (length path - 13)) + else [] + in + let g conf = + let year = String.sub conf.Data.Conference.date 0 4 in + [ ""; "/index.html" ] + |> List.concat_map (fun s -> + redirects ("/conferences/" :: confs) + ("/conferences/" ^ conf.slug) + ("ocaml/" ^ year ^ s)) + in + List.concat_map f Data.V2.assets @ List.concat_map g Data.Conference.all let from_v2 = [ @@ -228,91 +213,30 @@ let from_v2 = ("/learn/tutorials/streams.html", Url.tutorial "sequences"); ("/learn/tutorials/up_and_running.html", Url.tutorial "up-and-running"); (Url.tutorial "first-hour", Url.tutorial "tour-of-ocaml"); - ("/meetings/index.fr.html", Url.community); - ("/meetings/index.html", Url.community); - ("/meetings", Url.community); - ( "/meetings/ocaml/2008/index.html", - Url.conference "ocaml-users-and-developers-conference-2008" ); - ( "/meetings/ocaml/2008", - Url.conference "ocaml-users-and-developers-conference-2008" ); - ( "/meetings/ocaml/2008/index.html", - Url.conference "ocaml-users-and-developers-conference-2008" ); - ( "/meetings/ocaml/2008", - Url.conference "ocaml-users-and-developers-conference-2008" ); - ( "/meetings/ocaml/2009/index.html", - Url.conference "ocaml-users-and-developers-conference-2009" ); - ( "/meetings/ocaml/2009", - Url.conference "ocaml-users-and-developers-conference-2009" ); - ( "/meetings/ocaml/2010/index.html", - Url.conference "ocaml-users-and-developers-conference-2010" ); - ( "/meetings/ocaml/2010", - Url.conference "ocaml-users-and-developers-conference-2010" ); - ( "/meetings/ocaml/2011/index.html", - Url.conference "ocaml-users-and-developers-conference-2011" ); - ( "/meetings/ocaml/2011", - Url.conference "ocaml-users-and-developers-conference-2011" ); - ( "/meetings/ocaml/2012/index.html", - Url.conference "ocaml-users-and-developers-conference-2012" ); + ("/meetings/index.fr.html", Url.conferences); + ("/meetings/index.html", Url.conferences); + ("/meetings", Url.conferences); ( "/meetings/ocaml/2013/call.html", Url.conference "ocaml-users-and-developers-conference-2013" ); - ( "/meetings/ocaml/2013", - Url.conference "ocaml-users-and-developers-conference-2013" ); - ( "/meetings/ocaml/2013/index.html", - Url.conference "ocaml-users-and-developers-conference-2013" ); ( "/meetings/ocaml/2013/program.html", Url.conference "ocaml-users-and-developers-conference-2013" ); - ( "/meetings/ocaml/2013", - Url.conference "ocaml-users-and-developers-conference-2013" ); ( "/meetings/ocaml/2013/talks/index.html", Url.conference "ocaml-users-and-developers-conference-2013" ); ( "/meetings/ocaml/2014/cfp.html", Url.conference "ocaml-users-and-developers-conference-2014" ); - ( "/meetings/ocaml/2014", - Url.conference "ocaml-users-and-developers-conference-2014" ); - ( "/meetings/ocaml/2014/index.html", - Url.conference "ocaml-users-and-developers-conference-2014" ); ( "/meetings/ocaml/2014/ocaml2014_10.html", Url.conference "ocaml-users-and-developers-conference-2014" ); ( "/meetings/ocaml/2014/program.html", Url.conference "ocaml-users-and-developers-conference-2014" ); ( "/meetings/ocaml/2015/cfp.html", Url.conference "ocaml-users-and-developers-conference-2015" ); - ( "/meetings/ocaml/2015", - Url.conference "ocaml-users-and-developers-conference-2015" ); - ( "/meetings/ocaml/2015/index.html", - Url.conference "ocaml-users-and-developers-conference-2015" ); - ( "/meetings/ocaml/2015", - Url.conference "ocaml-users-and-developers-conference-2015" ); ( "/meetings/ocaml/2015/program.html", Url.conference "ocaml-users-and-developers-conference-2015" ); - ( "/meetings/ocaml/2015", - Url.conference "ocaml-users-and-developers-conference-2015" ); ( "/meetings/ocaml/2015/program.txt", Url.conference "ocaml-users-and-developers-conference-2015" ); - ( "/meetings/ocaml/2015", - Url.conference "ocaml-users-and-developers-conference-2015" ); - ( "/meetings/ocaml/2016/index.html", - Url.conference "ocaml-users-and-developers-conference-2016" ); - ( "/meetings/ocaml/2016", - Url.conference "ocaml-users-and-developers-conference-2016" ); - ( "/meetings/ocaml/2017/index.html", - Url.conference "ocaml-users-and-developers-conference-2017" ); - ( "/meetings/ocaml/2017", - Url.conference "ocaml-users-and-developers-conference-2017" ); - ( "/meetings/ocaml/2018/index.html", - Url.conference "ocaml-users-and-developers-conference-2018" ); - ( "/meetings/ocaml/2018", - Url.conference "ocaml-users-and-developers-conference-2018" ); - ( "/meetings/ocaml/2019/index.html", - Url.conference "ocaml-users-and-developers-conference-2019" ); - ( "/meetings/ocaml/2019", - Url.conference "ocaml-users-and-developers-conference-2019" ); - ( "/meetings/ocaml/2020/index.html", - Url.conference "ocaml-users-and-developers-conference-2020" ); - ( "/meetings/ocaml/2020", - Url.conference "ocaml-users-and-developers-conference-2020" ); - ("/meetings/ocaml/index.html", Url.community); - ("/meetings/ocaml", Url.community); + ("/meetings/ocaml/index.html", Url.conferences); + ("/meetings/ocaml", Url.conferences); + ("/workshops", Url.conferences); ("/ocamllabs/index.html", Url.index); ("/ocamllabs", Url.index); ("/platform/index.html", Url.learn_platform); @@ -340,30 +264,6 @@ let make ?(permanent = false) t = Some (Dream.get origin (fun req -> Dream.redirect ~status req new_))) t) -let ocaml_workshops = - List.map - (fun (slug : string) -> - make ~permanent:true [ ("/workshop/" ^ slug, Url.conference slug) ]) - [ - "ocaml-users-and-developers-conference-2008"; - "ocaml-users-and-developers-conference-2009"; - "ocaml-users-and-developers-conference-2010"; - "ocaml-users-and-developers-conference-2011"; - "ocaml-users-and-developers-conference-2012"; - "ocaml-users-and-developers-conference-2013"; - "ocaml-users-and-developers-conference-2014"; - "ocaml-users-and-developers-conference-2015"; - "ocaml-users-and-developers-conference-2016"; - "ocaml-users-and-developers-conference-2017"; - "ocaml-users-and-developers-conference-2018"; - "ocaml-users-and-developers-conference-2019"; - "ocaml-users-and-developers-conference-2020"; - "ocaml-users-and-developers-conference-2020"; - "ocaml-users-and-developers-conference-2021"; - "ocaml-users-and-developers-conference-2022"; - "ocaml-users-and-developers-conference-2023"; - ] - let package req = let package = Dream.param req "name" in Dream.redirect req (Url.Package.overview package) @@ -374,22 +274,19 @@ let package_docs req = let t = Dream.scope "" [] - ([ - make ~permanent:true [ ("feed.xml", "planet.xml") ]; - make from_v2; - make (List.map fwd_v2 v2_assets); - make [ ("/blog", "/ocaml-planet") ]; - make ~permanent:true [ ("/opportunities", "/jobs") ]; - make ~permanent:true - [ ("/carbon-footprint", "/policies/carbon-footprint") ]; - make ~permanent:true [ ("/privacy-policy", "/policies/privacy-policy") ]; - make ~permanent:true - [ ("/code-of-conduct", "/policies/code-of-conduct") ]; - make ~permanent:true [ ("/opportunities", "/jobs") ]; - (* make ~permanent:false [ (Url.conferences, Url.community ^ - "#conferences") ]; *) - Dream.get "/p/:name" package; - Dream.get "/u/:hash/p/:name" package; - Dream.get "/p/:name/doc" package_docs; - ] - @ ocaml_workshops) + [ + make ~permanent:true [ ("feed.xml", "planet.xml") ]; + make ~permanent:true from_v2; + make ~permanent:true v2_assets; + make ~permanent:true [ ("/blog", "/ocaml-planet") ]; + make ~permanent:true [ ("/opportunities", "/jobs") ]; + make ~permanent:true + [ ("/carbon-footprint", "/policies/carbon-footprint") ]; + make ~permanent:true [ ("/privacy-policy", "/policies/privacy-policy") ]; + make ~permanent:true [ ("/code-of-conduct", "/policies/code-of-conduct") ]; + (* make ~permanent:false [ (Url.conferences, Url.community ^ + "#conferences") ]; *) + Dream.get "/p/:name" package; + Dream.get "/u/:hash/p/:name" package; + Dream.get "/p/:name/doc" package_docs; + ] diff --git a/src/ocamlorg_web/lib/router.ml b/src/ocamlorg_web/lib/router.ml index d144c42ebb..7981760b7d 100644 --- a/src/ocamlorg_web/lib/router.ml +++ b/src/ocamlorg_web/lib/router.ml @@ -131,6 +131,7 @@ let router t = Dream.router [ Redirection.t; + Dream.get "/conferences/ocaml/**" Handler.v2_asset; page_routes t; package_route t; graphql_route t;