Skip to content

Commit

Permalink
fixing bower, adding lint, linting new stuff
Browse files Browse the repository at this point in the history
  • Loading branch information
bollwyvl committed Jul 16, 2014
1 parent e4973c6 commit adceb69
Show file tree
Hide file tree
Showing 8 changed files with 102 additions and 5 deletions.
84 changes: 84 additions & 0 deletions .jshintrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
{
// JSHint Default Configuration File (as on JSHint website)
// See http://jshint.com/docs/ for more details

"maxerr" : 50, // {int} Maximum error before stopping

// Enforcing
"bitwise" : true, // true: Prohibit bitwise operators (&, |, ^, etc.)
"camelcase" : false, // true: Identifiers must be in camelCase
"curly" : true, // true: Require {} for every new block or scope
"eqeqeq" : true, // true: Require triple equals (===) for comparison
"forin" : true, // true: Require filtering for..in loops with obj.hasOwnProperty()
"immed" : false, // true: Require immediate invocations to be wrapped in parens e.g. `(function () { } ());`
"indent" : 4, // {int} Number of spaces to use for indentation
"latedef" : false, // true: Require variables/functions to be defined before being used
"newcap" : false, // true: Require capitalization of all constructor functions e.g. `new F()`
"noarg" : true, // true: Prohibit use of `arguments.caller` and `arguments.callee`
"noempty" : true, // true: Prohibit use of empty blocks
"nonew" : false, // true: Prohibit use of constructors for side-effects (without assignment)
"plusplus" : false, // true: Prohibit use of `++` & `--`
"quotmark" : false, // Quotation mark consistency:
// false : do nothing (default)
// true : ensure whatever is used is consistent
// "single" : require single quotes
// "double" : require double quotes
"undef" : true, // true: Require all non-global variables to be declared (prevents global leaks)
"unused" : true, // true: Require all defined variables be used
"strict" : true, // true: Requires all functions run in ES5 Strict Mode
"maxparams" : false, // {int} Max number of formal params allowed per function
"maxdepth" : false, // {int} Max depth of nested blocks (within functions)
"maxstatements" : false, // {int} Max number statements per function
"maxcomplexity" : false, // {int} Max cyclomatic complexity per function
"maxlen" : false, // {int} Max number of characters per line

// Relaxing
"asi" : false, // true: Tolerate Automatic Semicolon Insertion (no semicolons)
"boss" : false, // true: Tolerate assignments where comparisons would be expected
"debug" : false, // true: Allow debugger statements e.g. browser breakpoints.
"eqnull" : false, // true: Tolerate use of `== null`
"es5" : false, // true: Allow ES5 syntax (ex: getters and setters)
"esnext" : false, // true: Allow ES.next (ES6) syntax (ex: `const`)
"moz" : false, // true: Allow Mozilla specific syntax (extends and overrides esnext features)
// (ex: `for each`, multiple try/catch, function expression…)
"evil" : false, // true: Tolerate use of `eval` and `new Function()`
"expr" : false, // true: Tolerate `ExpressionStatement` as Programs
"funcscope" : false, // true: Tolerate defining variables inside control statements"
"globalstrict" : true, // true: Allow global "use strict" (also enables 'strict')
"iterator" : false, // true: Tolerate using the `__iterator__` property
"lastsemic" : false, // true: Tolerate omitting a semicolon for the last statement of a 1-line block
"laxbreak" : false, // true: Tolerate possibly unsafe line breakings
"laxcomma" : false, // true: Tolerate comma-first style coding
"loopfunc" : false, // true: Tolerate functions being defined in loops
"multistr" : false, // true: Tolerate multi-line strings
"proto" : false, // true: Tolerate using the `__proto__` property
"scripturl" : false, // true: Tolerate script-targeted URLs
"shadow" : false, // true: Allows re-define variables later in code e.g. `var x=1; x=2;`
"sub" : false, // true: Tolerate using `[]` notation when it can still be expressed in dot notation
"supernew" : false, // true: Tolerate `new function () { ... };` and `new Object;`
"validthis" : false, // true: Tolerate using this in a non-constructor function

// Environments
"browser" : true, // Web Browser (window, document, etc)
"couch" : false, // CouchDB
"devel" : true, // Development/debugging (alert, confirm, etc)
"dojo" : false, // Dojo Toolkit
"jquery" : false, // jQuery
"mootools" : false, // MooTools
"node" : true, // Node.js
"nonstandard" : false, // Widely adopted globals (escape, unescape, etc)
"prototypejs" : false, // Prototype and Scriptaculous
"rhino" : false, // Rhino
"worker" : false, // Web Workers
"wsh" : false, // Windows Scripting Host
"yui" : false, // Yahoo User Interface

// Custom Globals
"globals" : {
"require": true,
"describe": true,
"it": true,
"before": true,
"casper": true
}
}
8 changes: 6 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,11 @@ MODULE = d3.carto
EXPORT = $(MODULE)
ENTRY = src/index.js
SRC = $(ENTRY) $(wildcard src/*.js) $(wildcard src/*/*.js)
TEST = $(wildcard test/*.js)
BUNDLE = d3.carto.map.js
MINIFY = d3.carto.map.min.js

.PHONY: all clean info watch test
.PHONY: all clean info watch test lint

all: $(MINIFY)

Expand All @@ -20,7 +21,10 @@ watch:
./node_modules/watchify/bin/cmd.js -s $(EXPORT) -o $(BUNDLE) $(ENTRY)

test: $(BUNDLE)
./node_modules/mocha-casperjs/bin/mocha-casperjs test/*.js
./node_modules/mocha-casperjs/bin/mocha-casperjs $(TEST)

lint:
./node_modules/jshint/bin/jshint $(SRC) $(TEST)

$(BUNDLE): $(SRC)
./node_modules/browserify/bin/cmd.js -s $(EXPORT) -o $@ $(ENTRY)
Expand Down
2 changes: 1 addition & 1 deletion bower.json
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@
"resources",
"sampledata",
"build",
"src"
"src",
"Makefile"
],
"dependencies": {
Expand Down
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@
"casper-chai": "^0.2.1",
"chai": "^1.9.1",
"glob": "^4.0.4",
"jshint": "^2.5.2",
"mocha": "^1.20.1",
"mocha-casperjs": "^0.5.0",
"uglify-js": "^2.4.15",
Expand Down
4 changes: 3 additions & 1 deletion src/index.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
"use strict";

module.exports = {
map: require("./map"),
layer: require("./layer")
}
};
2 changes: 2 additions & 0 deletions src/layer.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
"use strict";

var d3 = require('d3');

var Layer = module.exports = function() {
Expand Down
2 changes: 2 additions & 0 deletions src/map.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
"use strict";

var d3 = require("d3"),
Layer = require("./layer");

Expand Down
4 changes: 3 additions & 1 deletion test/examples.js
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
"use strict";

var fs = require("fs"),
examples = fs.list([fs.workingDirectory, "examples"].join(fs.separator))
.filter(function(file){ return /\.html$/.test(file); });

describe("The example", function() {
before(function() {
casper.start('./examples/')
casper.start("./examples/");
});

examples.forEach((function(file){
Expand Down

0 comments on commit adceb69

Please sign in to comment.