npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

gommitjs

v1.4.3

Published

A Nodejs wrapper for the gommit command line tool.

Downloads

5

Readme

Gommitjs

gommitjs is a lightweight Git commit message enforcer that wraps gommit.

Setup

First create your project

mkdir my-project
cd my-project
git init
npm init --yes

Then setup gommitjs

npm install gommitjs --save-dev
./node_modules/.bin/gommitjs init

The above commands will install the gommitjs NPM module and download the gommit binary for your OS and save it under the ./node_modules/gommitjs/tools folder. Then we initialize our project by creating a .gommit.toml config file if one doesn't exist and create a .git/hooks/commit-msg commit hook if one doesn't exist.

NOTE: If you already have a commit-msg hook then you'll have to maintain this hook yourself, using the gommit binary to check messages:

%gommit_path% check message "$(cat "$1")";

The gommit binary path can be obtained by calling:

./node_modules/.bin/gommitjs gommit-path

NOTE: If you prefer to install the gommit binary somewhere else then you can run the following.

./node_modules/.bin/gommitjs update --prefix tools

This will install the binary in the ./tools folder.

Usage

Ensure your commit messages are consistent

Usage:
  gommitjs [command]

Available Commands:
  init        Create the gommit config and commit-msg hook files
  update      Update the gommit binary
  gommit-path Get the path to the gommit binary
  check       Check ensure a message follows defined patterns
  version     App version

Flags:
      --config string    (default ".gommit.toml")
  -h, --help            help for gommit

Use "gommitjs [command] --help" for more information about a command.

Practical Usage

For details on how to use gommit with continuous integration servers see the gommit docs.

Versioning

This project will not have the same version as the gommit binary since any version of gommit should work with this wrapper.

OS Support

The following OSs are supported on 32 and 64-bit architecture:

  • OSX
  • Windows
  • Linux
  • FreeBSD
  • OpenBSD

The following OSs are supported on an ARM architecture:

  • Linux
  • FreeBSD
  • OpenBSD

For NetBSD support please use gommit directly.

NOTE: The os module provided by Nodejs is used to determine the platform and the system architecture.

See: https://nodejs.org/dist/latest-v6.x/docs/api/os.html#os_os_platform

See: https://nodejs.org/dist/latest-v6.x/docs/api/os.html#os_os_arch

API

installGommit(tag = 'latest', { prefix } = {}): Promise

Install the gommit binary for the current OS.

Example:

const gommitjs = require('gommitjs')
gommitjs.installGommit('v2.0.0').then(result => {
  console.log(`gommit ${result.tag} saved at ${result.path}`)
}).catch(error => {
  console.error(error)
})

// Or to install the gommit binary to a different location.
gommitjs.installGommit('v2.0.0', { prefix: 'tools' }).then(result => {
  console.log(`gommit ${result.tag} saved at ${result.path}`)
}).catch(error => {
  console.error(error)
})

getGommitUrl(tag = 'latest'): Promise

Retrieves the download URL for the gommit binary for the specified tag.

Example:

const gommitjs = require('gommitjs')
gommitjs.getGommitUrl().then(url => {
  console.log(`gommit download url is ${url}`)
}).catch(error => {
  // Error will be thrown if OS or architecture is unsupported.
  console.error(error)
})

getGommitBinaryPath({ url, prefix } = {}): Promise

Retrieves the path to the installed gommit binary.

Example:

const gommitjs = require('gommitjs')
gommitjs.getGommitBinaryPath().then(gommitPath => {
  console.log(`gommit installed at ${gommitPath}`)
})

// A path to the binary can be constructed if given the download URL and the
// prefix to where the binary is to be saved.
// NOTE: This interface is typically only used internally.
gommitjs.getGommitUrl('v2.0.0').then(url => {
  return gommitjs.getGommitBinaryPath({ url, prefix: 'tools' })
}).catch(error => {
  // Error will be thrown if OS or architecture is unsupported.
  console.error(error)
}).then(gommitPath => {
  console.log(`gommit installed at ${gommitPath}`)
})

gommit(args: []sring, { cwd }): Promise

Call gommit with the specified arguments just like you would at the command line.

Example:

const { gommit } = require('gommitjs')
gommit([ 'version' ])
  .then(version => console.log(version))
  .catch(error => console.error(error.toString()))

// Or to check a commit message and load a custom config file.
const message = 'Hello'
gommit([ 'check', 'message', message, '--config', 'my-config.toml' ])
  .then(() => console.log())
  .catch(error => console.error(error.toString()))

gommit.version(): Promise

Retrieves the gommit version tag.

Example:

const { gommit } = require('gommitjs')
gommit.version()
  .then(version => console.log(version))
  .catch(error => console.error(error.toString()))

gommit.checkCommit(commitHash, { config } = {}): Promise

Check one commit from its commit ID (must be full commit ID). Optionally the path to the TOML, YAML or JSON config file to load can be specified. If no path is specified then by default gommit will load ./.gommit.toml.

Example:

const { gommit } = require('gommitjs')
gommit.checkCommit('aeb603ba83614fae682337bdce9ee1bad1da6d6e')
  .then(() => console.log('commit is properly formatted!')
  .catch(error => console.error(error.toString()))

gommit.checkMessage(message, { config } = {}): Promise

Check a commit message. Optionally the path to the TOML, YAML or JSON config file to load can be specified. If no path is specified then by default gommit will load ./.gommit.toml.

Example:

const { gommit } = require('gommitjs')
gommit.checkMessage('Hello')
  .then(() => console.log('message is properly formatted!')
  .catch(error => console.error(error.toString()))

gommit.checkRange(refStart, refEnd, { config } = {}): Promise

Check a commit range. Ranges can be any of the following values:

  • with relative references : master~2^, master
  • with asbolute references : dev, test
  • with commit ids : 7bbb37ade3ff36e362d7e20bf34a1325a15b, 09f25db7971c100a8c0cfc2b22ab7f872ff0c18d

Optionally the path to the TOML, YAML or JSON config file to load can be specified. If no path is specified then by default gommit will load ./.gommit.toml.

Example:

const { gommit } = require('gommitjs')
gommit.checkRange('master~2^', 'master')
  .then(() => console.log('all commits are properly formatted!')
  .catch(error => console.error(error.toString()))