-
Notifications
You must be signed in to change notification settings - Fork 6
INDENT
Wei-Cheng Yeh (IID) edited this page Jun 5, 2023
·
28 revisions
This page describes the indentation style for the DreamBBS project.
- C & shell code
- Indent with 4 spaces
- No tabs
Good:
{
sth
}
Bad:
- 2-space (Maple3)
{
sth
}
- Hard tab
{
[tab]sth
}
-
- No trailing spaces
- Use
\n
for line breaks
-
- Both K&R and Allman style are allowed, but they should not be mixed within a file, especially within a function
- Allman style should be used only in existing codes indented using Allman style.
- From DreamBBS v4 and on, only K&R style will be allowed.
- The indentation size of continued lines should be 4 spaces
- Argument lists and initializer-lists
- The elements should be indented or be aligned with the start of the list
- The end of list without elements in the same line should be indented less that the elements
- No wrapping at operators with higher grouping precedence without wrapping at operators with lower grouping precedence
Good:
if (sth_long > 42
&& sth_else_long
)
if (sth_long
> (42 && sth_else_long)
)
- No line breaks between unary, prefix, and suffix operators other than
.
and->
and their operand - If needed, line breaks must come before the suffix operators
.
and->
Good:
sth_long
.member++;
- If needed, line breaks should come before the binary operators other than assignments and comma
Good:
if (sth_long
&& sth_else_long
)
- For the condition operator, if needed, line breaks should come before
:
or both after?
and before:
- This allows programmers to easily distinguish the conditions from the values
Good:
cond ? sth : sth_cond ? sth_else : else_sth
-
- Use the above form only if all the condition and result expressions contain no non-empty pairs of
(
&)
- Use the above form only if all the condition and result expressions contain no non-empty pairs of
cond ? (sth & 1)
: else_cond ? (sth_else | 0x80000000)
: else_sth
-
- Otherwise use the above form only if the condition expressions contain no non-empty pairs of
(
&)
- Otherwise use the above form only if the condition expressions contain no non-empty pairs of
(cond_0 || cond_1) ?
sth
: (else_cond_0 && else_cond_1) ?
sth_else
: else_sth
-
- Otherwise use the above form
- 如果 code 附近的相似 code 已被對齊排版,這段 code 應該對齊排版
- 新的 code 不應該對齊排版,除非附近相似的 code 已被對齊排版
- Label 須單獨一行出現,或與多個 labels 在同一行內單獨出現
Good:
switch (cond)
{
default: case 1: case 2: case 3:
sth();
break;
case -1:
sth_else();
break;
case 0:
;
}
-
goto
label 的 indentation 須與所在 function 的 code block 的{
/}
的所在行相同
Good:
int func(void)
{
if (sth)
{
sth:
}
}
-
case
label 的 indentation 須與switch
的 code block 的{
/}
的所在行相同 -
case
label 內的 code 須 indent -
default
label 與其它 labels 同在一行時,default
須在最前方
Good:
switch (sth)
{
case sth:
code
}
switch (sth)
{
case sth:
if (sth)
{
default: case sth_else:
code
}
}
Bad:
switch (sth)
{
case sth:
if (sth)
{
case sth_else: default:
code
}
}
-
C code
- 在 parameter list 及 condition list 後,與
{
之間要有空白字元 - 在 identifier 後,與
{
之間要有剛好一個 space - 在 identifier 前,與
}
之間要有 spaces
- 在 parameter list 及 condition list 後,與
-
在代表 code block 的
{
之後,以及}
之前,要有空白字元
Good:
{
code
}
{
}
- One-liner
{ code }
{ }
- 如果
else
/else if
和之前的}
在同一行裡,else
後面的{
也要在這一行裡
Good:
- K&R style
} else {
- K&R style (Stroustrup)
}
else {
- Allman style
}
else
{
- 必須使用
{
與}
作為 code block -
while
必須與}
在同一行中 -
while
後的;
不得單獨一行出現
Good:
do {
sth();
} while (cond);
Bad:
do {
sth();
}
while (cond);
-
{
與}
不得在同一行中 - 以下任一狀況成立則必須使用
{
與}
:- 為
do
-while
的 code block - Condition list 含有換行
- Code block 內含有
goto
/case
labels
- 為
- 除了必須使用
{
與}
的狀況外……- 若 code block 為空,應以單獨一行的
;
取代 - 若僅包含一句不換行的陳述式,可不使用
{
與}
,但該陳述式須單獨一行出現
- 若 code block 為空,應以單獨一行的
Good:
while (cond) {
label:
sth;
}
while (cond)
sth;
while (cond)
;
Bad:
while (cond) { sth; }
while (cond) sth;
while (cond);
- 若有
goto
/case
labels,則{
與}
必須在不同行中 - 若函式宣告的參數清單無換行,且若 code block 為空或僅包含一句不換行的陳述式,
{
與}
可在同一行中
Good:
int func(int x)
{
return x;
}
int func(int x) { return x; }
int func(int x)
{ return x; }
void func(void)
{
}
void func(void) { }
void func(void) {
loop:
goto loop;
}
Bad:
void func(void) { loop: goto loop; }
-
if
/for
/while
/switch
與 condition list 之間應有剛好一個 space -
例外:用來對齊
else if
後的 condition list 時,if
後可以有 6 個 spaces
Good:
[if/for/while/switch] (sth)
if (sth)
...
else if (sth)
- Condition list 含有換行時,結尾的
)
前須換行,而縮排與 code block 內的縮排相同
Good:
if (1 + 1 == 2
&& *p != '\0'
)
{
do_sth();
}
- 二元非賦值位元運算子,其運算元若直接包含與其不同的二元運算子,應以
(
與)
將此運算元包圍 - 二元非賦值運算子,其運算元若直接包含二元位元運算子,應以
(
與)
將此運算元包圍
Good:
-x | (y & 1) | (z + 3)
(-x | (y & 1) | (z + 3)) >= 42
res = -x | (y & 1) | (z + 3)
- 條件運算子
?
...:
的條件式直接包含二元運算子時,應以(
與)
將其包圍
Good:
!x ? 2 * a
: (b > 42) ? b - 1
: 2 * c + 1
- 條件運算子
?
...:
的結果式直接包含賦值運算子時,應以(
與)
將其包圍
Good:
!x ? (a *= 2)
: (b > 42) ? (b -= 1)
: (c = 2 * c + 1)
- 避免非必要的
(
與)
Good:
int (*parr)[N] = arr;
++(*parr)[base + idx];
Bad:
int ((*parr)[N]) = arr;
++((*parr)[base + idx]);
-
(
後與對應的)
前的 space 的使用應該一致,要就不使用 space,要就使用剛好一個 space -
例外:在字串中的
(
後與對應的)
前,如果一端是全形字,而另一端是半形字,不論全形字的那端有沒有使用 space,半形字的那一端都可以使用一個 space
Good:
( sth )
(sth)
( )
()
(sth...漢)
( sth...漢 )
(漢...sth)
( 漢...sth )
- In the strings
"( sth...漢)"
"(漢...sth )"
Bad:
-
(sth...漢 )
-
( 漢...sth)
-
函式宣告的參數清單與函式呼叫的引數清單,若含有換行,則開頭的
(
後換行,結尾的)
前不換行
Good:
void log_level(
const Logger *logger,
enum LogLevel level,
const char *format,
...)
{
/* Codes */
}
log_level(
logger,
LOGLV_DEBUG,
"Value in decimal: %d\n"
"Value in hexadecimal: %x\n",
value,
value);
- C code
- 在 initializer-list 中,
,
不能在被註解掉的 element list 之首,應從註解移出到前一個 element 後
- 在 initializer-list 中,
- Code
-
,
前不能有額外的 spaces -
,
後和 expression 之間要有至少一個 space -
,
後不能有不用於對齊的額外 spaces - 扣除空白字元之後,
,
不能在一行之首 - 例外:特殊功能字串不必符合此規則
-
Good:
sth, sth
sth,
sth
macro(,,)
macro(sth,, sth)
int a[] = {sth, sth, /* sth */};
- C & shell code
-
;
前不應有 spaces,除非;
前是行內註解 -
;
後,與 expression 之間,應有空白字元 - 扣除空白字元之後,
;
可以單獨成行 - 例外:ANSI escape sequence 相關的註解與字串不必符合此規則
-
Good:
code; sth
code;
sth
for (;;)
for (sth;; sth)
for (sth; sth; sth)
- The indentation size should be 2 spaces
- The indentation should be consistent within the whole block
- The indentation can come before or after
#
- The indentation can be omitted only for short blocks
Good:
#if COND
#define STH sth
#endif
#if COND
#define STH sth
#endif
#if COND
# define STH sth
#endif
Bad:
#if COND
... [Large directive block without indentation]
#endif
- The indentation should be independent of the indentation of C code
Good:
#if sth
int func(void)
{
if (sth)
{
#if sth_else
code;
#endif
}
}
#endif
- Home
- Install — 安裝說明
- Version
- Project Documentations — 專案說明文件
- Coding Style & Conventions — 程式碼撰寫風格與慣例
- Indentation
- Xover List System — Xover 列表系統
- Menu Systems — 選單系統
- Screen Coordinate System — 畫面座標系統
- BoardReadingHistory — BRH 看板閱讀紀錄系統
- Visio I/O Library — Visio 輸出入函式庫
- Permission System — 權限系統
- TANet BBS Family Genealogy Chart — TANet BBS 家族譜系圖
- 與 MapleBBS 3 的按鍵差異
- [WIP] 與 MapleBBS 3 的差異
- References — 參考資料
- Changelog & TODO
- Issue & TODO list — 問題與代辦事項清單
- MapleBBS-itoc Porting Project — MapleBBS-itoc 移植計畫
- BBS-Lua Changelog
- BBS-Ruby Changelog (external link — 外部鏈結)
- 新式密碼加密 (DLBBS v2.0+)
- [WIP] DreamBBS v3 發佈說明 Release Note
- Release Notes of Version 2.0.0 Artoria
- Version 2.0.0 Artoria 發行說明
- Release Notes of Version 1.0.0 Rimuru
- Version 1.0.0 Rimuru 發行說明
- NoCeM-innbbsd 原始說明文件
- WindTop 3.02 原始說明文件