grunt-unison

0.1.3 • Public • Published

grunt-unison Built with Grunt Build Status NPM

runs unison to keep hosts in sync

Getting Started

If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:

npm install grunt-unison --save-dev

Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:

grunt.loadNpmTasks('grunt-unison');

The "unison" task

Overview

In your project's Gruntfile, add a section named unison to the data object passed into grunt.initConfig().

grunt.initConfig({
    unison: {
        options: {
            verbose: false,
            args: [],
            src: '/path/to/source',
            dest: '/path/to/destination/'
        },
    },
});

Options

options.verbose

Type: Boolean Default value: false

Display unison command's output in console.

options.args

Type: Array Default value: []

An array of command-line arguments to pass to unison. Valid arguments are provided in the Unison User Manual

The following arguments are added by default:

    [
        '-auto',
        '-batch',
        '-confirmbigdel=false',
        '-times'
    ]

options.src

Type: String Default value: ``

The source directory to sync from.

Accepted formats are:

  • relative/path/of/root
  • /absolute/path/of/root
  • [protocol:]//[user@][host][:port][/path]

options.dest

Type: String Default value: ``

The destination directory to sync to.

Accepted formats are:

  • relative/path/of/root
  • /absolute/path/of/root
  • [protocol:]//[user@][host][:port][/absolute/path]

Usage Examples

Custom Options

In this example, custom options are used to do sync files between the local source and remote destination ignoring permissions and allowing for FAT drives.

grunt.initConfig({
    unison: {
        options: {
            verbose: false,
            args: [
                '-perms 0',
                '-fat'
            ],
            src: '/path/to/source',
            dest: 'ssh://remote.host:22//absolute/path/to/destination/'
        },
    },
});

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.

Release History

  • 2015-01-23   v0.1.3   Don't explode if unison isn't installed
  • 2014-12-02   v0.1.2   Initial release

Readme

Keywords

Package Sidebar

Install

npm i grunt-unison

Weekly Downloads

1

Version

0.1.3

License

none

Last publish

Collaborators

  • amsross