Restarts a vagrant isntance based on environment configuration.
This plugin requires Grunt.
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-vagrant-commands --save-dev
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-restart-vagrant');
The plugin knows how to get to your vagrant install based on your .npmrc
file. This file holds configuration for NPM, but since it's so easy to configure, we can make use of it to store our vagrant information.
npmcofig
looks first for project specific config, then user specific config, then finally globally. This means you can configure a different vagrant for your project by creating a vagrant specififc .npmrc
file.
The path to the vagrant file should be stored with the vagrantPath
key:
npm config set vagrantPath /path/to/Vagrantfile
You can opt to store it globally with the --global
flag, but this will affect all user accoundt on the machine, which is probably not what you want.
In your project's Gruntfile, add a section named vagrant_commands
to the data object passed into grunt.initConfig()
.
grunt.initConfig({
vagrant_commands: {
your_commands: {
commands: [
// each command in this array as an array arguments.
]
},
},
})
Type: String
Default value: null
This option allows you to load a custom .npmrc file from wherever you would like on your system.
In this example, the we use the default .npmrc
to trigger a vagrant halt
followed by a vagrant up --provision
.
grunt.initConfig({
vagrant_commands: {
vvv: {
commands: [
['halt'],
['up', '--provision']
]
},
},
})
In lieu of a formal styleguide, take care to maintain the existing coding style.
- Minor bug fix
- If no dir is present in config, try running in currend directory
- The first release
Copyright (c) 2014 Luke Woodward. Licensed under the MIT license.