Sofia-SIP辅助文档二 - C语言代码风格指南

来源:互联网 发布:淘宝的旺旺号是啥 编辑:程序博客网 时间:2024/04/19 20:58
http://sofia-sip.sourceforge.net/refdocs/styleguide.html,翻译自官网的这张网页。
 

这篇文章给出了Sofia-SIP库中关于一般性的C语言风格和编码格式通用指南。指南包括标识符命名规范,约定规范和工具使用指导。请牢记一点,C语言风格只是个人偏好而已。

命名规范

一般情况下,各个模块内的标识符都以本模块名作为前缀。例如,http解析器模块内的函数名都用http_作为前缀。由多个词组成的标识符在词与词之间用下划线“_”连接,所有英文单词都采用小写字母。例如,http_request_create()。

所有的宏都应该采用大写字母。文件名使用小写字母,可能的话用下划线作为分隔符。

通常情况下,typedef类型都有_t后缀,函数类型的后缀是_f。枚举类型名称的后缀是_e,结构类型名称的后缀是_s,以及联合体类型名称的后缀是_u。

建议类型本身都是typedef定义的类型,而不是指向类型的指针。这么做的好处是一眼就能看出一个变量是不是指针。

typedef struct foo_s foo_t;typedef int fun_f(foo_t *f, char const *s);

结构体和联合体成员应当有着一致的前缀。例如,

struct foo_s {  int    f_len;  char  *f_name;  fun_f *f_fun;};

前缀的使用使得发现在哪使用成员变量变得非常便利。

缩进和格式化代码

Sofia-SIP中的C代码采用K&R风格的两个字符缩进。单行最大字符数为80个。

例如,

void kluge(int foo){  if (foo) {    bar();  }  else {    switch (baz()) {    case a:      eeny();      break;    case b:      meeny();      break;    default:      moe();      break;    }  }}

缺省缩进可通过使用带参数的GNU indent获得。(这句啥意思?The default indentation can be achieved with GNU indent with options)

-nbad -bap -bbo -nbc -br -brs -c33 -cd33 -ncdb -ce -ci2 -cli0 -cp33 -cs-d0 -di1 -nfc1 -nfca -hnl -i2 -ip0 -l79 -lp -npcs -nprs -npsl -saf -sai-saw -nsc -nsob -nss

无条件循环采用for (;;)而不是while (1)。

  for (;;) {    foo();    if (bar())      break;    baz();  }

在中缀操作符的前后都有一个空格,除了.和->这两个操作符前后不能存在空格,以及逗号,它只需要在之后有空格。在关键字和紧跟其后的括号之间应该有一个空格,在标识符和紧跟其后的括号之间不应存在空格,

  while (i++ < n)    baz();  for (;;) {    x->x_foo();    if (bar())      break;    z.z_baz++;  }  return (13 * i);

0 0
原创粉丝点击