kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
160 lines (155 loc) • 18 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.getDuckDB = exports.DEBUG = void 0;
exports.initializeDuckDb = initializeDuckDb;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _duckdbWasm = _interopRequireWildcard(require("@duckdb/duckdb-wasm"));
var duckdb = _duckdbWasm;
var _perf = require("./utils/perf");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
// git@github.com:holdenmatt/duckdb-wasm-kit.git
var DEBUG;
var DuckDB;
/**
* Initialize DuckDB, ensuring we only initialize it once.
*
* @param debug If true, log DuckDB logs and elapsed times to the console.
* @param config An optional DuckDBConfig object.
*/
function initializeDuckDb(_x) {
return _initializeDuckDb2.apply(this, arguments);
}
/**
* Initialize DuckDB with a browser-specific Wasm bundle.
*/
function _initializeDuckDb2() {
_initializeDuckDb2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3(options) {
var _ref3, _ref3$debug, debug, config;
return _regenerator["default"].wrap(function _callee3$(_context3) {
while (1) switch (_context3.prev = _context3.next) {
case 0:
_ref3 = options || {}, _ref3$debug = _ref3.debug, debug = _ref3$debug === void 0 ? false : _ref3$debug, config = _ref3.config;
exports.DEBUG = DEBUG = debug;
if (DuckDB === undefined) {
DuckDB = _initializeDuckDb(config);
}
return _context3.abrupt("return", DuckDB);
case 4:
case "end":
return _context3.stop();
}
}, _callee3);
}));
return _initializeDuckDb2.apply(this, arguments);
}
var _initializeDuckDb = /*#__PURE__*/function () {
var _ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(config) {
var start, JSDELIVR_BUNDLES, bundle, worker_url, worker, logger, db, res, buffer, fileNameMatch;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
start = performance.now(); // Select a bundle based on browser checks
JSDELIVR_BUNDLES = duckdb.getJsDelivrBundles();
_context.next = 4;
return duckdb.selectBundle(JSDELIVR_BUNDLES);
case 4:
bundle = _context.sent;
if (bundle.mainWorker) {
_context.next = 7;
break;
}
throw new Error('Failed to initialize DuckDB');
case 7:
worker_url = URL.createObjectURL(new Blob(["importScripts(\"".concat(bundle.mainWorker, "\");")], {
type: 'text/javascript'
})); // Instantiate the async version of DuckDB-wasm
worker = new Worker(worker_url);
logger = DEBUG ? new duckdb.ConsoleLogger() : new duckdb.VoidLogger();
db = new _duckdbWasm.AsyncDuckDB(logger, worker);
_context.next = 13;
return db.instantiate(bundle.mainModule, bundle.pthreadWorker);
case 13:
URL.revokeObjectURL(worker_url);
if (!config) {
_context.next = 28;
break;
}
if (!config.path) {
_context.next = 26;
break;
}
_context.next = 18;
return fetch(config.path);
case 18:
res = _context.sent;
_context.next = 21;
return res.arrayBuffer();
case 21:
buffer = _context.sent;
fileNameMatch = config.path.match(/[^/]*$/);
if (fileNameMatch) {
config.path = fileNameMatch[0];
}
_context.next = 26;
return db.registerFileBuffer(config.path, new Uint8Array(buffer));
case 26:
_context.next = 28;
return db.open(config);
case 28:
if (DEBUG) {
(0, _perf.logElapsedTime)('DuckDB initialized', start);
if (config) {
console.debug("DuckDbConfig: ".concat(JSON.stringify(config, null, 2)));
}
}
return _context.abrupt("return", db);
case 30:
case "end":
return _context.stop();
}
}, _callee);
}));
return function _initializeDuckDb(_x2) {
return _ref.apply(this, arguments);
};
}();
/**
* Get the instance of DuckDB, initializing it if needed.
*
* Typically `useDuckDB` is used in React components instead, but this
* method provides access outside of React contexts.
*/
var getDuckDB = exports.getDuckDB = /*#__PURE__*/function () {
var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
return _regenerator["default"].wrap(function _callee2$(_context2) {
while (1) switch (_context2.prev = _context2.next) {
case 0:
if (!DuckDB) {
_context2.next = 4;
break;
}
return _context2.abrupt("return", DuckDB);
case 4:
_context2.next = 6;
return initializeDuckDb();
case 6:
return _context2.abrupt("return", _context2.sent);
case 7:
case "end":
return _context2.stop();
}
}, _callee2);
}));
return function getDuckDB() {
return _ref2.apply(this, arguments);
};
}();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_duckdbWasm","_interopRequireWildcard","require","duckdb","_perf","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DEBUG","DuckDB","initializeDuckDb","_x","_initializeDuckDb2","apply","arguments","_asyncToGenerator2","_regenerator","mark","_callee3","options","_ref3","_ref3$debug","debug","config","wrap","_callee3$","_context3","prev","next","exports","undefined","_initializeDuckDb","abrupt","stop","_ref","_callee","start","JSDELIVR_BUNDLES","bundle","worker_url","worker","logger","db","res","buffer","fileNameMatch","_callee$","_context","performance","now","getJsDelivrBundles","selectBundle","sent","mainWorker","Error","URL","createObjectURL","Blob","concat","type","Worker","ConsoleLogger","VoidLogger","AsyncDuckDB","instantiate","mainModule","pthreadWorker","revokeObjectURL","path","fetch","arrayBuffer","match","registerFileBuffer","Uint8Array","open","logElapsedTime","console","JSON","stringify","_x2","getDuckDB","_ref2","_callee2","_callee2$","_context2"],"sources":["../src/init.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n// git@github.com:holdenmatt/duckdb-wasm-kit.git\nimport * as duckdb from '@duckdb/duckdb-wasm';\nimport {AsyncDuckDB, DuckDBConfig} from '@duckdb/duckdb-wasm';\nimport {logElapsedTime} from './utils/perf';\n\nexport let DEBUG: boolean | undefined;\n\nlet DuckDB: Promise<AsyncDuckDB> | undefined;\n\n/**\n * Initialize DuckDB, ensuring we only initialize it once.\n *\n * @param debug If true, log DuckDB logs and elapsed times to the console.\n * @param config An optional DuckDBConfig object.\n */\nexport async function initializeDuckDb(options?: {\n  debug?: boolean;\n  config?: DuckDBConfig;\n}): Promise<AsyncDuckDB> {\n  const {debug = false, config} = options || {};\n  DEBUG = debug;\n\n  if (DuckDB === undefined) {\n    DuckDB = _initializeDuckDb(config);\n  }\n  return DuckDB;\n}\n\n/**\n * Initialize DuckDB with a browser-specific Wasm bundle.\n */\nconst _initializeDuckDb = async (config?: DuckDBConfig): Promise<AsyncDuckDB> => {\n  const start = performance.now();\n\n  // Select a bundle based on browser checks\n  const JSDELIVR_BUNDLES = duckdb.getJsDelivrBundles();\n  const bundle = await duckdb.selectBundle(JSDELIVR_BUNDLES);\n  if (!bundle.mainWorker) {\n    throw new Error('Failed to initialize DuckDB');\n  }\n\n  const worker_url = URL.createObjectURL(\n    new Blob([`importScripts(\"${bundle.mainWorker}\");`], {\n      type: 'text/javascript'\n    })\n  );\n\n  // Instantiate the async version of DuckDB-wasm\n  const worker = new Worker(worker_url);\n  const logger = DEBUG ? new duckdb.ConsoleLogger() : new duckdb.VoidLogger();\n  const db = new AsyncDuckDB(logger, worker);\n  await db.instantiate(bundle.mainModule, bundle.pthreadWorker);\n  URL.revokeObjectURL(worker_url);\n\n  if (config) {\n    if (config.path) {\n      const res = await fetch(config.path);\n      const buffer = await res.arrayBuffer();\n      const fileNameMatch = config.path.match(/[^/]*$/);\n      if (fileNameMatch) {\n        config.path = fileNameMatch[0];\n      }\n      await db.registerFileBuffer(config.path, new Uint8Array(buffer));\n    }\n    await db.open(config);\n  }\n\n  if (DEBUG) {\n    logElapsedTime('DuckDB initialized', start);\n    if (config) {\n      console.debug(`DuckDbConfig: ${JSON.stringify(config, null, 2)}`);\n    }\n  }\n  return db;\n};\n\n/**\n * Get the instance of DuckDB, initializing it if needed.\n *\n * Typically `useDuckDB` is used in React components instead, but this\n * method provides access outside of React contexts.\n */\nexport const getDuckDB = async (): Promise<AsyncDuckDB> => {\n  if (DuckDB) {\n    return DuckDB;\n  } else {\n    return await initializeDuckDb();\n  }\n};\n"],"mappings":"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","ignoreList":[]}
;