如何覆盖 xonsh 中的内置命令?
How to override built-in command in xonsh?
我正在尝试覆盖 'ls' 命令以显示 "dotfiles" 目录中的点文件。
这是我的代码。
def _ls():
if $(pwd).rstrip(os.linesep) == $DOTFILES:
ls -Ga
else:
ls -G
aliases['ls'] = _ls
此代码进入无限循环,因为 _ls
函数调用 ls
命令并且它调用 _ls
函数。
有什么想法吗?
不应该发生无限别名调用——您介意在 github 提出问题吗?com/xonsh/xonsh/issues?
在此期间,这里有一种构造别名的方法,无需任何修复即可使用:
def _ls(args):
args = args[0].replace('-', '') if args else ''
if $(pwd).rstrip(os.linesep) == $DOTFILES:
$(which -s ls) @(f"-{''.join(set(args + 'aG'))}")
else:
$(which -s ls) @(f"-{''.join(set(args + 'G'))}")
aliases['ls'] = _ls
which
的 -s
参数跳过别名解析,因此 returns 实际 ls
可执行文件的路径。然后 set
逻辑是确保参数不重复(尽管我不确定这是绝对必要的)。
我正在尝试覆盖 'ls' 命令以显示 "dotfiles" 目录中的点文件。
这是我的代码。
def _ls():
if $(pwd).rstrip(os.linesep) == $DOTFILES:
ls -Ga
else:
ls -G
aliases['ls'] = _ls
此代码进入无限循环,因为 _ls
函数调用 ls
命令并且它调用 _ls
函数。
有什么想法吗?
不应该发生无限别名调用——您介意在 github 提出问题吗?com/xonsh/xonsh/issues?
在此期间,这里有一种构造别名的方法,无需任何修复即可使用:
def _ls(args):
args = args[0].replace('-', '') if args else ''
if $(pwd).rstrip(os.linesep) == $DOTFILES:
$(which -s ls) @(f"-{''.join(set(args + 'aG'))}")
else:
$(which -s ls) @(f"-{''.join(set(args + 'G'))}")
aliases['ls'] = _ls
which
的 -s
参数跳过别名解析,因此 returns 实际 ls
可执行文件的路径。然后 set
逻辑是确保参数不重复(尽管我不确定这是绝对必要的)。