move version number to build-utils

Summary:
* The generation of the version number is moved to build-utils so it can be used from the headless build process as well.
* The prelude script for the headless version exposes the version number on `global.__VERSION__`
* While at this file, moving some functions in the build process to use the Sync version. Doesn't matter for the build process anyways and the syntax is much nicer.

Reviewed By: passy

Differential Revision: D13843678

fbshipit-source-id: 7df8364044ab6ebc83a4060aab2e3a42ae48a934
This commit is contained in:
Daniel Büchele
2019-02-04 07:21:55 -08:00
committed by Facebook Github Bot
parent 5b68c59b5c
commit 22f9401e05
3 changed files with 28 additions and 45 deletions

View File

@@ -12,15 +12,15 @@ const {
buildFolder,
compile,
compileDefaultPlugins,
getVersionNumber,
} = require('./build-utils.js');
function preludeBundle(dir) {
function preludeBundle(dir, versionNumber) {
return new Promise((resolve, reject) =>
lineReplace({
file: path.join(dir, 'bundle.js'),
line: 1,
text:
'var __DEV__=false; global.electronRequire = require; global.performance = require("perf_hooks").performance;',
text: `var __DEV__=false; global.electronRequire = require; global.performance = require("perf_hooks").performance;global.__VERSION__="${versionNumber}";`,
addNewLine: true,
callback: resolve,
}),
@@ -56,7 +56,8 @@ function preludeBundle(dir) {
// eslint-disable-next-line no-console
console.log('Created build directory', buildDir);
await compile(buildDir, path.join(__dirname, '..', 'headless', 'index.js'));
await preludeBundle(buildDir);
const versionNumber = getVersionNumber();
await preludeBundle(buildDir, versionNumber);
await compileDefaultPlugins(path.join(distDir, 'plugins'));
await createBinary([
path.join(buildDir, 'bundle.js'),

View File

@@ -13,6 +13,7 @@ const {
compile,
die,
compileDefaultPlugins,
getVersionNumber,
} = require('./build-utils.js');
function generateManifest(versionNumber) {
@@ -29,7 +30,7 @@ function generateManifest(versionNumber) {
);
}
function modifyPackageManifest(buildFolder) {
function modifyPackageManifest(buildFolder, versionNumber) {
// eslint-disable-next-line no-console
console.log('Creating package.json manifest');
const manifest = require('../package.json');
@@ -40,28 +41,11 @@ function modifyPackageManifest(buildFolder) {
// because all dependencies from the root-folder are already bundled by metro.
manifest.dependencies = manifestStatic.dependencies;
manifest.main = 'index.js';
const buildNumber = process.argv.join(' ').match(/--version=(\d+)/);
if (buildNumber && buildNumber.length > 0) {
manifest.version = [
...manifest.version.split('.').slice(0, 2),
buildNumber[1],
].join('.');
}
return new Promise((resolve, reject) => {
fs.writeFile(
path.join(buildFolder, 'package.json'),
JSON.stringify(manifest, null, ' '),
err => {
if (err) {
reject(err);
} else {
resolve(manifest.version);
}
},
);
}).catch(die);
manifest.version = versionNumber;
fs.writeFileSync(
path.join(buildFolder, 'package.json'),
JSON.stringify(manifest, null, ' '),
);
}
function buildDist(buildFolder) {
@@ -112,32 +96,20 @@ function buildDist(buildFolder) {
}
function copyStaticFolder(buildFolder) {
return new Promise((resolve, reject) => {
fs.copy(
path.join(__dirname, '..', 'static'),
buildFolder,
{
dereference: true,
},
err => {
if (err) {
reject(err);
} else {
resolve();
}
},
);
}).catch(die);
fs.copySync(path.join(__dirname, '..', 'static'), buildFolder, {
dereference: true,
});
}
(async () => {
const dir = await buildFolder();
// eslint-disable-next-line no-console
console.log('Created build directory', dir);
await copyStaticFolder(dir);
copyStaticFolder(dir);
await compileDefaultPlugins(path.join(dir, 'defaultPlugins'));
await compile(dir, path.join(__dirname, '..', 'src', 'init.js'));
const versionNumber = await modifyPackageManifest(dir);
const versionNumber = getVersionNumber();
modifyPackageManifest(dir, versionNumber);
generateManifest(versionNumber);
await buildDist(dir);
// eslint-disable-next-line no-console

View File

@@ -86,9 +86,19 @@ function buildFolder() {
}).catch(die);
}
function getVersionNumber() {
let {version} = require('../package.json');
const buildNumber = process.argv.join(' ').match(/--version=(\d+)/);
if (buildNumber && buildNumber.length > 0) {
version = [...version.split('.').slice(0, 2), buildNumber[1]].join('.');
}
return version;
}
module.exports = {
buildFolder,
compile,
die,
compileDefaultPlugins,
getVersionNumber,
};