Code Monkey home page Code Monkey logo

gitnim's Introduction

tests version-1-0 version-1-2 version-1-4 version-1-6 devel License Matrix

choosenim for choosey nimions

What Is It?

The aim of this tool is two-fold:

  • Provide an easy way to install the Nim compiler and tools.
  • Manage multiple Nim installations and allow them to be selected on-demand.

Basically, it gits nim for you.

Okay, But I Heard It Was Different. And, Like, Scary?

Yes, it's different. But not in a scary way; it's open and simple.

This program adds a git subcommand for Nim git nim and installs itself next to your Nim compiler so that if your compiler is in your PATH, so is gitnim.

It Installs Itself? Wait, Maybe It's Already Installed...

No, nimpleton, it's not already installed. 🤦

When you compile the source code, gitnim.nim, the output is a binary adjacent to your nim compiler and named git-nim.

This binary is detected by git such that git nim is a command you can run on the command-line and it will do a thing.

Yeah, Okay, a git Subcommand. But What Does It Do?

The git nim subcommand allows you to choose from precompiled Nim releases and download or install them by managing your Nim installation as any other git repository.

So? Why Should I Care? I Already Have Nim Installed.

Yeah, well, you can keep using your current Nim installation. 🤷

The aim of this tool is two-fold:

  • Provide an easy way to install the Nim compiler and tools.
  • Manage multiple Nim installations and allow them to be selected on-demand.

If you don't need either of these features, then gitnim is not for you.

So It's a Git Repo with Branches Matching Nim Versions? Is That All?

This Nim repository also links to the distribution from https://github.com/nim-works/dist, which is a hand-curated monorepo holding the most useful Nim modules from the ecosystem.

Okay, So What Makes That a Feature I Should Care About?

When run, gitnim displays or switches branches in the Nim repository and updates the dist submodules to ensure you always have easy access to the latest features and fixes as matched to your active compiler.

Y'know, That Actually Makes A Lot Of Sense.

Yeah, I know. You're welcome.

Installation

Clone the Repository

We use git for distribution; what else?

$ git clone https://github.com/nim-works/gitnim /somewhere

Add bin to $PATH

A critical step; humor me on this one. The location of the compiler is used to infer the installation directory for gitnim itself.

$ export PATH=/somewhere/bin:$PATH

Build gitnim

You now have a statically-linked Nim binary for your Linux-x64 system, so you can immediately compile gitnim.

This will automatically install the gitnim binary next to the compiler binary according to your PATH, enabling the git nim subcommand.

$ cd /somewhere
$ nim c gitnim/gitnim.nim

Usage

List Available Releases

With no additional arguments, git nim will check the network for updates and present the available Nim releases for selection.

The current distribution will be updated from the network, if necessary.

$ git nim

git nim

Choose a Release by Version

When a version is provided, git nim will switch to that version immediately without querying the network, provided the version exists locally.

The distribution will be updated without querying the network, if possible.

$ git nim 1.4.3

git nim 1.4.3

Choose a Release by Tag

When a tag is provided, git nim will switch to the tagged version immediately without querying the network, provided the tagged reference exists locally.

The distribution will be updated without querying the network, if possible.

$ git nim devel

git nim devel

$ git nim stable

git nim stable

Advanced Usage

Creating Your Own Nim Distribution

$ git checkout -b "my favorite nims"

Publishing Your Nim Distribution

$ git remote rename origin upstream
$ git remote add origin "[email protected]:your_name/gitnim.git"
$ git push --set-upstream origin "your branch name"

Adding a Custom Release Tag

$ git tag -a "tag_name" -m "your description"

Sharing Your Tags With Others

$ git push --tags

Revoking Your Tags With Others

$ git push --delete origin tag_name

Adding a Friend's Tags

$ git remote add jeff https://github.com/jeff/gitnim

Using a Friend's Tag

$ git nim jeff/1.3.3

Contributing

https://github.com/nim-works/gitnim

License

MIT

gitnim's People

Contributors

disruptek avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar

Forkers

saem 00mjk

gitnim's Issues

dist modules need to be omitted or renamed when excluded

Currently, arraymancer isn't available on 1.2.9:

git-nim against https://github.com/disruptek/gitnim
using the 1.2.9 compiler branch
using the 1.2.9 distribution branch
.git submodule update --checkout arraymancer
error: pathspec 'arraymancer' did not match any file(s) known to git

The right move is probably to parse the .gitmodules directly.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.