A python extension to gather filesystem events generated by the operating system (macOS) for a specific path.
Have a look at macos_watcher.py
for an example.
- homebrew (used to pull other requirements)
- xcode devutils
- golang (used to compile the go code)
- pkg-config (used to generate the header files)
xcode-select --install # installs xcode devutils
# make sure you have set your GOPATH
brew install pkg-config golang
mkdir -p $GOPATH/src/github.com/nilleb
cd $GOPATH/src/github.com/nilleb
git clone https://github.com/nilleb/fsevents-watcher
cd fsevents-watcher
# which python do you use? we try to detect it in the set-python-home.sh.
# if you feel it's not the right version, feel free to edit it.
./build.sh
# now you can:
# - launch the example by typing
./launch.sh
# - if you want to use the included mtime_file_watcher.py for your AppEngine dev_appserver.py
sudo python replace_mtime_file_watcher.py replace
# now you can start `dev_appserver.py` as usual
# - if you want to restore the original mtime_file_watcher.py,
sudo python replace_mtime_file_watcher.py restore
has been tested on
- Darwin 19.4.0 Darwin Kernel Version 19.4.0: Wed Mar 4 22:28:40 PST 2020; root:xnu-6153.101.6~15/RELEASE_X86_64 x86_64
- Darwin 17.4.0 Darwin Kernel Version 17.4.0: Sun Dec 17 09:19:54 PST 2017; root:xnu-4570.41.2~1/RELEASE_X86_64 x86_64 i386 MacBookPro12,1 Darwin (homebrew python 2.7.13)
- Darwin 17.4.0 Darwin Kernel Version 17.4.0: Sun Dec 17 09:19:54 PST 2017; root:xnu-4570.41.2~1/RELEASE_X86_64 x86_64 i386 MacBookPro13,1 Darwin (System Default Python Interpreter - 2.7.10 as of writing)
- Darwin 16.7.0 Darwin Kernel Version 16.7.0: Thu Jan 11 22:59:40 PST 2018; root:xnu-3789.73.8~1/RELEASE_X86_64 x86_64 i386 MacBookPro12,1 Darwin
Fatal Python error: PyThreadState_Get: no current thread
./launch.sh: line 4: 52141 Abort trap: 6 $PYTHON_HOME/bin/python macos_watcher.py
Execute a otool -L fsevents_watcher.so
and verify that the python path is the one of the python executable you are using to launch the code.
If the path seems to be the same, check that the Python path exists. When using homebrew it is possible that some symlinks evolve with updates. If it is missing, you should be able to create a symbolic link to the right version.
If the path differs, you can try the follow:
- check what commands are being issued by the golang comiler and linker, editing build.sh and adding the
-x
flag at the end of the last line - verify that the path of the python library being linked is the one pointed by
otool
- check that you have installed homebrew python, and the pkg-config files
brew ls python
orbrew ls python@2
and inspect the output of those two commands. if they contain a folder named pkg-config you're halfway to the solution - if this is the case, try setting the PKG_CONFIG_PATH to the full path of the pkg-config folder listed by brew
- if this is not the case, you could try reinstalling homebrew python
Usually, a homebrew install ends with a message like:
==> python@3.8
Python has been installed as
/usr/local/opt/python@3.8/bin/python3
You can install Python packages with
/usr/local/opt/python@3.8/bin/pip3 install <package>
They will install into the site-package directory
/usr/local/opt/python@3.8/Frameworks/Python.framework/Versions/3.8/lib/python3.8/site-packages
See: https://docs.brew.sh/Homebrew-and-Python
python@3.8 is keg-only, which means it was not symlinked into /usr/local,
because this is an alternate version of another formula.
If you need to have python@3.8 first in your PATH run:
echo 'export PATH="/usr/local/opt/python@3.8/bin:$PATH"' >> ~/.zshrc
For compilers to find python@3.8 you may need to set:
export LDFLAGS="-L/usr/local/opt/python@3.8/lib"
For pkg-config to find python@3.8 you may need to set:
export PKG_CONFIG_PATH="/usr/local/opt/python@3.8/lib/pkgconfig"
I suppose that a solution to this problem would be to execute the command:
export PKG_CONFIG_PATH="/usr/local/opt/python@3.8/lib/pkgconfig"
IOError: [Errno 13] Permission denied: '/google-cloud-sdk/platform/google_appengine/google/appengine/tools/devappserver2/mtime_file_watcher.py'
Have you typed sudo
before the replace_mtime_file_watcher.py
invocation?
If you update the gcloud components, you shall re-replace the mtime_file_watcher.py
again..