通过grep源码,分析grep返回值

来源:互联网 发布:怎样做一个域名服务器 编辑:程序博客网 时间:2024/06/04 20:09

grep源码分析结果:
1:grep返回值有三个,0匹配,1:不匹配,2:出错
2:错误信息(包括解析后的错误代码)输出到标准错误中
3:通过设置-s,可以屏蔽错误显示

 

ps:二个发现
1:源码里有个dfa.c和dfa.h, 应该是grep里有到的正则引擎,正则引擎分DFA和NFA二种,DFA快,但没NFA的d环视,回朔等功能
2:源码里,解析"-"为标准输入。之前讨论过关于"-"参数为标准输入的问题,现在可以确认grep对-参数,是程序解析,而非shell解析


具体源码分析如下:
main函数退出语句
  exit (errseen ? 2 : status);

errseen说明:
其中errseen在函数里设置,并通过error输出到标准输出
suppressible_error (char const *mesg, int errnum)
{
  if (! suppress_errors)
    error (0, errnum, "%s", mesg);
  errseen = 1;
}
suppressible_error 被调了四次,
包括buf,file,dir等几种错误,
在没有suppress,即屏蔽错误信息前提下,通过error函数,将错误输出到标准错误
error函数在第二个参数不为0的时候,调用perror解析错误代码,比如(这里用的是系统命令)
[root@localhost sc]# perror 5
+ perror 5
OS error code   5:  Input/output error


status说明:
默认为1,即不匹配:
  status = 1;
通过与grepfile返回值做逻辑与,若有匹配,置成0,
    if (optind < argc){
      status &= grepfile (strcmp (file, "-") == 0 ? (char *) NULL : file,
   }
    else
   {status = grepfile ((char *) NULL, &stats_base);}


grepfile函数分析:
匹配(count>1)返回0,没匹配(count=0)返回1
  status = !count;
  return status;