排错和完善

如果以前曾经安装过或者Utilities中有Onyx.app,那么第一次运行rmOnyx.pkg可以成功,之后再运行它就会报错。

问题出在哪里?熟悉脚本的读者会猜到,就是我们的安装包脚本处理不当造成的。在前面的postinstall脚本中运行最后一行rm命令。如果/Applications/Utilities/Onyx.app 不存在,rm命令会报错,并返回非零值以示出错,如果在脚本中的后续命令中不做处理,postinstall脚本会返回最后运行命令的返回值,这造成postinstall脚本返回值也是非零,而脚本返回错误值(非零)会导致安装程序报错。所以,要注意:安装包脚本一定要处理好脚本的返回值,尽量考虑周全并多做判断,避免返回不必要的错误代码。

下面我们来对postinstall做如下的改进:

#!/bin/bash
pkgutil --pkgs=lts.ApplePai.Onyx && pkgutil --forget lts.ApplePai.Onyx;
rm -r /Applications/Utilities/Onyx.app
exit 0

上面的改进是:

第2行:前半部分的“pkgutil --pkgs=lts.ApplePai.rmOnyx”,是使用 pkgutil 命令读取当前系统的安装包数据库的记录,如果存在“lts.ApplePai.rmOnyx”就会返回成功值0,否则会返回错误值。 “&&”的意思是:如果前面的命令返回0,就继续执行后面的命令。后面的命令“pkgutil --forget lts.ApplePai.rmOnyx”,让系统从数据库中删除该包标识符。读者需注意,pkgutil命令只管理系统包数据库,它不会清理所安装的文件,文件清理是操作人员的工作。

第4行:我们强制脚本退出值为0(成功)。因为无论该app是否存在,该包的标识符是否存在,我们的目的都是删除它们并认为移除工作成功完成,所以返回值应该是成功(=0)。

其实使用rm -fr 也可以避免rm命令返回错误值。作为普通的脚本一定要注意每个命令的返回值,在脚本最后最好使用exit 0返回0。

还有一种常见的错误就是,脚本文件没有被设置可执行或者脚本文件名不是 "postinstall"。

Last updated