You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
79 lines
2.5 KiB
79 lines
2.5 KiB
4 months ago
|
=========
|
||
|
LibFormat
|
||
|
=========
|
||
|
|
||
|
LibFormat is a library that implements automatic source code formatting based
|
||
|
on Clang. This documents describes the LibFormat interface and design as well
|
||
|
as some basic style discussions.
|
||
|
|
||
|
If you just want to use `clang-format` as a tool or integrated into an editor,
|
||
|
checkout :doc:`ClangFormat`.
|
||
|
|
||
|
Design
|
||
|
------
|
||
|
|
||
|
FIXME: Write up design.
|
||
|
|
||
|
|
||
|
Interface
|
||
|
---------
|
||
|
|
||
|
The core routine of LibFormat is ``reformat()``:
|
||
|
|
||
|
.. code-block:: c++
|
||
|
|
||
|
tooling::Replacements reformat(const FormatStyle &Style, Lexer &Lex,
|
||
|
SourceManager &SourceMgr,
|
||
|
std::vector<CharSourceRange> Ranges);
|
||
|
|
||
|
This reads a token stream out of the lexer ``Lex`` and reformats all the code
|
||
|
ranges in ``Ranges``. The ``FormatStyle`` controls basic decisions made during
|
||
|
formatting. A list of options can be found under :ref:`style-options`.
|
||
|
|
||
|
The style options are described in :doc:`ClangFormatStyleOptions`.
|
||
|
|
||
|
|
||
|
.. _style-options:
|
||
|
|
||
|
Style Options
|
||
|
-------------
|
||
|
|
||
|
The style options describe specific formatting options that can be used in
|
||
|
order to make `ClangFormat` comply with different style guides. Currently,
|
||
|
several style guides are hard-coded:
|
||
|
|
||
|
.. code-block:: c++
|
||
|
|
||
|
/// Returns a format style complying with the LLVM coding standards:
|
||
|
/// https://llvm.org/docs/CodingStandards.html.
|
||
|
FormatStyle getLLVMStyle();
|
||
|
|
||
|
/// Returns a format style complying with Google's C++ style guide:
|
||
|
/// http://google-styleguide.googlecode.com/svn/trunk/cppguide.xml.
|
||
|
FormatStyle getGoogleStyle();
|
||
|
|
||
|
/// Returns a format style complying with Chromium's style guide:
|
||
|
/// https://chromium.googlesource.com/chromium/src/+/master/styleguide/styleguide.md
|
||
|
FormatStyle getChromiumStyle();
|
||
|
|
||
|
/// Returns a format style complying with the GNU coding standards:
|
||
|
/// https://www.gnu.org/prep/standards/standards.html
|
||
|
FormatStyle getGNUStyle();
|
||
|
|
||
|
/// Returns a format style complying with Mozilla's style guide
|
||
|
/// https://firefox-source-docs.mozilla.org/code-quality/coding-style/index.html
|
||
|
FormatStyle getMozillaStyle();
|
||
|
|
||
|
/// Returns a format style complying with Webkit's style guide:
|
||
|
/// https://webkit.org/code-style-guidelines/
|
||
|
FormatStyle getWebkitStyle();
|
||
|
|
||
|
/// Returns a format style complying with Microsoft's style guide:
|
||
|
/// https://docs.microsoft.com/en-us/visualstudio/ide/editorconfig-code-style-settings-reference
|
||
|
FormatStyle getMicrosoftStyle();
|
||
|
|
||
|
These options are also exposed in the :doc:`standalone tools <ClangFormat>`
|
||
|
through the `-style` option.
|
||
|
|
||
|
In the future, we plan on making this configurable.
|