Mercurial > dotfiles
view unixSoft/bin/patchpipe @ 377:117e3c11d953
zprofile: introduce zprofile use
El Capitan (OS X 10.11) introduces a system-level /etc/zprofile which
uses a path_helper thing to mangle $PATH. Unfortunately, the way
path_helper works, it forces /usr/local/bin and /usr/bin to the
*start* of the PATH variable, which means that any PATH mutations I
want have to run after /etc/zprofile calls path_helper. As such, move
my path insertions into .zprofile{,-machine} rather than
.zshenv{,-machine} so that I can still ensure my path entries are at
the start of PATH rather than the end. This works because:
> Commands are then read from $ZDOTDIR/.zshenv. If the shell is a
> login shell, commands are read from /etc/zprofile and then
> $ZDOTDIR/.zprofile. Then, if the shell is interactive, commands
> are read from /etc/zshrc and then $ZDOTDIR/.zshrc. Finally, if the
> shell is a login shell, /etc/zlogin and $ZDOTDIR/.zlogin are read.
This means that non-login shells no longer pick up my custom PATH
entries, but as I only use OS X as a desktop OS that seems like a
workable tradeoff for now.
author | Augie Fackler <raf@durin42.com> |
---|---|
date | Sun, 31 Jan 2016 20:46:29 -0500 |
parents | c7a9cd793e37 |
children | a5a4f9e12c9f |
line wrap: on
line source
#!/usr/bin/env python import base64 import os import subprocess import sys import tempfile _PATCHHDR = '# HG changeset patch' _BASE64_MAGIC = 'Content-Transfer-Encoding: base64' def main(argv): tf = tempfile.NamedTemporaryFile(suffix='.diff') d = sys.stdin.read() if _PATCHHDR in d: junk, d = d.split(_PATCHHDR, 1) d = _PATCHHDR + d elif _BASE64_MAGIC in d: junk, d = d.split('\n\n', 1) d = d.decode('base64') tf.write(d) tf.flush() subprocess.check_call([os.environ['EDITOR'], tf.name], stdout=sys.stderr) sys.stdout.write(open(tf.name).read()) if __name__ == '__main__': main(argv=sys.argv)