Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@esy-nightly/esy

Package Overview
Dependencies
Maintainers
3
Versions
581
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@esy-nightly/esy

Package builder for esy

  • 0.3.4-5255ad
  • npm
  • Socket score

Version published
Weekly downloads
145
increased by46.46%
Maintainers
3
Weekly downloads
 
Created
Source

esy

package.json workflow for native development with Reason/OCaml.

AppVeyor Travis npm npm (tag)

This README serves as a development documentation for esy. For user documentation refer to esy.sh documentation site.

Repository structure

The following snippet lists esy repository structured (omitting irrelevant or obvious items) with further explanations:

├── CHANGELOG.md
├── LICENSE
├── README.md
│
├── Makefile
│   Common tasks and workflows for esy development.
│
├── bin
│
├── docs
│   esy end user documentation in markdown format.
│
├── dune
├── dune-project
│
├── esy
│   This dune library implements sandbox builder - a routine which builds
│   the enture dependency graph and provides other introspection APIs.
├── esy/bin
│   This dune executable implements "esy" command.
│
├── esyi
│   This dune library implements installer.
├── esyi/bin
│   This dune executable implements "esy install" command.
│
├── esy-build-package
│   This dune library implements package builder. esy library uses this to
│   build each package.
├── esy-build-package/bin
│   This dune executable implements "esy-build-package" command.
│
├── esy-installer
│   Implementation of installation procedure defined with *.install files.
│   This re-implements opam-installer.
│
├── esy-command-expression
│   Parser for #{...} syntax used in esy manifests.
├── esy-shell-expansion
│   A simple shell expansion.
├── esy-yarn-lockfile
│   Parser for a subset of yarn lockfile format.
│
├── esy-lib
│   A collection of utility modules shared between other libraries.
│
├── site
│   Sources for https://esy.sh
│
├── esy.lock.json
├── package.json
│
├── scripts
├── test
│   Unit tests.
│
└── test-e2e
    End-to-end test suite.

Workflow

To make changes to esy and test them locally:

% git clone git://github.com/esy/esy.git
% cd esy
% make bootstrap

Run:

% make

to see the description of development workflow.

Running Tests

% make test

Branches

There are two branches:

  • master — the active development, we cut new versions out of there regularly.
  • 0.0.x — maintainance branch for 0.0.x releases.

Workflow for esy.sh

To make changes to esy.sh:

  1. Bootstrap site's dev environment:
% make site-bootstrap
  1. Run site locally:
% make site-start
  1. When you are happy with the changes:
% make site-publish

Issues

Issues are tracked at esy/esy.

Publishing Releases

esy is released on npm.

Because esy is written in OCaml/Reason and compiled into a native executable we need to acquire a set of prebuilt binaries. We employ CI servers (thanks Travis CI) to build platform specific releases.

The release workflow is the following:

  1. Ensure you arre on master branch and run

    % make bump-patch-verson
    % git push && git push --tags
    

    (this bumps patch version, use bump-minor-version or bump-major-version correspondingly to bump either minor or major version of esy)

  2. Wait till CI finishes its task and uploads releases on GitHub, check https://github.com/esy/esy/releases for them.

  3. Run

    % make release
    

    Which downloads platform specific releases (which CI uploaded GitHub) and produces an npm releases with needed metadata inside _release directory.

  4. Ensure release inside _release directory is ok.

    You can cd _release && npm pack && npm install -g ./esy-*.tgz to test how release installs and feels.

  5. Run cd _release && npm publish to publish release on npm.

    Release tag next is used to publish preview releases.

FAQs

Package last updated on 24 Oct 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc