Skip to content

Code Style Guide

Michael edited this page Oct 8, 2018 · 11 revisions

The code in this repository follows the naming and style conventions of Julia Base with a few modifications. It is also heavily "inspired" by the style guides of John Myles White and JuMP.

Formatting

  • Use four spaces when indenting a new block (except module)

  • Use spaces between operators, except for ^ and :

  • Use single space after commas and semicolons

Bad: f(x,y) = [5*sin(x+y);y'] Good: f(x, y) = [5 * sin(x + y); y']

  • Use spacing with keyworda arguments

Bad: foo(x::Integer=1) Good: foo(x::Integer = 1)

  • Don't parenthesize conditions

Bad: if (a == b) Good: if a == b

Naming

  • Modules and Type names use capitilization and camel case, e.g. module LinearAlgebra, struct ConvexSets.
  • Functions are lowercase and use underscores to seperate words, e.g. has_key(x).
  • Constants are uppercase, e.g. const MY_CONSTANT
  • Always append ! to names of functions that modify their arguments.
  • Function arguments that are mutated come first. Otherwise follow the rules layed out in Julia Base Argument ordering

Syntax

  • Use 1.0 instead of 1.
Clone this wiki locally