Skip to content

Commit

Permalink
meta: Add clang-format
Browse files Browse the repository at this point in the history
  • Loading branch information
64 committed Oct 25, 2024
1 parent 5f6579a commit 464b78e
Show file tree
Hide file tree
Showing 4 changed files with 254 additions and 0 deletions.
222 changes: 222 additions & 0 deletions .clang-format
Original file line number Diff line number Diff line change
@@ -0,0 +1,222 @@
---
# commented out settings are not available in current host-llvm-toolchain but
# could still prove useful
Language: Cpp

# I don't see any stable default for this, lets just hope LLVM is sane enough
BasedOnStyle: LLVM

# private: should line up with struct
AccessModifierOffset: -8

# alignment is mostly problematic since it requires modifying multiple lines on
# a change to keep things aligned...
AlignArrayOfStructures: None
AlignConsecutiveAssignments: false
AlignConsecutiveBitFields: false
AlignConsecutiveMacros: false
AlignConsecutiveDeclarations: false
AlignTrailingComments: false

AlignAfterOpenBracket: DontAlign
# ... and right-align backslashes on the ends of macro lines, to preserve the
# validity of the macro while still keeping a constant column reserved for
# backslashes.
AlignEscapedNewlines: Right
# aligning operations also looks decent, in a single statement
AlignOperands: AlignAfterOperator

# prevent squashing args onto one line
AllowAllArgumentsOnNextLine: false
# prevent squashing arguments in declarations onto one line
AllowAllParametersOfDeclarationOnNextLine: false
# don't merge multiple statements into one line
AllowShortBlocksOnASingleLine: Never
AllowShortCaseLabelsOnASingleLine: false
AllowShortEnumsOnASingleLine: false
AllowShortIfStatementsOnASingleLine: Never
AllowShortLoopsOnASingleLine: false
# ... unless they're empty or class members, or small lambdas as args
AllowShortFunctionsOnASingleLine: Empty
AllowShortLambdasOnASingleLine: Inline

AlwaysBreakAfterReturnType: None
AlwaysBreakBeforeMultilineStrings: true
AlwaysBreakTemplateDeclarations: Yes

# no need to squash arguments
BinPackArguments: false
BinPackParameters: false

# we currently use ``type name : width;''
BitFieldColonSpacing: Both

BreakBeforeInlineASMColon: OnlyMultiline
# start lines with operators, but don't break before the assignments
BreakBeforeBinaryOperators: NonAssignment
# we never break before braces
BreakBeforeBraces: Attach
# in general, prefer to start lines with commas, question marks, etc.
# especially for commas (in initializer lists for instance), doing it like this
# means adding and removing new entries doesn't impact unrelated entries
BreakBeforeConceptDeclarations: true
BreakBeforeTernaryOperators: true
BreakConstructorInitializers: AfterColon
BreakInheritanceList: BeforeComma

# text being greppable is nice in languages that lack stack traces
BreakStringLiterals: false

# it's observable and well-known that long lines are hard to read; due to the
# C++ "nesting nature" being more aggressive than C, and us using 8column tabs
# for measurement, 100 should be a safe bet
ColumnLimit: 120
# namespace A { namespace B { ... would be silly to do in new c++ versions
CompactNamespaces: false

# same level as class name
ConstructorInitializerIndentWidth: 8
# one tab
ContinuationIndentWidth: 8
# we treat braced lists like function calls, rather than blocks
Cpp11BracedListStyle: true

# no need to guess, be consistent instead
DeriveLineEnding: false
UseCRLF: False
DerivePointerAlignment: false

# no need for extra lines after private:
EmptyLineAfterAccessModifier: Never

# allow grouping empty modifier blocks
EmptyLineBeforeAccessModifier: LogicalBlock
# consistent rather than guessed
ExperimentalAutoDetectBinPacking: False

# ``namespace A {} // namespace A'' comments
FixNamespaceComments: true

IncludeBlocks: Regroup
IncludeCategories:
- Regex: '".*.hpp"'
Priority: 0
- Regex: '<(arch|async|bragi|core|frg|helix|protocols)/.*>'
Priority: 1
- Regex: '<.*\.(h|hpp)>'
Priority: 2
- Regex: '.*'
Priority: 3
IncludeIsMainRegex: $

# same indent as struct/class
# (not sure what the relation with AccessModifierOffset is)
IndentAccessModifiers: false

# switch(x) {
# case 1: {
# f();
# } break;
# }
IndentCaseBlocks: false
IndentCaseLabels: false

# same as namespaces
IndentExternBlock: NoIndent

# glue to start of lines
IndentGotoLabels: false

# add visual indentation to preprocessor blocks
IndentPPDirectives: AfterHash
IndentRequiresClause: false

# indent by a tab character, and also use tabs for ContinuationIndentWidth
UseTab: ForContinuationAndIndentation
IndentWidth: 8

# if there's a need to break a function declaration after a type, don't indent
# the function name
IndentWrappedFunctionNames: false

# InsertBraces: true

InsertNewlineAtEOF: true

# not sure whether this is ever useful
KeepEmptyLinesAtTheStartOfBlocks: false

# indent bodies relative to the outer scope
LambdaBodyIndentation: OuterScope

# at most one empty line at a time
MaxEmptyLinesToKeep: 1

# no indentation, no matter the level
# XXX: should we do inner only? since, for nested namespaces, we can already
# use A::B::C syntax, that could help distinguish anonymous namespaces inside
# other namespaces?
NamespaceIndentation: None

# if initializers can't fit, break them into the next line and give each a line
PackConstructorInitializers: NextLine

# ``T *tptr; T &tref;'', always
PointerAlignment: Right
ReferenceAlignment: Pointer

# we put qualifiers on the west, the order is
# impacts-linking-and-optimization, impacts-optimization, type
QualifierAlignment: Custom
QualifierOrder: [constexpr, inline, static, const, volatile, restrict, type]

# allow long comments to be reflowed
ReflowComments: true

# keep braces around
RemoveBracesLLVM: false

# RequiresClausePosition: OwnLine

# give definitions blocks
SeparateDefinitionBlocks: Always

# always add namespace comments
ShortNamespaceLines: 0

# sort headers without case sensitivity
SortIncludes: CaseInsensitive

# sort using declarations
SortUsingDeclarations: true

# self explanatory
SpaceAfterCStyleCast: true
SpaceAfterLogicalNot: false
SpaceAfterTemplateKeyword: false
SpaceAroundPointerQualifiers: Default
SpaceBeforeAssignmentOperators: true
SpaceBeforeCaseColon: false
SpaceBeforeCpp11BracedList: true
SpaceBeforeCtorInitializerColon: true
SpaceBeforeInheritanceColon: true
SpaceBeforeParens: Never
SpaceBeforeRangeBasedForLoopColon: true
SpaceBeforeSquareBrackets: false
SpaceInEmptyBlock: false
SpaceInEmptyParentheses: false
SpacesBeforeTrailingComments: 2
SpacesInAngles: false
SpacesInCStyleCastParentheses: false
SpacesInConditionalStatement: false
SpacesInLineCommentPrefix:
Minimum: 1
Maximum: -1
SpacesInParentheses: false
SpacesInSquareBrackets: false
Standard: Latest

# count tabs as eight columns
# (this does not affect editors in any way)
TabWidth: 8
...
14 changes: 14 additions & 0 deletions .github/workflows/formatting.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
name: pre-commit

on: [push, merge_group, pull_request]

jobs:
pre-commit:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v3
- name: Install clang-format
run: |
pip install clang-format
- uses: pre-commit/[email protected]
14 changes: 14 additions & 0 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
fail_fast: false
repos:
- repo: https://github.com/pocc/pre-commit-hooks
rev: 336fdd7c3cab698ead0b1c95157b9e74d3906b62
hooks:
- id: clang-format
additional_dependencies: [clang-format]
args: ["-i"]
exclude: >
(?x)^(
options/ansi/musl-generic-math/.*|
options/ansi/generic/complex/.*|
options/posix/musl-generic-regex/.*
)
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,10 @@ The type of library to be built (static, shared, or both) is controlled by meson

We also support building with `-Db_sanitize=undefined` to use UBSan inside mlibc. Note that this does not enable UBSan for external applications which link against `libc.so`, but it can be useful during development to detect internal bugs (e.g when adding new sysdeps).

## Running pre-commit hooks

To format your code before submitting a PR, you should install [`pre-commit`](https://pre-commit.com/). Then do `pre-commit install` to install the git hook which runs each time you commit. Alternatively, you can do `pre-commit run -a` to manually format all files.

## Running Tests

The `mlibc` test suite can be run under a Linux host. To do this, first install a set of kernel headers (as described [here](https://docs.kernel.org/kbuild/headers_install.html)), then run from the project root:
Expand Down

0 comments on commit 464b78e

Please sign in to comment.