Skip to content

Latest commit

 

History

History
227 lines (147 loc) · 12.4 KB

CONTRIBUTING.md

File metadata and controls

227 lines (147 loc) · 12.4 KB

How to Contribute

Welcome to OCaml.org's contributing guide. Thank you for taking the time to read it! Your help with OCaml.org is extremely welcome. We are particularly motivated to support new contributors and people who are looking to learn and develop their skills. If you get stuck, please don’t hesitate to ask questions on Discuss or raise an issue.

This guide documents the best way to contribute to the project when adding things listed below in Contributing Content. If you're looking for a guide on how to setup the project and suggest a change to the code, you can refer to our HACKING guide, which will also give instructions on how to rebuild the website when making changes, if necessary.

  • Good First Issues: if you are either new to the repository or still getting started with OCaml in general, issues marked as a good first issue are ideal.
  • Suggesting Changes: most of the site content is stored in the data directory as Markdown or YAML. To suggest a change or update this content, you can edit those files directly and rebuild the website, detailed in the HACKING guide. This will promote the content into their .ml counterparts. If you would like to suggest entirely new website content or code, please open an issue to discuss it first.
  • Implementing Pages: most pages are implemented in src/ocamlorg_frontend/pages using the .eml templating preprocessor. This is mixture or OCaml and HTML.

Reporting Bugs

We use GitHub issues to track all bugs and feature requests. Feel free to open an issue over here if you have found a bug or wish to see a feature implemented.

Please include images and browser-specific information if the bug is related to some visual aspect of the site. This tends to make it easier to reproduce and fix.

Contributing Content

We've provided a list of community-driven content below. When adding content to any of these sections, it's best to fork the repo, add your file, and open a pull request (PR).

The following sections give more details on how to contribute to each.

Adding Images

Some of the data that can be contributed by users may include images or other media; e.g., success stories, academic and industrial users, or books.

Images can be added to the corresponding subfolder in the data/media/ folder.

For example, to add a university logo associated with an academic institution, you have to add the image file to the data/media/academic_institution/ folder.

Videos or other media should not be added to the OCaml.org GitHub repository.

Add Your RSS Feed or YouTube Channel to the OCaml Planet

Anyone can contribute to the OCaml Planet, which is composed of three types of content:

  • Community blog posts fetched from RSS feeds
  • Videos fetched from YouTube channels
  • Original blog posts linked from original source

Add Your RSS Feed

If you write about OCaml and have an RSS or Atom feed, you can add your feed to data/planet-sources.yml.

When compiling, the feed entries will be downloaded, and Markdown files for each item will be created in data/rss. For instance: building-ahrefs-codebase-with-melange.md`.

Please, make sure your feed only contains articles about OCaml.

Add Your YouTube Channel

If you have a YouTube channel and publish videos about OCaml (mention "OCaml" in the description of every video that should appear on the OCaml Planet!), you can add your channel to data/youtube.yml.

Link Original Blog Post

To contribute an individual link to your original blog post to the OCaml Planet, add a new Markdown file in data/planet/-individual_external_links/.

Create a .md file with the following header:

---
title: Title of Your Self-Hosted Post Here (title case)
description: one-sentence description
url: direct URL to your original blog post
date: 2023-06-13  (this format)
preview_image: direct link to preview image
---

Add an Entry to the Job Board

Contribute to the Job Board.

The job board displays OCaml job opportunities.

To add a new entry to the job board, you can add it to data/jobs.yml.

Please make sure that the job involves mostly writing OCaml. Contributions to add jobs unrelated to OCaml, or where OCaml is a negligible part of the job, won't be accepted.

If you notice that a job opportunity is outdated (e.g., already fulfilled or not open anymore), we also welcome PRs to remove it.

Add a Success Story

Contribute to the Success Stories.

You can contribute a new success story by adding a Markdown file in data/success_stories/. For instance: janestreet.md.

The success stories should be structured in the following way:

  • An overview of your company
  • The challenge you faced and solved
  • The solution you implemented, which should describe the role OCaml played in solving the challenge
  • A post-mortem describing the results you had after implementing the solution

You can read Ahref's Success Story for a good example.

Add an Academic or Industrial User

Contribute to the Academic Users and Industrial Users.

Add a new industrial user by creating a new Markdown file in data/industrial_users/. For instance: cryptosense.md.

You can add a new academic user by creating a new Markdown file in data/academic_institutions/. For instance: cornell.md.

Add a Book

Contribute to the OCaml Books.

Add a new OCaml book by creating a new Markdown file in data/books/. For instance: ocaml-from-the-very-beginning.md.

Add a Recipe to the OCaml Cookbook

The OCaml Cookbook is a place where OCaml developers share how to solve common tasks in OCaml using packages from the OCaml ecosystem.

Here are the steps to contribute a recipe for an existing task:

  • Find the task in the data/cookbook/tasks.yml file.
  • Go to the task folder inside data/cookbook/ that has the same name as the task's slug.
  • Create a .ml file containing the recipe and a YAML header with metadata about the recipe.

If the recipe does not fit into any existing task, you also need to create a task. Add a task: entry in data/cookbook/tasks.yml file. Fields title, description, and slug are mandatory. The task must be located under a relevant category: field.

Finally, it is also possible to create and organise groups of tasks by creating new categories. Categories are recursive and may have subcategories, which are full categories too. A task listed in data/cookbook/tasks.yml may have no recipes yet. On the other hand, it is not allowed to have a task folder in data/cookbook/ that does not correspond to a task from the data/cookbook/tasks.yml file because it triggers a compilation error.

Each recipe is a way to perform a task using a combination of open-source libraries.

OCaml Cookbook Recipe Review Checklist

Checklist for reviewing OCaml cookbook submissions:

  1. does this recipe implement the task it's assigned to?
  2. if this recipe is creating a new task: (1) is the new task substantially different from existing tasks, (2) there is no existing task that this recipe solves, (3) is the new task description very clear on what the task is (be specific!)
  3. is the code explained sufficiently without overexplaining (be short and focus on what matters)?
  4. is the code such that you would put it into production? I.e. are the libraries used stable enough and is the code readable?

Add A Recurring Event

Contribute a Recurring Event.

You can add a new recurring event by adding it to the YAML file data/events/recurring.yml.

Add an Upcoming Event

Contribute to the Upcoming Event.

You can add a new upcoming event by creating a new Markdown file in data/events/.

OCaml Changelog

The OCaml Changelog is a user-oriented blog that serves as a newsfeed for the OCaml ecosystem. It's important to note that despite its name, it's not a traditional changelog, but rather a curated blog of significant updates and news.

The Changelog covers developments across:

Purpose and Audience

The primary audience for the Changelog is OCaml users. Content should focus on changes, updates, and news that directly impact users of OCaml and its ecosystem.

Good candidates for Changelog posts include:

  1. Announcements of new releases
  2. Significant feature additions or changes
  3. Important updates to OCaml.org that affect user experience
  4. Infrastructure changes that impact users
  5. Regular updates on ongoing development as part of Developer Previews

The Changelog is not meant for:

  1. Internal refactoring that doesn't result in user-visible changes
  2. Highly technical details that are only relevant to OCaml core developers
  3. Sharing complete changelogs (although there is a changelog tag where you can include the changelogs as part of release announcements)

Contributing a Post

To contribute a new post to the Changelog:

  1. Create a new Markdown file in the data/changelog/ directory.
  2. Use a clear, descriptive filename (e.g., 2023-06-15-ocaml-5-1-release.md).
  3. Include relevant metadata at the top of the file (date, title, tags, etc.).
  4. Write the post content, focusing on how the news or change affects OCaml users.
  5. Submit a pull request with your new file.

Git and GitHub Workflow

The preferred workflow for contributing to a repository is to fork the main repository on GitHub, clone, and develop on a new branch.

If you aren't familiar with how to work with Github or would like to learn it, here is a great tutorial.

Feel free to use any approach while creating a PR. Here are a few suggestions from the Dev team:

  • If you are not sure whether your changes will be accepted or want to discuss the method before delving into it, please create an issue and ask.
  • Clone the repo locally (or continue editing directly in GitHub if the change is small). Checkout out the branch that you created.
  • Create a draft PR with a small initial commit. Here's how you can create a draft pull request..
  • Continue developing and feel free to ask questions in the PR if you run into obstacles or uncertainty as you make changes.
  • Review your implementation according to the checks noted in the PR template.
  • Once you feel your branch is ready, change the PR status to "ready to review."
  • Consult the tasks noted in the PR template.
  • When merging, consider cleaning up the commit body.
  • Close any issues that were addressed by this PR.