Windows 7 - Install gjslint (Google Closure JSLinter) into Python

Posted at


Use WinRAR or Universal Extractor

after extracting (twice),
you'll be left with the "installation":

open CMD, and navigate to this folder (shortcut -- hold shift, click in the folder once removing selection from files, then right click on empty space and you'll have 'open command window here' in the context menu -- open CMD in this folder),

as explained in the README file,
python ./ install
you will get a message
Installing fixjsstyle.exe script to C:\\PYTHON27\\Scripts
Installing gjslint.exe script to C:\\PYTHON27\\Scripts

now you can add the path
to your PATH Environment-variable, so you could use gjslint.exe from everywhere.

how to use:

gjslint.exe --strict file1.js
to get all the Google-Closure-JSlinter messages.
you don't have to use the '--strict' but it is probably better if you'll do.
gjslint.exe file1.js

to skip checking the @param and other annotations in the JSDoc, you can add --nojsdoc
gjslint.exe --strict --nojsdoc file1.js

you can run recursively on a folder's content, parsing without changing, the files, and writing the result to output.
gjslint.exe -r C:\\work\\trunk\\jsfolder

fixjsstyle.exe file1.js
to automatically preform style and code changes (make sure to backup first in case you won't like the result, it is not backing up by default, but changing the file directly).

the original document

the Google Closure page

Also check-out the "how to integrate with JetBrains WebStorm 6". (soon to come)

you can also run
gjslint.exe --help to get the following list of command line switches:

USAGE: C:\\Python27\\Scripts\\ [flags]


--closurized_namespaces: Namespace prefixes, used for testing
(default: '')
(a comma separated list)
--ignored_extra_namespaces: Fully qualified namespaces that should be not be
reported as extra by the linter.
(default: '')
(a comma separated list)

-e,--exclude_directories: Exclude the specified directories (only applicable
along with -r or --presubmit)
(default: '_demos')
(a comma separated list)
-x,--exclude_files: Exclude the specified files
(default: 'deps.js')
(a comma separated list)
-r,--recurse: Recurse in to the subdirectories of the given path;
repeat this option to specify a list of values

--custom_jsdoc_tags: Extra jsdoc tags to allow
(default: '')
(a comma separated list)

--jslint_error: List of specific lint errors to check. Here is a list of
accepted values:
- all: enables all following errors.
- blank_lines_at_top_level: validatesnumber of blank lines between blocks at
top level.
- indentation: checks correct indentation of code.
- well_formed_author: validates the @author JsDoc tags.
- no_braces_around_inherit_doc: forbids braces around @inheritdoc JsDoc
- braces_around_type: enforces braces around types in JsDoc tags.
- optional_type_marker: checks correct use of optional marker = in param
- unused_private_members: checks for unused private variables.
repeat this option to specify a list of values
(default: '[]')
--[no]strict: Whether to validate against the stricter Closure style. This
includes optional_type_marker, well_formed_author,
no_braces_around_inherit_doc, indentation, braces_around_type,
(default: 'false')

--[no]jsdoc: Whether to report errors for missing JsDoc.
(default: 'true')

--additional_extensions: List of additional file extensions (not js) that
should be treated as JavaScript files.
(a comma separated list)
--[no]beep: Whether to beep when errors are found.
(default: 'true')
--[no]check_html: Whether to check javascript in html files.
(default: 'false')
-?,--[no]help: show this help
--[no]helpshort: show usage only for this module
--[no]helpxml: like --help, but generates XML output
--[no]multiprocess: Whether to attempt parallelized linting using the
multiprocessing module. Enabled by default on Linux if the multiprocessing
module is present (Python 2.6+). Otherwise disabled by default. Disabling
may make debugging easier.
(default: 'false')
--[no]summary: Whether to show an error count summary.
(default: 'false')
--[no]time: Whether to emit timing statistics.
(default: 'false')
--[no]unix_mode: Whether to emit warnings in standard unix format.
(default: 'false')

--[no]debug_indentation: Whether to print debugging information for
(default: 'false')

--[no]error_trace: Whether to show error exceptions.
(default: 'false')
--limited_doc_files: List of files with relaxed documentation checks. Will not
report errors for missing documentation, some missing descriptions, or
methods whose @return tags don't have a matching return statement.
(default: 'dummy.js,externs.js')
(a comma separated list)

--flagfile: Insert flag definitions from the given file into the command line.
(default: '')
--undefok: comma-separated list of flag names that it is okay to specify on
the command line even if the program does not define a flag with that name.
IMPORTANT: flags in this list that have arguments MUST use the --flag=value
(default: '')

run fixjsstyle.exe --help to get the full command line switches or the "fix style" execute,

note that the HELP text is saying
USAGE: C:\\Python27\\Scripts\\ [flags]
USAGE: C:\\Python27\\Scripts\\ [flags]

but for windows you can you the exe-files with the flags,

you can also use the python syntax,
assuming your python path has set, you can also enter
python C:\\Python27\\Scripts\\ [flags]
python C:\\Python27\\Scripts\\ [flags]

which is the equivalent of running gjslint.exe or fixjsstyle.exe