Skip to content

Latest commit

 

History

History
188 lines (134 loc) · 5.09 KB

File metadata and controls

188 lines (134 loc) · 5.09 KB

The Algorithms Go Repository Style Guide

This guide contains a set of go idioms and best practices which should be followed while writing code whenever they are applicable. The instructions in this document should be given precedence if there is a conflict between this document and contribution guidelines. If you find any issue or ambiguity in this document, the maintainers of this repository should be consulted.

Table of Contents

Formatting

All go code should be formatted with the official formatting tool gofmt. This requirement is verified by the repository workflows.

Commenting

All exported symbols should be commented with documentation, so that their motivation and use is clear. All documentation should record any nuances of the symbol so that users are well aware of them.

C++ style line comments should be preferred over C-style block comments.

BadGood
/*
  Unmarshal converts a JSON string into a go interface
  ...
*/
// Unmarshal converts a JSON string into a go interface
// ...

Package Comments

Package comments should start with the word "Package" followed by the package name. For packages spanning multiple files or with a need for a large documentation, use a separate doc.go file for package level documentation comment.

BadGood
// sort is a package which implements sorting functions.
// Package sort implements sorting functions.

Documentation Comments

All doc comments for symbols should start with the symbol name.

BadGood
// Function Quick is an implementation
// of the Quicksort algorithm.
// Quick is an implementation
// of the Quicksort algorithm.

Author Comments

A comment recording the author of a particular file may also be added. This comment should be written at the top of the file and it should not be a part of the package documentation.

BadGood
// author: Rak Laptudirm (@raklaptudirm)
package sort

Comment is a part of the package documentation.

// author: Rak Laptudirm (@raklaptudirm)

package sort

Comment is not a part of the package documentation.

Naming

Package Naming

Package names should be short and to the point. Keep in mind that this identifier will be used to refer to your package, so make it easy to remember. It should be only composed of lower case letters. Prefer json to JSON or Json. If your package name has two words, merge them together. Prefer jsonencoding to jsonEncoding or json_encoding. Although, there is almost always a word to succinctly describe the package with an appropriate name. So if you have a name that describes the package nicely, please use that.

Add the _test suffix to your package name to implement black-box testing for your package in the test files.

Symbol Naming

Go symbols should be named in the camelCase or PascalCase, depending of whether the symbol is exported or not. The case when using acronyms in names should be consistent. Use json or JSON instead of Json.

For exported symbols, use the package name to your advantage to write concise symbol names. For example, if you have a package png, instead of defining a png.PNGFile, define a png.File. It is much clearer and avoids repetition.

Function Naming

Constructor Naming

Constructors should use the naming format New<Type>() for constructors which return pointers and Make<Type>() for constructors which return values in accordance with the Go Programming Language's new and make functions. If the package only exports a single constructor, use the name New(). Some valid names are reader.New(), metainfo.NewFile().

Getter Naming

Usage of Getters and Setters are discouraged. Use exported variables instead.

Getters should use the name of the field that is being fetched. For example, prefer a getter name like user.Name() to user.GetName().

Setter Naming

Setters should use names in the format Set<Field>. For example, user.SetName().

Interface Naming

Interfaces should use names in the format of <Method>er or <Method>. For example, some valid interface names are:

type Node interface {
  Node()
}
 
type Writer interface {
  Write()
}