Skip to content

forward OS X file system events to a VM, designed for use with Dinghy

License

Notifications You must be signed in to change notification settings

TechnologyAdvice/fsevents_to_vm

 
 

Repository files navigation

FSEvents To VM

Forward OS X file system events to a VM, designed for use with Dinghy. Updated by TechnologyAdvice for use with Dlite.

Installation of this Dlite-compatible fsevents_to_vm

cd to the folder you'd like to install into, then...

sudo gem install bundle rake
git clone https://github.com/TechnologyAdvice/fsevents_to_vm.git
cd fsevents_to_vm
bundler
sudo rake insall

Don't forget to execute with both the --ssh-identity-file and --ssh-ip arguments!

If you'd like fsevents_to_vm to run on startup for your home folder:

mkdir -p ~/Library/LaunchAgents
cp LaunchAgents/local.fsevents_to_vm.plist ~/Library/LaunchAgents
launchctl load -w ~/Library/LaunchAgents/local.fsevents_to_vm.plist

Installation of the original fsevents_to_vm

Normally you won't install this manually, Dinghy will do it for you.

If you want to manually install:

$ gem install fsevents_to_vm

Usage

Dinghy will start fsevents_to_vm automatically. If you would like to run in manually:

The Dinghy VM must be running. Then in a terminal run:

$ fsevents_to_vm start

You can specify a specific directory to watch. This directory must be already mounted in the VM over NFS. By default, this means anything in your home dir:

$ fsevents_to_vm start ~/projects

Known Limitations

  • Delete events are not forwarded.
  • Multiple events for the same file within the same 1/100th of a second may cause events to be missed.
  • Some directories that you are unlikely to care about are ignored, for example ~/Library.

Testing

First, make sure that fsevents isn't already running due to dinghy start, kill it if necessary.

Then run manually:

bundle exec ruby exe/fsevents_to_vm start --debug --ssh-identity-file ~/.docker/machine/machines/dinghy/id_rsa --ssh-ip $(dinghy ip) ~

You can use inotifywait in the VM to watch for events:

docker run --rm -it -v $HOME:/fstest ubuntu:trusty
apt-get update && apt-get install -y inotify-tools
inotifywait /fstest/some/dir

Then modify a file in ~/some/dir and watch for inotifywait to catch the change.

About

forward OS X file system events to a VM, designed for use with Dinghy

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 97.9%
  • Shell 2.1%