blob: eee3518d0e77cd574d2dc86ea33c4875c8682605 [file] [log] [blame] [view] [edit]
# PerfettoSQL Style Guide
_This page provides a suggested style guide for writing PerfettoSQL and is in
use inside the PerfettoSQL standard library in the trace processor. It also
provides guidance on the autoformatter._
## Rules
1. Keep lines below 80 characters long
2. Function names, macro names and table/view names should all be lower snake
case.
3. SQL keywords should all be upper case
4. When line-breaking SQL expressions, place the joining keyword (AND/OR) at the
_start of the next line_ rather than the _end of the previous line_.
## Autoformatter
PerfettoSQL comes with an auto-formatter as implemented by `tools/format_sql.py`
Python script. This is a simple script which can be run over any set of files or
directories and automatically formats the code to adhere to the above rules.
This script is _required_ to be run when making contributions to the standard
library. It's automatically executed as part of running `tools/gen_all` which is
part of the standard development workflow in Perfetto. Presubmit will check to
make sure you've done this.
The autoformatter is not perfect by any means and does often have subtle edge
cases:
1. It doesn't handle comments in the middle of complex expressions. Prefer
placing comments at the start of these expressions instead of in the middle.
2. It doesn't format macro invocations as they have very complex semantics
in many cases.