上次因为公司里机器要面临重装,开始仓皇地将Mac本里的文件scp到个人台式机上。忙乱之中原本要删除一个无用的文件夹的,结果用rm -rf的时候tab了一下,补全出来的文件都没看清就按下了回车,毫无疑问,文件删错了。因为rm命令是不走回收站的,连删前确认都不会有,因此就这么把一个有用的文件夹删掉了。幸好后来发现我曾在台式机上备份过这个文件,不然美好的回忆就由于这个操做失误而丢失了。git
为了防止此类事件的再度发生,我曾在Twitter上询问过别人关于实现rm时只把文件送到回收站而不删除的命令。有些人说用mv命令就好了,可是这显然是不够的,由于mv和rm命令选项并不兼容,尤为是本人惯用的rm -rf,mv显然作不到。其次把文件mv进回收站之后是不能put back的,那就更不行了。网上还有些方法提供了可以将文件送入回收站,而且可以put back的方法,这个仍是不错,可是就如我以前所说,并未彻底实现rm的选项功能。所以我就花了几个晚上的实现本身实现了一个符合我这一需求的工具:https://gitcafe.com/bachue/rm-trashgithub
其实起初我觉得这个工具并不难作,只是把文件夹往回收站一放便可,后来作到交互式删除的时候难度倍增,使得我不得很少次大规模重构了代码以符合这种需求。幸好项目之初就创建了完善的RSpec测试用例,不然确定无暇顾及如此多的边缘Case。同时随着更深刻的开发和研究,发现了愈来愈多刚开始没有发现的rm的行为细节,这些细节事实上至今为止我都没有彻底模仿出来,由于程序目前的算法不容许这么作,不过因为程序已经基本可用而时间宝贵,只能等到之后有空的时间再实现罢。算法