最后更新于 .

这几天在写一个项目,其中有用到打包和解包的网络通信,相信有过网络编程经验的朋友应该都知道,无非就是 将一个结构体打包成一段buff,以及反向的过程。(这里我们不考虑直接memcpy的情况,因为结构体里的字段有可能只是指针,当然如果都是定长数据的话,那么memcpy当然是最快的) 而在这个过程中,很多代码只是改了很少一部分,但是却要分别写两个函数,严重浪费了人力,而且容易出错。现在让我们看一下,能否用vim来替我们自动完成这件枯燥的事情。 我们来看这样一段示例代码:

int Output( unsigned int ver, char* & buf, int & iLen, int iMaxLen )
{
    int needLen = sizeof(char) * 3 + sizeof(short) + sizeof(int);
    if( needLen > iMaxLen )
    {         
        return FBErrSystemNoMem;
    }     
    char *t_Buff = buff;
    *(unsigned char *) t_Buff = placeId;
    t_Buff += sizeof(unsigned char);
    *(unsigned char *) t_Buff = bitmap;
    t_Buff += sizeof(unsigned char);
    *(unsigned short *) t_Buff = cId;
    t_Buff += sizeof(unsigned short);
    *(unsigned char *) t_Buff = harvestTimes;
    t_Buff += sizeof(unsigned char);
    *(unsigned int *) t_Buff = plantTime;
    t_Buff += sizeof(unsigned int);
    iLen = t_Buff - buff;
    return 0;
}

而,我们希望能够自动生成这样一个对应代码:

int Input(unsigned int ver,char *buf,int& iLen,int iMaxLen)  
{   
    int needLen = sizeof(char)*3+sizeof(short)+sizeof(int);
    if(needLen>iMaxLen)   
    {    
        return FBErrSystemNoMem;
    }
    char *t_Buff = buff;
    placeId = *(unsigned char*)t_Buff;
    t_Buff+=sizeof(unsigned char);
    bitmap = *(unsigned char*)t_Buff;
    t_Buff+=sizeof(unsigned char);
    cId = *(unsigned short*)t_Buff;
    t_Buff+=sizeof(unsigned short);
    harvestTimes = *(unsigned char*)t_Buff;
    t_Buff+=sizeof(unsigned char);
    plantTime = *(unsigned int*)t_Buff;
    t_Buff+=sizeof(unsigned int);
    iLen = t_Buff - buff;
    return 0;
} 

仔细观察就会发现,实际就是

*(unsigned char*)t_Buff = placeId;

这样的赋值语句等号左右两边的数据换一下~ OK,那么现在就好做啦,vim的脚本如下:

%s/\(^\s*\)\(.*[^+]\) = \(.*\);$/\1\3 = \2;/gc

实际上很简单,首先将

*(unsigned char*)t_Buff = placeId;

这一句分段匹配,即最前面的空白部分是\1,等号左边(不包括紧挨等号左边的空格)是\2,等号右边(不包括紧挨等号右边的空格);之前是\3,所以只要替换成

\1\3 = \2;

即可啦,等号两边的空格是因为之前并没有匹配空格进去,所以为了美观,在等号两边分别加了个空格。 结果截图如下:

OK,正在写代码呢,突然觉得这个命令很有用,所以就放在这里啦,希望对大家也有用处~~~

Pingbacks

Pingbacks已打开。

Trackbacks

引用地址

评论

暂无评论

发表评论