Skip to content

Commit

Permalink
revert: Volar 2.0 Upgrade
Browse files Browse the repository at this point in the history
  • Loading branch information
Princesseuh committed Dec 21, 2023
1 parent beccfef commit 7da69c4
Show file tree
Hide file tree
Showing 35 changed files with 1,075 additions and 1,060 deletions.
8 changes: 4 additions & 4 deletions packages/astro-check/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,20 +44,20 @@ export async function check(flags: Partial<Flags>): Promise<boolean | void> {
// Dynamically get the list of extensions to watch from the files already included in the project
const checkedExtensions = Array.from(
new Set(
checker.linter.languageHost.getScriptFileNames().map((fileName) => path.extname(fileName))
checker.project.languageHost.getScriptFileNames().map((fileName) => path.extname(fileName))
)
);
createWatcher(workspaceRoot, checkedExtensions)
.on('add', (fileName) => {
checker.linter.fileCreated(fileName);
checker.project.fileCreated(fileName);
update();
})
.on('unlink', (fileName) => {
checker.linter.fileDeleted(fileName);
checker.project.fileDeleted(fileName);
update();
})
.on('change', (fileName) => {
checker.linter.fileUpdated(fileName);
checker.project.fileUpdated(fileName);
update();
});
}
Expand Down
27 changes: 14 additions & 13 deletions packages/language-server/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,19 +28,21 @@
"dependencies": {
"@astrojs/compiler": "^2.2.2",
"@jridgewell/sourcemap-codec": "^1.4.15",
"@volar/kit": "2.0.0-alpha.10",
"@volar/language-core": "2.0.0-alpha.10",
"@volar/language-server": "2.0.0-alpha.10",
"@volar/language-service": "2.0.0-alpha.10",
"@volar/typescript": "2.0.0-alpha.10",
"@volar/kit": "~1.10.9",
"@volar/language-core": "~1.10.9",
"@volar/language-server": "~1.10.9",
"@volar/language-service": "~1.10.9",
"@volar/source-map": "~1.10.9",
"@volar/typescript": "~1.10.9",
"fast-glob": "^3.2.12",
"volar-service-css": "0.0.24",
"volar-service-emmet": "0.0.24",
"volar-service-html": "0.0.24",
"volar-service-prettier": "0.0.24",
"volar-service-typescript": "0.0.24",
"volar-service-typescript-twoslash-queries": "0.0.24",
"vscode-html-languageservice": "^5.1.1",
"muggle-string": "^0.3.1",
"volar-service-css": "0.0.16",
"volar-service-emmet": "0.0.16",
"volar-service-html": "0.0.16",
"volar-service-prettier": "0.0.16",
"volar-service-typescript": "0.0.16",
"volar-service-typescript-twoslash-queries": "0.0.16",
"vscode-html-languageservice": "^5.1.0",
"vscode-uri": "^3.0.8"
},
"devDependencies": {
Expand All @@ -49,7 +51,6 @@
"@types/chai": "^4.3.5",
"@types/mocha": "^10.0.1",
"@types/node": "^18.17.8",
"@volar/test-utils": "2.0.0-alpha.10",
"astro": "^3.3.0",
"chai": "^4.3.7",
"mocha": "^10.2.0",
Expand Down
37 changes: 26 additions & 11 deletions packages/language-server/src/check.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@ export interface CheckResult {

export class AstroCheck {
private ts!: typeof import('typescript/lib/tsserverlibrary.js');
public linter!: ReturnType<(typeof kit)['createTypeScriptChecker']>;
public project!: ReturnType<typeof kit.createProject>;
private linter!: ReturnType<typeof kit.createLinter>;

constructor(
private readonly workspacePath: string,
Expand Down Expand Up @@ -60,7 +61,7 @@ export class AstroCheck {
| undefined;
}): Promise<CheckResult> {
const files =
fileNames !== undefined ? fileNames : this.linter.languageHost.getScriptFileNames();
fileNames !== undefined ? fileNames : this.project.languageHost.getScriptFileNames();

const result: CheckResult = {
status: undefined,
Expand Down Expand Up @@ -97,7 +98,7 @@ export class AstroCheck {
console.info(errorText);
}

const fileSnapshot = this.linter.languageHost.getScriptSnapshot(file);
const fileSnapshot = this.project.languageHost.getScriptSnapshot(file);
const fileContent = fileSnapshot?.getText(0, fileSnapshot.getLength());

result.fileResult.push({
Expand Down Expand Up @@ -130,24 +131,38 @@ export class AstroCheck {
const tsconfigPath = this.getTsconfig();

const astroInstall = getAstroInstall([this.workspacePath]);
const languages = [
getLanguageModule(typeof astroInstall === 'string' ? undefined : astroInstall, this.ts),
getSvelteLanguageModule(),
getVueLanguageModule(),
];
const services = [createTypeScriptService(this.ts), createAstroService(this.ts)];
const config: kit.Config = {
languages: {
astro: getLanguageModule(
typeof astroInstall === 'string' ? undefined : astroInstall,
this.ts
),
svelte: getSvelteLanguageModule(),
vue: getVueLanguageModule(),
},
services: {
typescript: createTypeScriptService(),
astro: createAstroService(),
},
};

if (tsconfigPath) {
this.linter = kit.createTypeScriptChecker(languages, services, tsconfigPath);
this.project = kit.createProject(tsconfigPath, [
{ extension: 'astro', isMixedContent: true, scriptKind: 7 },
{ extension: 'vue', isMixedContent: true, scriptKind: 7 },
{ extension: 'svelte', isMixedContent: true, scriptKind: 7 },
]);
} else {
this.linter = kit.createTypeScriptInferredChecker(languages, services, () => {
this.project = kit.createInferredProject(this.workspacePath, () => {
return fg.sync('**/*.astro', {
cwd: this.workspacePath,
ignore: ['node_modules'],
absolute: true,
});
});
}

this.linter = kit.createLinter(config, this.project.languageHost);
}

private getTsconfig() {
Expand Down
67 changes: 39 additions & 28 deletions packages/language-server/src/core/astro2tsx.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { convertToTSX } from '@astrojs/compiler/sync';
import type { ConvertToTSXOptions, TSXResult } from '@astrojs/compiler/types';
import { decode } from '@jridgewell/sourcemap-codec';
import type { CodeInformation, VirtualFile } from '@volar/language-core';
import { FileKind, FileRangeCapabilities, VirtualFile } from '@volar/language-core';
import { HTMLDocument, TextDocument } from 'vscode-html-languageservice';
import { patchTSX } from './utils.js';

Expand Down Expand Up @@ -39,7 +39,7 @@ function safeConvertToTSX(content: string, options: ConvertToTSXOptions) {
export function astro2tsx(
input: string,
fileName: string,
ts: typeof import('typescript'),
ts: typeof import('typescript/lib/tsserverlibrary.js'),
htmlDocument: HTMLDocument
) {
const tsx = safeConvertToTSX(input, { filename: fileName });
Expand All @@ -54,13 +54,13 @@ function getVirtualFileTSX(
input: string,
tsx: TSXResult,
fileName: string,
ts: typeof import('typescript'),
ts: typeof import('typescript/lib/tsserverlibrary.js'),
htmlDocument: HTMLDocument
): VirtualFile {
tsx.code = patchTSX(tsx.code, fileName);
const v3Mappings = decode(tsx.map.mappings);
const sourcedDoc = TextDocument.create('file://' + fileName, 'astro', 0, input);
const genDoc = TextDocument.create('file://' + fileName + '.tsx', 'typescriptreact', 0, tsx.code);
const sourcedDoc = TextDocument.create(fileName, 'astro', 0, input);
const genDoc = TextDocument.create(fileName + '.tsx', 'typescriptreact', 0, tsx.code);

const mappings: VirtualFile['mappings'] = [];

Expand Down Expand Up @@ -93,37 +93,33 @@ function getVirtualFileTSX(
const lastMapping = mappings.length ? mappings[mappings.length - 1] : undefined;
if (
lastMapping &&
lastMapping.generatedOffsets[0] + lastMapping.lengths[0] === current.genOffset &&
lastMapping.sourceOffsets[0] + lastMapping.lengths[0] === current.sourceOffset
lastMapping.generatedRange[1] === current.genOffset &&
lastMapping.sourceRange[1] === current.sourceOffset
) {
lastMapping.lengths[0] += length;
lastMapping.generatedRange[1] = current.genOffset + length;
lastMapping.sourceRange[1] = current.sourceOffset + length;
} else {
// Disable features inside script tags. This is a bit annoying to do, I wonder if maybe leaving script tags
// unmapped would be better.
const node = htmlDocument.findNodeAt(current.sourceOffset);
const rangeCapabilities: CodeInformation =
const rangeCapabilities: FileRangeCapabilities =
node.tag !== 'script'
? {
verification: true,
completion: true,
semantic: true,
navigation: true,
structure: true,
format: true,
}
? FileRangeCapabilities.full
: {
verification: false,
completion: false,
semantic: false,
navigation: false,
structure: false,
format: false,
definition: false,
diagnostic: false,
displayWithLink: false,
hover: false,
references: false,
referencesCodeLens: false,
rename: false,
semanticTokens: false,
};

mappings.push({
sourceOffsets: [current.sourceOffset],
generatedOffsets: [current.genOffset],
lengths: [length],
sourceRange: [current.sourceOffset, current.sourceOffset + length],
generatedRange: [current.genOffset, current.genOffset + length],
data: rangeCapabilities,
});
}
Expand All @@ -140,12 +136,27 @@ function getVirtualFileTSX(
}
}

const ast = ts.createSourceFile('/a.tsx', tsx.code, ts.ScriptTarget.ESNext);
if (ast.statements[0]) {
mappings.push({
sourceRange: [0, input.length],
generatedRange: [ast.statements[0].getStart(ast), tsx.code.length],
data: {},
});
}

return {
fileName: fileName + '.tsx',
languageId: 'typescriptreact',
typescript: {
scriptKind: ts.ScriptKind.TSX,
kind: FileKind.TypeScriptHostFile,
capabilities: {
codeAction: true,
documentFormatting: false,
diagnostic: true,
documentSymbol: true,
inlayHint: true,
foldingRange: true,
},
codegenStacks: [],
snapshot: {
getText: (start, end) => tsx.code.substring(start, end),
getLength: () => tsx.code.length,
Expand Down
Loading

0 comments on commit 7da69c4

Please sign in to comment.