Skip to content

Commit

Permalink
Load minified version if available (#1749)
Browse files Browse the repository at this point in the history
  • Loading branch information
DeMoorJasper authored and devongovett committed Jul 21, 2018
1 parent 22937d0 commit 3aa9b9c
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 26 deletions.
27 changes: 11 additions & 16 deletions packages/core/parcel-bundler/src/packagers/JSConcatPackager.js
Original file line number Diff line number Diff line change
@@ -1,27 +1,22 @@
const Packager = require('./Packager');
const path = require('path');
const fs = require('fs');
const concat = require('../scope-hoisting/concat');
const urlJoin = require('../utils/urlJoin');
const getExisting = require('../utils/getExisting');
const walk = require('babylon-walk');
const babylon = require('babylon');
const t = require('babel-types');
const {getName, getIdentifier} = require('../scope-hoisting/utils');

const prelude = {
source: fs
.readFileSync(path.join(__dirname, '../builtins/prelude2.js'), 'utf8')
.trim(),
minified: fs
.readFileSync(path.join(__dirname, '../builtins/prelude2.min.js'), 'utf8')
.trim()
.replace(/;$/, '')
};

const helpers =
fs
.readFileSync(path.join(__dirname, '../builtins/helpers.js'), 'utf8')
.trim() + '\n';
const prelude = getExisting(
path.join(__dirname, '../builtins/prelude2.min.js'),
path.join(__dirname, '../builtins/prelude2.js')
);

const helpers = getExisting(
path.join(__dirname, '../builtins/helpers.min.js'),
path.join(__dirname, '../builtins/helpers.js')
);

class JSConcatPackager extends Packager {
async start() {
Expand Down Expand Up @@ -77,7 +72,7 @@ class JSConcatPackager extends Packager {
}
}

this.write(helpers);
this.write(helpers.minified);
}

write(string) {
Expand Down
15 changes: 5 additions & 10 deletions packages/core/parcel-bundler/src/packagers/JSPackager.js
Original file line number Diff line number Diff line change
@@ -1,19 +1,14 @@
const fs = require('fs');
const path = require('path');
const Packager = require('./Packager');
const getExisting = require('../utils/getExisting');
const urlJoin = require('../utils/urlJoin');
const lineCounter = require('../utils/lineCounter');
const objectHash = require('../utils/objectHash');

const prelude = {
source: fs
.readFileSync(path.join(__dirname, '../builtins/prelude.js'), 'utf8')
.trim(),
minified: fs
.readFileSync(path.join(__dirname, '../builtins/prelude.min.js'), 'utf8')
.trim()
.replace(/;$/, '')
};
const prelude = getExisting(
path.join(__dirname, '../builtins/prelude.min.js'),
path.join(__dirname, '../builtins/prelude.js')
);

class JSPackager extends Packager {
async start() {
Expand Down
17 changes: 17 additions & 0 deletions packages/core/parcel-bundler/src/utils/getExisting.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
const fs = require('fs');
/**
* Creates an object that contains both source and minified (using the source as a fallback).
* e.g. builtins.min.js and builtins.js.
*/
module.exports = (minifiedPath, sourcePath) => {
let source = fs.readFileSync(sourcePath, 'utf8').trim();
return {
source,
minified: fs.existsSync(minifiedPath)
? fs
.readFileSync(minifiedPath, 'utf8')
.trim()
.replace(/;$/, '')
: source
};
};

0 comments on commit 3aa9b9c

Please sign in to comment.