@tensorflow/tfjs-core
Version:
Hardware-accelerated JavaScript library for machine intelligence
113 lines (100 loc) • 3.78 kB
text/typescript
/**
* @license
* Copyright 2018 Google LLC. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* =============================================================================
*/
import {IOHandler} from './types';
export type IORouter = (url: string|string[], onProgress?: Function) =>
IOHandler;
export class IORouterRegistry {
// Singleton instance.
private static instance: IORouterRegistry;
private saveRouters: IORouter[];
private loadRouters: IORouter[];
private constructor() {
this.saveRouters = [];
this.loadRouters = [];
}
private static getInstance(): IORouterRegistry {
if (IORouterRegistry.instance == null) {
IORouterRegistry.instance = new IORouterRegistry();
}
return IORouterRegistry.instance;
}
/**
* Register a save-handler router.
*
* @param saveRouter A function that maps a URL-like string onto an instance
* of `IOHandler` with the `save` method defined or `null`.
*/
static registerSaveRouter(saveRouter: IORouter) {
IORouterRegistry.getInstance().saveRouters.push(saveRouter);
}
/**
* Register a load-handler router.
*
* @param loadRouter A function that maps a URL-like string onto an instance
* of `IOHandler` with the `load` method defined or `null`.
*/
static registerLoadRouter(loadRouter: IORouter) {
IORouterRegistry.getInstance().loadRouters.push(loadRouter);
}
/**
* Look up IOHandler for saving, given a URL-like string.
*
* @param url
* @returns If only one match is found, an instance of IOHandler with the
* `save` method defined. If no match is found, `null`.
* @throws Error, if more than one match is found.
*/
static getSaveHandlers(url: string|string[]): IOHandler[] {
return IORouterRegistry.getHandlers(url, 'save');
}
/**
* Look up IOHandler for loading, given a URL-like string.
*
* @param url
* @param onProgress Optional, progress callback function, fired periodically
* before the load is completed.
* @returns All valid handlers for `url`, given the currently registered
* handler routers.
*/
static getLoadHandlers(url: string|string[], onProgress?: Function):
IOHandler[] {
return IORouterRegistry.getHandlers(url, 'load', onProgress);
}
private static getHandlers(
url: string|string[], handlerType: 'save'|'load',
onProgress?: Function): IOHandler[] {
const validHandlers: IOHandler[] = [];
const routers = handlerType === 'load' ?
IORouterRegistry.getInstance().loadRouters :
IORouterRegistry.getInstance().saveRouters;
routers.forEach(router => {
const handler = router(url, onProgress);
if (handler !== null) {
validHandlers.push(handler);
}
});
return validHandlers;
}
}
export const registerSaveRouter = (loudRouter: IORouter) =>
IORouterRegistry.registerSaveRouter(loudRouter);
export const registerLoadRouter = (loudRouter: IORouter) =>
IORouterRegistry.registerLoadRouter(loudRouter);
export const getSaveHandlers = (url: string|string[]) =>
IORouterRegistry.getSaveHandlers(url);
export const getLoadHandlers = (url: string|string[], onProgress?: Function) =>
IORouterRegistry.getLoadHandlers(url, onProgress);