[code format]Upgrade clang-format in BE Code Formatter from 8 to 13 (#9602)

This commit is contained in:
Adonis Ling
2022-05-17 19:28:15 +08:00
committed by GitHub
parent 7417f9dfa3
commit ec2cd0083a
7 changed files with 30 additions and 19 deletions

View File

@ -36,5 +36,5 @@ jobs:
id: be_clang_format
with:
source: 'be/src be/test'
clangFormatVersion: 10
clangFormatVersion: 13
inplace: False

View File

@ -87,10 +87,9 @@ struct ParsedData {
*output = _data[offset];
break;
case ExplodeJsonArrayType::STRING:
*output = _string_nulls[offset]
? nullptr
: real ? reinterpret_cast<void*>(_backup_string[offset].data())
: &_data_string[offset];
*output = _string_nulls[offset] ? nullptr
: real ? reinterpret_cast<void*>(_backup_string[offset].data())
: &_data_string[offset];
break;
default:
CHECK(false) << type;

View File

@ -271,7 +271,8 @@ public:
}
void get_dict_word_info(StringRef* dict_word_info) {
if (_num_elems <= 0) [[unlikely]] return;
if (_num_elems <= 0) [[unlikely]]
return;
char* data_begin = (char*)&_data[0];
char* offset_ptr = (char*)&_data[_offsets_pos];

View File

@ -350,8 +350,8 @@ protected:
const T& operator*() const { return *value; }
T& operator*() { return value->assume_mutable_ref(); }
operator const immutable_ptr<T> &() const { return value; }
operator immutable_ptr<T> &() { return value; }
operator const immutable_ptr<T>&() const { return value; }
operator immutable_ptr<T>&() { return value; }
operator bool() const { return value != nullptr; }
bool operator!() const { return value == nullptr; }

View File

@ -236,7 +236,7 @@ TEST_F(ThreadPoolTest, TestRace) {
// so an cast is needed to use std::bind
EXPECT_TRUE(_pool
->submit_func(std::bind(
(void (CountDownLatch::*)())(&CountDownLatch::count_down), &l))
(void(CountDownLatch::*)())(&CountDownLatch::count_down), &l))
.ok());
l.wait();
// Sleeping a different amount in each iteration makes it more likely to hit

View File

@ -40,7 +40,7 @@ Doris uses clang-format for code formatting, and provides a package script in th
The code style of Doris is slightly modified on the basis of Google Style and is customized as a `.clang-format` file located in the root directory of Doris.
Currently, the `.clang-format` configuration file is adapted to versions above clang-format-8.0.1.
Currently, the `.clang-format` configuration file is adapted to versions above clang-format-13.0.1.
The code that you do not want to be formatted is recorded in the `.clang-format-ignore` file. These codes usually come from third-party code bases, and it is recommended to keep the original code style.
@ -50,19 +50,24 @@ You need to download and install clang-format, or you can use the clang-format p
### Download and install clang-format
It is recommended to use NPM to install clang-format 11 (different versions of clang-format may produce different code formats, it is recommended to use version 11):
It is recommended to use NPM to install clang-format 14 (different versions of clang-format may produce different code formats, it is recommended to use version 14):
`npm install clang-format@1.4.0`
`npm install clang-format@1.6.0`
Ubuntu: `apt-get install clang-format`
The current version is 10.0, you can also specify the old version, for example: `apt-get install clang-format-9`
The current version is 10.0, you can also specify the old version, for example: `apt-get install clang-format-9`. It is recommended to compile version 14.0 from source code.
Mac: `brew install clang-format`
Centos 7:
The version of clang-format installed by centos yum is too old and supports too few StyleOptions. It is recommended to compile version 10.0 from source code.
The version of clang-format installed by centos yum is too old and supports too few StyleOptions. It is recommended to compile version 14.0 from source code.
LDB toolchain:
If you are using [LDB toolchain](http://doris.incubator.apache.org/install/source-install/compilation-with-ldb-toolchain.html),
the latest version (>= v0.11) of [LDB toolchain](https://github.com/amosbird/ldb_toolchain_gen/releases) has already included clang-format with 13.0.1 version.
### clang-format plugin

View File

@ -40,7 +40,7 @@ Doris使用clang-format进行代码格式化,并在build-support目录下提
Doris的代码风格在Google Style的基础上稍有改动,定制为 `.clang-format` 文件,位于Doris根目录。
目前,`.clang-format` 配置文件适配clang-format-8.0.1以上的版本。
目前,`.clang-format` 配置文件适配clang-format-13.0.1以上的版本。
`.clang-format-ignore` 文件中记录了不希望被格式化的代码。这些代码通常来自第三方代码库,建议保持原有代码风格。
@ -50,19 +50,25 @@ Doris的代码风格在Google Style的基础上稍有改动,定制为 `.clang-
### 下载安装clang-format
推荐使用 NPM 安装 clang-format 11(不同版本的 clang-format 可能产生不同的代码格式,建议使用 11 版本):
推荐使用 NPM 安装 clang-format 14(不同版本的 clang-format 可能产生不同的代码格式,建议使用 14 版本):
`npm install clang-format@1.4.0`
`npm install clang-format@1.6.0`
Ubuntu: `apt-get install clang-format`
当前版本为10.0,也可指定旧版本,例如: `apt-get install clang-format-9`
当前版本为10.0,也可指定旧版本,例如: `apt-get install clang-format-9`,建议源码编译14.0版本。
Mac: `brew install clang-format`
Centos 7:
centos yum安装的clang-format版本过老,支持的StyleOption太少,建议源码编译10.0版本。
centos yum安装的clang-format版本过老,支持的StyleOption太少,建议源码编译14.0版本。
LDB toolchain:
如果使用[LDB toolchain](http://doris.incubator.apache.org/zh-CN/install/source-install/compilation-with-ldb-toolchain.html),
最新版本的[LDB toolchain](https://github.com/amosbird/ldb_toolchain_gen/releases)(>= v0.11)已经包含了预编译的clang-format
13.0.1的二进制文件。
### clang-format插件