agent-ide 0.7.1 → 0.7.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/dist/application/services/module-coordinator.service.d.ts +1 -1
- package/dist/application/services/module-coordinator.service.d.ts.map +1 -1
- package/dist/application/services/module-coordinator.service.js +7 -7
- package/dist/application/services/module-coordinator.service.js.map +1 -1
- package/dist/core/{shared → call-hierarchy}/call-hierarchy-analyzer.d.ts +16 -4
- package/dist/core/call-hierarchy/call-hierarchy-analyzer.d.ts.map +1 -0
- package/dist/core/{shared → call-hierarchy}/call-hierarchy-analyzer.js +163 -48
- package/dist/core/call-hierarchy/call-hierarchy-analyzer.js.map +1 -0
- package/dist/core/call-hierarchy/index.d.ts +17 -0
- package/dist/core/call-hierarchy/index.d.ts.map +1 -0
- package/dist/core/call-hierarchy/index.js +16 -0
- package/dist/core/call-hierarchy/index.js.map +1 -0
- package/dist/core/change-signature/change-signature-service.d.ts +2 -0
- package/dist/core/change-signature/change-signature-service.d.ts.map +1 -1
- package/dist/core/change-signature/change-signature-service.js +41 -23
- package/dist/core/change-signature/change-signature-service.js.map +1 -1
- package/dist/core/{dependency → cycles}/cycle-detector.d.ts +4 -14
- package/dist/core/cycles/cycle-detector.d.ts.map +1 -0
- package/dist/core/{dependency → cycles}/cycle-detector.js +6 -2
- package/dist/core/cycles/cycle-detector.js.map +1 -0
- package/dist/core/cycles/index.d.ts +13 -0
- package/dist/core/cycles/index.d.ts.map +1 -0
- package/dist/core/cycles/index.js +14 -0
- package/dist/core/cycles/index.js.map +1 -0
- package/dist/core/cycles/types.d.ts +67 -0
- package/dist/core/cycles/types.d.ts.map +1 -0
- package/dist/core/cycles/types.js +42 -0
- package/dist/core/cycles/types.js.map +1 -0
- package/dist/core/{dead-code → deadcode}/dead-code-detector.d.ts +1 -1
- package/dist/core/deadcode/dead-code-detector.d.ts.map +1 -0
- package/dist/core/{dead-code → deadcode}/dead-code-detector.js +11 -10
- package/dist/core/deadcode/dead-code-detector.js.map +1 -0
- package/dist/core/deadcode/dead-code-remover.d.ts.map +1 -0
- package/dist/core/deadcode/dead-code-remover.js.map +1 -0
- package/dist/core/deadcode/index.d.ts.map +1 -0
- package/dist/core/deadcode/index.js.map +1 -0
- package/dist/core/{dead-code → deadcode}/types.d.ts +2 -0
- package/dist/core/deadcode/types.d.ts.map +1 -0
- package/dist/core/{dead-code → deadcode}/types.js +2 -1
- package/dist/core/deadcode/types.js.map +1 -0
- package/dist/core/find-references/index.d.ts +10 -0
- package/dist/core/find-references/index.d.ts.map +1 -0
- package/dist/core/find-references/index.js +10 -0
- package/dist/core/find-references/index.js.map +1 -0
- package/dist/core/{dependency/dependency-analyzer.d.ts → impact/impact-analyzer.d.ts} +11 -5
- package/dist/core/impact/impact-analyzer.d.ts.map +1 -0
- package/dist/core/{dependency/dependency-analyzer.js → impact/impact-analyzer.js} +18 -13
- package/dist/core/impact/impact-analyzer.js.map +1 -0
- package/dist/core/impact/index.d.ts +17 -0
- package/dist/core/impact/index.d.ts.map +1 -0
- package/dist/core/impact/index.js +16 -0
- package/dist/core/impact/index.js.map +1 -0
- package/dist/core/{dependency → impact}/types.d.ts +3 -78
- package/dist/core/impact/types.d.ts.map +1 -0
- package/dist/core/impact/types.js +53 -0
- package/dist/core/impact/types.js.map +1 -0
- package/dist/core/move/import-resolver.d.ts.map +1 -0
- package/dist/core/move/import-resolver.js.map +1 -0
- package/dist/core/move/index.d.ts.map +1 -0
- package/dist/core/move/index.js.map +1 -0
- package/dist/core/move/move-service.d.ts.map +1 -0
- package/dist/core/move/move-service.js.map +1 -0
- package/dist/core/move/types.d.ts.map +1 -0
- package/dist/core/move/types.js.map +1 -0
- package/dist/core/{dependency → shared/dependency-graph}/dependency-graph.d.ts +1 -13
- package/dist/core/shared/dependency-graph/dependency-graph.d.ts.map +1 -0
- package/dist/core/{dependency → shared/dependency-graph}/dependency-graph.js +8 -1
- package/dist/core/shared/dependency-graph/dependency-graph.js.map +1 -0
- package/dist/core/shared/dependency-graph/index.d.ts +12 -0
- package/dist/core/shared/dependency-graph/index.d.ts.map +1 -0
- package/dist/core/shared/dependency-graph/index.js +13 -0
- package/dist/core/shared/dependency-graph/index.js.map +1 -0
- package/dist/core/shared/dependency-graph/types.d.ts +44 -0
- package/dist/core/shared/dependency-graph/types.d.ts.map +1 -0
- package/dist/core/shared/dependency-graph/types.js +5 -0
- package/dist/core/shared/dependency-graph/types.js.map +1 -0
- package/dist/core/shared/index.d.ts +2 -1
- package/dist/core/shared/index.d.ts.map +1 -1
- package/dist/core/shared/index.js +5 -1
- package/dist/core/shared/index.js.map +1 -1
- package/dist/core/{indexing → shared/indexing}/file-index.d.ts +1 -1
- package/dist/core/shared/indexing/file-index.d.ts.map +1 -0
- package/dist/core/{indexing → shared/indexing}/file-index.js +1 -1
- package/dist/core/shared/indexing/file-index.js.map +1 -0
- package/dist/core/{indexing → shared/indexing}/index-engine.d.ts +2 -2
- package/dist/core/shared/indexing/index-engine.d.ts.map +1 -0
- package/dist/core/{indexing → shared/indexing}/index-engine.js +5 -5
- package/dist/core/shared/indexing/index-engine.js.map +1 -0
- package/dist/core/shared/indexing/index.d.ts +26 -0
- package/dist/core/shared/indexing/index.d.ts.map +1 -0
- package/dist/core/shared/indexing/index.js +34 -0
- package/dist/core/shared/indexing/index.js.map +1 -0
- package/dist/core/{indexing → shared/indexing}/symbol-index.d.ts +1 -1
- package/dist/core/shared/indexing/symbol-index.d.ts.map +1 -0
- package/dist/core/shared/indexing/symbol-index.js.map +1 -0
- package/dist/core/{indexing → shared/indexing}/types.d.ts +1 -1
- package/dist/core/shared/indexing/types.d.ts.map +1 -0
- package/dist/core/shared/indexing/types.js.map +1 -0
- package/dist/core/shared/symbol-finder.d.ts +10 -3
- package/dist/core/shared/symbol-finder.d.ts.map +1 -1
- package/dist/core/shared/symbol-finder.js +95 -10
- package/dist/core/shared/symbol-finder.js.map +1 -1
- package/dist/core/snapshot/snapshot-generator.js +1 -1
- package/dist/core/snapshot/snapshot-generator.js.map +1 -1
- package/dist/interfaces/cli/commands/call-hierarchy.command.js +2 -2
- package/dist/interfaces/cli/commands/call-hierarchy.command.js.map +1 -1
- package/dist/interfaces/cli/commands/cycles.command.d.ts.map +1 -1
- package/dist/interfaces/cli/commands/cycles.command.js +8 -15
- package/dist/interfaces/cli/commands/cycles.command.js.map +1 -1
- package/dist/interfaces/cli/commands/deadcode.command.js +2 -2
- package/dist/interfaces/cli/commands/deadcode.command.js.map +1 -1
- package/dist/interfaces/cli/commands/find-references.command.js +3 -2
- package/dist/interfaces/cli/commands/find-references.command.js.map +1 -1
- package/dist/interfaces/cli/commands/impact.command.d.ts.map +1 -1
- package/dist/interfaces/cli/commands/impact.command.js +10 -17
- package/dist/interfaces/cli/commands/impact.command.js.map +1 -1
- package/dist/interfaces/cli/commands/move.command.js +1 -1
- package/dist/interfaces/cli/commands/move.command.js.map +1 -1
- package/dist/interfaces/cli/commands/rename.command.js +2 -2
- package/dist/interfaces/cli/commands/rename.command.js.map +1 -1
- package/package.json +1 -1
- package/dist/core/dead-code/dead-code-detector.d.ts.map +0 -1
- package/dist/core/dead-code/dead-code-detector.js.map +0 -1
- package/dist/core/dead-code/dead-code-remover.d.ts.map +0 -1
- package/dist/core/dead-code/dead-code-remover.js.map +0 -1
- package/dist/core/dead-code/index.d.ts.map +0 -1
- package/dist/core/dead-code/index.js.map +0 -1
- package/dist/core/dead-code/types.d.ts.map +0 -1
- package/dist/core/dead-code/types.js.map +0 -1
- package/dist/core/dependency/cycle-detector.d.ts.map +0 -1
- package/dist/core/dependency/cycle-detector.js.map +0 -1
- package/dist/core/dependency/dependency-analyzer.d.ts.map +0 -1
- package/dist/core/dependency/dependency-analyzer.js.map +0 -1
- package/dist/core/dependency/dependency-graph.d.ts.map +0 -1
- package/dist/core/dependency/dependency-graph.js.map +0 -1
- package/dist/core/dependency/index.d.ts +0 -27
- package/dist/core/dependency/index.d.ts.map +0 -1
- package/dist/core/dependency/index.js +0 -36
- package/dist/core/dependency/index.js.map +0 -1
- package/dist/core/dependency/types.d.ts.map +0 -1
- package/dist/core/dependency/types.js +0 -103
- package/dist/core/dependency/types.js.map +0 -1
- package/dist/core/indexing/file-index.d.ts.map +0 -1
- package/dist/core/indexing/file-index.js.map +0 -1
- package/dist/core/indexing/index-engine.d.ts.map +0 -1
- package/dist/core/indexing/index-engine.js.map +0 -1
- package/dist/core/indexing/index.d.ts +0 -17
- package/dist/core/indexing/index.d.ts.map +0 -1
- package/dist/core/indexing/index.js +0 -26
- package/dist/core/indexing/index.js.map +0 -1
- package/dist/core/indexing/symbol-index.d.ts.map +0 -1
- package/dist/core/indexing/symbol-index.js.map +0 -1
- package/dist/core/indexing/types.d.ts.map +0 -1
- package/dist/core/indexing/types.js.map +0 -1
- package/dist/core/move-file/import-resolver.d.ts.map +0 -1
- package/dist/core/move-file/import-resolver.js.map +0 -1
- package/dist/core/move-file/index.d.ts.map +0 -1
- package/dist/core/move-file/index.js.map +0 -1
- package/dist/core/move-file/move-service.d.ts.map +0 -1
- package/dist/core/move-file/move-service.js.map +0 -1
- package/dist/core/move-file/types.d.ts.map +0 -1
- package/dist/core/move-file/types.js.map +0 -1
- package/dist/core/shared/call-hierarchy-analyzer.d.ts.map +0 -1
- package/dist/core/shared/call-hierarchy-analyzer.js.map +0 -1
- /package/dist/core/{dead-code → deadcode}/dead-code-remover.d.ts +0 -0
- /package/dist/core/{dead-code → deadcode}/dead-code-remover.js +0 -0
- /package/dist/core/{dead-code → deadcode}/index.d.ts +0 -0
- /package/dist/core/{dead-code → deadcode}/index.js +0 -0
- /package/dist/core/{move-file → move}/import-resolver.d.ts +0 -0
- /package/dist/core/{move-file → move}/import-resolver.js +0 -0
- /package/dist/core/{move-file → move}/index.d.ts +0 -0
- /package/dist/core/{move-file → move}/index.js +0 -0
- /package/dist/core/{move-file → move}/move-service.d.ts +0 -0
- /package/dist/core/{move-file → move}/move-service.js +0 -0
- /package/dist/core/{move-file → move}/types.d.ts +0 -0
- /package/dist/core/{move-file → move}/types.js +0 -0
- /package/dist/core/{indexing → shared/indexing}/symbol-index.js +0 -0
- /package/dist/core/{indexing → shared/indexing}/types.js +0 -0
|
@@ -24,7 +24,7 @@ export declare class ModuleCoordinatorService implements IModuleCoordinatorServi
|
|
|
24
24
|
private readonly modules;
|
|
25
25
|
private readonly renameEngine;
|
|
26
26
|
private readonly moveService;
|
|
27
|
-
private readonly
|
|
27
|
+
private readonly impactAnalyzer;
|
|
28
28
|
private readonly indexEngine;
|
|
29
29
|
private readonly fileSystem;
|
|
30
30
|
constructor(eventBus: EventBus, stateManager: StateManager, errorHandler: ErrorHandlerService, fileSystem: IFileSystem);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"module-coordinator.service.d.ts","sourceRoot":"","sources":["../../../src/application/services/module-coordinator.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gDAAgD,CAAC;AAQrF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAEpE,OAAO,KAAK,EACV,yBAAyB,EACzB,YAAY,EACZ,eAAe,EACf,cAAc,EACd,eAAe,EACf,YAAY,EACZ,UAAU,EAGX,MAAM,aAAa,CAAC;AAErB;;GAEG;AACH,qBAAa,sBAAuB,SAAQ,SAAS;gBACvC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,KAAK,CAAC,EAAE,KAAK;CAG9E;AAaD;;GAEG;AACH,qBAAa,wBAAyB,YAAW,yBAAyB;IACxE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAW;IACpC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IAC5C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAsB;IACnD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAGlD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IAC5C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAc;IAC1C,OAAO,CAAC,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"module-coordinator.service.d.ts","sourceRoot":"","sources":["../../../src/application/services/module-coordinator.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gDAAgD,CAAC;AAQrF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAEpE,OAAO,KAAK,EACV,yBAAyB,EACzB,YAAY,EACZ,eAAe,EACf,cAAc,EACd,eAAe,EACf,YAAY,EACZ,UAAU,EAGX,MAAM,aAAa,CAAC;AAErB;;GAEG;AACH,qBAAa,sBAAuB,SAAQ,SAAS;gBACvC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,KAAK,CAAC,EAAE,KAAK;CAG9E;AAaD;;GAEG;AACH,qBAAa,wBAAyB,YAAW,yBAAyB;IACxE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAW;IACpC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IAC5C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAsB;IACnD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAGlD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IAC5C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAc;IAC1C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAChD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAc;IAC1C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAc;gBAGvC,QAAQ,EAAE,QAAQ,EAClB,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,mBAAmB,EACjC,UAAU,EAAE,WAAW;IAoBzB;;OAEG;IACG,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,cAAc,CAAC;IA6E7F;;OAEG;IACG,WAAW,CAAC,UAAU,EAAE,eAAe,EAAE,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IA8DzE;;OAEG;IACG,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IA8DpE;;OAEG;IACG,eAAe,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;IAyBhD;;OAEG;IACH,OAAO,CAAC,eAAe;IAmBvB;;OAEG;YACW,eAAe;IAoB7B;;OAEG;IACH,OAAO,CAAC,eAAe;CAWxB"}
|
|
@@ -6,9 +6,9 @@ import { BaseError } from '../../shared/errors/base-error.js';
|
|
|
6
6
|
import { EventPriority } from '../events/event-types.js';
|
|
7
7
|
// 核心模組引入
|
|
8
8
|
import { RenameEngine } from '../../core/rename/rename-engine.js';
|
|
9
|
-
import { MoveService } from '../../core/move
|
|
10
|
-
import {
|
|
11
|
-
import { IndexEngine } from '../../core/indexing/index-engine.js';
|
|
9
|
+
import { MoveService } from '../../core/move/move-service.js';
|
|
10
|
+
import { ImpactAnalyzer } from '../../core/impact/index.js';
|
|
11
|
+
import { IndexEngine } from '../../core/shared/indexing/index-engine.js';
|
|
12
12
|
/**
|
|
13
13
|
* 模組協調器錯誤
|
|
14
14
|
*/
|
|
@@ -28,7 +28,7 @@ export class ModuleCoordinatorService {
|
|
|
28
28
|
// 核心模組實例
|
|
29
29
|
renameEngine;
|
|
30
30
|
moveService;
|
|
31
|
-
|
|
31
|
+
impactAnalyzer;
|
|
32
32
|
indexEngine;
|
|
33
33
|
fileSystem;
|
|
34
34
|
constructor(eventBus, stateManager, errorHandler, fileSystem) {
|
|
@@ -41,7 +41,7 @@ export class ModuleCoordinatorService {
|
|
|
41
41
|
// 初始化核心模組實例
|
|
42
42
|
this.renameEngine = new RenameEngine();
|
|
43
43
|
this.moveService = new MoveService(this.fileSystem);
|
|
44
|
-
this.
|
|
44
|
+
this.impactAnalyzer = new ImpactAnalyzer(this.fileSystem);
|
|
45
45
|
this.indexEngine = new IndexEngine({}, this.fileSystem);
|
|
46
46
|
// 註冊所有模組
|
|
47
47
|
this.registerModules();
|
|
@@ -190,7 +190,7 @@ export class ModuleCoordinatorService {
|
|
|
190
190
|
};
|
|
191
191
|
try {
|
|
192
192
|
// 1. 分析移動影響
|
|
193
|
-
const dependencyResult = await this.
|
|
193
|
+
const dependencyResult = await this.impactAnalyzer.analyzeFile(source);
|
|
194
194
|
// 2. 執行移動操作
|
|
195
195
|
const moveResult = await this.moveService.moveFile({ source, target });
|
|
196
196
|
// 3. 確保 moveResult 格式正確
|
|
@@ -267,7 +267,7 @@ export class ModuleCoordinatorService {
|
|
|
267
267
|
*/
|
|
268
268
|
registerModules() {
|
|
269
269
|
const moduleConfigs = [
|
|
270
|
-
{ id: 'dependency', name: 'dependency', instance: this.
|
|
270
|
+
{ id: 'dependency', name: 'dependency', instance: this.impactAnalyzer },
|
|
271
271
|
{ id: 'indexing', name: 'indexing', instance: this.indexEngine },
|
|
272
272
|
{ id: 'move', name: 'move', instance: this.moveService },
|
|
273
273
|
{ id: 'rename', name: 'rename', instance: this.renameEngine }
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"module-coordinator.service.js","sourceRoot":"","sources":["../../../src/application/services/module-coordinator.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAIzD,OAAO,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAEnE,SAAS;AACT,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"module-coordinator.service.js","sourceRoot":"","sources":["../../../src/application/services/module-coordinator.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -62,6 +62,7 @@ export declare class CallHierarchyAnalyzer {
|
|
|
62
62
|
private isFunctionSymbol;
|
|
63
63
|
/**
|
|
64
64
|
* 找出 incoming 呼叫(誰呼叫了目標函數)
|
|
65
|
+
* 使用批次處理優化:按檔案分組,避免重複讀取/解析同一檔案
|
|
65
66
|
*/
|
|
66
67
|
private findIncomingCalls;
|
|
67
68
|
/**
|
|
@@ -79,13 +80,24 @@ export declare class CallHierarchyAnalyzer {
|
|
|
79
80
|
*/
|
|
80
81
|
private extractCallInfo;
|
|
81
82
|
/**
|
|
82
|
-
*
|
|
83
|
+
* 批次找出單一檔案中多個行號所在的外層函數
|
|
84
|
+
* 將 O(N) 檔案讀取降為 O(1)
|
|
83
85
|
*/
|
|
84
|
-
private
|
|
86
|
+
private findEnclosingFunctions;
|
|
85
87
|
/**
|
|
86
|
-
*
|
|
88
|
+
* 批次查詢多個檔案中多個行號的 enclosing functions
|
|
89
|
+
* 按檔案分組後批次處理,避免重複讀取/解析同一檔案
|
|
87
90
|
*/
|
|
88
|
-
private
|
|
91
|
+
private findEnclosingFunctionsMultiFile;
|
|
92
|
+
/**
|
|
93
|
+
* 在 AST 中找出指定 position 的 enclosing function 名稱
|
|
94
|
+
*/
|
|
95
|
+
private findEnclosingFunctionAtPosition;
|
|
96
|
+
/**
|
|
97
|
+
* 批次取得多個檔案中多個行號的程式碼內容
|
|
98
|
+
* 按檔案分組後批次處理,避免重複讀取同一檔案
|
|
99
|
+
*/
|
|
100
|
+
private getLineContextsBatch;
|
|
89
101
|
/**
|
|
90
102
|
* 讀取檔案內容
|
|
91
103
|
*/
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"call-hierarchy-analyzer.d.ts","sourceRoot":"","sources":["../../../src/core/call-hierarchy/call-hierarchy-analyzer.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAE7D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kDAAkD,CAAC;AAGpF,8BAA8B;AAC9B,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC5B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC;IAC/B,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,8BAA8B;AAC9B,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC5B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC;CACxC;AAED,eAAe;AACf,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,SAAS,EAAE,UAAU,GAAG,UAAU,GAAG,MAAM,CAAC;IACrD,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED,eAAe;AACf,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAChC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAChC,QAAQ,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC;IAClC,QAAQ,CAAC,QAAQ,EAAE,YAAY,EAAE,CAAC;CACnC;AAED;;;GAGG;AACH,qBAAa,qBAAqB;IAI9B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAJ7B,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;gBAGzB,cAAc,EAAE,cAAc,EAC9B,UAAU,EAAE,WAAW;IAK1C;;OAEG;IACG,OAAO,CACX,YAAY,EAAE,MAAM,EACpB,YAAY,EAAE,SAAS,MAAM,EAAE,EAC/B,OAAO,EAAE,oBAAoB,GAC5B,OAAO,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAgBpC;;;OAGG;IACG,qBAAqB,CACzB,YAAY,EAAE,MAAM,EACpB,cAAc,EAAE,MAAM,EACtB,eAAe,EAAE,KAAK,EACtB,YAAY,EAAE,SAAS,MAAM,EAAE,EAC/B,OAAO,EAAE,oBAAoB,GAC5B,OAAO,CAAC,iBAAiB,CAAC;IAmC7B;;OAEG;YACW,sBAAsB;IAapC;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAKxB;;;OAGG;YACW,iBAAiB;IA0E/B;;;OAGG;YACW,iBAAiB;IAuE/B;;;OAGG;IACH,OAAO,CAAC,gBAAgB;IA2CxB;;OAEG;IACH,OAAO,CAAC,eAAe;IAkCvB;;;OAGG;YACW,sBAAsB;IAoDpC;;;OAGG;YACW,+BAA+B;IAuC7C;;OAEG;IACH,OAAO,CAAC,+BAA+B;IAgCvC;;;OAGG;YACW,oBAAoB;IAiDlC;;OAEG;YACW,QAAQ;IAStB;;OAEG;IACH,OAAO,CAAC,YAAY;CAIrB;AAED;;GAEG;AACH,wBAAgB,2BAA2B,CACzC,cAAc,EAAE,cAAc,EAC9B,UAAU,EAAE,WAAW,GACtB,qBAAqB,CAEvB"}
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* 分析函數的呼叫層次關係(incoming/outgoing)
|
|
4
4
|
*/
|
|
5
5
|
import * as ts from 'typescript';
|
|
6
|
-
import { createSymbolFinder } from '
|
|
6
|
+
import { createSymbolFinder } from '../shared/symbol-finder.js';
|
|
7
7
|
/**
|
|
8
8
|
* Call Hierarchy Analyzer
|
|
9
9
|
* 分析函數的呼叫者(incoming)和被呼叫者(outgoing)
|
|
@@ -74,6 +74,7 @@ export class CallHierarchyAnalyzer {
|
|
|
74
74
|
}
|
|
75
75
|
/**
|
|
76
76
|
* 找出 incoming 呼叫(誰呼叫了目標函數)
|
|
77
|
+
* 使用批次處理優化:按檔案分組,避免重複讀取/解析同一檔案
|
|
77
78
|
*/
|
|
78
79
|
async findIncomingCalls(functionName, projectFiles, definitionFile, depth) {
|
|
79
80
|
const incoming = [];
|
|
@@ -84,26 +85,45 @@ export class CallHierarchyAnalyzer {
|
|
|
84
85
|
}
|
|
85
86
|
visited.add(targetName);
|
|
86
87
|
const callSites = await this.symbolFinder.findCallSites(targetName, projectFiles);
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
88
|
+
// 過濾掉遞迴自身呼叫
|
|
89
|
+
const filteredCallSites = callSites.filter(callSite => !(callSite.location.filePath === definitionFile
|
|
90
|
+
&& callSite.functionName === targetName));
|
|
91
|
+
if (filteredCallSites.length === 0) {
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
// 批次查詢所有 callSites 的 enclosing functions(按檔案分組處理)
|
|
95
|
+
const queries = filteredCallSites.map(callSite => ({
|
|
96
|
+
filePath: callSite.location.filePath,
|
|
97
|
+
line: callSite.location.range.start.line
|
|
98
|
+
}));
|
|
99
|
+
const enclosingFunctions = await this.findEnclosingFunctionsMultiFile(queries);
|
|
100
|
+
// 批次取得所有 context(按檔案分組處理)
|
|
101
|
+
const contexts = await this.getLineContextsBatch(queries);
|
|
102
|
+
// 建立 incoming 結果
|
|
103
|
+
// 使用 filePath:functionName 作為唯一鍵,避免同名但不同檔案的函數被去重
|
|
104
|
+
const callersToRecurse = new Map();
|
|
105
|
+
for (const callSite of filteredCallSites) {
|
|
106
|
+
const key = `${callSite.location.filePath}:${callSite.location.range.start.line}`;
|
|
107
|
+
const callerInfo = enclosingFunctions.get(key);
|
|
108
|
+
const context = contexts.get(key) || '';
|
|
96
109
|
incoming.push({
|
|
97
110
|
caller: callerInfo?.name || '<anonymous>',
|
|
98
111
|
location: callSite.location,
|
|
99
112
|
context,
|
|
100
113
|
callerDefinitionFile: callerInfo?.file
|
|
101
114
|
});
|
|
102
|
-
//
|
|
115
|
+
// 收集需要遞迴的 caller(使用 filePath:functionName 作為唯一鍵去重)
|
|
103
116
|
if (currentDepth < depth && callerInfo?.name && callerInfo.name !== '<anonymous>') {
|
|
104
|
-
|
|
117
|
+
const callerKey = `${callerInfo.file}:${callerInfo.name}`;
|
|
118
|
+
if (!callersToRecurse.has(callerKey)) {
|
|
119
|
+
callersToRecurse.set(callerKey, { name: callerInfo.name, file: callerInfo.file });
|
|
120
|
+
}
|
|
105
121
|
}
|
|
106
122
|
}
|
|
123
|
+
// 遞迴查找(如果深度允許)
|
|
124
|
+
for (const caller of callersToRecurse.values()) {
|
|
125
|
+
await findCallsRecursive(caller.name, currentDepth + 1);
|
|
126
|
+
}
|
|
107
127
|
};
|
|
108
128
|
await findCallsRecursive(functionName, 1);
|
|
109
129
|
return incoming;
|
|
@@ -241,63 +261,158 @@ export class CallHierarchyAnalyzer {
|
|
|
241
261
|
};
|
|
242
262
|
}
|
|
243
263
|
/**
|
|
244
|
-
*
|
|
264
|
+
* 批次找出單一檔案中多個行號所在的外層函數
|
|
265
|
+
* 將 O(N) 檔案讀取降為 O(1)
|
|
245
266
|
*/
|
|
246
|
-
async
|
|
267
|
+
async findEnclosingFunctions(filePath, lines) {
|
|
268
|
+
const results = new Map();
|
|
269
|
+
if (lines.length === 0) {
|
|
270
|
+
return results;
|
|
271
|
+
}
|
|
247
272
|
const content = await this.readFile(filePath);
|
|
248
273
|
if (!content) {
|
|
249
|
-
return
|
|
274
|
+
return results;
|
|
250
275
|
}
|
|
251
276
|
const parser = this.parserRegistry.getParser(this.getExtension(filePath));
|
|
252
277
|
if (!parser) {
|
|
253
|
-
return
|
|
278
|
+
return results;
|
|
254
279
|
}
|
|
255
280
|
try {
|
|
256
281
|
const ast = await parser.parse(content, filePath);
|
|
257
282
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
258
283
|
const sourceFile = ast.tsSourceFile;
|
|
259
284
|
if (!sourceFile) {
|
|
260
|
-
return
|
|
285
|
+
return results;
|
|
261
286
|
}
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
const
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
else if (ts.isVariableDeclaration(node)
|
|
276
|
-
&& ts.isIdentifier(node.name)
|
|
277
|
-
&& node.initializer
|
|
278
|
-
&& (ts.isArrowFunction(node.initializer) || ts.isFunctionExpression(node.initializer))) {
|
|
279
|
-
enclosingFunction = node.name.text;
|
|
280
|
-
}
|
|
281
|
-
ts.forEachChild(node, visit);
|
|
287
|
+
// 將行號轉換為 position 並建立映射(跳過超出範圍的行號)
|
|
288
|
+
const lineCount = sourceFile.getLineStarts().length;
|
|
289
|
+
const linePositions = lines
|
|
290
|
+
.filter(line => line >= 1 && line <= lineCount)
|
|
291
|
+
.map(line => ({
|
|
292
|
+
line,
|
|
293
|
+
position: sourceFile.getPositionOfLineAndCharacter(line - 1, 0)
|
|
294
|
+
}));
|
|
295
|
+
// 遍歷 AST 找出每個 position 的 enclosing function
|
|
296
|
+
for (const { line, position } of linePositions) {
|
|
297
|
+
const enclosingName = this.findEnclosingFunctionAtPosition(sourceFile, position);
|
|
298
|
+
if (enclosingName) {
|
|
299
|
+
results.set(line, { name: enclosingName, file: filePath });
|
|
282
300
|
}
|
|
283
|
-
}
|
|
284
|
-
visit(sourceFile);
|
|
285
|
-
return enclosingFunction ? { name: enclosingFunction, file: filePath } : null;
|
|
301
|
+
}
|
|
286
302
|
}
|
|
287
303
|
catch {
|
|
288
|
-
|
|
304
|
+
// Parser 失敗,返回空結果
|
|
289
305
|
}
|
|
306
|
+
return results;
|
|
290
307
|
}
|
|
291
308
|
/**
|
|
292
|
-
*
|
|
309
|
+
* 批次查詢多個檔案中多個行號的 enclosing functions
|
|
310
|
+
* 按檔案分組後批次處理,避免重複讀取/解析同一檔案
|
|
293
311
|
*/
|
|
294
|
-
async
|
|
295
|
-
const
|
|
296
|
-
if (
|
|
297
|
-
return
|
|
312
|
+
async findEnclosingFunctionsMultiFile(queries) {
|
|
313
|
+
const results = new Map();
|
|
314
|
+
if (queries.length === 0) {
|
|
315
|
+
return results;
|
|
298
316
|
}
|
|
299
|
-
|
|
300
|
-
|
|
317
|
+
// 按檔案分組(使用 Set 避免重複行號)
|
|
318
|
+
const fileGroups = new Map();
|
|
319
|
+
for (const query of queries) {
|
|
320
|
+
const existing = fileGroups.get(query.filePath);
|
|
321
|
+
if (existing) {
|
|
322
|
+
existing.add(query.line);
|
|
323
|
+
}
|
|
324
|
+
else {
|
|
325
|
+
fileGroups.set(query.filePath, new Set([query.line]));
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
// 批次處理每個檔案
|
|
329
|
+
await Promise.all(Array.from(fileGroups.entries()).map(async ([filePath, linesSet]) => {
|
|
330
|
+
try {
|
|
331
|
+
const fileResults = await this.findEnclosingFunctions(filePath, [...linesSet]);
|
|
332
|
+
for (const [line, result] of fileResults) {
|
|
333
|
+
// 使用 filePath:line 作為唯一鍵
|
|
334
|
+
results.set(`${filePath}:${line}`, result);
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
catch (error) {
|
|
338
|
+
// 個別檔案處理失敗不影響其他檔案,記錄偵錯資訊
|
|
339
|
+
console.debug(`[CallHierarchyAnalyzer] findEnclosingFunctionsMultiFile failed for ${filePath}:`, error);
|
|
340
|
+
}
|
|
341
|
+
}));
|
|
342
|
+
return results;
|
|
343
|
+
}
|
|
344
|
+
/**
|
|
345
|
+
* 在 AST 中找出指定 position 的 enclosing function 名稱
|
|
346
|
+
*/
|
|
347
|
+
findEnclosingFunctionAtPosition(sourceFile, position) {
|
|
348
|
+
let enclosingFunction = null;
|
|
349
|
+
const visit = (node) => {
|
|
350
|
+
if (position >= node.getStart(sourceFile) && position < node.getEnd()) {
|
|
351
|
+
// FunctionDeclaration
|
|
352
|
+
if (ts.isFunctionDeclaration(node) && node.name) {
|
|
353
|
+
enclosingFunction = node.name.text;
|
|
354
|
+
}
|
|
355
|
+
// MethodDeclaration
|
|
356
|
+
else if (ts.isMethodDeclaration(node) && ts.isIdentifier(node.name)) {
|
|
357
|
+
enclosingFunction = node.name.text;
|
|
358
|
+
}
|
|
359
|
+
// Arrow function 或 function expression 賦值給變數
|
|
360
|
+
else if (ts.isVariableDeclaration(node)
|
|
361
|
+
&& ts.isIdentifier(node.name)
|
|
362
|
+
&& node.initializer
|
|
363
|
+
&& (ts.isArrowFunction(node.initializer) || ts.isFunctionExpression(node.initializer))) {
|
|
364
|
+
enclosingFunction = node.name.text;
|
|
365
|
+
}
|
|
366
|
+
ts.forEachChild(node, visit);
|
|
367
|
+
}
|
|
368
|
+
};
|
|
369
|
+
visit(sourceFile);
|
|
370
|
+
return enclosingFunction;
|
|
371
|
+
}
|
|
372
|
+
/**
|
|
373
|
+
* 批次取得多個檔案中多個行號的程式碼內容
|
|
374
|
+
* 按檔案分組後批次處理,避免重複讀取同一檔案
|
|
375
|
+
*/
|
|
376
|
+
async getLineContextsBatch(queries) {
|
|
377
|
+
const results = new Map();
|
|
378
|
+
if (queries.length === 0) {
|
|
379
|
+
return results;
|
|
380
|
+
}
|
|
381
|
+
// 按檔案分組(使用 Set 避免重複行號)
|
|
382
|
+
const fileGroups = new Map();
|
|
383
|
+
for (const query of queries) {
|
|
384
|
+
const existing = fileGroups.get(query.filePath);
|
|
385
|
+
if (existing) {
|
|
386
|
+
existing.add(query.line);
|
|
387
|
+
}
|
|
388
|
+
else {
|
|
389
|
+
fileGroups.set(query.filePath, new Set([query.line]));
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
// 批次處理每個檔案
|
|
393
|
+
await Promise.all(Array.from(fileGroups.entries()).map(async ([filePath, linesSet]) => {
|
|
394
|
+
try {
|
|
395
|
+
const content = await this.readFile(filePath);
|
|
396
|
+
if (!content) {
|
|
397
|
+
return;
|
|
398
|
+
}
|
|
399
|
+
const contentLines = content.split('\n');
|
|
400
|
+
const lineCount = contentLines.length;
|
|
401
|
+
for (const line of linesSet) {
|
|
402
|
+
// 跳過超出範圍的行號
|
|
403
|
+
if (line < 1 || line > lineCount) {
|
|
404
|
+
continue;
|
|
405
|
+
}
|
|
406
|
+
const lineContent = contentLines[line - 1]?.trim() || '';
|
|
407
|
+
results.set(`${filePath}:${line}`, lineContent);
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
catch (error) {
|
|
411
|
+
// 個別檔案處理失敗不影響其他檔案,記錄偵錯資訊
|
|
412
|
+
console.debug(`[CallHierarchyAnalyzer] getLineContextsBatch failed for ${filePath}:`, error);
|
|
413
|
+
}
|
|
414
|
+
}));
|
|
415
|
+
return results;
|
|
301
416
|
}
|
|
302
417
|
/**
|
|
303
418
|
* 讀取檔案內容
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"call-hierarchy-analyzer.js","sourceRoot":"","sources":["../../../src/core/call-hierarchy/call-hierarchy-analyzer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 呼叫層次分析模組
|
|
3
|
+
* 分析函數的呼叫者(incoming)和被呼叫者(outgoing)
|
|
4
|
+
*/
|
|
5
|
+
import { CallHierarchyAnalyzer } from './call-hierarchy-analyzer.js';
|
|
6
|
+
import type { ParserRegistry } from '../../infrastructure/parser/registry.js';
|
|
7
|
+
import type { IFileSystem } from '../../infrastructure/storage/file-system.interface.js';
|
|
8
|
+
export { CallHierarchyAnalyzer };
|
|
9
|
+
export type { OutgoingCall, IncomingCall, CallHierarchyOptions, CallHierarchyData } from './call-hierarchy-analyzer.js';
|
|
10
|
+
/**
|
|
11
|
+
* 建立呼叫層次分析器的便利函式
|
|
12
|
+
* @param parserRegistry Parser 註冊表
|
|
13
|
+
* @param fileSystem 檔案系統
|
|
14
|
+
* @returns 呼叫層次分析器實例
|
|
15
|
+
*/
|
|
16
|
+
export declare function createCallHierarchyAnalyzer(parserRegistry: ParserRegistry, fileSystem: IFileSystem): CallHierarchyAnalyzer;
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/call-hierarchy/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AACrE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kDAAkD,CAAC;AAEpF,OAAO,EAAE,qBAAqB,EAAE,CAAC;AAEjC,YAAY,EACV,YAAY,EACZ,YAAY,EACZ,oBAAoB,EACpB,iBAAiB,EAClB,MAAM,8BAA8B,CAAC;AAEtC;;;;;GAKG;AACH,wBAAgB,2BAA2B,CACzC,cAAc,EAAE,cAAc,EAC9B,UAAU,EAAE,WAAW,GACtB,qBAAqB,CAEvB"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 呼叫層次分析模組
|
|
3
|
+
* 分析函數的呼叫者(incoming)和被呼叫者(outgoing)
|
|
4
|
+
*/
|
|
5
|
+
import { CallHierarchyAnalyzer } from './call-hierarchy-analyzer.js';
|
|
6
|
+
export { CallHierarchyAnalyzer };
|
|
7
|
+
/**
|
|
8
|
+
* 建立呼叫層次分析器的便利函式
|
|
9
|
+
* @param parserRegistry Parser 註冊表
|
|
10
|
+
* @param fileSystem 檔案系統
|
|
11
|
+
* @returns 呼叫層次分析器實例
|
|
12
|
+
*/
|
|
13
|
+
export function createCallHierarchyAnalyzer(parserRegistry, fileSystem) {
|
|
14
|
+
return new CallHierarchyAnalyzer(parserRegistry, fileSystem);
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/call-hierarchy/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AAIrE,OAAO,EAAE,qBAAqB,EAAE,CAAC;AASjC;;;;;GAKG;AACH,MAAM,UAAU,2BAA2B,CACzC,cAA8B,EAC9B,UAAuB;IAEvB,OAAO,IAAI,qBAAqB,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;AAC/D,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"change-signature-service.d.ts","sourceRoot":"","sources":["../../../src/core/change-signature/change-signature-service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kDAAkD,CAAC;AAEpF,OAAO,EACL,KAAK,sBAAsB,EAC3B,KAAK,qBAAqB,EAe3B,MAAM,YAAY,CAAC;AAGpB;;GAEG;AACH,qBAAa,sBAAsB;IAK/B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAL7B,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAkB;IAClD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;gBAGzB,cAAc,EAAE,cAAc,EAC9B,UAAU,EAAE,WAAW;IAM1C;;OAEG;IACG,eAAe,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAuEtF;;OAEG;IACH,OAAO,CAAC,eAAe;IAsFvB;;OAEG;IACH,OAAO,CAAC,uBAAuB;IA8E/B;;OAEG;YACW,wBAAwB;IAkCtC
|
|
1
|
+
{"version":3,"file":"change-signature-service.d.ts","sourceRoot":"","sources":["../../../src/core/change-signature/change-signature-service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kDAAkD,CAAC;AAEpF,OAAO,EACL,KAAK,sBAAsB,EAC3B,KAAK,qBAAqB,EAe3B,MAAM,YAAY,CAAC;AAGpB;;GAEG;AACH,qBAAa,sBAAsB;IAK/B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAL7B,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAkB;IAClD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;gBAGzB,cAAc,EAAE,cAAc,EAC9B,UAAU,EAAE,WAAW;IAM1C;;OAEG;IACG,eAAe,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAuEtF;;OAEG;IACH,OAAO,CAAC,eAAe;IAsFvB;;OAEG;IACH,OAAO,CAAC,uBAAuB;IA8E/B;;OAEG;YACW,wBAAwB;IAkCtC;;;;OAIG;YACW,uBAAuB;IAgErC;;OAEG;IACH,OAAO,CAAC,sBAAsB;IA4D9B;;OAEG;IACH,OAAO,CAAC,oBAAoB;IA2C5B;;OAEG;YACW,YAAY;IA6C1B;;OAEG;IACH,OAAO,CAAC,uBAAuB;IA6B/B;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAYzB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAO5B;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAO7B;;OAEG;YACW,eAAe;IAM7B;;OAEG;YACW,YAAY;IAmB1B;;OAEG;IACH,OAAO,CAAC,eAAe;IAKvB;;OAEG;YACW,QAAQ;IAStB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAKxB;;OAEG;IACH,OAAO,CAAC,iBAAiB;CAe1B;AAED;;GAEG;AACH,wBAAgB,4BAA4B,CAC1C,cAAc,EAAE,cAAc,EAC9B,UAAU,EAAE,WAAW,GACtB,sBAAsB,CAExB"}
|
|
@@ -249,39 +249,57 @@ export class ChangeSignatureService {
|
|
|
249
249
|
}
|
|
250
250
|
/**
|
|
251
251
|
* 生成呼叫點更新
|
|
252
|
+
* 效能優化:按檔案分組後批次讀取,避免重複讀取同一檔案
|
|
253
|
+
* 檔案讀取次數從 O(N) 降到 O(M),N = callSites 數量,M = 不重複檔案數
|
|
252
254
|
*/
|
|
253
255
|
async generateCallSiteUpdates(callSites, originalSignature, newSignature, changes) {
|
|
254
256
|
const updates = [];
|
|
255
257
|
// 建立參數映射
|
|
256
258
|
const parameterMapping = this.createParameterMapping(originalSignature, newSignature, changes);
|
|
259
|
+
// 按檔案分組 callSites,避免重複讀取同一檔案
|
|
260
|
+
const callSitesByFile = new Map();
|
|
257
261
|
for (const callSite of callSites) {
|
|
258
|
-
const
|
|
262
|
+
const filePath = callSite.location.filePath;
|
|
263
|
+
const existing = callSitesByFile.get(filePath);
|
|
264
|
+
if (existing) {
|
|
265
|
+
existing.push(callSite);
|
|
266
|
+
}
|
|
267
|
+
else {
|
|
268
|
+
callSitesByFile.set(filePath, [callSite]);
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
// 批次讀取所有不重複的檔案並處理
|
|
272
|
+
for (const [filePath, fileCallSites] of callSitesByFile) {
|
|
273
|
+
const content = await this.readFile(filePath);
|
|
259
274
|
if (!content) {
|
|
260
275
|
continue;
|
|
261
276
|
}
|
|
262
277
|
const lines = content.split('\n');
|
|
263
|
-
|
|
264
|
-
const
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
originalLine.substring(
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
278
|
+
// 處理該檔案的所有 callSites
|
|
279
|
+
for (const callSite of fileCallSites) {
|
|
280
|
+
const lineIndex = callSite.location.range.start.line - 1;
|
|
281
|
+
const originalLine = lines[lineIndex];
|
|
282
|
+
// 建立新的參數列表
|
|
283
|
+
const newArgs = this.mapCallSiteArguments(callSite, parameterMapping, changes);
|
|
284
|
+
const newArgsString = newArgs.join(', ');
|
|
285
|
+
// 找到呼叫的括號位置
|
|
286
|
+
const funcNameIndex = originalLine.indexOf(callSite.functionName);
|
|
287
|
+
if (funcNameIndex < 0) {
|
|
288
|
+
continue;
|
|
289
|
+
}
|
|
290
|
+
const openParenIndex = originalLine.indexOf('(', funcNameIndex);
|
|
291
|
+
const closeParenIndex = this.findMatchingParen(originalLine, openParenIndex);
|
|
292
|
+
const newLine = originalLine.substring(0, openParenIndex + 1) +
|
|
293
|
+
newArgsString +
|
|
294
|
+
originalLine.substring(closeParenIndex);
|
|
295
|
+
if (newLine !== originalLine) {
|
|
296
|
+
updates.push({
|
|
297
|
+
filePath: callSite.location.filePath,
|
|
298
|
+
originalCode: originalLine,
|
|
299
|
+
newCode: newLine,
|
|
300
|
+
location: callSite.location
|
|
301
|
+
});
|
|
302
|
+
}
|
|
285
303
|
}
|
|
286
304
|
}
|
|
287
305
|
return updates;
|