thedesk/app/node_modules/app-builder-lib/out/util/cacheManager.js
2019-09-12 23:38:13 +09:00

150 lines
3.9 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.digest = digest;
exports.BuildCacheManager = void 0;
function _bluebirdLst() {
const data = _interopRequireDefault(require("bluebird-lst"));
_bluebirdLst = function () {
return data;
};
return data;
}
function _builderUtil() {
const data = require("builder-util");
_builderUtil = function () {
return data;
};
return data;
}
function _fs() {
const data = require("builder-util/out/fs");
_fs = function () {
return data;
};
return data;
}
function _promise() {
const data = require("builder-util/out/promise");
_promise = function () {
return data;
};
return data;
}
function _fsExtra() {
const data = require("fs-extra");
_fsExtra = function () {
return data;
};
return data;
}
var path = _interopRequireWildcard(require("path"));
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
class BuildCacheManager {
constructor(outDir, executableFile, arch) {
this.executableFile = executableFile;
this.cacheInfo = null;
this.newDigest = null;
this.cacheDir = path.join(outDir, ".cache", _builderUtil().Arch[arch]);
this.cacheFile = path.join(this.cacheDir, "app.exe");
this.cacheInfoFile = path.join(this.cacheDir, "info.json");
}
async copyIfValid(digest) {
this.newDigest = digest;
this.cacheInfo = await (0, _promise().orNullIfFileNotExist)((0, _fsExtra().readJson)(this.cacheInfoFile));
const oldDigest = this.cacheInfo == null ? null : this.cacheInfo.executableDigest;
if (oldDigest !== digest) {
_builderUtil().log.debug({
oldDigest,
newDigest: digest
}, "no valid cached executable found");
return false;
}
_builderUtil().log.debug({
cacheFile: this.cacheFile,
file: this.executableFile
}, `copying cached executable`);
try {
await (0, _fs().copyFile)(this.cacheFile, this.executableFile, false);
return true;
} catch (e) {
if (e.code === "ENOENT" || e.code === "ENOTDIR") {
_builderUtil().log.debug({
error: e.code
}, "copy cached executable failed");
} else {
_builderUtil().log.warn({
error: e.stack || e
}, `cannot copy cached executable`);
}
}
return false;
}
async save() {
if (this.newDigest == null) {
throw new Error("call copyIfValid before");
}
if (this.cacheInfo == null) {
this.cacheInfo = {
executableDigest: this.newDigest
};
} else {
this.cacheInfo.executableDigest = this.newDigest;
}
try {
await (0, _fsExtra().ensureDir)(this.cacheDir);
await Promise.all([(0, _fsExtra().writeJson)(this.cacheInfoFile, this.cacheInfo), (0, _fs().copyFile)(this.executableFile, this.cacheFile, false)]);
} catch (e) {
_builderUtil().log.warn({
error: e.stack || e
}, `cannot save build cache`);
}
}
}
exports.BuildCacheManager = BuildCacheManager;
BuildCacheManager.VERSION = "0";
async function digest(hash, files) {
// do not use pipe - better do bulk file read (https://github.com/yarnpkg/yarn/commit/7a63e0d23c46a4564bc06645caf8a59690f04d01)
for (const content of await _bluebirdLst().default.map(files, it => (0, _fsExtra().readFile)(it))) {
hash.update(content);
}
hash.update(BuildCacheManager.VERSION);
return hash.digest("base64");
}
// __ts-babel@6.0.4
//# sourceMappingURL=cacheManager.js.map