2013-09-09 07:35:57 +00:00
|
|
|
# Coding style
|
|
|
|
|
2013-08-14 22:43:35 +00:00
|
|
|
## C++ and Python
|
|
|
|
|
2013-08-29 14:37:51 +00:00
|
|
|
For C++ and Python, we just follow Chromium's [Coding
|
|
|
|
Style](http://www.chromium.org/developers/coding-style), there is also a
|
|
|
|
script `script/cpplint.py` to check whether all files confirm.
|
2013-08-14 22:43:35 +00:00
|
|
|
|
|
|
|
The python's version we are using now is Python 2.7.
|
|
|
|
|
|
|
|
## CoffeeScript
|
|
|
|
|
2013-08-29 14:37:51 +00:00
|
|
|
For CoffeeScript, we follow GitHub's [Style
|
|
|
|
Guide](https://github.com/styleguide/javascript), and also following rules:
|
2013-08-14 22:43:35 +00:00
|
|
|
|
2013-08-29 14:37:51 +00:00
|
|
|
* Files should **NOT** end with new line, because we want to match Google's
|
|
|
|
styles.
|
|
|
|
* File names should be concatenated with `-` instead of `_`, e.g.
|
|
|
|
`file-name.coffee` rather than `file_name.coffee`, because in
|
|
|
|
[github/atom](https://github.com/github/atom) module names are usually in
|
|
|
|
the `module-name` form, this rule only apply to `.coffee` files.
|
2013-08-14 22:43:35 +00:00
|
|
|
|
|
|
|
## API Names
|
|
|
|
|
2013-08-29 14:37:51 +00:00
|
|
|
When creating a new API, we should prefer getters and setters instead of
|
|
|
|
jQuery's one-function style, for example, `.getText()` and `.setText(text)`
|
|
|
|
are preferred to `.text([text])`. There is a
|
|
|
|
[discussion](https://github.com/atom/atom-shell/issues/46) of this.
|