2021-01-03 14:25:43 +05:30
---
type: reference, dev
stage: none
group: Development
2022-11-25 23:54:43 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
2021-01-03 14:25:43 +05:30
---
2023-05-27 22:25:52 +05:30
# Development style guides
2018-12-13 13:39:08 +05:30
2020-04-08 14:13:33 +05:30
## Editor/IDE styling standardization
2023-04-23 21:23:45 +05:30
We use [EditorConfig ](https://editorconfig.org/ ) to automatically apply certain styling standards before files are saved
locally. Some editors and IDEs honor the `.editorconfig` settings [automatically by default ](https://editorconfig.org/#pre-installed ).
If your editor or IDE does not automatically support `.editorconfig` , we suggest investigating to
[see if a plugin exists ](https://editorconfig.org/#download ). For example, a
2020-04-08 14:13:33 +05:30
[plugin for vim ](https://github.com/editorconfig/editorconfig-vim ).
2021-03-11 19:13:27 +05:30
## Pre-push static analysis with Lefthook
2020-03-13 15:44:24 +05:30
2023-04-23 21:23:45 +05:30
[Lefthook ](https://github.com/evilmartians/lefthook ) is a Git hooks manager that allows
2021-03-11 19:13:27 +05:30
custom logic to be executed prior to Git committing or pushing. GitLab comes with
Lefthook configuration (`lefthook.yml`), but it must be installed.
2020-03-13 15:44:24 +05:30
2021-03-11 19:13:27 +05:30
We have a `lefthook.yml` checked in but it is ignored until Lefthook is installed.
2020-03-13 15:44:24 +05:30
2021-03-11 19:13:27 +05:30
### Uninstall Overcommit
We were using Overcommit prior to Lefthook, so you may want to uninstall it first with `overcommit --uninstall` .
### Install Lefthook
2023-05-27 22:25:52 +05:30
1. You can install lefthook in [different ways ](https://github.com/evilmartians/lefthook/blob/master/docs/install.md#install-lefthook ).
If you do not choose to install it globally (e.g. via Homebrew or package managers), and only want to use it for the GitLab project,
you can install the Ruby gem via:
2021-03-11 19:13:27 +05:30
```shell
bundle install
```
1. Install Lefthook managed Git hooks:
```shell
2023-05-27 22:25:52 +05:30
# If installed globally
lefthook install
# Or if installed via ruby gem
2021-03-11 19:13:27 +05:30
bundle exec lefthook install
```
2022-11-25 23:54:43 +05:30
1. Test Lefthook is working by running the Lefthook `pre-push` Git hook:
2021-03-11 19:13:27 +05:30
```shell
2023-05-27 22:25:52 +05:30
# If installed globally
lefthook run pre-push
# Or if installed via ruby gem
2022-11-25 23:54:43 +05:30
bundle exec lefthook run pre-push
2021-03-11 19:13:27 +05:30
```
2023-03-04 22:38:38 +05:30
This should return the Lefthook version and the list of executable commands with output.
2021-03-11 19:13:27 +05:30
### Lefthook configuration
2021-01-29 00:20:46 +05:30
2022-04-04 11:22:00 +05:30
Lefthook is configured with a combination of:
2021-01-29 00:20:46 +05:30
2022-04-04 11:22:00 +05:30
- Project configuration in [`lefthook.yml` ](https://gitlab.com/gitlab-org/gitlab/-/blob/master/lefthook.yml ).
2023-04-23 21:23:45 +05:30
- Any [local configuration ](https://github.com/evilmartians/lefthook/blob/master/README.md#local-config ).
2021-01-29 00:20:46 +05:30
2023-05-27 22:25:52 +05:30
### Lefthook auto-fixing files
We have a custom lefthook target to run all the linters with auto-fix capabilities,
but just on the files which changed in your branch.
```shell
# If installed globally
lefthook run auto-fix
# Or if installed via ruby gem
bundle exec lefthook run auto-fix
```
2021-03-11 19:13:27 +05:30
### Disable Lefthook temporarily
2021-01-29 00:20:46 +05:30
2021-03-11 19:13:27 +05:30
To disable Lefthook temporarily, you can set the `LEFTHOOK` environment variable to `0` . For instance:
2021-02-22 17:27:13 +05:30
2021-03-11 19:13:27 +05:30
```shell
LEFTHOOK=0 git push ...
2020-03-13 15:44:24 +05:30
```
2021-03-11 19:13:27 +05:30
### Run Lefthook hooks manually
To run the `pre-push` Git hook, run:
```shell
bundle exec lefthook run pre-push
```
2021-01-29 00:20:46 +05:30
2023-04-23 21:23:45 +05:30
For more information, check out [Lefthook documentation ](https://github.com/evilmartians/lefthook/blob/master/README.md#direct-control ).
2020-03-13 15:44:24 +05:30
2021-03-11 19:13:27 +05:30
### Skip Lefthook checks per tag
2020-03-13 15:44:24 +05:30
2021-03-11 19:13:27 +05:30
To skip some checks based on tags when pushing, you can set the `LEFTHOOK_EXCLUDE` environment variable. For instance:
```shell
LEFTHOOK_EXCLUDE=frontend,documentation git push ...
```
2021-09-30 23:02:18 +05:30
As an alternative, you can create `lefthook-local.yml` with this structure:
```yaml
pre-push:
exclude_tags:
- frontend
- documentation
```
2023-04-23 21:23:45 +05:30
For more information, check out [Lefthook documentation ](https://github.com/evilmartians/lefthook/blob/master/docs/configuration.md#exclude_tags ).
2020-03-13 15:44:24 +05:30
2021-09-30 23:02:18 +05:30
### Skip or enable a specific Lefthook check
To skip or enable a check based on its name when pushing, you can add `skip: true`
or `skip: false` to the `lefthook-local.yml` section for that hook. For instance,
you might want to enable the gettext check to detect issues with `locale/gitlab.pot` :
```yaml
pre-push:
commands:
gettext:
skip: false
```
2023-04-23 21:23:45 +05:30
For more information, check out [Lefthook documentation Skipping commands section ](https://github.com/evilmartians/lefthook/blob/master/docs/configuration.md#skip ).
2021-09-30 23:02:18 +05:30
2020-03-13 15:44:24 +05:30
## Database migrations
See the dedicated [Database Migrations Style Guide ](../migration_style_guide.md ).
## JavaScript
See the dedicated [JS Style Guide ](../fe_guide/style/javascript.md ).
## SCSS
See the dedicated [SCSS Style Guide ](../fe_guide/style/scss.md ).
2023-01-13 00:05:48 +05:30
## Ruby
See the dedicated [Ruby Style Guide ](../backend/ruby_style_guide.md ).
2020-03-13 15:44:24 +05:30
## Go
See the dedicated [Go standards and style guidelines ](../go_guide/index.md ).
## Shell commands (Ruby)
See the dedicated [Guidelines for shell commands in the GitLab codebase ](../shell_commands.md ).
## Shell scripting
See the dedicated [Shell scripting standards and style guidelines ](../shell_scripting_guide/index.md ).
## Markdown
2021-03-11 19:13:27 +05:30
<!-- vale gitlab.Spelling = NO -->
2020-07-28 23:09:34 +05:30
We're following [Ciro Santilli's Markdown Style Guide ](https://cirosantilli.com/markdown-style-guide/ ).
2020-03-13 15:44:24 +05:30
2021-03-11 19:13:27 +05:30
<!-- vale gitlab.Spelling = YES -->
2020-03-13 15:44:24 +05:30
## Documentation
2021-01-29 00:20:46 +05:30
See the dedicated [Documentation Style Guide ](../documentation/styleguide/index.md ).
2020-03-13 15:44:24 +05:30
2022-10-11 01:57:18 +05:30
### Guidelines for good practices
*Good practice* examples demonstrate encouraged ways of writing code while
comparing with examples of practices to avoid. These examples are labeled as
*Bad* or *Good* . In GitLab development guidelines, when presenting the cases,
it's recommended to follow a *first-bad-then-good* strategy. First demonstrate
the *Bad* practice (how things *could* be done, which is often still working
code), and then how things *should* be done better, using a *Good* example. This
is typically an improved example of the same code.
Consider the following guidelines when offering examples:
- First, offer the *Bad* example, and then the *Good* one.
- When only one bad case and one good case is given, use the same code block.
- When more than one bad case or one good case is offered, use separated code
blocks for each. With many examples being presented, a clear separation helps
the reader to go directly to the good part. Consider offering an explanation
(for example, a comment, or a link to a resource) on why something is bad
practice.
- Better and best cases can be considered part of the good cases' code block.
In the same code block, precede each with comments: `# Better` and `# Best` .
Although the bad-then-good approach is acceptable for the GitLab development
guidelines, do not use it for user documentation. For user documentation, use
*Do* and *Don't* . For examples, see the [Pajamas Design System ](https://design.gitlab.com/content/punctuation/ ).
2020-03-13 15:44:24 +05:30
## Python
See the dedicated [Python Development Guidelines ](../python_guide/index.md ).
## Misc
Code should be written in [US English ](https://en.wikipedia.org/wiki/American_English ).