Socket
Book a DemoInstallSign in
Socket

is-dirty

Package Overview
Dependencies
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

is-dirty

Returns false if a git repository has no staged, unstaged or untracked changes.

latest
Source
npmnpm
Version
0.2.1
Version published
Maintainers
1
Created
Source

is-dirty NPM version NPM downloads Build Status

Returns false if a git repository has no staged, unstaged or untracked changes.

Install

Install with npm:

$ npm install --save is-dirty

API

var isDirty = require('is-dirty');

isDirty(directory[, globPatterns], callback);

Params

  • directory {String}: a directory that contains a .git folder
  • globPatterns {String|Array}: optionally pass one or more glob patterns to use for matching any uncommitted files. This is useful if you only want to know if specific files have not been committed.
  • callback: {Function}: function to call after the git status is returned

Usage

isDirty(process.cwd(), function(err, status) {
  console.log(status);
});
  • err: if a .git directory does not exist
  • status: if .git directory exists, and there are no staged, unstaged or untracked changes, statuswill be undefined. Otherwise status is an object with staged, unstaged or untracked changes, and matches if glob patterns are passed.

Example

Given you have a project with the following staged files:

.
├── a.txt
├── b.txt
├── c.txt
├── d.txt
└── e.txt

The following:

isDirty(process.cwd(), function(err, status) {
  if (err) return console.log(err);
  console.log(status);
});

Would result in:

{ staged:
   [ { file: 'a.txt', status: 'new file' },
     { file: 'b.txt', status: 'new file' },
     { file: 'c.txt', status: 'new file' },
     { file: 'd.txt', status: 'new file' },
     { file: 'e.txt', status: 'new file' } ],
  unstaged: [],
  untracked: [],
  matches: [] }

Matches

Pass a glob or array of globs as the second argument to return an array of matching files on the status.matches array:

isDirty(process.cwd(), ['{a,c}.txt'], function(err, status) {
  if (err) return console.log(err);
  console.log(status);
});

Would result in:

{ staged:
   [ { file: 'a.txt', status: 'new file' },
     { file: 'b.txt', status: 'new file' },
     { file: 'c.txt', status: 'new file' },
     { file: 'd.txt', status: 'new file' },
     { file: 'e.txt', status: 'new file' } ],
  unstaged: [],
  untracked: [],
  matches: [ 'a.txt', 'c.txt' ] }

About

Contributing

Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.

Building docs

(This document was generated by verb-generate-readme (a verb generator), please don't edit the readme directly. Any changes to the readme must be made in .verb.md.)

To generate the readme and API documentation with verb:

$ npm install -g verb verb-generate-readme && verb

Running tests

Install dev dependencies:

$ npm install -d && npm test

Author

Jon Schlinkert

License

Copyright © 2016, Jon Schlinkert. Released under the MIT license.

This file was generated by verb, v0.9.0, on July 17, 2016.

Keywords

dirty

FAQs

Package last updated on 17 Jul 2016

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