@coeiro-operator/audio 1.0.1 → 1.0.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.
Files changed (46) hide show
  1. package/LICENSE +21 -0
  2. package/dist/audio-player.d.ts +134 -0
  3. package/dist/audio-player.d.ts.map +1 -0
  4. package/dist/audio-player.js +707 -0
  5. package/dist/audio-player.js.map +1 -0
  6. package/dist/audio-stream-controller.d.ts +52 -0
  7. package/dist/audio-stream-controller.d.ts.map +1 -0
  8. package/dist/audio-stream-controller.js +121 -0
  9. package/dist/audio-stream-controller.js.map +1 -0
  10. package/dist/audio-synthesizer.d.ts +86 -0
  11. package/dist/audio-synthesizer.d.ts.map +1 -0
  12. package/dist/audio-synthesizer.js +437 -0
  13. package/dist/audio-synthesizer.js.map +1 -0
  14. package/dist/chunk-generation-manager.d.ts +77 -0
  15. package/dist/chunk-generation-manager.d.ts.map +1 -0
  16. package/dist/chunk-generation-manager.js +178 -0
  17. package/dist/chunk-generation-manager.js.map +1 -0
  18. package/dist/constants.d.ts +180 -0
  19. package/dist/constants.d.ts.map +1 -0
  20. package/dist/constants.js +219 -0
  21. package/dist/constants.js.map +1 -0
  22. package/dist/index.d.ts +77 -0
  23. package/dist/index.d.ts.map +1 -0
  24. package/dist/index.js +194 -0
  25. package/dist/index.js.map +1 -0
  26. package/dist/speech-queue.d.ts +52 -0
  27. package/dist/speech-queue.d.ts.map +1 -0
  28. package/dist/speech-queue.js +143 -0
  29. package/dist/speech-queue.js.map +1 -0
  30. package/dist/synthesis-processor.d.ts +39 -0
  31. package/dist/synthesis-processor.d.ts.map +1 -0
  32. package/dist/synthesis-processor.js +131 -0
  33. package/dist/synthesis-processor.js.map +1 -0
  34. package/dist/test-helpers.d.ts +19 -0
  35. package/dist/test-helpers.d.ts.map +1 -0
  36. package/dist/test-helpers.js +167 -0
  37. package/dist/test-helpers.js.map +1 -0
  38. package/dist/types.d.ts +63 -0
  39. package/dist/types.d.ts.map +1 -0
  40. package/dist/types.js +5 -0
  41. package/dist/types.js.map +1 -0
  42. package/dist/voice-resolver.d.ts +25 -0
  43. package/dist/voice-resolver.d.ts.map +1 -0
  44. package/dist/voice-resolver.js +141 -0
  45. package/dist/voice-resolver.js.map +1 -0
  46. package/package.json +16 -13
@@ -0,0 +1,437 @@
1
+ /**
2
+ * src/say/audio-synthesizer.ts: 音声合成処理
3
+ * COEIROINK APIを使用した音声合成機能を担当
4
+ */
5
+ import { logger } from '@coeiro-operator/common';
6
+ import { SAMPLE_RATES, SPLIT_SETTINGS, PADDING_SETTINGS, SYNTHESIS_SETTINGS } from './constants.js';
7
+ import { getSpeakerProvider } from '@coeiro-operator/core';
8
+ import { AudioStreamController } from './audio-stream-controller.js';
9
+ // ストリーミング設定
10
+ const STREAM_CONFIG = {
11
+ chunkSizeChars: 50, // 文字単位でのチャンク分割
12
+ overlapChars: 5, // チャンク間のオーバーラップ(音切れ防止)
13
+ bufferSize: 3, // 音声バッファサイズ(並列処理数)
14
+ audioBufferMs: 100, // 音声出力バッファ時間
15
+ silencePaddingMs: 50, // 音切れ防止用の無音パディング
16
+ preloadChunks: 2, // 先読みチャンク数
17
+ };
18
+ export class AudioSynthesizer {
19
+ config;
20
+ audioConfig;
21
+ speakerProvider = getSpeakerProvider();
22
+ streamController;
23
+ constructor(config) {
24
+ this.config = config;
25
+ this.audioConfig = this.getAudioConfig();
26
+ // 接続設定を更新
27
+ this.speakerProvider.updateConnection({
28
+ host: this.config.connection.host,
29
+ port: this.config.connection.port,
30
+ });
31
+ // AudioStreamControllerを初期化(設定ファイルベース)
32
+ const parallelConfig = this.config.audio?.parallelGeneration || {};
33
+ this.streamController = new AudioStreamController(this.synthesizeChunk.bind(this), {
34
+ maxConcurrency: parallelConfig.maxConcurrency || 2,
35
+ delayBetweenRequests: parallelConfig.delayBetweenRequests || 50,
36
+ bufferAheadCount: parallelConfig.bufferAheadCount || 1,
37
+ pauseUntilFirstComplete: parallelConfig.pauseUntilFirstComplete || true,
38
+ });
39
+ }
40
+ /**
41
+ * スピーカー一覧を取得
42
+ */
43
+ async getSpeakers() {
44
+ return await this.speakerProvider.getSpeakers();
45
+ }
46
+ /**
47
+ * オーディオ設定を取得
48
+ */
49
+ getAudioConfig() {
50
+ const latencyMode = this.config.audio?.latencyMode || 'balanced';
51
+ const presets = {
52
+ 'ultra-low': {
53
+ splitSettings: SPLIT_SETTINGS.PRESETS.ULTRA_LOW,
54
+ paddingSettings: PADDING_SETTINGS.PRESETS.ULTRA_LOW,
55
+ },
56
+ balanced: {
57
+ splitSettings: SPLIT_SETTINGS.PRESETS.BALANCED,
58
+ paddingSettings: PADDING_SETTINGS.PRESETS.BALANCED,
59
+ },
60
+ quality: {
61
+ splitSettings: SPLIT_SETTINGS.PRESETS.QUALITY,
62
+ paddingSettings: PADDING_SETTINGS.PRESETS.QUALITY,
63
+ },
64
+ };
65
+ const preset = presets[latencyMode];
66
+ return {
67
+ latencyMode,
68
+ splitSettings: { ...preset.splitSettings, ...this.config.audio?.splitSettings },
69
+ paddingSettings: { ...preset.paddingSettings, ...this.config.audio?.paddingSettings },
70
+ };
71
+ }
72
+ /**
73
+ * 設定から音声生成時のサンプルレートを取得
74
+ */
75
+ getSynthesisRate() {
76
+ return this.config.audio.processing?.synthesisRate || SAMPLE_RATES.SYNTHESIS;
77
+ }
78
+ /**
79
+ * 設定ファイルに基づいて分割モード設定を生成
80
+ */
81
+ getSplitModeConfig() {
82
+ // latencyModeプリセットの値を優先し、個別設定で上書き
83
+ const splitSettings = {
84
+ smallSize: this.audioConfig.splitSettings?.smallSize || SPLIT_SETTINGS.DEFAULTS.SMALL_SIZE,
85
+ mediumSize: this.audioConfig.splitSettings?.mediumSize || SPLIT_SETTINGS.DEFAULTS.MEDIUM_SIZE,
86
+ largeSize: this.audioConfig.splitSettings?.largeSize || SPLIT_SETTINGS.DEFAULTS.LARGE_SIZE,
87
+ overlapRatio: this.audioConfig.splitSettings?.overlapRatio || SPLIT_SETTINGS.DEFAULTS.OVERLAP_RATIO,
88
+ };
89
+ return {
90
+ none: { chunkSize: Infinity, overlap: 0 },
91
+ small: {
92
+ chunkSize: splitSettings.smallSize,
93
+ overlap: Math.round(splitSettings.smallSize * splitSettings.overlapRatio),
94
+ },
95
+ medium: {
96
+ chunkSize: splitSettings.mediumSize,
97
+ overlap: Math.round(splitSettings.mediumSize * splitSettings.overlapRatio),
98
+ },
99
+ large: {
100
+ chunkSize: splitSettings.largeSize,
101
+ overlap: Math.round(splitSettings.largeSize * splitSettings.overlapRatio),
102
+ },
103
+ punctuation: {
104
+ chunkSize: SPLIT_SETTINGS.PUNCTUATION.MAX_CHUNK_SIZE,
105
+ overlap: SPLIT_SETTINGS.PUNCTUATION.OVERLAP_CHARS,
106
+ },
107
+ };
108
+ }
109
+ /**
110
+ * サーバー接続確認
111
+ */
112
+ async checkServerConnection() {
113
+ return await this.speakerProvider.checkConnection();
114
+ }
115
+ /**
116
+ * 利用可能な音声一覧を取得
117
+ */
118
+ async listVoices() {
119
+ await this.speakerProvider.logAvailableVoices();
120
+ }
121
+ /**
122
+ * 句読点に基づくテキスト分割
123
+ */
124
+ splitByPunctuation(text) {
125
+ const chunks = [];
126
+ const config = SPLIT_SETTINGS.PUNCTUATION;
127
+ // 複数の句読点で分割(。!?)
128
+ // 複合句読点も考慮(?!、!?等)
129
+ const punctuationPattern = /([。!?]+)/;
130
+ const parts = text.split(punctuationPattern);
131
+ logger.debug(`Parts after punctuation split: ${JSON.stringify(parts)}`);
132
+ const sentences = [];
133
+ for (let i = 0; i < parts.length; i += 2) {
134
+ const sentence = parts[i] ? parts[i].trim() : '';
135
+ const punctuation = parts[i + 1] || '';
136
+ if (sentence.length > 0) {
137
+ sentences.push(sentence + punctuation);
138
+ }
139
+ }
140
+ logger.debug(`Processed sentences: ${JSON.stringify(sentences)}`);
141
+ // 短いテキストの場合は全体を1つのチャンクとして扱う
142
+ if (text.trim().length > 0 && sentences.length === 0) {
143
+ chunks.push({
144
+ text: text.trim(),
145
+ index: 0,
146
+ isFirst: true,
147
+ isLast: true,
148
+ overlap: 0,
149
+ });
150
+ return chunks;
151
+ }
152
+ // 句読点分割:適切な長さのチャンクを作成し、短いチャンクは結合する
153
+ let currentChunk = '';
154
+ for (let i = 0; i < sentences.length; i++) {
155
+ const sentence = sentences[i];
156
+ // 文が最大文字数を超える場合は個別のチャンクとして処理
157
+ if (sentence.length > config.MAX_CHUNK_SIZE) {
158
+ // 現在のチャンクがあれば先に追加
159
+ if (currentChunk.length > 0) {
160
+ chunks.push({
161
+ text: currentChunk,
162
+ index: chunks.length,
163
+ isFirst: chunks.length === 0,
164
+ isLast: false,
165
+ overlap: 0,
166
+ });
167
+ currentChunk = '';
168
+ }
169
+ // 長い文は個別処理(読点分割など)
170
+ if (config.ALLOW_COMMA_SPLIT && sentence.includes('、')) {
171
+ const subChunks = this.splitLongSentenceByComma(sentence, config.MAX_CHUNK_SIZE);
172
+ subChunks.forEach(subChunk => {
173
+ chunks.push({
174
+ text: subChunk,
175
+ index: chunks.length,
176
+ isFirst: chunks.length === 0,
177
+ isLast: false,
178
+ overlap: 0,
179
+ });
180
+ });
181
+ }
182
+ else {
183
+ // 長い文をそのままチャンクとして追加
184
+ chunks.push({
185
+ text: sentence,
186
+ index: chunks.length,
187
+ isFirst: chunks.length === 0,
188
+ isLast: false,
189
+ overlap: 0,
190
+ });
191
+ }
192
+ }
193
+ else {
194
+ // 短い文の結合処理
195
+ const combinedLength = currentChunk.length + sentence.length;
196
+ if (currentChunk.length === 0) {
197
+ // 最初の文
198
+ currentChunk = sentence;
199
+ }
200
+ else if (combinedLength <= config.MAX_CHUNK_SIZE &&
201
+ (currentChunk.length < config.MIN_CHUNK_SIZE || sentence.length < config.MIN_CHUNK_SIZE)) {
202
+ // 結合条件: 最大サイズ以下 かつ どちらかが最小サイズ未満
203
+ currentChunk += sentence;
204
+ }
205
+ else {
206
+ // 現在のチャンクを確定し、新しいチャンクを開始
207
+ chunks.push({
208
+ text: currentChunk,
209
+ index: chunks.length,
210
+ isFirst: chunks.length === 0,
211
+ isLast: false,
212
+ overlap: 0,
213
+ });
214
+ currentChunk = sentence;
215
+ }
216
+ }
217
+ }
218
+ // 残ったチャンクを追加
219
+ if (currentChunk.length > 0) {
220
+ chunks.push({
221
+ text: currentChunk,
222
+ index: chunks.length,
223
+ isFirst: chunks.length === 0,
224
+ isLast: false,
225
+ overlap: 0,
226
+ });
227
+ }
228
+ // 最後のチャンクのisLastフラグを設定
229
+ if (chunks.length > 0) {
230
+ chunks[chunks.length - 1].isLast = true;
231
+ }
232
+ else {
233
+ // 全てのチャンクが最小サイズ未満の場合、元のテキストを1つのチャンクとして作成
234
+ chunks.push({
235
+ text: text.trim(),
236
+ index: 0,
237
+ isFirst: true,
238
+ isLast: true,
239
+ overlap: 0,
240
+ });
241
+ }
242
+ return chunks;
243
+ }
244
+ /**
245
+ * 文字数で強制分割
246
+ */
247
+ forceSplitByLength(text, maxSize) {
248
+ const chunks = [];
249
+ for (let i = 0; i < text.length; i += maxSize) {
250
+ chunks.push(text.slice(i, i + maxSize));
251
+ }
252
+ return chunks;
253
+ }
254
+ /**
255
+ * 長い文を読点で分割
256
+ */
257
+ splitLongSentenceByComma(sentence, maxSize) {
258
+ const parts = [];
259
+ const commaParts = sentence.split('、');
260
+ let currentChunk = '';
261
+ for (let i = 0; i < commaParts.length; i++) {
262
+ const part = commaParts[i] + (i < commaParts.length - 1 ? '、' : '');
263
+ if (currentChunk.length + part.length <= maxSize) {
264
+ currentChunk += part;
265
+ }
266
+ else {
267
+ if (currentChunk.length > 0) {
268
+ parts.push(currentChunk);
269
+ currentChunk = part;
270
+ }
271
+ else {
272
+ // 単一パートが最大サイズを超える場合は強制的に文字数分割
273
+ parts.push(part);
274
+ }
275
+ }
276
+ }
277
+ if (currentChunk.length > 0) {
278
+ parts.push(currentChunk);
279
+ }
280
+ return parts;
281
+ }
282
+ /**
283
+ * テキストを音切れ防止のためのオーバーラップ付きチャンクに分割
284
+ */
285
+ splitTextIntoChunks(text, splitMode = 'punctuation') {
286
+ logger.debug('=== SPLIT_TEXT_INTO_CHUNKS DEBUG ===');
287
+ logger.debug(`Input splitMode: ${splitMode}`);
288
+ logger.debug(`Text length: ${text.length}`);
289
+ logger.debug(`Text preview: "${text.substring(0, 100)}${text.length > 100 ? '...' : ''}"`);
290
+ // 句読点分割の場合は専用処理
291
+ if (splitMode === 'punctuation') {
292
+ logger.debug('Using punctuation-based splitting');
293
+ const chunks = this.splitByPunctuation(text);
294
+ logger.debug(`Punctuation splitting result: ${chunks.length} chunks`);
295
+ chunks.forEach((chunk, index) => {
296
+ logger.debug(` Chunk ${index}: "${chunk.text.substring(0, 50)}${chunk.text.length > 50 ? '...' : ''}"`);
297
+ });
298
+ return chunks;
299
+ }
300
+ logger.debug(`Using ${splitMode} splitting mode`);
301
+ const chunks = [];
302
+ const config = this.getSplitModeConfig()[splitMode];
303
+ const chunkSize = config.chunkSize;
304
+ const overlap = config.overlap;
305
+ logger.debug(`Split config - chunkSize: ${chunkSize}, overlap: ${overlap}`);
306
+ for (let i = 0; i < text.length; i += chunkSize - overlap) {
307
+ const end = Math.min(i + chunkSize, text.length);
308
+ const chunk = text.slice(i, end);
309
+ if (chunk.trim().length > 0) {
310
+ chunks.push({
311
+ text: chunk,
312
+ index: chunks.length,
313
+ isFirst: i === 0,
314
+ isLast: end >= text.length,
315
+ overlap: i > 0 ? overlap : 0,
316
+ });
317
+ }
318
+ }
319
+ logger.debug(`Non-punctuation splitting result: ${chunks.length} chunks`);
320
+ chunks.forEach((chunk, index) => {
321
+ logger.debug(` Chunk ${index}: "${chunk.text.substring(0, 50)}${chunk.text.length > 50 ? '...' : ''}"`);
322
+ });
323
+ return chunks;
324
+ }
325
+ /**
326
+ * 単一チャンクの音声合成
327
+ */
328
+ async synthesizeChunk(chunk, voiceConfig, speed) {
329
+ logger.log(`音声合成: チャンク${chunk.index} "${chunk.text.substring(0, 30)}${chunk.text.length > 30 ? '...' : ''}"`);
330
+ const url = `http://${this.config.connection.host}:${this.config.connection.port}/v1/synthesis`;
331
+ // VoiceConfigから音声IDとスタイルIDを取得
332
+ const voiceId = voiceConfig.speaker.speakerId;
333
+ const styleId = voiceConfig.selectedStyleId;
334
+ // 音切れ防止: 前後に無音パディングを追加(設定に基づく)
335
+ let paddingMs = 0;
336
+ let postPaddingMs = 0;
337
+ if (this.audioConfig.paddingSettings?.enabled) {
338
+ const basePrePadding = this.audioConfig.paddingSettings.prePhonemeLength ||
339
+ PADDING_SETTINGS.DEFAULTS.PRE_PHONEME_LENGTH;
340
+ const basePostPadding = this.audioConfig.paddingSettings.postPhonemeLength ||
341
+ PADDING_SETTINGS.DEFAULTS.POST_PHONEME_LENGTH;
342
+ const firstChunkOnly = this.audioConfig.paddingSettings.firstChunkOnly;
343
+ if (!firstChunkOnly || chunk.isFirst) {
344
+ paddingMs = (chunk.isFirst ? basePrePadding : basePrePadding / 2) * 1000;
345
+ postPaddingMs = (chunk.isLast ? basePostPadding : basePostPadding / 2) * 1000;
346
+ }
347
+ }
348
+ const synthesisParam = {
349
+ text: chunk.text,
350
+ speakerUuid: voiceId,
351
+ styleId: styleId,
352
+ speedScale: speed,
353
+ volumeScale: SYNTHESIS_SETTINGS.DEFAULT_VOLUME,
354
+ pitchScale: SYNTHESIS_SETTINGS.DEFAULT_PITCH,
355
+ intonationScale: SYNTHESIS_SETTINGS.DEFAULT_INTONATION,
356
+ prePhonemeLength: paddingMs / 1000,
357
+ postPhonemeLength: postPaddingMs / 1000,
358
+ outputSamplingRate: this.getSynthesisRate(),
359
+ };
360
+ const startTime = Date.now();
361
+ try {
362
+ const response = await fetch(url, {
363
+ method: 'POST',
364
+ headers: {
365
+ 'Content-Type': 'application/json',
366
+ },
367
+ body: JSON.stringify(synthesisParam),
368
+ });
369
+ if (!response.ok) {
370
+ const errorText = await response.text().catch(() => 'レスポンス読み取り失敗');
371
+ logger.error(`COEIROINK APIエラー: ${response.status} ${response.statusText}, body: ${errorText}`);
372
+ throw new Error(`HTTP ${response.status}: ${response.statusText}`);
373
+ }
374
+ const audioBuffer = await response.arrayBuffer();
375
+ const latency = Date.now() - startTime;
376
+ return {
377
+ chunk,
378
+ audioBuffer,
379
+ latency,
380
+ };
381
+ }
382
+ catch (error) {
383
+ logger.error(`チャンク${chunk.index}合成エラー詳細:`, error);
384
+ throw new Error(`チャンク${chunk.index}合成エラー: ${error.message}`);
385
+ }
386
+ }
387
+ /**
388
+ * レート値をスピード値に変換
389
+ */
390
+ convertRateToSpeed(rate) {
391
+ const baseRate = 200;
392
+ let speed = rate / baseRate;
393
+ if (speed < 0.5)
394
+ speed = 0.5;
395
+ if (speed > 2.0)
396
+ speed = 2.0;
397
+ return speed;
398
+ }
399
+ /**
400
+ * ストリーミング音声合成(リファクタリング版)
401
+ */
402
+ async *synthesizeStream(text, voiceConfig, speed, chunkMode = 'punctuation') {
403
+ logger.debug('=== SYNTHESIZE_STREAM DEBUG ===');
404
+ logger.debug(`chunkMode parameter: ${chunkMode}`);
405
+ logger.debug(`text length: ${text.length}`);
406
+ const chunks = this.splitTextIntoChunks(text, chunkMode);
407
+ logger.debug(`Total chunks generated: ${chunks.length}`);
408
+ // AudioStreamControllerを使用してストリーミング生成
409
+ yield* this.streamController.synthesizeStream(chunks, voiceConfig, speed);
410
+ logger.debug('=== SYNTHESIZE_STREAM COMPLETE ===');
411
+ }
412
+ /**
413
+ * 並行生成モードの切り替え
414
+ */
415
+ setParallelGenerationEnabled(enabled) {
416
+ this.streamController.setParallelGenerationEnabled(enabled);
417
+ }
418
+ /**
419
+ * ストリーム制御オプションの更新
420
+ */
421
+ updateStreamControllerOptions(options) {
422
+ this.streamController.updateOptions(options);
423
+ }
424
+ /**
425
+ * 現在のストリーム制御設定を取得
426
+ */
427
+ getStreamControllerOptions() {
428
+ return this.streamController.getOptions();
429
+ }
430
+ /**
431
+ * 生成統計情報を取得
432
+ */
433
+ getGenerationStats() {
434
+ return this.streamController.getGenerationStats();
435
+ }
436
+ }
437
+ //# sourceMappingURL=audio-synthesizer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audio-synthesizer.js","sourceRoot":"","sources":["../src/audio-synthesizer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,77 @@
1
+ /**
2
+ * src/core/say/chunk-generation-manager.ts: 並行チャンク生成管理
3
+ * 複数チャンクの生成を並行して行い、完成順序ではなく論理順序で管理
4
+ */
5
+ import type { Chunk, AudioResult, VoiceConfig } from './types.js';
6
+ export interface GenerationTask {
7
+ chunk: Chunk;
8
+ voiceConfig: VoiceConfig;
9
+ speed: number;
10
+ startTime: number;
11
+ promise: Promise<AudioResult>;
12
+ }
13
+ export interface GenerationOptions {
14
+ maxConcurrency: number;
15
+ delayBetweenRequests: number;
16
+ pauseUntilFirstComplete: boolean;
17
+ }
18
+ /**
19
+ * チャンク生成の並行制御管理クラス
20
+ */
21
+ export declare class ChunkGenerationManager {
22
+ private activeTasks;
23
+ private completedResults;
24
+ private options;
25
+ private synthesizeFunction;
26
+ private firstChunkCompleted;
27
+ constructor(synthesizeFunction: (chunk: Chunk, voiceConfig: VoiceConfig, speed: number) => Promise<AudioResult>, options?: Partial<GenerationOptions>);
28
+ /**
29
+ * チャンクの生成を開始(並行制御あり)
30
+ */
31
+ startGeneration(chunk: Chunk, voiceConfig: VoiceConfig, speed: number): Promise<void>;
32
+ /**
33
+ * 指定されたチャンクの生成結果を取得(完了まで待機)
34
+ */
35
+ getResult(chunkIndex: number): Promise<AudioResult>;
36
+ /**
37
+ * 指定されたチャンクが生成完了しているかチェック
38
+ */
39
+ isCompleted(chunkIndex: number): boolean;
40
+ /**
41
+ * 指定されたチャンクが生成中かチェック
42
+ */
43
+ isInProgress(chunkIndex: number): boolean;
44
+ /**
45
+ * 現在の並行生成数を取得
46
+ */
47
+ getActiveConcurrency(): number;
48
+ /**
49
+ * 完了待ちの結果数を取得
50
+ */
51
+ getPendingResultsCount(): number;
52
+ /**
53
+ * すべてのタスクの完了を待機
54
+ */
55
+ waitForAllTasks(): Promise<void>;
56
+ /**
57
+ * すべてのタスクをクリア
58
+ */
59
+ clear(): void;
60
+ /**
61
+ * 生成統計情報を取得
62
+ */
63
+ getStats(): {
64
+ activeTasks: number;
65
+ completedResults: number;
66
+ totalMemoryUsage: number;
67
+ };
68
+ private waitForAnyTaskCompletion;
69
+ /**
70
+ * 初回チャンク(チャンク0)の完了を待機
71
+ */
72
+ private waitForFirstChunkCompletion;
73
+ private onTaskCompleted;
74
+ private onTaskFailed;
75
+ private delay;
76
+ }
77
+ //# sourceMappingURL=chunk-generation-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunk-generation-manager.d.ts","sourceRoot":"","sources":["../src/chunk-generation-manager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAElE,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,KAAK,CAAC;IACb,WAAW,EAAE,WAAW,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;CAC/B;AAED,MAAM,WAAW,iBAAiB;IAChC,cAAc,EAAE,MAAM,CAAC;IACvB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,uBAAuB,EAAE,OAAO,CAAC;CAClC;AAED;;GAEG;AACH,qBAAa,sBAAsB;IACjC,OAAO,CAAC,WAAW,CAA0C;IAC7D,OAAO,CAAC,gBAAgB,CAAuC;IAC/D,OAAO,CAAC,OAAO,CAAoB;IACnC,OAAO,CAAC,kBAAkB,CAIA;IAC1B,OAAO,CAAC,mBAAmB,CAAkB;gBAG3C,kBAAkB,EAAE,CAClB,KAAK,EAAE,KAAK,EACZ,WAAW,EAAE,WAAW,EACxB,KAAK,EAAE,MAAM,KACV,OAAO,CAAC,WAAW,CAAC,EACzB,OAAO,GAAE,OAAO,CAAC,iBAAiB,CAAM;IAW1C;;OAEG;IACG,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAyC3F;;OAEG;IACG,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAiBzD;;OAEG;IACH,WAAW,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO;IAIxC;;OAEG;IACH,YAAY,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO;IAIzC;;OAEG;IACH,oBAAoB,IAAI,MAAM;IAI9B;;OAEG;IACH,sBAAsB,IAAI,MAAM;IAIhC;;OAEG;IACG,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAKtC;;OAEG;IACH,KAAK,IAAI,IAAI;IAMb;;OAEG;IACH,QAAQ,IAAI;QACV,WAAW,EAAE,MAAM,CAAC;QACpB,gBAAgB,EAAE,MAAM,CAAC;QACzB,gBAAgB,EAAE,MAAM,CAAC;KAC1B;YAaa,wBAAwB;IAStC;;OAEG;YACW,2BAA2B;IAkBzC,OAAO,CAAC,eAAe;IAiBvB,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,KAAK;CAGd"}