Skip to content

crystal-lang/shards

Folders and files

NameName
Last commit message
Last commit date

Latest commit

e74e050 · Mar 15, 2025
Dec 8, 2023
Nov 11, 2024
May 20, 2015
Dec 18, 2024
Mar 15, 2025
Jan 23, 2025
Jan 21, 2025
Jan 21, 2025
May 14, 2024
Nov 8, 2024
Feb 22, 2025
Jan 23, 2025
Sep 28, 2015
Feb 22, 2025
Feb 22, 2025
Feb 22, 2025
Feb 1, 2021
Jan 23, 2025
Dec 18, 2024
May 14, 2024
May 14, 2024
Jan 5, 2024
Feb 23, 2024
Feb 22, 2021
Jan 23, 2025

Repository files navigation

Shards

CI

Dependency manager for the Crystal language.

Usage

Crystal applications and libraries are expected to have a shard.yml file at their root looking like this:

name: shards
version: 0.1.0

dependencies:
  openssl:
    github: datanoise/openssl.cr
    branch: master

development_dependencies:
  minitest:
    git: https://github.com/ysbaddaden/minitest.cr.git
    version: ~> 0.3.1

license: MIT

When libraries are installed from Git repositories, the repository is expected to have version tags following a semver-like format, prefixed with a v. Examples: v1.2.3, v2.0.0-rc1 or v2017.04.1.

Please see the SPEC for more details about the shard.yml format.

Install

Shards is usually distributed with Crystal itself (e.g. Homebrew and Debian packages). Alternatively, a shards package may be available for your system.

You can download a source tarball from the same page (or clone the repository) then run make release=1and copy bin/shards into your PATH. For example /usr/local/bin.

You are now ready to create a shard.yml for your projects (see details in SPEC). You can type shards init to have an example shard.yml file created for your project.

Run shards install to install your dependencies, which will lock your dependencies into a shard.lock file. You should check both shard.yml and shard.lock into version control, so further shards install will always install locked versions, achieving reproducible installations across computers.

Run shards --help to list other commands with their options.

Happy Hacking!

Developers

Requirements

These requirements are only necessary for compiling Shards.

  • Crystal

    Please refer to https://crystal-lang.org/install/ for instructions for your operating system.

  • libyaml

    On Debian/Ubuntu Linux you may install the libyaml-dev package.

    On Mac OS X you may install it using homebrew with brew install libyaml then make sure to have /usr/local/lib in your LIBRARY_PATH environment variable (eg: export LIBRARY_PATH="/usr/local/lib:$LIBRARY_PATH"). Please adjust the path per your Homebrew installation.

  • asciidoctor

    Needed for building manpages.

Getting started

It is strongly recommended to use make for building shards and developing it. The Makefile contains recipes for compiling and testing.

Run make bin/shards to build the binary.

  • release=1 for a release build (applies optimizations)
  • static=1 for static linking (only works with musl-libc)
  • debug=1 for full symbolic debug info

Run make install to install the binary. Target path can be adjusted with PREFIX (default: PREFIX=/usr/bin).

Run make test to run the test suites:

  • make test_unit runs unit tests (./spec/unit)
  • make test_integration runs integration tests (./spec/integration) on bin/shards

Run make docs to build the manpages.

Devenv

This repository contains a configuration for devenv.sh which makes it easy to setup a reproducible environment with all necessary tools for building and testing.

  • Checkout the repository
  • Run devenv shell to get a shell with development environment

A hook for automatic shell activation is also included. If you have direnv installed, the devenv environment loads automatically upon entering the repo folder.

License

Licensed under the Apache License, Version 2.0. See LICENSE for details.