/** * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * * @format */ "use strict"; function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === "function") { ownKeys = ownKeys.concat( Object.getOwnPropertySymbols(source).filter(function(sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; }) ); } ownKeys.forEach(function(key) { _defineProperty(target, key, source[key]); }); } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } const os = require("os"); const path = require("path"); const process = require("process"); const _require = require("events"), EventEmitter = _require.EventEmitter; const VERSION = require("../package.json").version; const log_session = `${os.hostname()}-${Date.now()}`; const eventEmitter = new EventEmitter(); function on(event, handler) { eventEmitter.on(event, handler); } function createEntry(data) { const logEntry = typeof data === "string" ? { log_entry_label: data } : data; const entryPoint = logEntry.entry_point; if (entryPoint) { logEntry.entry_point = path.relative(process.cwd(), entryPoint); } return _objectSpread({}, logEntry, { log_session, metro_bundler_version: VERSION }); } function createActionStartEntry(data) { const logEntry = typeof data === "string" ? { action_name: data } : data; const action_name = logEntry.action_name; return createEntry( _objectSpread({}, logEntry, { action_name, action_phase: "start", log_entry_label: action_name, start_timestamp: process.hrtime() }) ); } function createActionEndEntry(logEntry) { const action_name = logEntry.action_name, action_phase = logEntry.action_phase, start_timestamp = logEntry.start_timestamp; if (action_phase !== "start" || !Array.isArray(start_timestamp)) { throw new Error("Action has not started or has already ended"); } const timeDelta = process.hrtime(start_timestamp); const duration_ms = Math.round((timeDelta[0] * 1e9 + timeDelta[1]) / 1e6); return createEntry( _objectSpread({}, logEntry, { action_name, action_phase: "end", duration_ms, log_entry_label: action_name }) ); } function log(logEntry) { eventEmitter.emit("log", logEntry); return logEntry; } module.exports = { on, createEntry, createActionStartEntry, createActionEndEntry, log };