mirror of
https://github.com/jquery/jquery-ui.git
synced 2025-01-07 20:34:24 +00:00
Build: Implement an asciilint task to verify content of ui files (ignore i18n). Fixes #9037 - Build: Verify characters in output
This commit is contained in:
parent
4ed52cba65
commit
7da828375a
@ -244,7 +244,7 @@ grunt.initConfig({
|
|||||||
});
|
});
|
||||||
|
|
||||||
grunt.registerTask( "default", [ "lint", "test" ] );
|
grunt.registerTask( "default", [ "lint", "test" ] );
|
||||||
grunt.registerTask( "lint", [ "jshint", "csslint", "htmllint" ] );
|
grunt.registerTask( "lint", [ "asciilint", "jshint", "csslint", "htmllint" ] );
|
||||||
grunt.registerTask( "test", [ "qunit" ] );
|
grunt.registerTask( "test", [ "qunit" ] );
|
||||||
grunt.registerTask( "sizer", [ "concat:ui", "uglify:main", "compare_size:all" ] );
|
grunt.registerTask( "sizer", [ "concat:ui", "uglify:main", "compare_size:all" ] );
|
||||||
grunt.registerTask( "sizer_all", [ "concat:ui", "uglify", "compare_size" ] );
|
grunt.registerTask( "sizer_all", [ "concat:ui", "uglify", "compare_size" ] );
|
||||||
|
@ -135,4 +135,37 @@ grunt.registerTask( "clean", function() {
|
|||||||
require( "rimraf" ).sync( "dist" );
|
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;
|
||||||
|
});
|
||||||
|
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user