UNPKG

packfs-core

Version:

Semantic filesystem operations for LLM agent frameworks with natural language understanding. See LLM_AGENT_GUIDE.md for copy-paste examples.

231 lines 7.25 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); Object.defineProperty(exports, "__esModule", { value: true }); exports.CustomTransport = exports.MemoryTransport = exports.CategoryLogger = exports.Logger = exports.FileTransport = exports.ConsoleTransport = exports.LogLevel = void 0; const fs = __importStar(require("fs")); const path = __importStar(require("path")); var LogLevel; (function (LogLevel) { LogLevel[LogLevel["DEBUG"] = 0] = "DEBUG"; LogLevel[LogLevel["INFO"] = 1] = "INFO"; LogLevel[LogLevel["WARN"] = 2] = "WARN"; LogLevel[LogLevel["ERROR"] = 3] = "ERROR"; LogLevel[LogLevel["NONE"] = 4] = "NONE"; })(LogLevel || (exports.LogLevel = LogLevel = {})); class ConsoleTransport { formatLevel(level) { switch (level) { case LogLevel.DEBUG: return 'DEBUG'; case LogLevel.INFO: return 'INFO'; case LogLevel.WARN: return 'WARN'; case LogLevel.ERROR: return 'ERROR'; default: return 'UNKNOWN'; } } log(entry) { const timestamp = entry.timestamp.toISOString(); const level = this.formatLevel(entry.level); const message = `[${timestamp}] [${level}] [${entry.category}] ${entry.message}`; if (entry.data) { console.log(message, entry.data); } else { console.log(message); } } } exports.ConsoleTransport = ConsoleTransport; class FileTransport { constructor(filePath, append = true) { this.filePath = filePath; this.append = append; this.stream = null; this.initializeStream(); } initializeStream() { this.ensureDirectory(); this.stream = fs.createWriteStream(this.filePath, { flags: this.append ? 'a' : 'w', encoding: 'utf8' }); } ensureDirectory() { const dir = path.dirname(this.filePath); if (!fs.existsSync(dir)) { fs.mkdirSync(dir, { recursive: true }); } } formatLevel(level) { switch (level) { case LogLevel.DEBUG: return 'DEBUG'; case LogLevel.INFO: return 'INFO'; case LogLevel.WARN: return 'WARN'; case LogLevel.ERROR: return 'ERROR'; default: return 'UNKNOWN'; } } log(entry) { if (!this.stream) return; const timestamp = entry.timestamp.toISOString(); const level = this.formatLevel(entry.level); const message = `[${timestamp}] [${level}] [${entry.category}] ${entry.message}`; if (entry.data) { this.stream.write(`${message} ${JSON.stringify(entry.data)}\n`); } else { this.stream.write(`${message}\n`); } } close() { if (this.stream) { this.stream.end(); this.stream = null; } } } exports.FileTransport = FileTransport; class Logger { constructor() { this.config = { level: LogLevel.INFO, transports: [new ConsoleTransport()] }; } static getInstance() { if (!Logger.instance) { Logger.instance = new Logger(); } return Logger.instance; } configure(config) { if (config.level !== undefined) { this.config.level = config.level; } if (config.transports !== undefined) { this.config.transports = config.transports; } } shouldLog(level) { return level >= this.config.level; } log(level, category, message, data) { if (!this.shouldLog(level)) return; const entry = { timestamp: new Date(), level, category, message, data }; for (const transport of this.config.transports) { try { const result = transport.log(entry); if (result instanceof Promise) { result.catch(err => console.error('Logging transport error:', err)); } } catch (err) { console.error('Logging transport error:', err); } } } debug(category, message, data) { this.log(LogLevel.DEBUG, category, message, data); } info(category, message, data) { this.log(LogLevel.INFO, category, message, data); } warn(category, message, data) { this.log(LogLevel.WARN, category, message, data); } error(category, message, data) { this.log(LogLevel.ERROR, category, message, data); } createChildLogger(category) { return new CategoryLogger(this, category); } } exports.Logger = Logger; Logger.instance = null; class CategoryLogger { constructor(logger, category) { this.logger = logger; this.category = category; } debug(message, data) { this.logger.debug(this.category, message, data); } info(message, data) { this.logger.info(this.category, message, data); } warn(message, data) { this.logger.warn(this.category, message, data); } error(message, data) { this.logger.error(this.category, message, data); } } exports.CategoryLogger = CategoryLogger; class MemoryTransport { constructor(maxSize = 1000) { this.logs = []; this.maxSize = maxSize; } log(entry) { this.logs.push(entry); if (this.logs.length > this.maxSize) { this.logs.shift(); } } getLogs() { return [...this.logs]; } clear() { this.logs = []; } } exports.MemoryTransport = MemoryTransport; class CustomTransport { constructor(logFunction) { this.logFunction = logFunction; } log(entry) { return this.logFunction(entry); } } exports.CustomTransport = CustomTransport; //# sourceMappingURL=logger.js.map