clang-format

Clang-Format

Clang-Format Style Options — Clang 18.0.0git documentation

VSCode

1.1 安装扩展 C++

1.2 设置

1.3 使用 .clang-fornat 

  • 放置在项目(代码)文件夹下
  • 使用 .clang-fornat 为文件名

---

# https://clang.llvm.org/docs/ClangFormatStyleOptions.html

BasedOnStyle: LLVM

Language: Cpp

# this style configuration is based on google style configuration.

# The following configuration is different from the basic configuration.

# 缩进宽度

IndentWidth: 4

# 访问权限说明符(public/private等)的偏移

AccessModifierOffset: -4

# 开括号(开圆括号、尖括号、方括号)后的对齐: Align, DontAlign, AlwaysBreak(总是在开括号后换行)

AlignAfterOpenBracket: AlwaysBreak

# 连续赋值时,对齐所有等号

AlignConsecutiveAssignments: true

# 连续声明时,对齐所有声明的变量名

AlignConsecutiveDeclarations: true

# 反斜杆换行的对齐方式

# -- DontAlign - 不进行对齐

# -- Left - 反斜杠靠左对齐

# -- Right - 反斜杠靠右对齐

AlignEscapedNewlines: Right

# 二元、三元表达式的对齐方式(当表达式需要占用多行时)

# -- DontAlign - 不进行对齐

# -- Align - 从操作符开始对齐

# -- AlignAfterOperator - 从操作数开始对齐

AlignOperands: true

# 是否对齐行尾注释

AlignTrailingComments: true

# # 函数声明的所有参数在放在下一行

# AllowAllParametersOfDeclarationOnNextLine: false

# # 是否允许短的代码块放在同一行

# AllowShortBlocksOnASingleLine: false

# # 短的case标签和语句放在同一行

# AllowShortCaseLabelsOnASingleLine: true

# # 短的函数放在同一行

# -- None - 不把短的函数放在同一行

# -- InlineOnly - 只把类内的内联函数放在同一行,全局的空函数不放在同一行

# -- Empty - 只把空的函数放在同一行

# -- Inline - 把类内的内联函数放在同一行,全局的空函数不放在同一行

# -- All - 都允许放在同一行

AllowShortFunctionsOnASingleLine: InlineOnly

# 短的if语句保持在同一行

AllowShortIfStatementsOnASingleLine: false

# # 短的循环保持在同一行

# AllowShortLoopsOnASingleLine: true

# 总是在返回类型后换行: None, All, TopLevel(顶级函数,不包括在类中的函数),

# AllDefinitions(所有的定义,不包括声明), TopLevelDefinitions(所有的顶级函数的定义)

AlwaysBreakAfterReturnType: None

# # 总是在多行string字面量前换行

# AlwaysBreakBeforeMultilineStrings: true

# # 总是在template声明后换行

AlwaysBreakTemplateDeclarations: true

# # 函数调用时,参数的放置规则

# -- false - 参数要么放在同一行,要么每个参数占用一行

# -- true - 不做强制要求

BinPackArguments: true

# 函数声明、定义时,参数的放置规则

# -- false - 参数要么放在同一行,要么每个参数占用一行

# -- true - 不做强制要求

BinPackParameters: false

# 大括号放置风格

# -- Attach - 大括号紧随前方内容,放在同一行

# -- Linux - 与 Attach 类似,除了 函数、命名空间、类定义 的大括号放在下一行

# -- Mozilla - 与 Attach 类似,除了枚举、函数、结构(class\struct\union)的大括号放在下一行

# -- Stroustrup - 与 Attach 类似,但函数定义前、catch前方、else前方的"{}"放在单独一行

# -- Allman - 总是换行

# -- Whitesmiths - 类似 Allman,但"{}"和内部的语句对齐到同样位置

# -- GNU - 总是换行,但在控制语句后的"{}"总是对齐到下一个位置

# -- WebKit - 与 Attach 类似,但在函数定义前换行

# -- Custom - 依赖 BraceWrapping

#   注:这里认为语句块也属于函数

BreakBeforeBraces: Custom

# 大括号换行,只有当BreakBeforeBraces设置为Custom时才有效

BraceWrapping:

  # class定义后面

  AfterClass: true

  # 控制语句后面

  AfterControlStatement: false

  # enum定义后面

  AfterEnum: true

  # 函数定义后面

  AfterFunction: true

  # 命名空间定义后面

  AfterNamespace: true

  # ObjC定义后面

  AfterObjCDeclaration: false

  # struct定义后面

  AfterStruct: false

  # union定义后面

  AfterUnion: true

  # extern之后

  AfterExternBlock: true

  # catch之前

  BeforeCatch: true

  # else之前

  BeforeElse: true

  # 继续缩进大括号

  IndentBraces: false

  # 分离空函数

  # # 当空白函数的"{}"和函数名称不需要放在同一行时,是否拆分函数体

  SplitEmptyFunction: true

  # 分离空语句

  # # 当空白结构(class\struct\union)的"{}"需要放在单独的行时,是否拆分"{}"

  SplitEmptyRecord: true

  # 分离空命名空间

  # # 当空白的命名空间的"{}"需要放在单独的行时,是否拆分"{}"

  SplitEmptyNamespace: true

# # 在二元运算符前换行: None(在操作符后换行), NonAssignment(在非赋值的操作符前换行), All(在操作符前换行)

BreakBeforeBinaryOperators: NonAssignment

# BreakBeforeInheritanceComma: false

# # 在三元运算符前换行

# 当三元表达式不能放在同一行时,是否在三元操作符前方换行

# -- true - 操作符位于新行的首部

# -- false - 操作符位于上一行的尾部

BreakBeforeTernaryOperators: true

# BreakConstructorInitializersBeforeComma: false

# # 构造函数初始化列表分割方式

# -- BeforeColon - 在冒号 ':' 前方分割,冒号位于行首,逗号','位于行尾

# -- BeforeComma - 在冒号和逗号前方分割,冒号和逗号都位于行首,并且对齐

# -- AfterColon - 在冒号和逗号后方分割,冒号和逗号位于行尾

BreakConstructorInitializers: BeforeColon

# # 是否在每个java注解后方换行

BreakAfterJavaFieldAnnotations: true

# # 是否分割过长的字符串

# BreakStringLiterals: false

# # 每行字符长度的限制,0表示没有限制

ColumnLimit: 100

# # 用于匹配注释信息的正则表达式,被匹配的行不会做任何修改

# CommentPragmas:  '^ IWYU pragma:'

# 是否压缩紧接的命名空间

# -- true - 将紧跟的命名空间放在同一行

# -- false - 每个命名空间位于新的一行

CompactNamespaces: false

# # 构造函数的初始化列表要么都在同一行,要么都各自一行

# -- true - 如果可能,初始化列表放在同一行;如果不满足长度选择,则每个单独放一行

# -- false - 初始化列表可以随意放置

# ConstructorInitializerAllOnOneLineOrOnePerLine: false

# # 构造函数的初始化列表和基类集成列表的对齐宽度

ConstructorInitializerIndentWidth: 4

# # 延续语句的对齐宽度

ContinuationIndentWidth: 4

# # 去除C++11的列表初始化的大括号{后和}前的空格

Cpp11BracedListStyle: true

# 是否自动分析指针的对齐方式

# -- true - 自动分析并使用指针的对齐方式,若无法分析,则使用 PointerAlignment

# -- false - 不自动分析

DerivePointerAlignment: true

# 是否禁用格式化

DisableFormat: false

# ExperimentalAutoDetectBinPacking: false

# 是否自动修正命名空间的结束注释

# -- true - 在短的命名空间尾部,自动添加或修改错误的命名空间结束注释

# -- false - 不自动修正

FixNamespaceComments: true

# foreach 循环

ForEachMacros:

  - foreach

  - Q_FOREACH

  - BOOST_FOREACH

# 多个 include 块(有空行分隔的include)排序时的分组规则

# -- Preserve - 保留原有的块分隔,各自排序

# -- Merge - 将所有的块视为同一个,然后进行排序

# -- Regroup - 将所有的块视为同一个进行排序,然后按照 IncludeCategories 的规则进行分组

IncludeBlocks: Preserve

# IfMacros:

#   - KJ_IF_MAYBE

# IncludeBlocks:   Regroup

# IncludeCategories:

#   - Regex:           '^<ext/.*\.h>'

#     Priority:        2

#     SortPriority:    0

#     CaseSensitive:   false

#   - Regex:           '^<.*\.h>'

#     Priority:        1

#     SortPriority:    0

#     CaseSensitive:   false

#   - Regex:           '^<.*'

#     Priority:        2

#     SortPriority:    0

#     CaseSensitive:   false

#   - Regex:           '.*'

#     Priority:        3

#     SortPriority:    0

#     CaseSensitive:   false

# IncludeIsMainRegex: '([-_](test|unittest))?$'

# # 缩进case标签

# -- true - case 不与 switch 对齐

# -- false - case 和 switch 对齐

IndentCaseLabels: true

# 预处理命令(#if\#ifdef\#endif等)的缩进规则

# -- None - 不进行缩进

# -- AfterHash - 在前导'#'后缩进,'#'放在最左侧,之后的语句参与缩进

# -- BeforeHash - 在前导'#'前进行缩进

IndentPPDirectives: AfterHash

# # 函数返回类型换行时,缩进函数声明或函数定义的函数名

# IndentWrappedFunctionNames: false

# JavaScript 中的字符串引号规则

# -- Leave - 保持原样

# -- Single - 全部使用单引号

# -- Double - 全部使用双引号

JavaScriptQuotes: Leave

# 是否在 JavaScript 的 import/export 语句后换行

# JavaScriptWrapImports: true

# 保留在块开始处的空行

# -- true - 保留块起始的空行

# -- false - 删除块起始的空行

KeepEmptyLinesAtTheStartOfBlocks: true

# 用于识别宏定义型块起始的正则表达式

# MacroBlockBegin: ''

# 用于识别宏定义型块结束的正则表达式

# MacroBlockEnd:   ''

# 连续空行的最大数量

MaxEmptyLinesToKeep: 2

# 命名空间内部的缩进规则

# -- None - 都不缩进

# -- Inner - 只缩进嵌套的命名空间内容

# -- All - 缩进所有命名空间内容

NamespaceIndentation: Inner

# Objective-C 相关配置

# ObjCBlockIndentWidth: 2

# ObjCSpaceAfterProperty: false

# ObjCSpaceBeforeProtocolList: false

# PenaltyBreakAssignment: 2

# PenaltyBreakBeforeFirstCallParameter: 1

# PenaltyBreakComment: 300

# PenaltyBreakFirstLessLess: 120

# PenaltyBreakString: 1000

# PenaltyExcessCharacter: 1000000

# PenaltyReturnTypeOnItsOwnLine: 200

# 指针和引用(*和&)的对齐规则

# -- Left - * 靠近左侧

# -- Right - * 靠近右侧

# -- Middle - * 放在中间

# NOTE : 在 SpaceAroundPointerQualifiers 为 Default,

#      且 DerivePointerAlignment 失效后启用

PointerAlignment: Middle

# RawStringFormats:

#   - Delimiter:       pb

#     Language:        TextProto

#     BasedOnStyle:    google

# 重新排版注释

ReflowComments: false

# 重新排序#include

# -- Never - 不进行排序

# -- CaseSensitive - 排序时大小写敏感

# -- CaseInsensitive - 排序时大小写不敏感

SortIncludes: false

# java 中静态 import 的排序规则

# -- Before - 静态放在非静态前方

# -- After - 静态放在非静态后方

# SortJavaStaticImport: Before

# 重新排序using声明

SortUsingDeclarations: false

# 在C风格类型转换后添加空格

SpaceAfterCStyleCast: false

# 在Template关键字后面添加空格

SpaceAfterTemplateKeyword: true

# 在赋值运算符之前添加空格

SpaceBeforeAssignmentOperators: true

# 在 C++11 的初始化列表前加空格

# SpaceBeforeCpp11BracedList: true

# 在构造函数的初始化冒号":"前加空格

# SpaceBeforeCtorInitializerColon: true

# 在构造函数的继承冒号":"前加空格

# SpaceBeforeInheritanceColon: true

# 小括号"()"前加空格的规则

# -- Never - 从不加空格

# -- ControlStatements - 只在控制语句(for/if/while...)时加空格

# -- ControlStatementsExceptForEachMacros - 类型 ControlStatements,只是不再 ForEach 后加空格

# -- Always - 总是添加空格

# -- NonEmptyParentheses - 类似 Always,只是不再空白括号前加空格

SpaceBeforeParens: ControlStatements

# 在 for 循环的冒号":"前加空格

# SpaceBeforeRangeBasedForLoopColon: true

# 在空白的小括号"()"中添加空格

SpaceInEmptyParentheses: false

# 在行尾的注释前添加的空格数(只适用于//)

SpacesBeforeTrailingComments: 1

# 在尖括号的"<"后,和">"前添加空格

SpacesInAngles: false

# 在容器(ObjC和JavaScript的数组和字典等)字面量中添加空格

SpacesInContainerLiterals: true

# 在C风格类型转换的括号中添加空格

SpacesInCStyleCastParentheses: false

# 在圆括号的"("后,和")"前添加空格

SpacesInParentheses: false

# 在中括号中加空格

# 当中括号内没有数据时,不受本规则影响(如空白的lambda 捕获表、不定长度的数组声明)

SpacesInSquareBrackets: false

# 语言标准: Cpp03, Cpp11, Auto

Standard: Cpp11

# tab宽度

TabWidth: 4

# 使用tab字符: Never, ForIndentation, ForContinuationAndIndentation, Always

UseTab: Never

---

VS

2.1 安装扩展 ClangFormat

2.2 使用 .clang-fornat 

同 vscode

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/317087.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java仓库管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 java Web仓库管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.0&…

STC进阶开发(三)蜂鸣器、RTC时钟、I2C总线、外部中断、RTC闹钟设置、RTC计时器设置

前言 这一期我们首先学习如何让蜂鸣器响起来&#xff0c;并且如何让蜂鸣器发出简单的歌曲&#xff0c;然后我们介绍RTC时钟&#xff0c;要想明白RTC时钟&#xff0c;我们还需要先介绍I2C总线和外部中断。接下来就开始这一期的学习吧&#xff01; 蜂鸣器 简单介绍 蜂鸣器是一种…

AntDB设计之CheckPoint——引言与功能简述

1.引言 数据库服务能力提升是一项系统性的工程&#xff0c;在不同的应用场景下&#xff0c;用户对于数据库各项能力的关注点也不同&#xff0c;如&#xff1a;读写延迟、吞吐量、扩展性、可靠性、可用性等等。国内不少数据库系统通过系统架构优化、硬件设备升级等方式&#xf…

echarts实现控制图(设置阈值上下限超出变色)

echarts实现控制图组件&#xff0c;拓展超出阈值变色显示&#xff0c;图中标记平均值及最大值和最小值 代码如下&#xff1a; <template><div :class"className" :style"{height:height,width:width}" /> </template><script>im…

2024.1.2 Redis 数据类型 Stream、Geospatial、HyperLogLog、Bitmaps、Bitfields 简介

目录 引言 Stream 类型 Geospatial 类型 HyperLogLog 类型 Bitmaps 类型 Bitfields 类型 引言 Redis 最关键&#xff08;应用广泛、频繁使用&#xff09;的五个数据类型 StringListHashSetZSet 下文介绍的数据类型一般适合在特定的场景中使用&#xff01; Stream 类型 St…

JumpServer3.0版本(用户管理、邮件、MFA认证配置)

创建用户组 控制台页面可以看见左侧的用户管理下,有用户列表和用户组 点击用户组、点击创建按钮、设置名称,用户不用选择还没建用户,提交即可 创建用户 点击用户列表创建按钮,设置名称、用户名、邮箱等必填项 这个时候用户组选项,可以选好我们创建的用户组了,先创用…

【性能测试】性能压测TPS上不去原因分析,13年老鸟总结...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、性能测试TPS上…

每日一题 2487. 从链表中移除节点(中等,回溯)

显然只要从后往前遍历链表&#xff0c;设 t 为当前的最大值&#xff0c;只要在遍历过程中比 t 小的节点都删除&#xff0c;大于等于 t 的则更新 t 为新的节点 通过递归回溯的方法可以很简单地实现从后往前遍历链表 # Definition for singly-linked list. # class ListNode: # …

fs-extra 文件操作的常用API

fs-extra 是一个比 node 内置 fs 模块更安全、更强大的文件操作库&#xff0c;支持 promise 和 async/await&#xff0c;为使用者免去了很多心理负担。 一、安装使用 安装&#xff1a; pnpm add fs-extra文件复制代码演示&#xff1a; const {copy,copySync } require(fs-e…

揭示AUTOSAR中隐藏的漏洞

AUTOSAR是一个普遍采用的软件框架&#xff0c;用于各种汽车零部件&#xff0c;如ABS, ECU,自动照明、环境控制、充电控制器、信息娱乐系统等。AUTOSAR的创建目的是促进汽车零部件之间形成标准接口&#xff0c;可以在不同制造商之间互通。 因此&#xff0c;任何配备微控制器(MC…

陈述式资源管理(2)

命令行。声明式资源管理 三种常见的项目发布方式&#xff1a; 1、蓝绿发布 2、金丝雀发布&#xff08;灰度发布&#xff09; 3、滚动发布 应用程序升级&#xff0c;最大困难就是新旧业务之间的切换。立项 --- 定稿 --- 需求发布 --- 开发 --- 测试 --- 发布。测试之后上线…

深度生成模型之GAN基础 ->(个人学习记录笔记)

文章目录 深度生成模型之GAN基础生成对抗网络1. 生成对抗网络如何生成数据2. 生成对抗原理3. GAN的核心优化目标4. D的优化5. GAN的理想状态6. GAN的训练7. 梯度不稳定与模式崩塌(collapse mode)问题8. 梯度消失问题 深度生成模型之GAN基础 生成对抗网络 1. 生成对抗网络如何…