Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/s2gatev/lingo
Define and enforce project-specific Go lingo
https://github.com/s2gatev/lingo
analysis go linter
Last synced: 3 months ago
JSON representation
Define and enforce project-specific Go lingo
- Host: GitHub
- URL: https://github.com/s2gatev/lingo
- Owner: sgatev
- License: mit
- Created: 2017-10-21T18:01:43.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2018-08-15T06:47:53.000Z (over 6 years ago)
- Last Synced: 2024-05-22T20:34:58.609Z (8 months ago)
- Topics: analysis, go, linter
- Language: Go
- Size: 999 KB
- Stars: 9
- Watchers: 3
- Forks: 0
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# lingo
[![Build Status](https://travis-ci.org/s2gatev/lingo.svg?branch=master)](https://travis-ci.org/s2gatev/lingo)
[![Build status](https://ci.appveyor.com/api/projects/status/r56oupucuay39tu8?svg=true)](https://ci.appveyor.com/project/s2gatev/lingo)
[![Coverage Status](https://coveralls.io/repos/github/s2gatev/lingo/badge.svg?branch=master)](https://coveralls.io/github/s2gatev/lingo?branch=master)
[![Go Report Card](https://goreportcard.com/badge/github.com/s2gatev/lingo)](https://goreportcard.com/report/github.com/s2gatev/lingo)Lingo helps you define and enforce project-specific Go lingo.
## Description
Lingo is a tool for fully-automated static code analysis of Go code. It is designed
to be integrated in continuous delivery pipelines and act as a single source of truth
for a project's code style.## Installation
To install the latest version of lingo execute:
```sh
go get -u github.com/s2gatev/lingo
```## Configuration
The static analysis checks performed by lingo are defined in a configuration file
that needs to be provided upon execution. The following example defines five
static analysis checks that are executed against all `.go` files except those
under `vendor/` and those with names ending in `_test`:```yaml
matchers:
-
type: 'glob'
config:
pattern: '**/*.go'
-
type: 'not'
config:
type: 'glob'
config:
pattern: '**/vendor/**/*'
-
type: 'not'
config:
type: 'glob'
config:
pattern: '**/*_test.go'checkers:
local_return:
multi_word_ident_name:
exported_ident_doc:
test_package:
consistent_receiver_names:
```[Here](doc/checkers.md) is a list of the available checkers.
## Check
To check all files rooted at the current directory for lingo violations execute:
```sh
lingo check ./...
```## Guide
To read a guide with all the lingo rules applicable for the project execute:
```sh
lingo guide
```## Contributing
1. Fork the project
2. Clone your fork (`git clone https://github.com/username/lingo && cd lingo`)
3. Create a feature branch (`git checkout -b new-feature`)
4. Make changes and add them (`git add .`)
5. Make sure tests are passing and coverage is good (`go test ./... -race -cover`)
6. Make sure code style is matching the lingo of the project (`lingo ./...`)
7. Commit your changes (`git commit -m 'Add some feature'`)
8. Push the branch (`git push origin new-feature`)
9. Create a new pull request## Credits
Lingo draws huge inspiration from [RuboCop](https://github.com/bbatsov/rubocop) and
other Go tools such as [dep](https://github.com/golang/dep), [cobra](https://github.com/spf13/cobra)
and [golint](https://github.com/golang/lint).## Copyright
Copyright (c) 2017 Stanislav Gatev. See [LICENSE](LICENSE) for
further details.