0.3.5 wip

This commit is contained in:
anki-code 2020-03-01 10:24:58 +03:00
parent 91c1b8c0fe
commit 8087dd44b4
3 changed files with 12 additions and 25 deletions

View file

@ -62,7 +62,7 @@ The xxh is for using the xonsh shell wherever you go through the ssh.
The xxh is using pip and python from `xonsh.AppImage` by default. You can update pip (`pip install --upgrade pip`) and install packages ordinally: `pip install --upgrade pandas`. The packages will appear in host xxh home `~/.xxh/pip` by default. The xxh is using pip and python from `xonsh.AppImage` by default. You can update pip (`pip install --upgrade pip`) and install packages ordinally: `pip install --upgrade pandas`. The packages will appear in host xxh home `~/.xxh/pip` by default.
To install [xontribs](https://xon.sh/xontribs.html) in xxh session use `xontrib-install <package>`. Never use `pip` or `xpip` to install xontribs! ([details](https://github.com/xonsh/xonsh/issues/3463)) To install [xontribs](https://xon.sh/xontribs.html) in xxh session use `xpip install <package>`. Never use `pip` to install xontribs ([details](https://github.com/xonsh/xonsh/issues/3463)).
### How it works? ### How it works?

View file

@ -1,7 +1,7 @@
import sys, os import sys, os
global_settings = { global_settings = {
'XXH_VERSION': '0.3.4' 'XXH_VERSION': '0.3.5'
} }
if __name__ == "__main__": if __name__ == "__main__":

View file

@ -15,35 +15,22 @@ $PATH = [ p"$PYTHONHOME" / 'bin', $XXH_HOME ] + $PATH
sys.path.append(str($PIP_TARGET)) sys.path.append(str($PIP_TARGET))
sys.path.remove('') if '' in sys.path else None sys.path.remove('') if '' in sys.path else None
aliases['pip'] = ['python','-m','pip'] aliases['pip'] = ['python','-m','pip']
aliases['xpip'] = lambda args: ![echo "\n\033[0;33mTO INSTALL XONTRIBS USE: xontrib-install <package>\033[0m\n"] and ![pip @(args)]
def _xxh_xontrib_install(args, stdin, stdout): # https://github.com/xonsh/xonsh/issues/3463 def _xxh_pip(args): # https://github.com/xonsh/xonsh/issues/3463
argp = argparse.ArgumentParser(description=f"Install xontribs", prog='xontrib-install') if args and 'install' in args and '-h' not in args and '--help' not in args:
argp.add_argument('xontrib',help="pip package with xontrib") print('\033[0;33mRun xpip in xontrib safe mode\033[0m')
argp.add_argument('-f', '--force', default=False, action='store_true', help="Force install") pip_xontrib_tmp = $PIP_XONTRIB_TARGET.parent / 'xontrib-safe'
argp.usage = argp.format_usage().replace('usage: ', '')
opt = argp.parse_args(args)
if !(pip search -q @(opt.xontrib)).returncode:
print(f'pip search {opt.xontrib}: not found')
return 1
if not opt.force and opt.xontrib in $(pip list).split():
print(f'pip list: {opt.xontrib} already installed, try -f option to force install')
return 1
if list($PIP_XONTRIB_TARGET.glob('*')):
pip_xontrib_tmp = str($PIP_XONTRIB_TARGET) + '_'
mv @($PIP_XONTRIB_TARGET) @(pip_xontrib_tmp) mv @($PIP_XONTRIB_TARGET) @(pip_xontrib_tmp)
xpip install --upgrade @(opt.xontrib) pip @(args)
mkdir -p @($PIP_XONTRIB_TARGET) mkdir -p @($PIP_XONTRIB_TARGET)
bash -c $(echo mv @(pip_xontrib_tmp + '/*') @($PIP_XONTRIB_TARGET)) if list(pip_xontrib_tmp.glob('*')):
bash -c $(echo mv @(pip_xontrib_tmp / '*') @($PIP_XONTRIB_TARGET))
rm -r @(pip_xontrib_tmp) rm -r @(pip_xontrib_tmp)
else: else:
xpip install --upgrade @(opt.xontrib) pip @(args)
aliases['xontrib-install'] = _xxh_xontrib_install aliases['xpip'] = _xxh_pip
del _xxh_xontrib_install del _xxh_pip
for plugin_path in sorted(($XXH_HOME / 'plugins').glob('*')): for plugin_path in sorted(($XXH_HOME / 'plugins').glob('*')):
if (plugin_path / 'xonshrc.xsh').exists(): if (plugin_path / 'xonshrc.xsh').exists():