在工作的过程中,有时候解bug需要频繁的clean,make,拼凑镜像,这是一个相当麻烦的问题.
因为make之后需要等待一段时间,然后make完成之后需要查看是否有报错,如果没有报错的话需要拼凑镜像,这其中的时间说长不长,说短不短,为了能在这些过程中我可以去做其他的事情,然后完成的时候马上如果没有报错我就打开网页进行升级,,就会省去很多繁琐的步骤.
在此,首先解决一个问题,一般的编译命令是这样:
make O=build/dhcp/ core-dirclean
./mk_upgrade build/dhcp/ lx-dhcp_v2
如果没有报错就直接拼凑镜像,如果出错就继续解决bug,由于都是在linux输出命令,因此此处可以使用shell脚本解决,然后将信息传递到win上,需要一个客户端往win发送信息,由于是通知的形式和简洁考虑,直接使用udp就可以了,由于最近复习python,就使用python做服务器端吧
在这个过程中遇到一个问题,由于我想做到编译好了之后就是用一个类似于弹窗的方式告知我信息的一个效果,我本来的想法是使用win图形化编程,然后客户端和通知程序都集合在一起,但是不会啊,所以退而求其次,使用python作为服务端,然后收到信息就调用vbs脚本弹窗告知,曲线救国.
shell脚本的编译,我计划使用三部分参数,
第一个:编译的文件夹名字
第二个:编译结束的标识
第三个:需要重新编译的模块名字
遇到的技术问题:
- 参数拼接到命令后面,字符串的拼接
- 判断字符串相等
- 判断数字相等
- 循环语句的使用,以及变量的自增
- if语句的使用
- 命令字符串的输出,怎么使其生效
- 输入sh的参数带空格,这种情况怎么处理
- 字符串命令怎么执行
- 执行完的命令怎么获取结果
所以,综合所上,实现出来的shell脚本如下:第一个参数是机型的名字,第二个参数是标识着结束,后面的参数是需要clean的模块名字:
#!/bin/bash
array=($*)
arraylen=$#
index=1
makestr=`./makeimage.sh`
#makestr=`make`
endstr=""
for ((i=1;i<=arraylen;i++));
do
if [ $i -eq 1 ]; then
makestr="$makestr O=build/${array[$i-1]}"
elif [ $i -eq 2 ]; then
endstr="${array[$i-1]}"
#echo "end str is ${endstr}"
else
if [ ${array[$i-1]} == "tp" ]; then
makestr="$makestr tp-clean"
else
makestr="$makestr ${array[$i-1]}-dirclean"
fi
fi
done
check_out=$makestr
getout=$(echo $check_out | grep "${endstr}")
if [[ "$getout" != "" ]]; then
./sendToWin success
echo "make success"
else
./sendToWin fail
echo "make fail"
fi
python实现一个udp服务器端,监听信息,并且调用vbs脚本:
import socket
import subprocess
def makesuccess():
subprocess.call(['cscript.exe', "C:\\userlx\\codeproject\\linuxnotifywin\\makesuccess.vbs"])
def makefail():
subprocess.call(['cscript.exe', "C:\\userlx\\codeproject\\linuxnotifywin\\makefail.vbs"])
def startserver():
sersock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
sersock.bind(('192.168.31.101', 60012))
while(True):
print("start to listen")
recv_data = sersock.recv(1024)
msg = recv_data.decode("utf-8")
print(msg)
if("fail" in msg ):
makefail()
elif("success" in msg):
makesuccess()
else:
print("no")
pass
if __name__ == '__main__':
startserver()
vbs脚本,这个没什么好说的,一个msgbox就可以了
msgbox( "make fail! " )
最后,就是确认编译OK了之后使用一个udp程序进行发包,这个本来可以使用ns命令进行操作的,但是就拿c练练手吧,问题不大
/*
udp client
*/
//常用的头文件
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <ctype.h>
#define BUFFLEN 1024
#define SERVPORT 60012
#define SERVADDR 192.168.31.101
int main(int argc, char* argv[])
{
int cfd = socket(AF_INET, SOCK_DGRAM, 0);
if (cfd < 0)
{
perror("socket error");
return -1;
}
int n;
char buf[BUFFLEN];
struct sockaddr_in serv;
serv.sin_family = AF_INET;
serv.sin_port = htons(SERVPORT);
inet_pton(AF_INET, "192.168.31.101", &serv.sin_addr.s_addr);
memset(buf,0,sizeof(buf));
strncpy(buf, argv[1], strlen(argv[1]));
sendto(cfd, buf, BUFFLEN,0,(struct sockaddr*)&serv,sizeof(serv));
return 0;
}
不足:在这里,脚本对命令模块的读取是可以选择的,但是对于python,要接受传参监听IP,监听的端口的选择,