Skip to content
Permalink
Browse files

Add release support for map files.

  • Loading branch information
dmethvin committed Dec 29, 2012
1 parent 861a45b commit c9b75df7fba7c96f38efcd60629830e76ce24863
Showing with 45 additions and 10 deletions.
  1. +45 −10 build/release.js
@@ -13,7 +13,7 @@ var fs = require("fs"),

var releaseVersion,
nextVersion,
finalFiles,
CDNFiles,
isBeta,
pkg,
branch,
@@ -28,14 +28,18 @@ var releaseVersion,

devFile = "dist/jquery.js",
minFile = "dist/jquery.min.js",
mapFile = "dist/jquery.min.map",

releaseFiles = {
"jquery-VER.js": devFile,
"jquery-VER.min.js": minFile,
"jquery-VER.min.map": mapFile,
"jquery.js": devFile,
"jquery-latest.js": devFile,
"jquery.min.js": minFile,
"jquery-latest.min.js": minFile
"jquery.min.map": mapFile,
"jquery-latest.js": devFile,
"jquery-latest.min.js": minFile,
"jquery-latest.min.map": mapFile
};

steps(
@@ -93,6 +97,7 @@ function initialize( next ) {
nextVersion = major + "." + minor + "." + ( isBeta ? patch : +patch + 1 ) + "pre";
next();
}

function checkGitStatus( next ) {
git( [ "status" ], function( error, stdout, stderr ) {
var onBranch = ((stdout||"").match( /On branch (\S+)/ ) || [])[1];
@@ -108,12 +113,14 @@ function checkGitStatus( next ) {
next();
});
}

function tagReleaseVersion( next ) {
updatePackageVersion( releaseVersion );
git( [ "commit", "-a", "-m", "Tagging the " + releaseVersion + " release." ], function(){
git( [ "tag", releaseVersion ], next, debug);
}, debug);
}

function gruntBuild( next ) {
exec( gruntCmd, [], function( error, stdout ) {
if ( error ) {
@@ -123,28 +130,48 @@ function gruntBuild( next ) {
next();
}, debug);
}

function makeReleaseCopies( next ) {
finalFiles = {};
CDNFiles = {};
Object.keys( releaseFiles ).forEach(function( key ) {
var builtFile = releaseFiles[ key ],
var text,
builtFile = releaseFiles[ key ],
releaseFile = key.replace( /VER/g, releaseVersion );

// Beta releases don't update the jquery-latest etc. copies
if ( !isBeta || key !== releaseFile ) {
copy( builtFile, releaseFile );
finalFiles[ releaseFile ] = builtFile;

if ( /\.map$/.test( releaseFile ) ) {
// Map files need to reference the new uncompressed name;
// assume that all files reside in the same directory.
// "file":"jquery.min.js","sources":["jquery.js"]
text = fs.readFileSync( builtFile, "utf8" )
.replace( /"file":"([^"]+)","sources":\["([^"]+)"\]/,
"\"file\":\"" + releaseFile.replace( /\.min\.map/, ".min.js" ) +
"\",\"sources\":[\"" + releaseFile.replace( /\.min\.map/, ".js" ) + "\"]" );
console.log( "Modifying map " + builtFile + " to " + releaseFile );
if ( !debug ) {
fs.writeFileSync( releaseFile, text );
}
} else {
copy( builtFile, releaseFile );
}

CDNFiles[ releaseFile ] = builtFile;
}
});
next();
}

function setNextVersion( next ) {
updatePackageVersion( nextVersion );
git( [ "commit", "-a", "-m", "Updating the source version to " + nextVersion ], next, debug );
}

function uploadToCDN( next ) {
var cmds = [];

Object.keys( finalFiles ).forEach(function( name ) {
Object.keys( CDNFiles ).forEach(function( name ) {
cmds.push(function( nxt ){
exec( "scp", [ name, scpURL ], nxt, debug || skipRemote );
});
@@ -156,6 +183,7 @@ function uploadToCDN( next ) {

steps.apply( this, cmds );
}

function pushToGithub( next ) {
git( [ "push", "--tags", repoURL, branch ], next, debug || skipRemote );
}
@@ -166,26 +194,31 @@ function steps() {
var cur = 0,
steps = arguments;
(function next(){
var step = steps[ cur++ ];
step( next );
process.nextTick(function(){
steps[ cur++ ]( next );
});
})();
}

function updatePackageVersion( ver ) {
console.log( "Updating package.json version to " + ver );
pkg.version = ver;
if ( !debug ) {
fs.writeFileSync( "package.json", JSON.stringify( pkg, null, "\t" ) + "\n" );
}
}

function copy( oldFile, newFile ) {
console.log( "Copying " + oldFile + " to " + newFile );
if ( !debug ) {
fs.writeFileSync( newFile, fs.readFileSync( oldFile, "utf8" ) );
}
}

function git( args, fn, skip ) {
exec( "git", args, fn, skip );
}

function exec( cmd, args, fn, skip ) {
if ( skip ) {
console.log( "# " + cmd + " " + args.join(" ") );
@@ -202,10 +235,12 @@ function exec( cmd, args, fn, skip ) {
);
}
}

function die( msg ) {
console.error( "ERROR: " + msg );
process.exit( 1 );
}

function exit() {
process.exit( 0 );
}

1 comment on commit c9b75df

@jaubourg

This comment has been minimized.

Copy link
Member

jaubourg commented on c9b75df Dec 29, 2012

\o/

Please sign in to comment.
You can’t perform that action at this time.