data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
coffee-jshint
Advanced tools
Runs your CoffeeScript source through JSHint to check for errors.
NOTE: As of version 1.0.0
, coffee-jshint
changed its dependencies to be on coffeescript
in favor of the, now deprecated, coffee-script
name.
npm install coffeescript -g // See package.json for supported versions (most)
npm install coffee-jshint -g
To check some files:
coffee-jshint file1.coffee file2.coffee ...
JSHint takes a bunch of options that tell it various rules to enforce or relax. Some of these don't make much sense to check for JS generated by the CoffeeScript compiler, so by default these options are turned on:
== null
, which CoffeeScript uses in its generated JSobj['field']
) when you could use dot notation (obj.field
) since we're grown ups and can make our own decisions about what lookup syntax is bestTo turn on more options, you can use the --options
or -o
flag:
coffee-jshint -o trailing,browser,sub file1.coffee file2.coffee ...
If you really must turn off some of the default options, use the --default-options-off
flag (you can always use --options
to turn some back on):
coffee-jshint --default-options-off --options undef,eqnull ...
You'll probably get a lot of complaints from Coffee->JSHint about undefined global variables like console
, $
, or require
. Depending on where you're running your code, you might want to allow a few global variables. One easy way to handle this is to use JSHint's built in environment options.
For instance, if you're running your code using Node.js, then you'll want to turn on the node
option. It works like any other option:
coffee-jshint -o node ...
If you have some globals that aren't covered by any of environments, well then you should probably check yo'self before you wreck yo'self. But if you really want to turn off warnings for some global variables, Coffee->JSHint supports it using the --globals
or -g
option. One use case is when using Mocha, a testing library:
coffee-jshint -o node --globals describe,it ...
Coffee->JSHint plays nicely with your favorite Unix utilities. If you want to recursively search all the files in a directory, try piping in the results of a find
. Here's an example that also uses grep
to filter out files in node_modules/
:
find . -type f -path "*.coffee" | grep -v "node_modules/" | xargs coffee-jshint
To use Coffee->JSHint as a git pre-commit hook to check changed files before you commit, put something like this in .git/hooks/pre-commit
:
git diff --staged --name-only | xargs coffee-jshint
if [[ $? -ne 0 ]]; then
echo 'WARNING: You are about to commit files with coffee-jshint warnings'
exit 1
fi
This will take all the files you plan to commit changes to, run them through coffee-jshint
, and exit with status code 1
if there are any warnings (which it will also print out). If there are warnings, the commit will be aborted, but you can always do git commit --no-verify
to bypass the hook.
Clone this repository somewhere, switch to it, then:
$ git config commit.template ./.gitmessage
$ npm install
This will:
make
(no args) for you, creating a build.make
This project uses conventional-changelog/standard-version
for automatic versioning and
CHANGELOG management.
To make this work, please ensure that your commit messages adhere to the
Commit Message Format. Setting your git config
to
have the commit.template
as referenced below will help you with a detailed reminder of how to do this on every git commit
.
$ git config commit.template ./.gitmessage
Determine what your next semver <version>
should be:
$ version="<version>"
Bump the package's .version
, update the CHANGELOG, commit these, and tag the commit as v<version>
:
$ npm run release
If all is well this new version
should be identical to your intended <version>
:
$ jq ".version == \"${version}\"" package.json
If this is not the case, then either your assumptions about what changed are wrong, or (at least) one of your commits did not adhere to the Commit Message Format Discipline; Abort the release, and sort it out first.
$ npm publish
git push --follow-tags --all
Draft a new release
button;v<version>
tag from the dropdown menu;Publish release
button;See CHANGELOG.
1.0.0 (2017-10-03)
<3
) (94c40ce)peerDepencies
are now to coffeescript
in favor of the, now deprecated, coffee-script
<a name="0.2.7"></a>
FAQs
Checks CoffeeScript source for errors using JSHint
The npm package coffee-jshint receives a total of 1,491 weekly downloads. As such, coffee-jshint popularity was classified as popular.
We found that coffee-jshint demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.