{
	// http://www.jshint.com/docs/
	// Based on node-jshint@0.9.1

	// ENFORCING OPTIONS
	// These options tell JSHint to be more strict towards your code. Use them if
	// you want to allow only a safe subset of JavaScript—very useful when your
	// codebase is shared with a big number of developers with different skill
	// levels.

	"bitwise"   : true,   //prohibits the use of bitwise operators such as ^ (XOR), | (OR) and others
	"camelcase" : false,   //force all variable names to use either camelCase style or UPPER_CASE with underscores
	"curly"     : true,   //requires you to always put curly braces around blocks in loops and conditionals
	"eqeqeq"    : true,   //prohibits the use of == and != in favor of === and !==
	"forin"     : true,   //requires all `for in` loops to filter object's items with `hasOwnProperty()`
	"immed"     : true,   //prohibits the use of immediate function invocations without wrapping them in parentheses
	"indent"    : 4,      //enforces specific tab width
	"latedef"   : true,   //prohibits the use of a variable before it was defined
	"newcap"    : false,   //requires you to capitalize names of constructor functions
	"noarg"     : true,   //prohibits the use of `arguments.caller` and `arguments.callee`
	"noempty"   : true,   //warns when you have an empty block in your code
	"nonew"     : true,   //prohibits the use of constructor functions for side-effects
	"plusplus"  : false,  //prohibits the use of unary increment and decrement operators
	"quotmark"  : true,   //enforces the consistency of quotation marks used throughout your code
	"regexp"    : false,  //prohibits the use of unsafe `.` in regular expressions
	"undef"     : true,   //prohibits the use of explicitly undeclared variables
	"unused"    : false,  //warns when you define and never use your variables
	"strict"    : false,  //requires all functions to run in EcmaScript 5's strict mode
	"trailing"  : false,  //makes it an error to leave a trailing whitespace in your code
	// "maxparams":      0,      //set the max number of formal parameters allowed per function,
	// "maxdepth":       0,      //control how nested do you want your blocks to be
	// "maxstatements":  0,      //set the max number of statements allowed per function
	// "maxcomplexity":  0,      //control cyclomatic complexity throughout your code
	// "maxlen":         80,     //set the maximum length of a line

	// RELAXING OPTIONS
	// These options allow you to suppress certain types of warnings. Use them
	// only if you are absolutely positive that you know what you are doing.

	"asi"          : false,  //suppresses warnings about missing semicolons
	"boss"         : true,   //suppresses warnings about the use of assignments in cases where comparisons are expected
	"debug"        : false,  //suppresses warnings about the debugger statements in your code
	"eqnull"       : false,  //suppresses warnings about == null comparisons
	"es5"          : true,  //your code uses ECMAScript 5 specific features such as getters and setters
	"esnext"       : true,  //your code uses ES.next specific features such as const
	"evil"         : false,  //suppresses warnings about the use of eval
	"expr"         : true,  //suppresses warnings about the use of expressions where normally you would expect to see assignments or function calls
	"funcscope"    : false,  //suppresses warnings about declaring variables inside of control structures while accessing them later from the outside
	"globalstrict" : false,  //suppresses warnings about the use of global strict mode
	"iterator"     : false,  //suppresses warnings about the `__iterator__` property
	"lastsemic"    : false,  //suppresses warnings about missing semicolons, but only when the semicolon is omitted for the last statement in a one-line block
	"laxbreak"     : true,  //suppresses most of the warnings about possibly unsafe line breakings in your code
	"laxcomma"     : false,  //suppresses warnings about comma-first coding style
	"loopfunc"     : false,  //suppresses warnings about functions inside of loops
	"multistr"     : false,  //suppresses warnings about multi-line strings
	"onecase"      : false,  //suppresses warnings about switches with just one case
	"proto"        : false,  //suppresses warnings about the `__proto__` property
	"regexdash"    : true,   //suppresses warnings about unescaped `-` in the end of regular expressions
	"scripturl"    : false,  //suppresses warnings about the use of script-targeted URLs—such as `javascript:...`
	"smarttabs"    : true,   //suppresses warnings about mixed tabs and spaces when the latter are used for alignmnent only
	"shadow"       : false,  //suppresses warnings about variable shadowing
	"sub"          : false,  //suppresses warnings about using `[]` notation when it can be expressed in dot notation
	"supernew"     : false,  //suppresses warnings about "weird" constructions like `new function () { ... }` and `new Object;`
	"validthis"    : false,  //suppresses warnings about possible strict violations when the code is running in strict mode and you use `this` in a non-constructor function

	// ENVIRONMENTS
	// These options pre-define global variables that are exposed by popular
	// JavaScript libraries and runtime environments—such as browser or node.js.
	// Essentially they are shortcuts for explicit declarations like
	// /*global $:false, jQuery:false */

	"browser"     : true,   //defines globals exposed by modern browsers
	"couch"       : false,  //defines globals exposed by CouchDB
	"devel"       : true,   //defines globals that are usually used for logging poor-man's debugging: `console`, `alert`, etc.
	"dojo"        : false,  //defines globals exposed by the Dojo Toolkit
	"jquery"      : false,  //defines globals exposed by the jQuery JavaScript library
	"mootools"    : false,  //defines globals exposed by the MooTools JavaScript framework
	"node"        : false,   //defines globals available when your code is running inside of the Node runtime environment
	"nonstandard" : true,   //defines non-standard but widely adopted globals such as `escape` and `unescape`
	"prototypejs" : false,  //defines globals exposed by the Prototype JavaScript framework
	"rhino"       : false,  //defines globals available when your code is running inside of the Rhino runtime environment
	"worker"      : false,   //defines globals available when your code is running inside of a Web Worker
	"wsh"         : false,  //defines globals available when your code is running as a script for the Windows Script Host
	"yui"         : false,  //defines globals exposed by the YUI JavaScript framework

	"predef" : [  // Custom globals.
		"define", "module", "require", "describe", "before", "beforeEach", "after", "afterEach", "it"
	],

	// LEGACY
	// These options are legacy from JSLint. Aside from bug fixes they will not
	// be improved in any way and might be removed at any point.

	"nomen"    : false,  //disallows the use of dangling `_` in variables
	"onevar"   : false,  //allows only one `var` statement per function
	"passfail" : false,  //makes JSHint stop on the first error or warning
	"white"    : false   //make JSHint check your source code against Douglas Crockford's JavaScript coding style
}
