unix - unix shell 中 2 个别名 cd 之间的行为差异
问题描述
我通过 VNC 连接到远程计算机并使用 Konsole 进行工作。Konsole 是使用 KDE 4.3.4 的 2.3.3 版本。我有这两个别名:
alias ll 'ls -haltr; pwd'
alias cd 'cd \!*; ll'
我观察到有以下行为:
- 当路径存在时,它将
cd
对其进行ll
别名处理 - 当路径不存在时,它只会说路径不存在并且不会
ll
再做
例子:
路径存在
[10] % cd foo
total 14K
-rw-r----- 1 user group 913 Jun 3 2014 readme
-rw-r----- 1 user group 1.2K Dec 3 2020 report.txt
drwxr-x--- 2 user group 4.0K Jan 12 17:50 ./
drwx------ 77 user group 8.0K Jun 24 11:57 ../
/home/user/foo
[11] %
路径不存在
[10] % cd nowhere
nowhere: No such file or directory.
[11] %
现在我们的部门已经转移到另一个部门,我们刚刚开始通过 Exceed TurboX 进行远程连接。我仍然使用 Konsole,但现在使用 KDE 4.10.5 的版本是 2.10.5。我复制了相同的两个别名,但我现在观察到不同的行为:
- 当路径存在时,它将
cd
对其进行ll
别名处理(与上面的#1基本相同) - 当路径不存在时,它将尝试
cd
AND仍然执行ll
(与上面的 #2不同)
所以对于#2,它是这样的:
[10] % cd nowhere
nowhere: No such file or directory.
total 120K
-rw-r----- 1 user group 272 Jan 6 2021 .cshrc
-rw-r----- 1 user group 1.2K Jan 6 2021 .alias
drwxr-x--- 2 user group 4.0K Jan 12 17:50 ./
drwx------ 77 user group 8.0K Jun 24 11:57 ../
/home/user
[11] %
我想知道如何将先前工作环境的行为#2 转换为当前工作环境。
我已经添加了关于 Konsole 和 KDE 版本的信息,因为如果行为是由于版本引起的并且没有解决方法,那么我将在这个新的远程桌面环境中工作的余生感到难过。^_^
我目前正在探索“在做之前先检查路径是否存在ll
”,但无济于事。:'(
编辑:
我使用的外壳tcsh
% printenv SHELL
在两种环境中都显示/bin/tcsh
了此外:
旧环境
% echo $version
tcsh 6.17.00 (Astron) 2009-07-10 (x86_64-unknown-linux) options wide,nls,dl,al,kan,sm,rh,color,filec
新环境
% echo $version
3
解决方案
问题中的信息仍然不足以找出为什么 tcsh
在两种工作环境中表现不同。
别名定义了一系列命令(cd
后跟ll
),没有任何条件。
alias cd 'cd \!*; ll'
cd
在一个系统上,如果命令由于当前未知原因报告错误,则别名的执行似乎会停止。
防止在命令ll
失败后执行的正确方法cd
是有条件地执行ll
命令,例如
alias cd 'cd \!* && ll'
推荐阅读
- java - 如何反转这个等式?
- r - 如何在R中转换每月时间序列
- serialization - 序列化/反序列化 Xodus-dnq 实体的正确方法
- node.js - Node/Express:在将标头发送到客户端后无法设置标头
- libc - 意外重命名 libc.so.6 并且无法在救援模式下 chroot
- android-studio - 升级我的 Android SDK 后出现“错误:无法访问 FragmentActivity”
- javascript - 如何中止调用的ajax方法c#.net
- delphi - Delphi - 快速报告(动态报告预览)
- sql - 显示耗时最长的任务 sql
- r - 当 n = 1 时,为什么 TTR::SMA 为系列的第一个元素返回 NA?