polymer-build
Version:
A library of Gulp build tasks
60 lines (50 loc) • 1.9 kB
text/typescript
/**
* @license
* Copyright (c) 2016 The Polymer Project Authors. All rights reserved.
* This code may only be used under the BSD style license found at
* http://polymer.github.io/LICENSE.txt
* The complete set of authors may be found at
* http://polymer.github.io/AUTHORS.txt
* The complete set of contributors may be found at
* http://polymer.github.io/CONTRIBUTORS.txt
* Code distributed by Google as part of the polymer project is also
* subject to an additional IP rights grant found at
* http://polymer.github.io/PATENTS.txt
*/
import {ResolvedUrl, UrlLoader} from 'polymer-analyzer';
import {getFileContents} from './streams';
import File = require('vinyl');
/**
* This is a `UrlLoader` for use with a `polymer-analyzer` that reads files
* that have been gathered by a `BuildBundler` transform stream.
*/
export class FileMapUrlLoader implements UrlLoader {
files: Map<ResolvedUrl, File>;
fallbackLoader?: UrlLoader;
constructor(files: Map<ResolvedUrl, File>, fallbackLoader?: UrlLoader) {
this.files = files;
this.fallbackLoader = fallbackLoader;
}
// Return true if we can return load the given url.
canLoad(url: ResolvedUrl): boolean {
return !!(
this.files.has(url) ||
this.fallbackLoader && this.fallbackLoader.canLoad(url));
}
// Try to load the file from the map. If not in the map, try to load
// from the fallback loader.
async load(url: ResolvedUrl): Promise<string> {
const file = this.files.get(url);
if (file == null) {
if (this.fallbackLoader) {
if (this.fallbackLoader.canLoad(url)) {
return this.fallbackLoader.load(url);
}
throw new Error(
`${url} not present in file map and fallback loader can not load.`);
}
throw new Error(`${url} not present in file map and no fallback loader.`);
}
return getFileContents(file);
}
}