aboutsummaryrefslogtreecommitdiffstats
path: root/build/tasks/build.js
diff options
context:
space:
mode:
authorFelix Nagel <info@felixnagel.com>2013-07-09 22:55:35 +0200
committerFelix Nagel <info@felixnagel.com>2013-07-09 22:55:35 +0200
commit05832d6b6a1e313c172a903be54e98dd46fa2b5c (patch)
treecaee34ff88b3af85c8bb9bf0f03b198c3f5e8f0c /build/tasks/build.js
parent009aa6a953ac0a7376baf0a7615e4c119ea59b23 (diff)
parentafeaf565bb0b91c399603a0ddd82a925cabef6aa (diff)
downloadjquery-ui-05832d6b6a1e313c172a903be54e98dd46fa2b5c.tar.gz
jquery-ui-05832d6b6a1e313c172a903be54e98dd46fa2b5c.zip
Merge branch 'master' into selectmenu
Diffstat (limited to 'build/tasks/build.js')
-rw-r--r--build/tasks/build.js33
1 files changed, 33 insertions, 0 deletions
diff --git a/build/tasks/build.js b/build/tasks/build.js
index 4d803df77..c50745899 100644
--- a/build/tasks/build.js
+++ b/build/tasks/build.js
@@ -135,4 +135,37 @@ grunt.registerTask( "clean", function() {
require( "rimraf" ).sync( "dist" );
});
+grunt.registerTask( "asciilint", function() {
+ var valid = true,
+ files = grunt.file.expand({ filter: "isFile" }, "ui/*.js" );
+ files.forEach(function( filename ) {
+ var i, c,
+ text = grunt.file.read( filename );
+
+ // Ensure files use only \n for line endings, not \r\n
+ if ( /\x0d\x0a/.test( text ) ) {
+ grunt.log.error( filename + ": Incorrect line endings (\\r\\n)" );
+ valid = false;
+ }
+
+ // Ensure only ASCII chars so script tags don't need a charset attribute
+ if ( text.length !== Buffer.byteLength( text, "utf8" ) ) {
+ grunt.log.error( filename + ": Non-ASCII characters detected:" );
+ for ( i = 0; i < text.length; i++ ) {
+ c = text.charCodeAt( i );
+ if ( c > 127 ) {
+ grunt.log.error( "- position " + i + ": " + c );
+ grunt.log.error( "-- " + text.substring( i - 20, i + 20 ) );
+ break;
+ }
+ }
+ valid = false;
+ }
+ });
+ if ( valid ) {
+ grunt.log.ok( files.length + " files lint free." );
+ }
+ return valid;
+});
+
};