@volar/typescript 2.3.5-alpha.1 → 2.4.0-alpha.0
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/index.d.ts +46 -1
- package/index.js +1 -1
- package/lib/node/proxyCreateProgram.d.ts +5 -2
- package/lib/node/proxyCreateProgram.js +11 -2
- package/lib/node/transform.d.ts +2 -1
- package/lib/node/utils.d.ts +2 -1
- package/lib/protocol/createProject.d.ts +2 -1
- package/lib/quickstart/runTsc.d.ts +5 -2
- package/package.json +4 -4
package/index.d.ts
CHANGED
|
@@ -1,7 +1,52 @@
|
|
|
1
|
+
export * from './lib/common';
|
|
1
2
|
export * from './lib/node/decorateLanguageService';
|
|
2
3
|
export * from './lib/node/decorateLanguageServiceHost';
|
|
3
4
|
export * from './lib/node/decorateProgram';
|
|
4
5
|
export * from './lib/node/proxyCreateProgram';
|
|
5
6
|
export * from './lib/protocol/createProject';
|
|
6
7
|
export * from './lib/protocol/createSys';
|
|
7
|
-
|
|
8
|
+
import type { VirtualCode } from '@volar/language-core';
|
|
9
|
+
import type * as ts from 'typescript';
|
|
10
|
+
declare module '@volar/language-core' {
|
|
11
|
+
interface Language<T> {
|
|
12
|
+
typescript?: {
|
|
13
|
+
configFileName: string | undefined;
|
|
14
|
+
sys: ts.System & {
|
|
15
|
+
version?: number;
|
|
16
|
+
sync?(): Promise<number>;
|
|
17
|
+
};
|
|
18
|
+
languageServiceHost: ts.LanguageServiceHost;
|
|
19
|
+
getExtraServiceScript(fileName: string): TypeScriptExtraServiceScript | undefined;
|
|
20
|
+
asScriptId(fileName: string): T;
|
|
21
|
+
asFileName(scriptId: T): string;
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
interface LanguagePlugin<T = unknown, K extends VirtualCode = VirtualCode> {
|
|
25
|
+
typescript?: TypeScriptGenericOptions<K> & TypeScriptNonTSPluginOptions<K>;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* The following options available to all situations.
|
|
30
|
+
*/
|
|
31
|
+
interface TypeScriptGenericOptions<K> {
|
|
32
|
+
extraFileExtensions: ts.FileExtensionInfo[];
|
|
33
|
+
resolveHiddenExtensions?: boolean;
|
|
34
|
+
getServiceScript(root: K): TypeScriptServiceScript | undefined;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* The following options will not be available in TS plugin.
|
|
38
|
+
*/
|
|
39
|
+
interface TypeScriptNonTSPluginOptions<K> {
|
|
40
|
+
getExtraServiceScripts?(fileName: string, rootVirtualCode: K): TypeScriptExtraServiceScript[];
|
|
41
|
+
resolveLanguageServiceHost?(host: ts.LanguageServiceHost): ts.LanguageServiceHost;
|
|
42
|
+
}
|
|
43
|
+
export interface TypeScriptServiceScript {
|
|
44
|
+
code: VirtualCode;
|
|
45
|
+
extension: '.ts' | '.js' | '.mts' | '.mjs' | '.cjs' | '.cts' | '.d.ts' | string;
|
|
46
|
+
scriptKind: ts.ScriptKind;
|
|
47
|
+
/** See #188 */
|
|
48
|
+
preventLeadingOffset?: boolean;
|
|
49
|
+
}
|
|
50
|
+
export interface TypeScriptExtraServiceScript extends TypeScriptServiceScript {
|
|
51
|
+
fileName: string;
|
|
52
|
+
}
|
package/index.js
CHANGED
|
@@ -14,11 +14,11 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./lib/common"), exports);
|
|
17
18
|
__exportStar(require("./lib/node/decorateLanguageService"), exports);
|
|
18
19
|
__exportStar(require("./lib/node/decorateLanguageServiceHost"), exports);
|
|
19
20
|
__exportStar(require("./lib/node/decorateProgram"), exports);
|
|
20
21
|
__exportStar(require("./lib/node/proxyCreateProgram"), exports);
|
|
21
22
|
__exportStar(require("./lib/protocol/createProject"), exports);
|
|
22
23
|
__exportStar(require("./lib/protocol/createSys"), exports);
|
|
23
|
-
__exportStar(require("./lib/common"), exports);
|
|
24
24
|
//# sourceMappingURL=index.js.map
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
-
import { LanguagePlugin } from '@volar/language-core';
|
|
1
|
+
import { Language, LanguagePlugin } from '@volar/language-core';
|
|
2
2
|
import type * as ts from 'typescript';
|
|
3
|
-
export declare function proxyCreateProgram(ts: typeof import('typescript'), original: typeof ts['createProgram'],
|
|
3
|
+
export declare function proxyCreateProgram(ts: typeof import('typescript'), original: typeof ts['createProgram'], create: (ts: typeof import('typescript'), options: ts.CreateProgramOptions) => LanguagePlugin<string>[] | {
|
|
4
|
+
languagePlugins: LanguagePlugin<string>[];
|
|
5
|
+
setup?(language: Language<string>): void;
|
|
6
|
+
}): typeof import("typescript").createProgram;
|
|
@@ -29,7 +29,7 @@ const objectEqual = (a, b) => {
|
|
|
29
29
|
}
|
|
30
30
|
return true;
|
|
31
31
|
};
|
|
32
|
-
function proxyCreateProgram(ts, original,
|
|
32
|
+
function proxyCreateProgram(ts, original, create) {
|
|
33
33
|
const sourceFileSnapshots = new language_core_1.FileMap(ts.sys.useCaseSensitiveFileNames);
|
|
34
34
|
const parsedSourceFiles = new WeakMap();
|
|
35
35
|
let lastOptions;
|
|
@@ -47,7 +47,13 @@ function proxyCreateProgram(ts, original, getLanguagePlugins) {
|
|
|
47
47
|
|| !objectEqual(options.options, lastOptions.options)) {
|
|
48
48
|
moduleResolutionCache = ts.createModuleResolutionCache(options.host.getCurrentDirectory(), options.host.getCanonicalFileName, options.options);
|
|
49
49
|
lastOptions = options;
|
|
50
|
-
|
|
50
|
+
const created = create(ts, options);
|
|
51
|
+
if (Array.isArray(created)) {
|
|
52
|
+
languagePlugins = created;
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
languagePlugins = created.languagePlugins;
|
|
56
|
+
}
|
|
51
57
|
language = (0, language_core_1.createLanguage)([
|
|
52
58
|
...languagePlugins,
|
|
53
59
|
{ getLanguageId: common_1.resolveFileLanguageId },
|
|
@@ -79,6 +85,9 @@ function proxyCreateProgram(ts, original, getLanguagePlugins) {
|
|
|
79
85
|
language.scripts.delete(fileName);
|
|
80
86
|
}
|
|
81
87
|
});
|
|
88
|
+
if ('setup' in created) {
|
|
89
|
+
created.setup?.(language);
|
|
90
|
+
}
|
|
82
91
|
}
|
|
83
92
|
const originalHost = options.host;
|
|
84
93
|
const extensions = languagePlugins
|
package/lib/node/transform.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import type { CodeInformation, SourceScript
|
|
1
|
+
import type { CodeInformation, SourceScript } from '@volar/language-core';
|
|
2
2
|
import { Language } from '@volar/language-core';
|
|
3
3
|
import type * as ts from 'typescript';
|
|
4
|
+
import type { TypeScriptServiceScript } from '../..';
|
|
4
5
|
export declare function transformCallHierarchyItem(language: Language<string>, item: ts.CallHierarchyItem, filter: (data: CodeInformation) => boolean): ts.CallHierarchyItem;
|
|
5
6
|
export declare function transformDiagnostic<T extends ts.Diagnostic>(language: Language<string>, diagnostic: T, program: ts.Program | undefined, isTsc: boolean): T | undefined;
|
|
6
7
|
export declare function fillSourceFileText(language: Language<string>, sourceFile: ts.SourceFile): void;
|
package/lib/node/utils.d.ts
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
import type { Language, SourceScript
|
|
1
|
+
import type { Language, SourceScript } from '@volar/language-core';
|
|
2
|
+
import type { TypeScriptServiceScript } from '../..';
|
|
2
3
|
export declare function getServiceScript(language: Language<string>, fileName: string): [serviceScript: TypeScriptServiceScript, targetScript: SourceScript<string>, sourceScript: SourceScript<string>] | [serviceScript: undefined, sourceScript: SourceScript<string>, sourceScript: SourceScript<string>] | [serviceScript: undefined, sourceScript: undefined, targetScript: undefined];
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { Language
|
|
1
|
+
import { Language } from '@volar/language-core';
|
|
2
2
|
import type * as ts from 'typescript';
|
|
3
|
+
import type { TypeScriptExtraServiceScript } from '../..';
|
|
3
4
|
import type { createSys } from './createSys';
|
|
4
5
|
export interface TypeScriptProjectHost extends Pick<ts.LanguageServiceHost, 'getLocalizedDiagnosticMessages' | 'getCurrentDirectory' | 'getCompilationSettings' | 'getProjectReferences' | 'getScriptFileNames' | 'getProjectVersion' | 'getScriptSnapshot'> {
|
|
5
6
|
}
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
import type * as ts from 'typescript';
|
|
2
|
-
import type { LanguagePlugin } from '@volar/language-core';
|
|
3
|
-
export declare let getLanguagePlugins: (ts: typeof import('typescript'), options: ts.CreateProgramOptions) => LanguagePlugin<string>[]
|
|
2
|
+
import type { Language, LanguagePlugin } from '@volar/language-core';
|
|
3
|
+
export declare let getLanguagePlugins: (ts: typeof import('typescript'), options: ts.CreateProgramOptions) => LanguagePlugin<string>[] | {
|
|
4
|
+
plugins: LanguagePlugin<string>[];
|
|
5
|
+
setup?(language: Language<string>): void;
|
|
6
|
+
};
|
|
4
7
|
export declare function runTsc(tscPath: string, extensions: string[], _getLanguagePlugins: typeof getLanguagePlugins): void;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@volar/typescript",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.4.0-alpha.0",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"files": [
|
|
6
6
|
"**/*.js",
|
|
@@ -12,14 +12,14 @@
|
|
|
12
12
|
"directory": "packages/typescript"
|
|
13
13
|
},
|
|
14
14
|
"dependencies": {
|
|
15
|
-
"@volar/language-core": "2.
|
|
15
|
+
"@volar/language-core": "2.4.0-alpha.0",
|
|
16
16
|
"path-browserify": "^1.0.1",
|
|
17
17
|
"vscode-uri": "^3.0.8"
|
|
18
18
|
},
|
|
19
19
|
"devDependencies": {
|
|
20
20
|
"@types/node": "latest",
|
|
21
21
|
"@types/path-browserify": "latest",
|
|
22
|
-
"@volar/language-service": "2.
|
|
22
|
+
"@volar/language-service": "2.4.0-alpha.0"
|
|
23
23
|
},
|
|
24
|
-
"gitHead": "
|
|
24
|
+
"gitHead": "007fc74c461e2fd3fb269bf4f3924cc23c35ba56"
|
|
25
25
|
}
|