小工具--编译完成通知win

在工作的过程中,有时候解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,监听的端口的选择,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值