Migrating from JSCS

In April 2016, we announced that the JSCS project was shutting down and the JSCS team would be joining the ESLint team. This guide is intended to help those who are using JSCS to migrate their settings and projects to use ESLint. We've tried to automate as much of the conversion as possible, but there are some manual changes that are needed.

Terminology

Before beginning the process of migrating to ESLint, it's helpful to understand some of the terminology that ESLint uses and how it relates to terminology that JSCS uses.

Convert Configuration Files Using Polyjuice

Polyjuice is a utility for converting JSCS (and JSHint) configuration files into ESLint configuration files automatically. It understands the equivalent rules from each utility and will automatically output an ESLint configuration file that is a good approximation of your existing JSCS file.

To install Polyjuice:

npm install -g polyjuice

Polyjuice works with JSON configuration files, so if you're using a JavaScript or YAML JSCS configuration file, you should first convert it into a JSON configuration file.

To convert your configuration file, pass in the location of your .jscs.json file using the --jscs flag:

polyjuice --jscs .jscsrc.json > .eslintrc.json

This creates a .eslintrc.json with the equivalent rules from .jscsrc.json.

If you have multiple .jscsrc.json files, you can pass them all and Polyjuice will combine them into one .eslintrc.json file:

polyjuice --jscs .jscsrc.json ./foo/.jscsrc.json > .eslintrc.json

Note: Polyjuice does a good job of creating a reasonable ESLint configuration from your JSCS configuration, but it may not be 100%. You may still see different warnings than you saw with JSCS, and so you may need to further modify your configuration after using Polyjuice. This is especially true if you're using inline comments to enable/disable certain rules in JSCS (you'll need to manually convert those to use ESLint-style comments instead, see "Disabling Rules Inline" later in this page).

Creating a New Configuration From Scratch

If you don't want to convert your JSCS configuration directly into an ESLint configuration, then you can use ESLint's built-in wizard to get you started. Just run:

npm init @eslint/config

You'll be guided through a series of questions that will help you setup a basic configuration file to get you started.

Converting Presets

There are shareable configs available for most JSCS presets. The equivalent shareable configs for each JSCS preset are listed in the following table:

JSCS PresetESLint Shareable Config
airbnbeslint-config-airbnb-base
crockford(not available)
googleeslint-config-google
grunteslint-config-grunt
idiomaticeslint-config-idiomatic
jqueryeslint-config-jquery
mdcseslint-config-mdcs
node-style-guideeslint-config-node-style-guide
wikimediaeslint-config-wikimedia
wordpresseslint-config-wordpress

As an example, suppose that you are using the airbnb preset, so your .jscsrc file looks like this:

{
    "preset": "airbnb"
}

In order to get the same functionality in ESLint, you would first need to install the eslint-config-airbnb shareable config package:

npm install eslint-config-airbnb-base --save-dev

And then you would modify your configuration file like this:

{
    "extends": "airbnb-base"
}

ESLint sees "airbnb-base" and will look for eslint-config-airbnb-base (to save you some typing).

Disabling Rules Inline

Both JSCS and ESLint use comments inside of files to disable rules around certain parts of your code. The following table lists out the JSCS inline configuration comments and their ESLint equivalents.

DescriptionJSCS CommentESLint Comment
Disable all rules// jscs:disable or /* jscs:disable *//* eslint-disable */
Enable all rules// jscs:enable or /* jscs:enable *//* eslint-enable */
Disable one rule// jscs:disable ruleName or /* jscs:disable ruleName *//* eslint-disable rule-name */
Enable one rule// jscs:enable ruleName or /* jscs:enable ruleName *//* eslint-enable rule-name */
Disable multiple rules// jscs:disable ruleName1, ruleName2 or /* jscs:disable ruleName1, ruleName2 *//* eslint-disable rule-name1, rule-name2 */
Enable multiple rules// jscs:enable ruleName1, ruleName2 or /* jscs:enable ruleName1, ruleName2 *//* eslint-enable rule-name1, rule-name2 */
Disable one rule on single line// jscs:ignore ruleName// eslint-disable-line rule-name

Command Line Options

Both JSCS and ESLint have command line arguments corresponding to many of their configuration options. The following are the ESLint equivalents of JSCS command line options.

--fix

JSCS uses the --fix option to apply automatic fixes to code:

jscs --fix file.js

ESLint has the same option:

eslint --fix file.js

--auto-configure

The JSCS --auto-configure option created a configuration based on what it found in a given file:

jscs --auto-configure file.js

In ESLint, there's a similar option when you use --init. Just select "Inspect your JavaScript file(s)":

eslint --init
? How would you like to configure ESLint? (Use arrow keys)
> Answer questions about your style
  Use a popular style guide
  Inspect your JavaScript file(s)

--config, -c

JSCS allows you to specify a configuration file to use on the command line using either --config or -c, such as:

jscs --config myconfig.json file.js
jscs -c myconfig.json file.js

Both flags are also supported by ESLint:

eslint --config myconfig.json file.js
eslint -c myconfig.json file.js

Piping Code Into ESLint

In JSCS, you can pipe code in like this:

cat file.js | jscs

In ESLint, you can also pipe in code, but you need to use the --stdin flag:

cat file.js | eslint --stdin