This is the the same as the older CoffeeLint, with some changes to enable better support new CoffeeScript 2 features.
- CJSX files (JSX-style) are fully compatible
- All rules output column numbers as well.
CoffeeLint2
CoffeeLint is a style checker that helps keep CoffeeScript code
clean and consistent.
For guides on installing, using and configuring CoffeeLint, head over
here.
To suggest a feature, report a bug, or general discussion, head over
here.
Team
Current:
Past:
Contributing
-
New rules should be set to a warn
level. Developers will expect new changes to NOT break their existing workflow, so unless your change is extremely usefull, default to warn
. Expect discussion if you choose to use error
.
-
Look at existing rules and test structures when deciding how to name your rule. no_foo.coffee
is used for many tests designed to catch specific errors, whereas foo.coffee
is used for tests that are designed to enforce formatting and syntax.
Steps
- Fork the repo locally.
- Run
npm install
to get dependencies. - Create your rule in a single file as
src/rules/your_rule_here.coffee
, using the existing
rules as a guide.
You may examine the AST and tokens using
http://asaayers.github.io/clfiddle/. - Add your test file
my_test.coffee
to the test
directory. - Register your rule in
src/coffeelint.coffee
. - Run your test using
npm run testrule test/your_test_here.coffee
. - Run the whole tests suite using
npm test
. - Check that your rule's documentation is generated properly (see Updating documentation when
adding a new rule below).
- Squash all commits into a single commit when done.
- Submit a pull request.
Updating documentation when adding a new rule
When adding a new rule, its documentation is specified by setting a
description
property within its rule
property:
module.exports = class NoComment
rule:
name: 'no_comment'
level: 'ignore'
message: 'No comment'
description: '''
Disallows any comment in the code
'''
tokens: ['#', '###']
lintToken : (token, tokenApi) ->
return {context: "Found '#{token[0]}'"}
The description property is a string that can embed HTML code:
description: '''
Disallows any comment in the code. This code would not pass:
<pre>
<code>### Some code with comments
foo = ->
# some other comments
bar()
</code>
</pre>
'''
Coffeelint's website generates each
rule's documentation based on this description
property.
When adding a new rule, it is suggested that you check that the documentation
for your new rule is generated correctly. In order to do that, you should
follow these steps:
- Checkout the branch that contains the changes adding the new rule.
- Run
npm run compile
. - Checkout the
gh-pages
branch: git checkout origin/gh-pages
. - Run
cp lib/coffeelint.js js/coffeelint.js
. - Regenerate the HTML documentation:
rake updatehtml
. Note that you will
probably need to install rake. - Open the
index.html
file with your favorite browser and make sure that your
rule's documentation is generated properly.