首页 > 其他 > 详细

调试 shell script 方法

时间:2014-08-20 02:31:46      阅读:338      评论:0      收藏:0      [点我收藏+]
wade@V1088:~$ cat b.sh
#!/bin/bash dir=`pwd` dir=$dir/ for f in `ls *.png` do echo $dir$f done

看每一行代码的执行:

wade@V1088:~$ bash -x b.sh
++ pwd
+ dir=/home/wade
+ dir=/home/wade/
++ ls chrome_1407299385726.png chrome_1427299385726.png
+ for f in `ls *.png`
+ echo /home/wade/chrome_1407299385726.png
/home/wade/chrome_1407299385726.png
+ for f in `ls *.png`
+ echo /home/wade/chrome_1427299385726.png

进一步,看具体执行的代码与行号对应:

wade@V1088:~$ export PS4=+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: 
wade@V1088:~$ bash -x b.sh
++b.sh:2:: pwd
+b.sh:2:: dir=/home/wade
+b.sh:3:: dir=/home/wade/
++b.sh:8:: ls chrome_1407299385726.png chrome_1427299385726.png
+b.sh:4:: for f in `ls *.png`
+b.sh:7:: echo /home/wade/chrome_1407299385726.png
/home/wade/chrome_1407299385726.png
+b.sh:4:: for f in `ls *.png`
+b.sh:7:: echo /home/wade/chrome_1427299385726.png

指定脚本的部分去跑详细的行号,其余的忽略:

wade@V1088:~$ cat b.sh 
#!/bin/bash
dir=`pwd`
dir=$dir/
#this line above wont log out 
set -x
for f in `ls *.png`
do

  echo $dir$f
done
set +x
#the follow line wont log out 
echo end
abc=new var

运行输出:

wade@V1088:~$ ./b.sh
++./b.sh:10:: ls chrome_1407299385726.png chrome_1427299385726.png
+./b.sh:6:: for f in `ls *.png`
+./b.sh:9:: echo /home/wade/chrome_1407299385726.png
/home/wade/chrome_1407299385726.png
+./b.sh:6:: for f in `ls *.png`
+./b.sh:9:: echo /home/wade/chrome_1427299385726.png
/home/wade/chrome_1427299385726.png
+./b.sh:11:: set +x
end

 

调试 shell script 方法,布布扣,bubuko.com

调试 shell script 方法

原文:http://www.cnblogs.com/no7dw/p/3923657.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!