You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.4 KiB
69 lines
2.4 KiB
"use strict"; |
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); |
|
|
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); |
|
|
|
/* |
|
Copyright 2018 Google LLC |
|
|
|
Use of this source code is governed by an MIT-style |
|
license that can be found in the LICENSE file or at |
|
https://opensource.org/licenses/MIT. |
|
*/ |
|
const checkForDeprecatedOptions = require('../lib/check-for-deprecated-options'); |
|
|
|
const getFileManifestEntries = require('../lib/get-file-manifest-entries'); |
|
|
|
const getManifestSchema = require('./options/get-manifest-schema'); |
|
|
|
const validate = require('./options/validate'); |
|
/** |
|
* This method returns a list of URLs to precache, referred to as a "precache |
|
* manifest", along with details about the number of entries and their size, |
|
* based on the options you provide. |
|
* |
|
* @param {Object} config Please refer to the |
|
* [configuration guide](https://developers.google.com/web/tools/workbox/modules/workbox-build#getmanifest_mode). |
|
* @return {Promise<{manifestEntries: Array<ManifestEntry>, |
|
* count: number, size: number, warnings: Array<string>}>} A promise that |
|
* resolves once the precache manifest is determined. The `size` property |
|
* contains the aggregate size of all the precached entries, in bytes, the |
|
* `count` property contains the total number of precached entries, and the |
|
* `manifestEntries` property contains all the `ManifestEntry` items. Any |
|
* non-fatal warning messages will be returned via `warnings`. |
|
* |
|
* @memberof module:workbox-build |
|
*/ |
|
|
|
|
|
function getManifest(_x) { |
|
return _getManifest.apply(this, arguments); |
|
} |
|
|
|
function _getManifest() { |
|
_getManifest = (0, _asyncToGenerator2.default)(function* (config) { |
|
// This check needs to be done before validation, since the deprecated options |
|
// will be renamed. |
|
const deprecationWarnings = checkForDeprecatedOptions(config); |
|
const options = validate(config, getManifestSchema); |
|
|
|
const _ref = yield getFileManifestEntries(options), |
|
manifestEntries = _ref.manifestEntries, |
|
count = _ref.count, |
|
size = _ref.size, |
|
warnings = _ref.warnings; // Add in any deprecation warnings. |
|
|
|
|
|
warnings.push(...deprecationWarnings); |
|
return { |
|
manifestEntries, |
|
count, |
|
size, |
|
warnings |
|
}; |
|
}); |
|
return _getManifest.apply(this, arguments); |
|
} |
|
|
|
module.exports = getManifest; |