Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

OCaml project generator.

License

NotificationsYou must be signed in to change notification settings

tmattio/spin

Repository files navigation

Logo

OCaml project generator.

Build Statusnpm version

FeaturesInstallationTemplatesUsageRoadmapContributingLicenseAcknowledgements

Demo

Features

🚀 Quickly start new projects that are ready for the real world.

❤️ Have a great developer experience when developing with OCaml.

🏄 Be as productive as Ruby-on-Rails or Elixir's Mix users.

🔌 Establish a convention for projects organizations to make it easy to get into new projects.

Installation

Using Homebrew (macOS)

brew install tmattio/tap/spin

Using Opam

opam install spin

Using a script

curl -fsSL https://github.com/tmattio/spin/raw/main/script/install.sh| bash

Templates

You can generate a new project using a template withspin new. For instance:

spin new bin my_app

Will create a new binary application in the directory./my_app/

Anyone can create new Spin templates, but we provide official templates for a lot of use cases.

Official templates

The official Spin templates templates are the following:

  • bin - Native project containing a binary.
  • cli - Command Line Interface releasable on Opam.
  • lib - Library releasable on Opam.
  • ppx - PPX library.
  • c-bindings - Bindings to a C library.
  • js - Js application with Js_of_ocaml.

If you'd like to add an official template, don't hesitate to open a PR!

Other OCaml templates

You can find community Spin templates for various projects here:https://github.com/ocaml-templates

Here are some non-official Spin templates that you can use:

Other non-OCaml templates

Although the focus of Spin is to offer a great project generator for the OCaml ecosystem, it can also be used to generate non-OCaml templates. Here are a few examples:

Usage

For a detailed documentation of Spin's CLI, runspin --help, or refer to theCLI documentation.

spin new TEMPLATE [PATH] [--default] [--ignore-config]

Create a new ReasonML/Ocaml project from a template.

PATH defaults to the current working directory.

When--default is passed, the user will not be prompted for configurations that have a default value.

When--ignore-config is passed, the configuration file will be ignored and the user will be prompted for all the configurations.

spin ls

List the official Spin templates.

spin config

Prompt the user for values that can be saved in the configuration file.

If a value is present in the configuration file, it will not be prompted when generating a new project.

Roadmap

See ourdevelopment board for a list of selected features and issues.

Here are some of the improvements we'll be working on as well in for next releases:

  • Support windows
  • Support CLI options/args for configurations
  • Minimalhello template
  • Generators forlib/bin/test for all templates

Contributing

We'd love your help improving Spin!

Take a look at ourContributing Guide to get started.

License

Distributed under the ISC License. SeeLICENSE for more information.

Acknowledgements

Thanks to everyone whocontributed to Spin!

Special thanks to@wesoudshoorn for creating Spin's logo.


[8]ページ先頭

©2009-2025 Movatter.jp