yellow team mailing list archive
-
yellow team
-
Mailing list archive
-
Message #02241
[Merge] lp:~makyo/juju-gui/recess into lp:juju-gui
Matthew Scott has proposed merging lp:~makyo/juju-gui/recess into lp:juju-gui.
Requested reviews:
Juju GUI Hackers (juju-gui)
For more details, see:
https://code.launchpad.net/~makyo/juju-gui/recess/+merge/142572
Use recess as CSS linter
This is the first step to implementing a CSS linter (recess). Currently, most of the options are turned off in order to keep this slack task short, so our LESS file passes the linter. Further slack tasks may be created for options that we decide to turn on down the road (personal suggestions: noOverqualifying and zeroUnits, ambivalent about strictPropertyOrder). There is one work-around in place in lib/templates.js due to https://github.com/twitter/recess/issues/22 in that recess is called twice - once to lint and once to compile - in order to side-step an OOM error. This is still quite fast, and not used in production.
https://codereview.appspot.com/7067057/
--
https://code.launchpad.net/~makyo/juju-gui/recess/+merge/142572
Your team Juju GUI Hackers is requested to review the proposed merge of lp:~makyo/juju-gui/recess into lp:juju-gui.
=== modified file 'Makefile'
--- Makefile 2012-12-21 12:52:30 +0000
+++ Makefile 2013-01-09 18:46:30 +0000
@@ -38,7 +38,7 @@
node_modules/minimatch node_modules/mocha node_modules/node-markdown \
node_modules/node-minify node_modules/node-spritesheet \
node_modules/rimraf node_modules/should node_modules/yui \
- node_modules/yuidocjs
+ node_modules/yuidocjs node_modules/recess
EXPECTED_NODE_TARGETS=$(shell echo "$(NODE_TARGETS)" | tr ' ' '\n' | sort \
| tr '\n' ' ')
@@ -223,7 +223,10 @@
yuidoc-lint: $(JSFILES)
bin/lint-yuidoc
-lint: gjslint jshint yuidoc-lint
+recess: node_modules/recess
+ recess lib/views/stylesheet.less --config recess.json | grep -q Perfect
+
+lint: gjslint jshint recess yuidoc-lint
virtualenv/bin/gjslint virtualenv/bin/fixjsstyle:
virtualenv virtualenv
=== modified file 'lib/templates.js'
--- lib/templates.js 2012-12-20 21:59:21 +0000
+++ lib/templates.js 2013-01-09 18:46:30 +0000
@@ -5,7 +5,7 @@
exec = require('child_process').exec,
YUI = require('yui').YUI,
view = require('./view.js'),
- less = require('less'),
+ recess = require('recess'),
config = require('../config.js').config,
cache = {};
@@ -159,21 +159,36 @@
stylesheet: {
output: __dirname + '/../build-shared/juju-ui/assets/juju-gui.css',
callback: function(strategy, name) {
- var parser = new less.Parser({
- paths: [config.server.view_dir],
- filename: 'stylesheet.less'
- }),
- css_data = fs.readFileSync(
- path.join(config.server.view_dir, 'stylesheet.less'), 'utf8');
- parser.parse(css_data, function(e, tree) {
- if (e) {
- console.log('LESS Generation Error', e);
- return;
- }
- fs.writeFileSync(strategy.output,
- tree.toCSS({compress: true}));
- });
+ // Lint the file without compiling using our config first.
+ var recessConfig = JSON.parse(
+ fs.readFileSync(__dirname + '/../recess.json'));
+ recess(
+ path.join(config.server.view_dir, 'stylesheet.less'),
+ recessConfig,
+ function(err, obj) {
+ if (err) {
+ console.log('LESS Generation Error', err);
+ return;
+ }
+ // Warn of lint errors.
+ console.log(obj.errors);
+ });
+ // Compile the less to the output file without worrying about our config.
+ // This is due to a memory-leak in recess when multiple options are
+ // specified with compile=true.
+ // See: https://github.com/twitter/recess/issues/22
+ recess(
+ path.join(config.server.view_dir, 'stylesheet.less'),
+ { compile: true },
+ function(err, obj) {
+ if (err) {
+ console.log('LESS Generation Error', err);
+ return;
+ }
+ // Write to output.
+ fs.writeFileSync(strategy.output, obj.output);
+ });
}
}
};
=== modified file 'package.json'
--- package.json 2013-01-09 16:42:50 +0000
+++ package.json 2013-01-09 18:46:30 +0000
@@ -24,6 +24,7 @@
"chai": ">=1.2.0",
"less": "1.3.x",
"jshint": ">=0.9.1",
+ "recess": "1.1.x",
"node-markdown": "0.1.x",
"yuidocjs": "0.3.x",
"minimatch": "0.2.x",
=== added file 'recess.json'
--- recess.json 1970-01-01 00:00:00 +0000
+++ recess.json 2013-01-09 18:46:30 +0000
@@ -0,0 +1,7 @@
+{
+ "compile": false,
+ "noIDs": false,
+ "noOverqualifying": false,
+ "strictPropertyOrder": false,
+ "zeroUnits": false
+}
Follow ups