@sochdb/sochdb 0.5.1 → 0.5.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +357 -3164
- package/_bin/aarch64-apple-darwin/libsochdb_storage.dylib +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-bulk +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-grpc-server +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-server +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-bulk.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-grpc-server.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb_storage.dll +0 -0
- package/_bin/x86_64-unknown-linux-gnu/libsochdb_storage.so +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-bulk +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-grpc-server +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-server +0 -0
- package/dist/cjs/embedded/database.js +279 -1
- package/dist/cjs/index.js +3 -3
- package/dist/cjs/namespace.js +33 -6
- package/dist/cjs/queue.js +143 -24
- package/dist/esm/embedded/database.js +279 -1
- package/dist/esm/index.js +3 -3
- package/dist/esm/namespace.js +33 -6
- package/dist/esm/queue.js +143 -24
- package/dist/types/embedded/database.d.ts +69 -0
- package/dist/types/embedded/database.d.ts.map +1 -1
- package/dist/types/index.d.ts +2 -2
- package/dist/types/namespace.d.ts.map +1 -1
- package/dist/types/queue.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/esm/queue.js
CHANGED
|
@@ -96,21 +96,73 @@ function encodeQueueKey(key) {
|
|
|
96
96
|
return Buffer.concat(parts);
|
|
97
97
|
}
|
|
98
98
|
/**
|
|
99
|
-
* Decode queue key from bytes
|
|
99
|
+
* Decode queue key from bytes using positional parsing.
|
|
100
|
+
* Key format: "queue/" + queueId + "/" + i64BE(priority) + "/" + u64BE(readyTs) + "/" + u64BE(sequence) + "/" + taskId
|
|
101
|
+
* Binary fields may contain 0x2F ('/'), so split('/') is NOT safe.
|
|
100
102
|
*/
|
|
101
103
|
function decodeQueueKey(data) {
|
|
102
|
-
|
|
103
|
-
const
|
|
104
|
-
if (
|
|
105
|
-
throw new errors_1.SochDBError('Invalid queue key format');
|
|
104
|
+
// Must start with "queue/"
|
|
105
|
+
const prefix = Buffer.from('queue/');
|
|
106
|
+
if (data.length < prefix.length || data.subarray(0, prefix.length).compare(prefix) !== 0) {
|
|
107
|
+
throw new errors_1.SochDBError('Invalid queue key format: missing queue/ prefix');
|
|
106
108
|
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
109
|
+
let offset = prefix.length;
|
|
110
|
+
// Find queueId: scan for the '/' before the 8-byte priority field
|
|
111
|
+
// The queueId ends at the first '/' followed by exactly 8 bytes + '/' + 8 bytes + '/' + 8 bytes + '/' + taskId
|
|
112
|
+
// Strategy: walk from the end. Structure after queueId:
|
|
113
|
+
// "/" + 8-byte priority + "/" + 8-byte readyTs + "/" + 8-byte sequence + "/" + taskId
|
|
114
|
+
// Total fixed overhead after queueId: 1 + 8 + 1 + 8 + 1 + 8 + 1 = 28 bytes, then taskId
|
|
115
|
+
// Find queueId by scanning for '/' such that remaining = 28 + taskId.len
|
|
116
|
+
// We know: after queueId, fixed structure is:
|
|
117
|
+
// /[8 bytes]/[8 bytes]/[8 bytes]/[taskId]
|
|
118
|
+
// So scan forward to find the separator. QueueId is a plain string (no binary),
|
|
119
|
+
// so find the first '/' after "queue/" that has at least 28 bytes remaining after it.
|
|
120
|
+
let queueIdEnd = -1;
|
|
121
|
+
for (let i = offset; i < data.length; i++) {
|
|
122
|
+
if (data[i] === 0x2F) { // '/'
|
|
123
|
+
const remaining = data.length - i - 1; // bytes after this '/'
|
|
124
|
+
// Need 8 (priority) + 1 (/) + 8 (readyTs) + 1 (/) + 8 (sequence) + 1 (/) + at least 1 (taskId) = 28
|
|
125
|
+
if (remaining >= 28) {
|
|
126
|
+
queueIdEnd = i;
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
if (queueIdEnd < 0) {
|
|
132
|
+
throw new errors_1.SochDBError('Invalid queue key format: cannot find queueId');
|
|
133
|
+
}
|
|
134
|
+
const queueId = data.subarray(offset, queueIdEnd).toString();
|
|
135
|
+
offset = queueIdEnd + 1; // skip '/'
|
|
136
|
+
// Read priority (8 bytes, i64 big-endian order-preserving)
|
|
137
|
+
if (offset + 8 > data.length)
|
|
138
|
+
throw new errors_1.SochDBError('Invalid queue key: truncated priority');
|
|
139
|
+
const priority = decodeI64BE(data.subarray(offset, offset + 8));
|
|
140
|
+
offset += 8;
|
|
141
|
+
// Skip '/'
|
|
142
|
+
if (data[offset] !== 0x2F)
|
|
143
|
+
throw new errors_1.SochDBError('Invalid queue key: expected / after priority');
|
|
144
|
+
offset += 1;
|
|
145
|
+
// Read readyTs (8 bytes, u64 big-endian)
|
|
146
|
+
if (offset + 8 > data.length)
|
|
147
|
+
throw new errors_1.SochDBError('Invalid queue key: truncated readyTs');
|
|
148
|
+
const readyTs = decodeU64BE(data.subarray(offset, offset + 8));
|
|
149
|
+
offset += 8;
|
|
150
|
+
// Skip '/'
|
|
151
|
+
if (data[offset] !== 0x2F)
|
|
152
|
+
throw new errors_1.SochDBError('Invalid queue key: expected / after readyTs');
|
|
153
|
+
offset += 1;
|
|
154
|
+
// Read sequence (8 bytes, u64 big-endian)
|
|
155
|
+
if (offset + 8 > data.length)
|
|
156
|
+
throw new errors_1.SochDBError('Invalid queue key: truncated sequence');
|
|
157
|
+
const sequence = decodeU64BE(data.subarray(offset, offset + 8));
|
|
158
|
+
offset += 8;
|
|
159
|
+
// Skip '/'
|
|
160
|
+
if (data[offset] !== 0x2F)
|
|
161
|
+
throw new errors_1.SochDBError('Invalid queue key: expected / after sequence');
|
|
162
|
+
offset += 1;
|
|
163
|
+
// Remaining is taskId
|
|
164
|
+
const taskId = data.subarray(offset).toString();
|
|
165
|
+
return { queueId, priority, readyTs, sequence, taskId };
|
|
114
166
|
}
|
|
115
167
|
// ============================================================================
|
|
116
168
|
// Priority Queue
|
|
@@ -183,9 +235,42 @@ class PriorityQueue {
|
|
|
183
235
|
*/
|
|
184
236
|
async dequeue(workerId) {
|
|
185
237
|
const now = Date.now();
|
|
186
|
-
const prefix = `queue/${this.config.name}
|
|
187
|
-
//
|
|
188
|
-
|
|
238
|
+
const prefix = Buffer.from(`queue/${this.config.name}/`);
|
|
239
|
+
// Scan all tasks in priority order (binary sort = priority order due to big-endian encoding)
|
|
240
|
+
try {
|
|
241
|
+
for await (const [keyBuf, valueBuf] of this.db.scanPrefix(prefix)) {
|
|
242
|
+
const task = JSON.parse(valueBuf.toString());
|
|
243
|
+
// Skip non-pending tasks
|
|
244
|
+
if (task.state !== TaskState.PENDING) {
|
|
245
|
+
continue;
|
|
246
|
+
}
|
|
247
|
+
// Decode key to check readyTs
|
|
248
|
+
try {
|
|
249
|
+
const queueKey = decodeQueueKey(keyBuf);
|
|
250
|
+
if (queueKey.readyTs > now) {
|
|
251
|
+
continue; // Not ready yet
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
catch {
|
|
255
|
+
continue; // Skip malformed keys
|
|
256
|
+
}
|
|
257
|
+
// Claim this task atomically
|
|
258
|
+
task.state = TaskState.CLAIMED;
|
|
259
|
+
task.claimedAt = now;
|
|
260
|
+
task.claimedBy = workerId;
|
|
261
|
+
// Re-serialize the payload correctly (it's stored as base64 in JSON)
|
|
262
|
+
const updatedValue = Buffer.from(JSON.stringify(task));
|
|
263
|
+
await this.db.put(keyBuf, updatedValue);
|
|
264
|
+
// Update stats
|
|
265
|
+
await this.decrementStat('pending');
|
|
266
|
+
await this.incrementStat('claimed');
|
|
267
|
+
await this.incrementStat('totalDequeued');
|
|
268
|
+
return task;
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
catch {
|
|
272
|
+
// If scan is not available via scanPrefix, return null
|
|
273
|
+
}
|
|
189
274
|
return null;
|
|
190
275
|
}
|
|
191
276
|
/**
|
|
@@ -193,10 +278,11 @@ class PriorityQueue {
|
|
|
193
278
|
*/
|
|
194
279
|
async ack(taskId) {
|
|
195
280
|
// Find and update task state
|
|
196
|
-
const
|
|
197
|
-
if (!
|
|
281
|
+
const result = await this.getTask(taskId);
|
|
282
|
+
if (!result) {
|
|
198
283
|
throw new errors_1.SochDBError(`Task not found: ${taskId}`);
|
|
199
284
|
}
|
|
285
|
+
const { task } = result;
|
|
200
286
|
if (task.state !== TaskState.CLAIMED) {
|
|
201
287
|
throw new errors_1.SochDBError(`Task not in claimed state: ${taskId}`);
|
|
202
288
|
}
|
|
@@ -212,10 +298,11 @@ class PriorityQueue {
|
|
|
212
298
|
* Negative acknowledge - return task to queue
|
|
213
299
|
*/
|
|
214
300
|
async nack(taskId) {
|
|
215
|
-
const
|
|
216
|
-
if (!
|
|
301
|
+
const result = await this.getTask(taskId);
|
|
302
|
+
if (!result) {
|
|
217
303
|
throw new errors_1.SochDBError(`Task not found: ${taskId}`);
|
|
218
304
|
}
|
|
305
|
+
const { task } = result;
|
|
219
306
|
task.retries++;
|
|
220
307
|
if (task.retries >= (this.config.maxRetries || 3)) {
|
|
221
308
|
// Move to dead letter queue
|
|
@@ -251,19 +338,51 @@ class PriorityQueue {
|
|
|
251
338
|
* Purge completed tasks
|
|
252
339
|
*/
|
|
253
340
|
async purge() {
|
|
254
|
-
|
|
255
|
-
|
|
341
|
+
const prefix = Buffer.from(`queue/${this.config.name}/`);
|
|
342
|
+
let purged = 0;
|
|
343
|
+
try {
|
|
344
|
+
const toDelete = [];
|
|
345
|
+
for await (const [keyBuf, valueBuf] of this.db.scanPrefix(prefix)) {
|
|
346
|
+
const task = JSON.parse(valueBuf.toString());
|
|
347
|
+
if (task.state === TaskState.COMPLETED || task.state === TaskState.DEAD_LETTERED) {
|
|
348
|
+
toDelete.push(keyBuf);
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
for (const key of toDelete) {
|
|
352
|
+
await this.db.delete(key);
|
|
353
|
+
purged++;
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
catch {
|
|
357
|
+
// Return count so far
|
|
358
|
+
}
|
|
359
|
+
return purged;
|
|
256
360
|
}
|
|
257
361
|
// Helper methods
|
|
258
362
|
generateTaskId() {
|
|
259
363
|
return `${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
|
|
260
364
|
}
|
|
261
365
|
async getTask(taskId) {
|
|
262
|
-
|
|
366
|
+
const prefix = Buffer.from(`queue/${this.config.name}/`);
|
|
367
|
+
try {
|
|
368
|
+
for await (const [keyBuf, valueBuf] of this.db.scanPrefix(prefix)) {
|
|
369
|
+
const task = JSON.parse(valueBuf.toString());
|
|
370
|
+
if (task.taskId === taskId) {
|
|
371
|
+
return { task, keyBuf };
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
catch {
|
|
376
|
+
// Scan not available
|
|
377
|
+
}
|
|
263
378
|
return null;
|
|
264
379
|
}
|
|
265
380
|
async updateTask(task) {
|
|
266
|
-
|
|
381
|
+
const result = await this.getTask(task.taskId);
|
|
382
|
+
if (result) {
|
|
383
|
+
const valueBuf = Buffer.from(JSON.stringify(task));
|
|
384
|
+
await this.db.put(result.keyBuf, valueBuf);
|
|
385
|
+
}
|
|
267
386
|
}
|
|
268
387
|
async getStat(name) {
|
|
269
388
|
const key = `_queue_stats/${this.config.name}/${name}`;
|
|
@@ -288,4 +407,4 @@ exports.PriorityQueue = PriorityQueue;
|
|
|
288
407
|
function createQueue(db, name, config) {
|
|
289
408
|
return PriorityQueue.fromDatabase(db, name, config);
|
|
290
409
|
}
|
|
291
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../src/queue.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SochDB Priority Queue\n * \n * First-class queue API with ordered-key task entries, providing efficient\n * priority queue operations without the O(N) blob rewrite anti-pattern.\n * \n * Features:\n * - Ordered-key representation: Each task has its own key, no blob parsing\n * - O(log N) enqueue/dequeue with ordered scans\n * - Atomic claim protocol for concurrent workers\n * - Visibility timeout for crash recovery\n * \n * @example\n * ```typescript\n * import { Database, PriorityQueue } from '@sochdb/sochdb';\n * \n * const db = await Database.open('./queue_db');\n * const queue = PriorityQueue.fromDatabase(db, 'tasks');\n * \n * // Enqueue task\n * await queue.enqueue(1, Buffer.from('high priority task'));\n * \n * // Dequeue and process\n * const task = await queue.dequeue('worker-1');\n * if (task) {\n *   // Process task...\n *   await queue.ack(task.taskId);\n * }\n * ```\n */\n\nimport { SochDBError } from './errors';\n\n// ============================================================================\n// Task State\n// ============================================================================\n\nexport enum TaskState {\n  PENDING = 'pending',\n  CLAIMED = 'claimed',\n  COMPLETED = 'completed',\n  DEAD_LETTERED = 'dead_lettered',\n}\n\n// ============================================================================\n// Queue Configuration\n// ============================================================================\n\nexport interface QueueConfig {\n  name: string;\n  visibilityTimeout?: number; // milliseconds, default 30000\n  maxRetries?: number; // default 3\n  deadLetterQueue?: string;\n}\n\n// ============================================================================\n// Queue Key Encoding\n// ============================================================================\n\n/**\n * Encode u64 as big-endian for lexicographic ordering\n */\nfunction encodeU64BE(value: number): Buffer {\n  const buf = Buffer.allocUnsafe(8);\n  buf.writeBigUInt64BE(BigInt(value));\n  return buf;\n}\n\n/**\n * Decode big-endian u64\n */\nfunction decodeU64BE(buf: Buffer): number {\n  return Number(buf.readBigUInt64BE(0));\n}\n\n/**\n * Encode i64 as big-endian preserving order\n */\nfunction encodeI64BE(value: number): Buffer {\n  // Map i64 to u64 by adding offset\n  const mapped = BigInt(value) + (1n << 63n);\n  const buf = Buffer.allocUnsafe(8);\n  buf.writeBigUInt64BE(mapped);\n  return buf;\n}\n\n/**\n * Decode big-endian i64\n */\nfunction decodeI64BE(buf: Buffer): number {\n  const mapped = buf.readBigUInt64BE(0);\n  return Number(mapped - (1n << 63n));\n}\n\n// ============================================================================\n// Queue Key\n// ============================================================================\n\nexport interface QueueKey {\n  queueId: string;\n  priority: number;\n  readyTs: number; // timestamp in milliseconds\n  sequence: number;\n  taskId: string;\n}\n\n/**\n * Encode queue key to bytes for storage\n */\nfunction encodeQueueKey(key: QueueKey): Buffer {\n  const parts = [\n    Buffer.from('queue/'),\n    Buffer.from(key.queueId),\n    Buffer.from('/'),\n    encodeI64BE(key.priority),\n    Buffer.from('/'),\n    encodeU64BE(key.readyTs),\n    Buffer.from('/'),\n    encodeU64BE(key.sequence),\n    Buffer.from('/'),\n    Buffer.from(key.taskId),\n  ];\n  \n  return Buffer.concat(parts);\n}\n\n/**\n * Decode queue key from bytes\n */\nfunction decodeQueueKey(data: Buffer): QueueKey {\n  const str = data.toString();\n  const parts = str.split('/');\n  \n  if (parts.length < 6 || parts[0] !== 'queue') {\n    throw new SochDBError('Invalid queue key format');\n  }\n  \n  return {\n    queueId: parts[1],\n    priority: 0, // Would need to decode from bytes\n    readyTs: 0,\n    sequence: 0,\n    taskId: parts[parts.length - 1],\n  };\n}\n\n// ============================================================================\n// Task\n// ============================================================================\n\nexport interface Task {\n  taskId: string;\n  priority: number;\n  payload: Buffer;\n  state: TaskState;\n  enqueuedAt: number;\n  claimedAt?: number;\n  claimedBy?: string;\n  completedAt?: number;\n  retries: number;\n  metadata?: Record<string, any>;\n}\n\n// ============================================================================\n// Queue Statistics\n// ============================================================================\n\nexport interface QueueStats {\n  pending: number;\n  claimed: number;\n  completed: number;\n  deadLettered: number;\n  totalEnqueued: number;\n  totalDequeued: number;\n}\n\n// ============================================================================\n// Priority Queue\n// ============================================================================\n\nexport class PriorityQueue {\n  private static sequenceCounter = 0;\n\n  constructor(\n    private db: any,\n    private config: QueueConfig\n  ) {\n    // Set defaults\n    this.config.visibilityTimeout = config.visibilityTimeout || 30000;\n    this.config.maxRetries = config.maxRetries || 3;\n  }\n\n  /**\n   * Create queue from embedded database\n   */\n  static fromDatabase(db: any, name: string, config?: Partial<QueueConfig>): PriorityQueue {\n    const fullConfig: QueueConfig = {\n      name,\n      ...config,\n    };\n    return new PriorityQueue(db, fullConfig);\n  }\n\n  /**\n   * Create queue from gRPC client\n   */\n  static fromClient(client: any, name: string, config?: Partial<QueueConfig>): PriorityQueue {\n    const fullConfig: QueueConfig = {\n      name,\n      ...config,\n    };\n    return new PriorityQueue(client, fullConfig);\n  }\n\n  /**\n   * Enqueue a task with priority\n   * Lower priority number = higher urgency\n   */\n  async enqueue(\n    priority: number,\n    payload: Buffer,\n    metadata?: Record<string, any>\n  ): Promise<string> {\n    const taskId = this.generateTaskId();\n    const now = Date.now();\n    \n    const key: QueueKey = {\n      queueId: this.config.name,\n      priority,\n      readyTs: now,\n      sequence: PriorityQueue.sequenceCounter++,\n      taskId,\n    };\n\n    const task: Task = {\n      taskId,\n      priority,\n      payload,\n      state: TaskState.PENDING,\n      enqueuedAt: now,\n      retries: 0,\n      metadata,\n    };\n\n    const keyBuf = encodeQueueKey(key);\n    const valueBuf = Buffer.from(JSON.stringify(task));\n    \n    await this.db.put(keyBuf, valueBuf);\n    \n    // Update stats\n    await this.incrementStat('totalEnqueued');\n    await this.incrementStat('pending');\n    \n    return taskId;\n  }\n\n  /**\n   * Dequeue the highest priority task\n   * Returns null if no tasks available\n   */\n  async dequeue(workerId: string): Promise<Task | null> {\n    const now = Date.now();\n    const prefix = `queue/${this.config.name}/`;\n    \n    // TODO: Implement range scan to find first ready task\n    // For now, this is a placeholder\n    \n    return null;\n  }\n\n  /**\n   * Acknowledge task completion\n   */\n  async ack(taskId: string): Promise<void> {\n    // Find and update task state\n    const task = await this.getTask(taskId);\n    if (!task) {\n      throw new SochDBError(`Task not found: ${taskId}`);\n    }\n\n    if (task.state !== TaskState.CLAIMED) {\n      throw new SochDBError(`Task not in claimed state: ${taskId}`);\n    }\n\n    // Update task state\n    task.state = TaskState.COMPLETED;\n    task.completedAt = Date.now();\n    \n    await this.updateTask(task);\n    \n    // Update stats\n    await this.decrementStat('claimed');\n    await this.incrementStat('completed');\n  }\n\n  /**\n   * Negative acknowledge - return task to queue\n   */\n  async nack(taskId: string): Promise<void> {\n    const task = await this.getTask(taskId);\n    if (!task) {\n      throw new SochDBError(`Task not found: ${taskId}`);\n    }\n\n    task.retries++;\n    \n    if (task.retries >= (this.config.maxRetries || 3)) {\n      // Move to dead letter queue\n      task.state = TaskState.DEAD_LETTERED;\n      await this.updateTask(task);\n      await this.decrementStat('claimed');\n      await this.incrementStat('deadLettered');\n    } else {\n      // Return to pending\n      task.state = TaskState.PENDING;\n      task.claimedAt = undefined;\n      task.claimedBy = undefined;\n      await this.updateTask(task);\n      await this.decrementStat('claimed');\n      await this.incrementStat('pending');\n    }\n  }\n\n  /**\n   * Get queue statistics\n   */\n  async stats(): Promise<QueueStats> {\n    return {\n      pending: await this.getStat('pending'),\n      claimed: await this.getStat('claimed'),\n      completed: await this.getStat('completed'),\n      deadLettered: await this.getStat('deadLettered'),\n      totalEnqueued: await this.getStat('totalEnqueued'),\n      totalDequeued: await this.getStat('totalDequeued'),\n    };\n  }\n\n  /**\n   * Purge completed tasks\n   */\n  async purge(): Promise<number> {\n    // TODO: Implement purging of completed tasks\n    return 0;\n  }\n\n  // Helper methods\n  private generateTaskId(): string {\n    return `${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;\n  }\n\n  private async getTask(taskId: string): Promise<Task | null> {\n    // TODO: Implement task lookup\n    return null;\n  }\n\n  private async updateTask(task: Task): Promise<void> {\n    // TODO: Implement task update\n  }\n\n  private async getStat(name: string): Promise<number> {\n    const key = `_queue_stats/${this.config.name}/${name}`;\n    const value = await this.db.get(Buffer.from(key));\n    return value ? parseInt(value.toString()) : 0;\n  }\n\n  private async incrementStat(name: string): Promise<void> {\n    const current = await this.getStat(name);\n    const key = `_queue_stats/${this.config.name}/${name}`;\n    await this.db.put(Buffer.from(key), Buffer.from((current + 1).toString()));\n  }\n\n  private async decrementStat(name: string): Promise<void> {\n    const current = await this.getStat(name);\n    const key = `_queue_stats/${this.config.name}/${name}`;\n    await this.db.put(Buffer.from(key), Buffer.from(Math.max(0, current - 1).toString()));\n  }\n}\n\n/**\n * Create a queue instance\n */\nexport function createQueue(\n  db: any,\n  name: string,\n  config?: Partial<QueueConfig>\n): PriorityQueue {\n  return PriorityQueue.fromDatabase(db, name, config);\n}\n"]}
|
|
410
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../src/queue.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SochDB Priority Queue\n * \n * First-class queue API with ordered-key task entries, providing efficient\n * priority queue operations without the O(N) blob rewrite anti-pattern.\n * \n * Features:\n * - Ordered-key representation: Each task has its own key, no blob parsing\n * - O(log N) enqueue/dequeue with ordered scans\n * - Atomic claim protocol for concurrent workers\n * - Visibility timeout for crash recovery\n * \n * @example\n * ```typescript\n * import { Database, PriorityQueue } from '@sochdb/sochdb';\n * \n * const db = await Database.open('./queue_db');\n * const queue = PriorityQueue.fromDatabase(db, 'tasks');\n * \n * // Enqueue task\n * await queue.enqueue(1, Buffer.from('high priority task'));\n * \n * // Dequeue and process\n * const task = await queue.dequeue('worker-1');\n * if (task) {\n *   // Process task...\n *   await queue.ack(task.taskId);\n * }\n * ```\n */\n\nimport { SochDBError } from './errors';\n\n// ============================================================================\n// Task State\n// ============================================================================\n\nexport enum TaskState {\n  PENDING = 'pending',\n  CLAIMED = 'claimed',\n  COMPLETED = 'completed',\n  DEAD_LETTERED = 'dead_lettered',\n}\n\n// ============================================================================\n// Queue Configuration\n// ============================================================================\n\nexport interface QueueConfig {\n  name: string;\n  visibilityTimeout?: number; // milliseconds, default 30000\n  maxRetries?: number; // default 3\n  deadLetterQueue?: string;\n}\n\n// ============================================================================\n// Queue Key Encoding\n// ============================================================================\n\n/**\n * Encode u64 as big-endian for lexicographic ordering\n */\nfunction encodeU64BE(value: number): Buffer {\n  const buf = Buffer.allocUnsafe(8);\n  buf.writeBigUInt64BE(BigInt(value));\n  return buf;\n}\n\n/**\n * Decode big-endian u64\n */\nfunction decodeU64BE(buf: Buffer): number {\n  return Number(buf.readBigUInt64BE(0));\n}\n\n/**\n * Encode i64 as big-endian preserving order\n */\nfunction encodeI64BE(value: number): Buffer {\n  // Map i64 to u64 by adding offset\n  const mapped = BigInt(value) + (1n << 63n);\n  const buf = Buffer.allocUnsafe(8);\n  buf.writeBigUInt64BE(mapped);\n  return buf;\n}\n\n/**\n * Decode big-endian i64\n */\nfunction decodeI64BE(buf: Buffer): number {\n  const mapped = buf.readBigUInt64BE(0);\n  return Number(mapped - (1n << 63n));\n}\n\n// ============================================================================\n// Queue Key\n// ============================================================================\n\nexport interface QueueKey {\n  queueId: string;\n  priority: number;\n  readyTs: number; // timestamp in milliseconds\n  sequence: number;\n  taskId: string;\n}\n\n/**\n * Encode queue key to bytes for storage\n */\nfunction encodeQueueKey(key: QueueKey): Buffer {\n  const parts = [\n    Buffer.from('queue/'),\n    Buffer.from(key.queueId),\n    Buffer.from('/'),\n    encodeI64BE(key.priority),\n    Buffer.from('/'),\n    encodeU64BE(key.readyTs),\n    Buffer.from('/'),\n    encodeU64BE(key.sequence),\n    Buffer.from('/'),\n    Buffer.from(key.taskId),\n  ];\n  \n  return Buffer.concat(parts);\n}\n\n/**\n * Decode queue key from bytes using positional parsing.\n * Key format: \"queue/\" + queueId + \"/\" + i64BE(priority) + \"/\" + u64BE(readyTs) + \"/\" + u64BE(sequence) + \"/\" + taskId\n * Binary fields may contain 0x2F ('/'), so split('/') is NOT safe.\n */\nfunction decodeQueueKey(data: Buffer): QueueKey {\n  // Must start with \"queue/\"\n  const prefix = Buffer.from('queue/');\n  if (data.length < prefix.length || data.subarray(0, prefix.length).compare(prefix) !== 0) {\n    throw new SochDBError('Invalid queue key format: missing queue/ prefix');\n  }\n\n  let offset = prefix.length;\n\n  // Find queueId: scan for the '/' before the 8-byte priority field\n  // The queueId ends at the first '/' followed by exactly 8 bytes + '/' + 8 bytes + '/' + 8 bytes + '/' + taskId\n  // Strategy: walk from the end. Structure after queueId:\n  //   \"/\" + 8-byte priority + \"/\" + 8-byte readyTs + \"/\" + 8-byte sequence + \"/\" + taskId\n  // Total fixed overhead after queueId: 1 + 8 + 1 + 8 + 1 + 8 + 1 = 28 bytes, then taskId\n  // Find queueId by scanning for '/' such that remaining = 28 + taskId.len\n\n  // We know: after queueId, fixed structure is:\n  //   /[8 bytes]/[8 bytes]/[8 bytes]/[taskId]\n  // So scan forward to find the separator. QueueId is a plain string (no binary), \n  // so find the first '/' after \"queue/\" that has at least 28 bytes remaining after it.\n  let queueIdEnd = -1;\n  for (let i = offset; i < data.length; i++) {\n    if (data[i] === 0x2F) { // '/'\n      const remaining = data.length - i - 1; // bytes after this '/'\n      // Need 8 (priority) + 1 (/) + 8 (readyTs) + 1 (/) + 8 (sequence) + 1 (/) + at least 1 (taskId) = 28\n      if (remaining >= 28) {\n        queueIdEnd = i;\n        break;\n      }\n    }\n  }\n\n  if (queueIdEnd < 0) {\n    throw new SochDBError('Invalid queue key format: cannot find queueId');\n  }\n\n  const queueId = data.subarray(offset, queueIdEnd).toString();\n  offset = queueIdEnd + 1; // skip '/'\n\n  // Read priority (8 bytes, i64 big-endian order-preserving)\n  if (offset + 8 > data.length) throw new SochDBError('Invalid queue key: truncated priority');\n  const priority = decodeI64BE(data.subarray(offset, offset + 8) as Buffer);\n  offset += 8;\n\n  // Skip '/'\n  if (data[offset] !== 0x2F) throw new SochDBError('Invalid queue key: expected / after priority');\n  offset += 1;\n\n  // Read readyTs (8 bytes, u64 big-endian)\n  if (offset + 8 > data.length) throw new SochDBError('Invalid queue key: truncated readyTs');\n  const readyTs = decodeU64BE(data.subarray(offset, offset + 8) as Buffer);\n  offset += 8;\n\n  // Skip '/'\n  if (data[offset] !== 0x2F) throw new SochDBError('Invalid queue key: expected / after readyTs');\n  offset += 1;\n\n  // Read sequence (8 bytes, u64 big-endian)\n  if (offset + 8 > data.length) throw new SochDBError('Invalid queue key: truncated sequence');\n  const sequence = decodeU64BE(data.subarray(offset, offset + 8) as Buffer);\n  offset += 8;\n\n  // Skip '/'\n  if (data[offset] !== 0x2F) throw new SochDBError('Invalid queue key: expected / after sequence');\n  offset += 1;\n\n  // Remaining is taskId\n  const taskId = data.subarray(offset).toString();\n\n  return { queueId, priority, readyTs, sequence, taskId };\n}\n\n// ============================================================================\n// Task\n// ============================================================================\n\nexport interface Task {\n  taskId: string;\n  priority: number;\n  payload: Buffer;\n  state: TaskState;\n  enqueuedAt: number;\n  claimedAt?: number;\n  claimedBy?: string;\n  completedAt?: number;\n  retries: number;\n  metadata?: Record<string, any>;\n}\n\n// ============================================================================\n// Queue Statistics\n// ============================================================================\n\nexport interface QueueStats {\n  pending: number;\n  claimed: number;\n  completed: number;\n  deadLettered: number;\n  totalEnqueued: number;\n  totalDequeued: number;\n}\n\n// ============================================================================\n// Priority Queue\n// ============================================================================\n\nexport class PriorityQueue {\n  private static sequenceCounter = 0;\n\n  constructor(\n    private db: any,\n    private config: QueueConfig\n  ) {\n    // Set defaults\n    this.config.visibilityTimeout = config.visibilityTimeout || 30000;\n    this.config.maxRetries = config.maxRetries || 3;\n  }\n\n  /**\n   * Create queue from embedded database\n   */\n  static fromDatabase(db: any, name: string, config?: Partial<QueueConfig>): PriorityQueue {\n    const fullConfig: QueueConfig = {\n      name,\n      ...config,\n    };\n    return new PriorityQueue(db, fullConfig);\n  }\n\n  /**\n   * Create queue from gRPC client\n   */\n  static fromClient(client: any, name: string, config?: Partial<QueueConfig>): PriorityQueue {\n    const fullConfig: QueueConfig = {\n      name,\n      ...config,\n    };\n    return new PriorityQueue(client, fullConfig);\n  }\n\n  /**\n   * Enqueue a task with priority\n   * Lower priority number = higher urgency\n   */\n  async enqueue(\n    priority: number,\n    payload: Buffer,\n    metadata?: Record<string, any>\n  ): Promise<string> {\n    const taskId = this.generateTaskId();\n    const now = Date.now();\n    \n    const key: QueueKey = {\n      queueId: this.config.name,\n      priority,\n      readyTs: now,\n      sequence: PriorityQueue.sequenceCounter++,\n      taskId,\n    };\n\n    const task: Task = {\n      taskId,\n      priority,\n      payload,\n      state: TaskState.PENDING,\n      enqueuedAt: now,\n      retries: 0,\n      metadata,\n    };\n\n    const keyBuf = encodeQueueKey(key);\n    const valueBuf = Buffer.from(JSON.stringify(task));\n    \n    await this.db.put(keyBuf, valueBuf);\n    \n    // Update stats\n    await this.incrementStat('totalEnqueued');\n    await this.incrementStat('pending');\n    \n    return taskId;\n  }\n\n  /**\n   * Dequeue the highest priority task\n   * Returns null if no tasks available\n   */\n  async dequeue(workerId: string): Promise<Task | null> {\n    const now = Date.now();\n    const prefix = Buffer.from(`queue/${this.config.name}/`);\n\n    // Scan all tasks in priority order (binary sort = priority order due to big-endian encoding)\n    try {\n      for await (const [keyBuf, valueBuf] of this.db.scanPrefix(prefix)) {\n        const task: Task = JSON.parse(valueBuf.toString());\n\n        // Skip non-pending tasks\n        if (task.state !== TaskState.PENDING) {\n          continue;\n        }\n\n        // Decode key to check readyTs\n        try {\n          const queueKey = decodeQueueKey(keyBuf);\n          if (queueKey.readyTs > now) {\n            continue; // Not ready yet\n          }\n        } catch {\n          continue; // Skip malformed keys\n        }\n\n        // Claim this task atomically\n        task.state = TaskState.CLAIMED;\n        task.claimedAt = now;\n        task.claimedBy = workerId;\n\n        // Re-serialize the payload correctly (it's stored as base64 in JSON)\n        const updatedValue = Buffer.from(JSON.stringify(task));\n        await this.db.put(keyBuf, updatedValue);\n\n        // Update stats\n        await this.decrementStat('pending');\n        await this.incrementStat('claimed');\n        await this.incrementStat('totalDequeued');\n\n        return task;\n      }\n    } catch {\n      // If scan is not available via scanPrefix, return null\n    }\n\n    return null;\n  }\n\n  /**\n   * Acknowledge task completion\n   */\n  async ack(taskId: string): Promise<void> {\n    // Find and update task state\n    const result = await this.getTask(taskId);\n    if (!result) {\n      throw new SochDBError(`Task not found: ${taskId}`);\n    }\n\n    const { task } = result;\n\n    if (task.state !== TaskState.CLAIMED) {\n      throw new SochDBError(`Task not in claimed state: ${taskId}`);\n    }\n\n    // Update task state\n    task.state = TaskState.COMPLETED;\n    task.completedAt = Date.now();\n    \n    await this.updateTask(task);\n    \n    // Update stats\n    await this.decrementStat('claimed');\n    await this.incrementStat('completed');\n  }\n\n  /**\n   * Negative acknowledge - return task to queue\n   */\n  async nack(taskId: string): Promise<void> {\n    const result = await this.getTask(taskId);\n    if (!result) {\n      throw new SochDBError(`Task not found: ${taskId}`);\n    }\n\n    const { task } = result;\n    task.retries++;\n    \n    if (task.retries >= (this.config.maxRetries || 3)) {\n      // Move to dead letter queue\n      task.state = TaskState.DEAD_LETTERED;\n      await this.updateTask(task);\n      await this.decrementStat('claimed');\n      await this.incrementStat('deadLettered');\n    } else {\n      // Return to pending\n      task.state = TaskState.PENDING;\n      task.claimedAt = undefined;\n      task.claimedBy = undefined;\n      await this.updateTask(task);\n      await this.decrementStat('claimed');\n      await this.incrementStat('pending');\n    }\n  }\n\n  /**\n   * Get queue statistics\n   */\n  async stats(): Promise<QueueStats> {\n    return {\n      pending: await this.getStat('pending'),\n      claimed: await this.getStat('claimed'),\n      completed: await this.getStat('completed'),\n      deadLettered: await this.getStat('deadLettered'),\n      totalEnqueued: await this.getStat('totalEnqueued'),\n      totalDequeued: await this.getStat('totalDequeued'),\n    };\n  }\n\n  /**\n   * Purge completed tasks\n   */\n  async purge(): Promise<number> {\n    const prefix = Buffer.from(`queue/${this.config.name}/`);\n    let purged = 0;\n\n    try {\n      const toDelete: Buffer[] = [];\n      for await (const [keyBuf, valueBuf] of this.db.scanPrefix(prefix)) {\n        const task: Task = JSON.parse(valueBuf.toString());\n        if (task.state === TaskState.COMPLETED || task.state === TaskState.DEAD_LETTERED) {\n          toDelete.push(keyBuf);\n        }\n      }\n\n      for (const key of toDelete) {\n        await this.db.delete(key);\n        purged++;\n      }\n    } catch {\n      // Return count so far\n    }\n\n    return purged;\n  }\n\n  // Helper methods\n  private generateTaskId(): string {\n    return `${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;\n  }\n\n  private async getTask(taskId: string): Promise<{ task: Task; keyBuf: Buffer } | null> {\n    const prefix = Buffer.from(`queue/${this.config.name}/`);\n\n    try {\n      for await (const [keyBuf, valueBuf] of this.db.scanPrefix(prefix)) {\n        const task: Task = JSON.parse(valueBuf.toString());\n        if (task.taskId === taskId) {\n          return { task, keyBuf };\n        }\n      }\n    } catch {\n      // Scan not available\n    }\n\n    return null;\n  }\n\n  private async updateTask(task: Task): Promise<void> {\n    const result = await this.getTask(task.taskId);\n    if (result) {\n      const valueBuf = Buffer.from(JSON.stringify(task));\n      await this.db.put(result.keyBuf, valueBuf);\n    }\n  }\n\n  private async getStat(name: string): Promise<number> {\n    const key = `_queue_stats/${this.config.name}/${name}`;\n    const value = await this.db.get(Buffer.from(key));\n    return value ? parseInt(value.toString()) : 0;\n  }\n\n  private async incrementStat(name: string): Promise<void> {\n    const current = await this.getStat(name);\n    const key = `_queue_stats/${this.config.name}/${name}`;\n    await this.db.put(Buffer.from(key), Buffer.from((current + 1).toString()));\n  }\n\n  private async decrementStat(name: string): Promise<void> {\n    const current = await this.getStat(name);\n    const key = `_queue_stats/${this.config.name}/${name}`;\n    await this.db.put(Buffer.from(key), Buffer.from(Math.max(0, current - 1).toString()));\n  }\n}\n\n/**\n * Create a queue instance\n */\nexport function createQueue(\n  db: any,\n  name: string,\n  config?: Partial<QueueConfig>\n): PriorityQueue {\n  return PriorityQueue.fromDatabase(db, name, config);\n}\n"]}
|
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
*/
|
|
7
7
|
import { NativeBindings } from './ffi/bindings';
|
|
8
8
|
import { EmbeddedTransaction } from './transaction';
|
|
9
|
+
import { Namespace, NamespaceConfig } from '../namespace';
|
|
9
10
|
export interface EmbeddedDatabaseConfig {
|
|
10
11
|
walEnabled?: boolean;
|
|
11
12
|
syncMode?: 'full' | 'normal' | 'off';
|
|
@@ -166,5 +167,73 @@ export declare class EmbeddedDatabase {
|
|
|
166
167
|
* @internal
|
|
167
168
|
*/
|
|
168
169
|
getBindings(): NativeBindings;
|
|
170
|
+
/**
|
|
171
|
+
* Create a new namespace
|
|
172
|
+
*/
|
|
173
|
+
createNamespace(name: string, config?: Partial<NamespaceConfig>): Promise<Namespace>;
|
|
174
|
+
/**
|
|
175
|
+
* Get an existing namespace
|
|
176
|
+
*/
|
|
177
|
+
namespace(name: string): Promise<Namespace>;
|
|
178
|
+
/**
|
|
179
|
+
* Get or create a namespace
|
|
180
|
+
*/
|
|
181
|
+
getOrCreateNamespace(name: string, config?: Partial<NamespaceConfig>): Promise<Namespace>;
|
|
182
|
+
/**
|
|
183
|
+
* Delete a namespace and all its data
|
|
184
|
+
*/
|
|
185
|
+
deleteNamespace(name: string): Promise<boolean>;
|
|
186
|
+
/**
|
|
187
|
+
* List all namespace names
|
|
188
|
+
*/
|
|
189
|
+
listNamespaces(): Promise<string[]>;
|
|
190
|
+
/**
|
|
191
|
+
* Add a node to the graph overlay
|
|
192
|
+
*/
|
|
193
|
+
addNode(namespace: string, nodeId: string, nodeType: string, properties?: Record<string, string>): Promise<void>;
|
|
194
|
+
/**
|
|
195
|
+
* Add an edge between nodes
|
|
196
|
+
*/
|
|
197
|
+
addEdge(namespace: string, fromId: string, edgeType: string, toId: string, properties?: Record<string, string>): Promise<void>;
|
|
198
|
+
/**
|
|
199
|
+
* Traverse the graph from a starting node
|
|
200
|
+
*/
|
|
201
|
+
traverse(namespace: string, startNode: string, maxDepth?: number, order?: 'bfs' | 'dfs'): Promise<{
|
|
202
|
+
nodes: any[];
|
|
203
|
+
edges: any[];
|
|
204
|
+
}>;
|
|
205
|
+
/**
|
|
206
|
+
* Put a value in the semantic cache
|
|
207
|
+
*/
|
|
208
|
+
cachePut(cacheName: string, key: string, value: string, embedding: number[], ttlSeconds?: number): Promise<void>;
|
|
209
|
+
/**
|
|
210
|
+
* Get a value from the semantic cache by embedding similarity
|
|
211
|
+
*/
|
|
212
|
+
cacheGet(cacheName: string, queryEmbedding: number[], threshold?: number): Promise<string | null>;
|
|
213
|
+
/**
|
|
214
|
+
* Delete a cache entry
|
|
215
|
+
*/
|
|
216
|
+
cacheDelete(cacheName: string, key: string): Promise<void>;
|
|
217
|
+
/**
|
|
218
|
+
* Clear all entries in a semantic cache
|
|
219
|
+
*/
|
|
220
|
+
cacheClear(cacheName: string): Promise<number>;
|
|
221
|
+
/**
|
|
222
|
+
* Convert records to TOON format
|
|
223
|
+
*/
|
|
224
|
+
static toToon(tableName: string, records: Array<Record<string, any>>, fields?: string[]): string;
|
|
225
|
+
/**
|
|
226
|
+
* Convert records to JSON format
|
|
227
|
+
*/
|
|
228
|
+
static toJson(tableName: string, records: Array<Record<string, any>>, fields?: string[], compact?: boolean): string;
|
|
229
|
+
/**
|
|
230
|
+
* Parse JSON format
|
|
231
|
+
*/
|
|
232
|
+
static fromJson(jsonStr: string): {
|
|
233
|
+
table: string;
|
|
234
|
+
fields: string[];
|
|
235
|
+
records: Array<Record<string, any>>;
|
|
236
|
+
};
|
|
237
|
+
private static cosineSimilarity;
|
|
169
238
|
}
|
|
170
239
|
//# sourceMappingURL=database.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../../src/embedded/database.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../../src/embedded/database.ts"],"names":[],"mappings":"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"}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* SochDB Node.js SDK v0.5.
|
|
2
|
+
* SochDB Node.js SDK v0.5.3
|
|
3
3
|
*
|
|
4
4
|
* Dual-mode architecture: Embedded (FFI) + Server (gRPC/IPC)
|
|
5
5
|
*
|
|
@@ -49,7 +49,7 @@
|
|
|
49
49
|
* await client.putKv('key', Buffer.from('value'));
|
|
50
50
|
* ```
|
|
51
51
|
*/
|
|
52
|
-
export declare const VERSION = "0.5.
|
|
52
|
+
export declare const VERSION = "0.5.3";
|
|
53
53
|
export { EmbeddedDatabase, EmbeddedDatabaseConfig } from './embedded';
|
|
54
54
|
export { EmbeddedTransaction } from './embedded';
|
|
55
55
|
export { HnswIndex, HnswConfig, HnswBindings } from './embedded';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../src/namespace.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../src/namespace.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,EAAE,WAAW,EAAiB,MAAM,UAAU,CAAC;AAuEtD,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,qBAAa,sBAAuB,SAAQ,WAAW;gBACzC,SAAS,EAAE,MAAM;CAI9B;AAED,qBAAa,oBAAqB,SAAQ,WAAW;gBACvC,SAAS,EAAE,MAAM;CAI9B;AAED,qBAAa,uBAAwB,SAAQ,WAAW;gBAC1C,UAAU,EAAE,MAAM;CAI/B;AAED,qBAAa,qBAAsB,SAAQ,WAAW;gBACxC,UAAU,EAAE,MAAM;CAI/B;AAMD,oBAAY,cAAc;IACxB,MAAM,WAAW;IACjB,SAAS,cAAc;IACvB,UAAU,QAAQ;CACnB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,cAAc,CAAC;IACxB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,aAAa;IAC5B,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,CAAC,EAAE,MAAM,CAAC;IACV,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC7B,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAoHD,qBAAa,UAAU;IAQnB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,MAAM;IAVhB,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,WAAW,CAAS;IAC5B,OAAO,CAAC,eAAe,CAAK;IAC5B,OAAO,CAAC,kBAAkB,CAA6B;gBAG7C,EAAE,EAAE,GAAG,EACP,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,gBAAgB;IA0BlC;;;;OAIG;IACH,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAMnC;;;OAGG;IACG,MAAM,CACV,MAAM,EAAE,MAAM,EAAE,EAChB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC9B,EAAE,CAAC,EAAE,MAAM,GACV,OAAO,CAAC,MAAM,CAAC;IAyClB;;;OAGG;IACG,UAAU,CACd,OAAO,EAAE,MAAM,EAAE,EAAE,EACnB,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,EACjC,GAAG,CAAC,EAAE,MAAM,EAAE,GACb,OAAO,CAAC,MAAM,EAAE,CAAC;IAkEpB;;OAEG;IACG,YAAY,IAAI,OAAO,CAAC,MAAM,CAAC;IAqBrC;;OAEG;IACH,IAAI,YAAY,IAAI,OAAO,CAE1B;IAED;;;OAGG;IACG,MAAM,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAgF7D;;OAEG;IACG,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,EAAE,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;KAAE,GAAG,IAAI,CAAC;IAe3F;;OAEG;IACG,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAQ1C;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC;IAU9B,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,UAAU;IAKlB,OAAO,CAAC,gBAAgB;CAazB;AAMD,qBAAa,SAAS;IAElB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,MAAM;gBAFN,EAAE,EAAE,GAAG,EACP,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,eAAe;IAGjC;;OAEG;IACG,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,UAAU,CAAC;IAuBrE;;OAEG;IACG,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAYnD;;OAEG;IACG,qBAAqB,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,UAAU,CAAC;IAW1E;;OAEG;IACG,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAqBtD;;OAEG;IACG,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAqB1C,OAAO,IAAI,MAAM;IAIjB,SAAS,IAAI,eAAe;CAG7B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../../src/queue.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AAQH,oBAAY,SAAS;IACnB,OAAO,YAAY;IACnB,OAAO,YAAY;IACnB,SAAS,cAAc;IACvB,aAAa,kBAAkB;CAChC;AAMD,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AA6CD,MAAM,WAAW,QAAQ;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;CAChB;
|
|
1
|
+
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../../src/queue.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AAQH,oBAAY,SAAS;IACnB,OAAO,YAAY;IACnB,OAAO,YAAY;IACnB,SAAS,cAAc;IACvB,aAAa,kBAAkB;CAChC;AAMD,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AA6CD,MAAM,WAAW,QAAQ;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;CAChB;AAuGD,MAAM,WAAW,IAAI;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,SAAS,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAMD,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;CACvB;AAMD,qBAAa,aAAa;IAItB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,MAAM;IAJhB,OAAO,CAAC,MAAM,CAAC,eAAe,CAAK;gBAGzB,EAAE,EAAE,GAAG,EACP,MAAM,EAAE,WAAW;IAO7B;;OAEG;IACH,MAAM,CAAC,YAAY,CAAC,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,aAAa;IAQxF;;OAEG;IACH,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,aAAa;IAQ1F;;;OAGG;IACG,OAAO,CACX,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EACf,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAC7B,OAAO,CAAC,MAAM,CAAC;IAkClB;;;OAGG;IACG,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;IA+CrD;;OAEG;IACG,GAAG,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBxC;;OAEG;IACG,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA0BzC;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,UAAU,CAAC;IAWlC;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC;IAyB9B,OAAO,CAAC,cAAc;YAIR,OAAO;YAiBP,UAAU;YAQV,OAAO;YAMP,aAAa;YAMb,aAAa;CAK5B;AAED;;GAEG;AACH,wBAAgB,WAAW,CACzB,EAAE,EAAE,GAAG,EACP,IAAI,EAAE,MAAM,EACZ,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,aAAa,CAEf"}
|
package/package.json
CHANGED