@synthart/synthlite
Version:
A fast, lightweight Gen AI powered synthetic data generator written in TypeScript. 🌞
78 lines (77 loc) • 3.11 kB
JavaScript
;
/**
*
* @file synthlite-emitter.ts
* @description 🚀 SynthliteEmitter is a singleton class that extends EventEmitter to handle custom events.
* @date January 2024
* @version 1.0.0
* @license Affero General Public License v3.0
* ✨ "Move fast, break things." — Meta Platforms, Inc.
*
*/
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.SynthliteEmitter = void 0;
const events_1 = require("events");
const generated_dataset_1 = require("./generated-dataset");
/**
* SynthliteEmitter: Singleton class extending EventEmitter to handle custom events.
* @class SynthliteEmitter
*/
class SynthliteEmitter extends events_1.EventEmitter {
/**
* Private constructor to prevent direct instantiation.
*/
constructor() {
super();
this.EVENT_WRITE_DATA = "synthlite:write_data";
}
/**
* Returns the singleton instance of SynthliteEmitter.
* @returns {SynthliteEmitter} - The singleton instance.
*/
static getInstance() {
if (!this.instance) {
this.instance = new SynthliteEmitter();
}
return this.instance;
}
/**
* Emits a custom event with the given arguments.
* @param {string} event - The event name.
* @param {any[]} args - The arguments to pass to the event listeners.
*/
emitEvent(event, ...args) {
this.emit(event, ...args);
}
/**
* Adds a listener for the specified event.
* @param {string} event - The event name.
* @param {(...args: any[]) => void} listener - The listener function.
*/
addEventListener(event, listener) {
this.on(event, listener);
}
/**
* Sets up a listener for the "synthlite:write_data" event and saves the generated data to a file.
* @param options The CLI options created by the user
* @description Adds a listener for the "synthlite:write_data" event and saves the generated data to a file.
* @returns void
*/
addOnDataGeneratedSaveFileListener(options) {
const emitter = SynthliteEmitter.getInstance();
emitter.on(this.EVENT_WRITE_DATA, (data) => __awaiter(this, void 0, void 0, function* () {
const generatedDataset = new generated_dataset_1.GeneratedDataset(data);
yield generatedDataset.saveToFile(options.output, options.format);
}));
}
}
exports.SynthliteEmitter = SynthliteEmitter;