From 2f5207d49b519101c0b43f60dc08eda50aeaee4a Mon Sep 17 00:00:00 2001 From: tjprescott Date: Fri, 3 Mar 2023 15:18:33 -0800 Subject: [PATCH] Rename Cadl to TypeSpec. --- .../emitters/cadl-apiview/.eslintrc.cjs | 6 -- .../emitters/cadl-apiview/.prettierrc.yaml | 8 --- .../.c8rc.json | 0 .../emitters/typespec-apiview/.eslintrc.cjs | 6 ++ .../.mocharc.yaml | 0 .../.prettierignore | 0 .../typespec-apiview/.prettierrc.yaml | 8 +++ .../CHANGELOG.md | 5 +- .../README.md | 40 +++++------ .../{cadl-apiview => typespec-apiview}/ci.yml | 24 +++---- .../cspell.yaml | 6 +- .../package.json | 35 +++++----- .../src/apiview.ts | 70 +++++++++---------- .../src/diagnostic.ts | 0 .../src/emitter.ts | 6 +- .../src/index.ts | 0 .../src/lib.ts | 4 +- .../src/namespace-model.ts | 4 +- .../src/navigation.ts | 2 +- .../src/testing/index.ts | 10 +-- .../src/version.ts | 0 .../test/apiview-options.test.ts | 22 +++--- .../test/apiview.test.ts | 22 +++--- .../test/test-host.ts | 24 +++---- .../tsconfig.json | 0 25 files changed, 151 insertions(+), 151 deletions(-) delete mode 100644 tools/apiview/emitters/cadl-apiview/.eslintrc.cjs delete mode 100644 tools/apiview/emitters/cadl-apiview/.prettierrc.yaml rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/.c8rc.json (100%) create mode 100644 tools/apiview/emitters/typespec-apiview/.eslintrc.cjs rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/.mocharc.yaml (100%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/.prettierignore (100%) create mode 100644 tools/apiview/emitters/typespec-apiview/.prettierrc.yaml rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/CHANGELOG.md (95%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/README.md (55%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/ci.yml (77%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/cspell.yaml (95%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/package.json (68%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/apiview.ts (94%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/diagnostic.ts (100%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/emitter.ts (97%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/index.ts (100%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/lib.ts (96%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/namespace-model.ts (99%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/navigation.ts (99%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/testing/index.ts (51%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/src/version.ts (100%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/test/apiview-options.test.ts (78%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/test/apiview.test.ts (94%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/test/test-host.ts (81%) rename tools/apiview/emitters/{cadl-apiview => typespec-apiview}/tsconfig.json (100%) diff --git a/tools/apiview/emitters/cadl-apiview/.eslintrc.cjs b/tools/apiview/emitters/cadl-apiview/.eslintrc.cjs deleted file mode 100644 index 8ce089ccb78..00000000000 --- a/tools/apiview/emitters/cadl-apiview/.eslintrc.cjs +++ /dev/null @@ -1,6 +0,0 @@ -require("@cadl-lang/eslint-config-cadl/patch/modern-module-resolution"); - -module.exports = { - extends: "@cadl-lang/eslint-config-cadl", - parserOptions: { tsconfigRootDir: __dirname }, -}; diff --git a/tools/apiview/emitters/cadl-apiview/.prettierrc.yaml b/tools/apiview/emitters/cadl-apiview/.prettierrc.yaml deleted file mode 100644 index 544f4b35e98..00000000000 --- a/tools/apiview/emitters/cadl-apiview/.prettierrc.yaml +++ /dev/null @@ -1,8 +0,0 @@ -trailingComma: "all" -printWidth: 120 -quoteProps: "consistent" -endOfLine: lf -arrowParens: always -plugins: - - "./node_modules/@cadl-lang/prettier-plugin-cadl" -overrides: [{ "files": "*.cadl", "options": { "parser": "cadl" } }] diff --git a/tools/apiview/emitters/cadl-apiview/.c8rc.json b/tools/apiview/emitters/typespec-apiview/.c8rc.json similarity index 100% rename from tools/apiview/emitters/cadl-apiview/.c8rc.json rename to tools/apiview/emitters/typespec-apiview/.c8rc.json diff --git a/tools/apiview/emitters/typespec-apiview/.eslintrc.cjs b/tools/apiview/emitters/typespec-apiview/.eslintrc.cjs new file mode 100644 index 00000000000..a02edcee2a1 --- /dev/null +++ b/tools/apiview/emitters/typespec-apiview/.eslintrc.cjs @@ -0,0 +1,6 @@ +require("@typespec/eslint-config-typespec/patch/modern-module-resolution"); + +module.exports = { + extends: "@typespec/eslint-config-typespec", + parserOptions: { tsconfigRootDir: __dirname }, +}; diff --git a/tools/apiview/emitters/cadl-apiview/.mocharc.yaml b/tools/apiview/emitters/typespec-apiview/.mocharc.yaml similarity index 100% rename from tools/apiview/emitters/cadl-apiview/.mocharc.yaml rename to tools/apiview/emitters/typespec-apiview/.mocharc.yaml diff --git a/tools/apiview/emitters/cadl-apiview/.prettierignore b/tools/apiview/emitters/typespec-apiview/.prettierignore similarity index 100% rename from tools/apiview/emitters/cadl-apiview/.prettierignore rename to tools/apiview/emitters/typespec-apiview/.prettierignore diff --git a/tools/apiview/emitters/typespec-apiview/.prettierrc.yaml b/tools/apiview/emitters/typespec-apiview/.prettierrc.yaml new file mode 100644 index 00000000000..e19c948bb5e --- /dev/null +++ b/tools/apiview/emitters/typespec-apiview/.prettierrc.yaml @@ -0,0 +1,8 @@ +trailingComma: "all" +printWidth: 120 +quoteProps: "consistent" +endOfLine: lf +arrowParens: always +plugins: + - "./node_modules/@typespec/prettier-plugin-typespec" +overrides: [{ "files": "*.tsp", "options": { "parser": "typespec" } }] diff --git a/tools/apiview/emitters/cadl-apiview/CHANGELOG.md b/tools/apiview/emitters/typespec-apiview/CHANGELOG.md similarity index 95% rename from tools/apiview/emitters/cadl-apiview/CHANGELOG.md rename to tools/apiview/emitters/typespec-apiview/CHANGELOG.md index 6b12380fa64..0c78840998e 100644 --- a/tools/apiview/emitters/cadl-apiview/CHANGELOG.md +++ b/tools/apiview/emitters/typespec-apiview/CHANGELOG.md @@ -1,6 +1,9 @@ # Release History -## Version 0.3.5 (Unreleased) +## Version 0.4.0 (03-06-2023) +Update for rename of Cadl to TypeSpec. + +## Version 0.3.5 (02-10-2023) Support latest release of Cadl compiler. **BREAKING CHANGE**: Removed the `--namespace` emitter option. Added the `--service` emitter option to support filtering output for multi-service specs. diff --git a/tools/apiview/emitters/cadl-apiview/README.md b/tools/apiview/emitters/typespec-apiview/README.md similarity index 55% rename from tools/apiview/emitters/cadl-apiview/README.md rename to tools/apiview/emitters/typespec-apiview/README.md index 7157d0ae539..b99c736f75f 100644 --- a/tools/apiview/emitters/cadl-apiview/README.md +++ b/tools/apiview/emitters/typespec-apiview/README.md @@ -1,26 +1,26 @@ -# Cadl APIView Emitter +# TypeSpec APIView Emitter -This package provides the [Cadl](https://github.com/microsoft/cadl) emitter to produce APIView token file output from Cadl source. +This package provides the [TypeSpec](https://github.com/microsoft/typespec) emitter to produce APIView token file output from TypeSpec source. ## Install -Add `@azure-tools/cadl-apiview` to your `package.json` and run `npm install`. +Add `@azure-tools/typespec-apiview` to your `package.json` and run `npm install`. ## Emit APIView spec 1. Via the command line ```bash -cadl compile {path to cadl project} --emit=@azure-tools/cadl-apiview +tsc compile {path to typespec project} --emit=@azure-tools/typespec-apiview ``` 2. Via the config -Add the following to the `cadl-project.yaml` file. +Add the following to the `typespec-project.yaml` file. ```yaml emitters: - @azure-tools/cadl-apiview: true + @azure-tools/typespec-apiview: true ``` For configuration [see options](#emitter-options) @@ -29,7 +29,7 @@ For configuration [see options](#emitter-options) 1. Log in to the API View site (apiview.dev)[https://apiview.dev]. 2. Click the blue "Create Review" button in the bottom-right corner of the screen. -3. In the first block, load the token file generated by the `cadl-apiview` emitter. +3. In the first block, load the token file generated by the `typespec-apiview` emitter. ## Revise API View @@ -37,7 +37,7 @@ For configuration [see options](#emitter-options) 2. Navigate to your review. 3. Click the "Revisions" tab in the top left. 4. Click the blue "Add Revision" button in the bottom-right corner of the screen. -5. In the first block, load the token file generated by the `cadl-apiview` emitter. +5. In the first block, load the token file generated by the `typespec-apiview` emitter. ## Use APIView-specific decorators: @@ -45,37 +45,37 @@ Currently there are no APIView-specific decorators... ## Emitter options: -Emitter options can be configured via the `cadl-project.yaml` configuration: +Emitter options can be configured via the `tspconfig.yaml` configuration: ```yaml emitters: - '@azure-tools/cadl-apiview': + '@azure-tools/typespec-apiview': : # For example emitters: - '@azure-tools/cadl-apiview': + '@azure-tools/typespec-apiview': output-file: my-custom-apiview.json ``` or via the command line with ```bash ---option "@azure-tools/cadl-apiview.=" +--option "@azure-tools/typespec-apiview.=" # For example ---option "@azure-tools/cadl-apiview.output-file=my-custom-apiview.json" +--option "@azure-tools/typespec-apiview.output-file=my-custom-apiview.json" ``` ### `emitter-output-dir` -Configure the name of the output directory. Default is `cadl-output/@azure-tools/cadl-apiview`. +Configure the name of the output directory. Default is `tsc-output/@azure-tools/typespec-apiview`. ### `include-global-namespace` Normally, APIView will filter all namespaces and only output those in the service namespace and any -subnamespaces. This is to filter out types that come from the Cadl compiler and supporting libraries. +subnamespaces. This is to filter out types that come from the TypeSpec compiler and supporting libraries. This setting, if `true`, tells APIView to output the contents of the global (empty) namespace, which would normally be excluded. @@ -93,13 +93,13 @@ all services in a multi-service spec, the output filename will be the service ro ### `version` -For multi-versioned Cadl specs, this parameter is used to control which version to emit. This -is not required for single-version specs. For multi-versioned specs, the unprojected Cadl will +For multi-versioned TypeSpec, this parameter is used to control which version to emit. This +is not required for single-version specs. For multi-versioned specs, the unprojected TypeSpec will be rendered if this is not supplied. For multi-service specs, this option cannot be supplied unless the `service` option is also set. ## See also -- [Cadl Getting Started](https://github.com/microsoft/cadl#getting-started) -- [Cadl Tutorial](https://github.com/microsoft/cadl/blob/main/docs/tutorial.md) -- [Cadl for the OpenAPI Developer](https://github.com/microsoft/cadl/blob/main/docs/cadl-for-openapi-dev.md) +- [TypeSpec Getting Started](https://github.com/microsoft/typespec#getting-started) +- [TypeSpec Tutorial](https://github.com/microsoft/typespec/blob/main/docs/tutorial.md) +- [TypeSpec for the OpenAPI Developer](https://github.com/microsoft/typespec/blob/main/docs/typespec-for-openapi-dev.md) diff --git a/tools/apiview/emitters/cadl-apiview/ci.yml b/tools/apiview/emitters/typespec-apiview/ci.yml similarity index 77% rename from tools/apiview/emitters/cadl-apiview/ci.yml rename to tools/apiview/emitters/typespec-apiview/ci.yml index b35909715be..0dc2d7d4de5 100644 --- a/tools/apiview/emitters/cadl-apiview/ci.yml +++ b/tools/apiview/emitters/typespec-apiview/ci.yml @@ -8,7 +8,7 @@ trigger: - hotfix/* paths: include: - - tools/apiview/emitters/cadl-apiview + - tools/apiview/emitters/typespec-apiview pr: branches: @@ -19,11 +19,11 @@ pr: - hotfix/* paths: include: - - tools/apiview/emitters/cadl-apiview + - tools/apiview/emitters/typespec-apiview variables: NodeVersion: '16.x' - CadlEmitterDirectory: 'tools/apiview/emitters/cadl-apiview' + TypeSpecEmitterDirectory: 'tools/apiview/emitters/typespec-apiview' ArtifactName: 'apiview' FeedRegistry: 'https://registry.npmjs.org/' @@ -44,23 +44,23 @@ stages: - script: | npm install - workingDirectory: $(CadlEmitterDirectory) - displayName: "Install npm packages for CADL emiter" + workingDirectory: $(TypeSpecEmitterDirectory) + displayName: "Install npm packages for TypeSpec emiter" - script: | npm run-script build - workingDirectory: $(CadlEmitterDirectory) - displayName: "Build CADL emitter" + workingDirectory: $(TypeSpecEmitterDirectory) + displayName: "Build TypeSpec emitter" - script: | npm run-script test - workingDirectory: $(CadlEmitterDirectory) - displayName: "Test CADL emitter" + workingDirectory: $(TypeSpecEmitterDirectory) + displayName: "Test TypeSpec emitter" - pwsh: | - npm pack $(CadlEmitterDirectory) + npm pack $(TypeSpecEmitterDirectory) Copy-Item ./*.tgz $(Build.ArtifactStagingDirectory) - displayName: "Pack CADL Emitter" + displayName: "Pack TypeSpec Emitter" - task: PublishBuildArtifacts@1 inputs: @@ -73,7 +73,7 @@ stages: condition: Succeeded() jobs: - job: PublishPackage - displayName: 'Publish cadl-apiview package to devops feed' + displayName: 'Publish typespec-apiview package to devops feed' pool: name: azsdk-pool-mms-ubuntu-2204-general vmImage: MMSUbuntu22.04 diff --git a/tools/apiview/emitters/cadl-apiview/cspell.yaml b/tools/apiview/emitters/typespec-apiview/cspell.yaml similarity index 95% rename from tools/apiview/emitters/cadl-apiview/cspell.yaml rename to tools/apiview/emitters/typespec-apiview/cspell.yaml index 76aaf687b3a..de4ed1284d3 100644 --- a/tools/apiview/emitters/cadl-apiview/cspell.yaml +++ b/tools/apiview/emitters/typespec-apiview/cspell.yaml @@ -10,7 +10,7 @@ words: - azurecr - blockful - blockless - - cadl + - typespec - Contoso - CRUDL - devdriven @@ -62,6 +62,6 @@ ignorePaths: - "**/node_modules/**" - "**/dist/**" - "**/dist-dev/**" - - "**/cadl-output/**" + - "**/tsp-output/**" enableFiletypes: - - cadl \ No newline at end of file + - tsp \ No newline at end of file diff --git a/tools/apiview/emitters/cadl-apiview/package.json b/tools/apiview/emitters/typespec-apiview/package.json similarity index 68% rename from tools/apiview/emitters/cadl-apiview/package.json rename to tools/apiview/emitters/typespec-apiview/package.json index 0950984ac6e..718807fec41 100644 --- a/tools/apiview/emitters/cadl-apiview/package.json +++ b/tools/apiview/emitters/typespec-apiview/package.json @@ -1,8 +1,8 @@ { - "name": "@azure-tools/cadl-apiview", - "version": "0.3.5", + "name": "@azure-tools/typespec-apiview", + "version": "0.4.0", "author": "Microsoft Corporation", - "description": "Cadl library for emitting APIView token files from Cadl specifications", + "description": "Library for emitting APIView token files from TypeSpec", "homepage": "https://github.com/Azure/azure-sdk-tools", "readme": "https://github.com/Azure/azure-sdk-tools/blob/master/README.md", "license": "MIT", @@ -14,7 +14,7 @@ "url": "https://github.com/Azure/azure-sdk-tools/issues" }, "keywords": [ - "cadl", + "typespec", "apiview" ], "type": "module", @@ -33,39 +33,38 @@ ] } }, - "cadlMain": "dist/src/index.js", + "typespecMain": "dist/src/index.js", "engines": { "node": ">=16.0.0" }, "scripts": { "clean": "rimraf ./dist ./temp", "prebuild": "node -p \"'export const LIB_VERSION = ' + JSON.stringify(require('./package.json').version) + ';'\" > src/version.ts", - "build": "npm run prebuild && tsc -p . && npm run lint-cadl-library", + "build": "npm run prebuild && tsc -p . && npm run lint-typespec-library", "watch": "tsc -p . --watch", - "lint-cadl-library": "cadl compile . --warn-as-error --import @cadl-lang/library-linter --no-emit", + "lint-typespec-library": "tsp compile . --warn-as-error --import @typespec/library-linter --no-emit", "test": "mocha", "test-official": "c8 mocha --forbid-only --reporter mocha-multi-reporters", "lint": "eslint . --ext .ts --max-warnings=0", "lint:fix": "eslint . --fix --ext .ts" }, "files": [ - "lib/*.cadl", + "lib/*.tsp", "dist/**", "!dist/test/**" ], "dependencies": { - "@azure-tools/cadl-azure-core": "0.26.0", - "@azure-tools/cadl-autorest": "0.26.0", - "@azure-tools/cadl-dpg": "latest", - "@cadl-lang/compiler": "0.40.0", - "@cadl-lang/rest": "latest", - "@cadl-lang/versioning": "latest" + "@azure-tools/typespec-azure-core": "0.27.0", + "@azure-tools/typespec-autorest": "0.27.0", + "@typespec/compiler": "0.41.0", + "@typespec/rest": "0.41.0", + "@typespec/versioning": "0.41.0" }, "devDependencies": { - "@cadl-lang/eslint-plugin": "~0.40.0", - "@cadl-lang/library-linter": "~0.40.0", - "@cadl-lang/prettier-plugin-cadl": "^0.40.0", - "@cadl-lang/eslint-config-cadl": "~0.4.1", + "@typespec/eslint-plugin": "~0.41.0", + "@typespec/library-linter": "~0.41.0", + "@typespec/prettier-plugin-typespec": "^0.41.0", + "@typespec/eslint-config-typespec": "~0.6.0", "@types/mocha": "~9.1.0", "@types/node": "~16.0.3", "@changesets/cli": "^2.24.4", diff --git a/tools/apiview/emitters/cadl-apiview/src/apiview.ts b/tools/apiview/emitters/typespec-apiview/src/apiview.ts similarity index 94% rename from tools/apiview/emitters/cadl-apiview/src/apiview.ts rename to tools/apiview/emitters/typespec-apiview/src/apiview.ts index a103706b2bc..6ed14f6a79d 100644 --- a/tools/apiview/emitters/cadl-apiview/src/apiview.ts +++ b/tools/apiview/emitters/typespec-apiview/src/apiview.ts @@ -33,7 +33,7 @@ import { UnionExpressionNode, UnionStatementNode, UnionVariantNode, -} from "@cadl-lang/compiler"; +} from "@typespec/compiler"; import { ApiViewDiagnostic, ApiViewDiagnosticLevel } from "./diagnostic.js"; import { ApiViewNavigation } from "./navigation.js"; import { generateId, NamespaceModel } from "./namespace-model.js"; @@ -130,7 +130,7 @@ export class ApiView { trim() { let last = this.tokens[this.tokens.length - 1] while (last) { - if (last.Kind == ApiViewTokenKind.Whitespace) { + if (last.Kind === ApiViewTokenKind.Whitespace) { this.tokens.pop(); last = this.tokens[this.tokens.length - 1]; } else { @@ -159,7 +159,7 @@ export class ApiView { } space() { - if (this.tokens[this.tokens.length - 1]?.Kind != ApiViewTokenKind.Whitespace) { + if (this.tokens[this.tokens.length - 1]?.Kind !== ApiViewTokenKind.Whitespace) { this.tokens.push({ Kind: ApiViewTokenKind.Whitespace, Value: WHITESPACE, @@ -182,9 +182,9 @@ export class ApiView { let newlineCount: number = 0; for (let i = this.tokens.length; i > 0; i--) { const token = this.tokens[i - 1]; - if (token.Kind == ApiViewTokenKind.Newline) { + if (token.Kind === ApiViewTokenKind.Newline) { newlineCount++; - } else if (token.Kind == ApiViewTokenKind.Whitespace) { + } else if (token.Kind === ApiViewTokenKind.Whitespace) { continue; } else { break; @@ -201,7 +201,7 @@ export class ApiView { let toRemove = newlineCount - (count + 1); while (toRemove) { const popped = this.tokens.pop(); - if (popped?.Kind == ApiViewTokenKind.Newline) { + if (popped?.Kind === ApiViewTokenKind.Newline) { toRemove--; } } @@ -281,7 +281,7 @@ export class ApiView { stringLiteral(value: string) { const lines = value.split("\n"); - if (lines.length == 1) { + if (lines.length === 1) { this.tokens.push({ Kind: ApiViewTokenKind.StringLiteral, Value: `\u0022${value}\u0022`, @@ -343,7 +343,7 @@ export class ApiView { continue; } // use a fake name to make the global namespace clear - const namespaceName = name == "" ? "::GLOBAL::" : name; + const namespaceName = name === "" ? "::GLOBAL::" : name; const nsModel = new NamespaceModel(namespaceName, ns, program); if (nsModel.shouldEmit()) { this.tokenizeNamespaceModel(nsModel); @@ -354,7 +354,7 @@ export class ApiView { private emitHeader() { const toolVersion = LIB_VERSION; - const headerText = `// Package parsed using @azure-tools/cadl-apiview (version:${toolVersion})`; + const headerText = `// Package parsed using @azure-tools/typespec-apiview (version:${toolVersion})`; this.token(ApiViewTokenKind.SkipDiffRangeStart); this.literal(headerText); this.namespaceStack.push("GLOBAL"); @@ -399,7 +399,7 @@ export class ApiView { for (let x = 0; x < obj.arguments.length; x++) { const arg = obj.arguments[x]; this.tokenize(arg); - if (x != last) { + if (x !== last) { this.punctuation(",", false, true); } } @@ -413,7 +413,7 @@ export class ApiView { break; case SyntaxKind.BlockComment: throw new Error(`Case "BlockComment" not implemented`); - case SyntaxKind.CadlScript: + case SyntaxKind.TypeSpecScript: throw new Error(`Case "CadlScript" not implemented`); case SyntaxKind.DecoratorExpression: obj = node as DecoratorExpressionNode; @@ -426,7 +426,7 @@ export class ApiView { for (let x = 0; x < obj.arguments.length; x++) { const arg = obj.arguments[x]; this.tokenize(arg); - if (x != last) { + if (x !== last) { this.punctuation(",", false, true); } } @@ -442,7 +442,7 @@ export class ApiView { this.tokenizeDecorators(obj.decorators, false); this.tokenizeIdentifier(obj.id, "member"); this.lineMarker(); - if (obj.value != undefined) { + if (obj.value) { this.punctuation(":", false, true); this.tokenize(obj.value); } @@ -470,7 +470,7 @@ export class ApiView { for (let x = 0; x < obj.options.length; x++) { const opt = obj.options[x]; this.tokenize(opt); - if (x != obj.options.length - 1) { + if (x !== obj.options.length - 1) { this.punctuation("&", true, true); } } @@ -539,11 +539,11 @@ export class ApiView { case SyntaxKind.TemplateParameterDeclaration: obj = node as TemplateParameterDeclarationNode; this.tokenize(obj.id); - if (obj.constraint != undefined) { + if (obj.constraint) { this.keyword("extends", true, true); this.tokenize(obj.constraint); } - if (obj.default != undefined) { + if (obj.default) { this.punctuation("=", true, true); this.tokenize(obj.default); } @@ -554,7 +554,7 @@ export class ApiView { for (let x = 0; x < obj.values.length; x++) { const val = obj.values[x]; this.tokenize(val); - if (x != obj.values.length - 1) { + if (x !== obj.values.length - 1) { this.renderPunctuation(","); } } @@ -568,7 +568,7 @@ export class ApiView { for (let x = 0; x < obj.arguments.length; x++) { const arg = obj.arguments[x]; this.tokenize(arg); - if (x != obj.arguments.length - 1) { + if (x !== obj.arguments.length - 1) { this.renderPunctuation(","); } } @@ -580,7 +580,7 @@ export class ApiView { for (let x = 0; x < obj.options.length; x++) { const opt = obj.options[x]; this.tokenize(opt); - if (x != obj.options.length -1) { + if (x !== obj.options.length -1) { this.punctuation("|", true, true); } } @@ -610,11 +610,11 @@ export class ApiView { this.tokenizeDecorators(node.decorators, false); this.keyword("model", false, true); this.tokenizeIdentifier(node.id, "declaration"); - if (node.extends != undefined) { + if (node.extends) { this.keyword("extends", true, true); this.tokenize(node.extends); } - if (node.is != undefined) { + if (node.is) { this.keyword("is", true, true); this.tokenize(node.is); } @@ -641,7 +641,7 @@ export class ApiView { this.tokenizeDecorators(node.decorators, false); this.keyword("scalar", false, true); this.tokenizeIdentifier(node.id, "declaration"); - if (node.extends != undefined) { + if (node.extends) { this.keyword("extends", true, true); this.tokenize(node.extends); } @@ -660,7 +660,7 @@ export class ApiView { for (let x = 0; x < node.operations.length; x++) { const op = node.operations[x]; this.tokenizeOperationStatement(op, true); - this.blankLines((x != node.operations.length -1) ? 1 : 0); + this.blankLines((x !== node.operations.length -1) ? 1 : 0); } this.endGroup(); this.namespaceStack.pop(); @@ -696,7 +696,7 @@ export class ApiView { this.namespaceStack.push(variantName); this.tokenize(variant); this.namespaceStack.pop(); - if (x != node.options.length - 1) { + if (x !== node.options.length - 1) { this.punctuation(","); } this.blankLines(0); @@ -719,7 +719,7 @@ export class ApiView { this.lineMarker(); this.punctuation(node.optional ? "?:" : ":", false, true); this.tokenize(node.value); - if (node.default != undefined) { + if (node.default) { this.punctuation("=", true, true); this.tokenize(node.default); } @@ -741,7 +741,7 @@ export class ApiView { break; } if (isOperationSignature) { - if (x != node.properties.length - 1) { + if (x !== node.properties.length - 1) { this.punctuation(",", false, true); } } else { @@ -777,7 +777,7 @@ export class ApiView { } this.namespaceStack.pop(); if (isOperationSignature) { - if (x != node.properties.length - 1) { + if (x !== node.properties.length - 1) { this.renderPunctuation(","); } } else { @@ -861,7 +861,7 @@ export class ApiView { if (!inline && nodes.length) { while (this.tokens.length) { const item = this.tokens.pop()!; - if (item.Kind == ApiViewTokenKind.LineIdMarker && item.DefinitionId == "GLOBAL") { + if (item.Kind === ApiViewTokenKind.LineIdMarker && item.DefinitionId === "GLOBAL") { this.tokens.push(item); this.blankLines(2); break; @@ -930,7 +930,7 @@ export class ApiView { } break; case SyntaxKind.StringLiteral: - if (style != "member") { + if (style !== "member") { throw new Error(`StringLiteral type can only be a member name. Unexpectedly "${style}"`); } this.stringLiteral(node.value); @@ -960,7 +960,7 @@ export class ApiView { for (let x = 0; x < nodes.length; x++) { const param = nodes[x]; this.tokenize(param); - if (x != nodes.length - 1) { + if (x !== nodes.length - 1) { this.renderPunctuation(","); this.space(); } @@ -990,7 +990,7 @@ export class ApiView { private getNameForNode(node: BaseNode | NamespaceModel): string { const id = generateId(node); - if (id != undefined) { + if (id) { return id.split(".").splice(-1)[0]; } else { throw new Error("Unable to get name for node."); @@ -999,7 +999,7 @@ export class ApiView { private renderPunctuation(punc: string) { const last = this.tokens.pop()!; - if (last?.Kind == ApiViewTokenKind.Whitespace) { + if (last?.Kind === ApiViewTokenKind.Whitespace) { // hacky workaround to ensure comma is after trailing bracket for expanded anonymous models this.tokens.pop(); } else { @@ -1010,7 +1010,7 @@ export class ApiView { resolveMissingTypeReferences() { for (const token of this.tokens) { - if (token.Kind == ApiViewTokenKind.TypeName && token.NavigateToId == "__MISSING__") { + if (token.Kind === ApiViewTokenKind.TypeName && token.NavigateToId === "__MISSING__") { token.NavigateToId = this.definitionIdFor(token.Value!, this.packageName); } } @@ -1024,7 +1024,7 @@ export class ApiView { Navigation: this.navigationItems, Diagnostics: this.diagnostics, VersionString: this.versionString, - Language: "Cadl" + Language: "TypeSpec" }; } @@ -1034,7 +1034,7 @@ export class ApiView { return this.typeDeclarations.has(fullName) ? fullName : undefined; } for (const item of this.typeDeclarations) { - if (item.split(".").splice(-1)[0] == value) { + if (item.split(".").splice(-1)[0] === value) { return item; } } diff --git a/tools/apiview/emitters/cadl-apiview/src/diagnostic.ts b/tools/apiview/emitters/typespec-apiview/src/diagnostic.ts similarity index 100% rename from tools/apiview/emitters/cadl-apiview/src/diagnostic.ts rename to tools/apiview/emitters/typespec-apiview/src/diagnostic.ts diff --git a/tools/apiview/emitters/cadl-apiview/src/emitter.ts b/tools/apiview/emitters/typespec-apiview/src/emitter.ts similarity index 97% rename from tools/apiview/emitters/cadl-apiview/src/emitter.ts rename to tools/apiview/emitters/typespec-apiview/src/emitter.ts index 09e0f7322b9..370c3b0177e 100644 --- a/tools/apiview/emitters/cadl-apiview/src/emitter.ts +++ b/tools/apiview/emitters/typespec-apiview/src/emitter.ts @@ -1,5 +1,3 @@ -// See: https://cadlwebsite.z1.web.core.windows.net/docs/extending-cadl/emitters-basics - import { EmitContext, emitFile, @@ -12,8 +10,8 @@ import { projectProgram, resolvePath, Service, -} from "@cadl-lang/compiler"; -import { buildVersionProjections, getVersion } from "@cadl-lang/versioning"; +} from "@typespec/compiler"; +import { buildVersionProjections, getVersion } from "@typespec/versioning"; import path from "path"; import { ApiView } from "./apiview.js"; import { ApiViewEmitterOptions, reportDiagnostic } from "./lib.js"; diff --git a/tools/apiview/emitters/cadl-apiview/src/index.ts b/tools/apiview/emitters/typespec-apiview/src/index.ts similarity index 100% rename from tools/apiview/emitters/cadl-apiview/src/index.ts rename to tools/apiview/emitters/typespec-apiview/src/index.ts diff --git a/tools/apiview/emitters/cadl-apiview/src/lib.ts b/tools/apiview/emitters/typespec-apiview/src/lib.ts similarity index 96% rename from tools/apiview/emitters/cadl-apiview/src/lib.ts rename to tools/apiview/emitters/typespec-apiview/src/lib.ts index a2e613b90e3..ef8dfd3cd05 100644 --- a/tools/apiview/emitters/cadl-apiview/src/lib.ts +++ b/tools/apiview/emitters/typespec-apiview/src/lib.ts @@ -1,4 +1,4 @@ -import { createCadlLibrary, JSONSchemaType, paramMessage } from "@cadl-lang/compiler"; +import { createCadlLibrary, JSONSchemaType, paramMessage } from "@typespec/compiler"; export interface ApiViewEmitterOptions { "output-file"?: string; @@ -21,7 +21,7 @@ const ApiViewEmitterOptionsSchema: JSONSchemaType = { export const $lib = createCadlLibrary({ - name: "@azure-tools/cadl-apiview", + name: "@azure-tools/typespec-apiview", diagnostics: { "no-services-found": { severity: "error", diff --git a/tools/apiview/emitters/cadl-apiview/src/namespace-model.ts b/tools/apiview/emitters/typespec-apiview/src/namespace-model.ts similarity index 99% rename from tools/apiview/emitters/cadl-apiview/src/namespace-model.ts rename to tools/apiview/emitters/typespec-apiview/src/namespace-model.ts index 06eeaf95436..a7a141704f6 100644 --- a/tools/apiview/emitters/cadl-apiview/src/namespace-model.ts +++ b/tools/apiview/emitters/typespec-apiview/src/namespace-model.ts @@ -26,7 +26,7 @@ import { Node, visitChildren, ScalarStatementNode, -} from "@cadl-lang/compiler"; +} from "@typespec/compiler"; export class NamespaceModel { kind = SyntaxKind.NamespaceStatement; @@ -144,7 +144,7 @@ function inNamespace(node: Node, program: Program, namespace: Namespace): boolea switch (n.kind) { case SyntaxKind.NamespaceStatement: return program.checker.getTypeForNode(n) === namespace; - case SyntaxKind.CadlScript: + case SyntaxKind.TypeSpecScript: if (n.inScopeNamespaces.length > 0 && inNamespace(n.inScopeNamespaces[0], program, namespace)) { return true; } diff --git a/tools/apiview/emitters/cadl-apiview/src/navigation.ts b/tools/apiview/emitters/typespec-apiview/src/navigation.ts similarity index 99% rename from tools/apiview/emitters/cadl-apiview/src/navigation.ts rename to tools/apiview/emitters/typespec-apiview/src/navigation.ts index 511e2308198..4abf8cb063a 100644 --- a/tools/apiview/emitters/cadl-apiview/src/navigation.ts +++ b/tools/apiview/emitters/typespec-apiview/src/navigation.ts @@ -11,7 +11,7 @@ import { SyntaxKind, UnionExpressionNode, UnionStatementNode, -} from "@cadl-lang/compiler"; +} from "@typespec/compiler"; import { ApiView, NamespaceStack } from "./apiview.js"; import { NamespaceModel } from "./namespace-model.js"; diff --git a/tools/apiview/emitters/cadl-apiview/src/testing/index.ts b/tools/apiview/emitters/typespec-apiview/src/testing/index.ts similarity index 51% rename from tools/apiview/emitters/cadl-apiview/src/testing/index.ts rename to tools/apiview/emitters/typespec-apiview/src/testing/index.ts index 07a6d3bac90..0c79177717a 100644 --- a/tools/apiview/emitters/cadl-apiview/src/testing/index.ts +++ b/tools/apiview/emitters/typespec-apiview/src/testing/index.ts @@ -1,20 +1,20 @@ -import { resolvePath } from "@cadl-lang/compiler"; -import { CadlTestLibrary } from "@cadl-lang/compiler/testing"; +import { resolvePath } from "@typespec/compiler"; +import { CadlTestLibrary } from "@typespec/compiler/testing"; import { fileURLToPath } from "url"; export const ApiViewTestLibrary: CadlTestLibrary = { - name: "@azure-tools/cadl-apiview", + name: "@azure-tools/typespec-apiview", packageRoot: resolvePath(fileURLToPath(import.meta.url), "../../../../"), files: [ { realDir: "", pattern: "package.json", - virtualPath: "./node_modules/@azure-tools/cadl-apiview", + virtualPath: "./node_modules/@azure-tools/typespec-apiview", }, { realDir: "dist/src", pattern: "*.js", - virtualPath: "./node_modules/@azure-tools/cadl-apiview/dist/src", + virtualPath: "./node_modules/@azure-tools/typespec-apiview/dist/src", }, ], }; diff --git a/tools/apiview/emitters/cadl-apiview/src/version.ts b/tools/apiview/emitters/typespec-apiview/src/version.ts similarity index 100% rename from tools/apiview/emitters/cadl-apiview/src/version.ts rename to tools/apiview/emitters/typespec-apiview/src/version.ts diff --git a/tools/apiview/emitters/cadl-apiview/test/apiview-options.test.ts b/tools/apiview/emitters/typespec-apiview/test/apiview-options.test.ts similarity index 78% rename from tools/apiview/emitters/cadl-apiview/test/apiview-options.test.ts rename to tools/apiview/emitters/typespec-apiview/test/apiview-options.test.ts index 29ea0a74afb..c8c7bef8da5 100644 --- a/tools/apiview/emitters/cadl-apiview/test/apiview-options.test.ts +++ b/tools/apiview/emitters/typespec-apiview/test/apiview-options.test.ts @@ -1,5 +1,5 @@ -import { Diagnostic, logDiagnostics, resolvePath } from "@cadl-lang/compiler"; -import { expectDiagnosticEmpty, expectDiagnostics } from "@cadl-lang/compiler/testing"; +import { Diagnostic, logDiagnostics, resolvePath } from "@typespec/compiler"; +import { expectDiagnosticEmpty, expectDiagnostics } from "@typespec/compiler/testing"; import { strictEqual } from "assert"; import { apiViewFor, apiViewText, compare, createApiViewTestRunner, diagnosticsFor } from "./test-host.js"; @@ -7,7 +7,7 @@ describe("apiview-options: tests", () => { it("omits namespaces that aren't proper subnamespaces", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Foo {}; } @@ -38,7 +38,7 @@ describe("apiview-options: tests", () => { const input = ` model SomeGlobal {}; - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Foo {}; } @@ -48,7 +48,7 @@ describe("apiview-options: tests", () => { model SomeGlobal {} } - @Cadl.service( + @TypeSpec.service( { title: "Test"; version: "1"; @@ -67,12 +67,12 @@ describe("apiview-options: tests", () => { it("emits error if multi-service package tries to specify version", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Foo {}; } - @Cadl.service( { title: "OtherTest", version: "1" } ) + @TypeSpec.service( { title: "OtherTest", version: "1" } ) namespace Azure.OtherTest { model Foo {}; } @@ -80,11 +80,11 @@ describe("apiview-options: tests", () => { const diagnostics = await diagnosticsFor(input, {"version": "1"}); expectDiagnostics(diagnostics, [ { - code: "@azure-tools/cadl-apiview/invalid-option", + code: "@azure-tools/typespec-apiview/invalid-option", message: `Option "--output-file" cannot be used with multi-service specs unless "--service" is also supplied.` }, { - code: "@azure-tools/cadl-apiview/invalid-option", + code: "@azure-tools/typespec-apiview/invalid-option", message: `Option "--version" cannot be used with multi-service specs unless "--service" is also supplied.` } ]); @@ -92,12 +92,12 @@ describe("apiview-options: tests", () => { it("allows options if multi-service package specifies --service", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Foo {}; } - @Cadl.service( { title: "OtherTest", version: "1" } ) + @TypeSpec.service( { title: "OtherTest", version: "1" } ) namespace Azure.OtherTest { model Foo {}; } diff --git a/tools/apiview/emitters/cadl-apiview/test/apiview.test.ts b/tools/apiview/emitters/typespec-apiview/test/apiview.test.ts similarity index 94% rename from tools/apiview/emitters/cadl-apiview/test/apiview.test.ts rename to tools/apiview/emitters/typespec-apiview/test/apiview.test.ts index 97f9689bb48..770af72c10b 100644 --- a/tools/apiview/emitters/cadl-apiview/test/apiview.test.ts +++ b/tools/apiview/emitters/typespec-apiview/test/apiview.test.ts @@ -35,7 +35,7 @@ describe("apiview: tests", () => { it("describes model", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Animal { species: string; @@ -89,7 +89,7 @@ describe("apiview: tests", () => { it("describes scalar", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { scalar Password extends string; @@ -116,7 +116,7 @@ describe("apiview: tests", () => { it("describes alias", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Animal { species: string; @@ -142,7 +142,7 @@ describe("apiview: tests", () => { it("describes augment decorator", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Animal { species: string; @@ -169,7 +169,7 @@ describe("apiview: tests", () => { it("describes templated model", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model Thing { property: T; @@ -241,7 +241,7 @@ describe("apiview: tests", () => { it("describes enum", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { enum SomeEnum { @@ -284,7 +284,7 @@ describe("apiview: tests", () => { it("describes union", async () =>{ const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { union MyUnion { cat: Cat, @@ -335,7 +335,7 @@ describe("apiview: tests", () => { it("describes template operation", async () =>{ const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { model FooParams { a: string; @@ -397,7 +397,7 @@ describe("apiview: tests", () => { it("describes operation with anonymous models", async () =>{ const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { op SomeOp( param1: { @@ -429,7 +429,7 @@ describe("apiview: tests", () => { it("describes interface", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { interface Foo { @get @@ -466,7 +466,7 @@ describe("apiview: tests", () => { it("describes string literals", async () => { const input = ` - @Cadl.service( { title: "Test", version: "1" } ) + @TypeSpec.service( { title: "Test", version: "1" } ) namespace Azure.Test { @doc("Short string") model Foo {}; diff --git a/tools/apiview/emitters/cadl-apiview/test/test-host.ts b/tools/apiview/emitters/typespec-apiview/test/test-host.ts similarity index 81% rename from tools/apiview/emitters/cadl-apiview/test/test-host.ts rename to tools/apiview/emitters/typespec-apiview/test/test-host.ts index 6f030ba197b..d19f7536231 100644 --- a/tools/apiview/emitters/cadl-apiview/test/test-host.ts +++ b/tools/apiview/emitters/typespec-apiview/test/test-host.ts @@ -1,12 +1,12 @@ -import { createTestHost, createTestWrapper } from "@cadl-lang/compiler/testing"; -import { RestTestLibrary } from "@cadl-lang/rest/testing"; -import { VersioningTestLibrary } from "@cadl-lang/versioning/testing"; -import { AzureCoreTestLibrary } from "@azure-tools/cadl-azure-core/testing"; +import { createTestHost, createTestWrapper } from "@typespec/compiler/testing"; +import { RestTestLibrary } from "@typespec/rest/testing"; +import { VersioningTestLibrary } from "@typespec/versioning/testing"; +import { AzureCoreTestLibrary } from "@azure-tools/typespec-azure-core/testing"; import { ApiViewTestLibrary } from "../src/testing/index.js"; -import "@azure-tools/cadl-apiview"; +import "@azure-tools/typespec-apiview"; import { ApiViewEmitterOptions } from "../src/lib.js"; import { ApiViewDocument, ApiViewTokenKind } from "../src/apiview.js"; -import { Diagnostic, resolvePath } from "@cadl-lang/compiler"; +import { Diagnostic, resolvePath } from "@typespec/compiler"; import { strictEqual } from "assert"; export async function createApiViewTestHost() { @@ -20,16 +20,16 @@ export async function createApiViewTestRunner({ }: { withVersioning?: boolean } = {}) { const host = await createApiViewTestHost(); const autoUsings = [ - "Cadl.Rest", - "Cadl.Http", + "TypeSpec.Rest", + "TypeSpec.Http", ] if (withVersioning) { - autoUsings.push("Cadl.Versioning"); + autoUsings.push("TypeSpec.Versioning"); } return createTestWrapper(host, { autoUsings: autoUsings, compilerOptions: { - emit: ["@azure-tools/cadl-apiview"], + emit: ["@azure-tools/typespec-apiview"], } }); } @@ -39,7 +39,7 @@ export async function diagnosticsFor(code: string, options: ApiViewEmitterOption const outPath = resolvePath("/apiview.json"); const diagnostics = await runner.diagnose(code, { noEmit: false, - emitters: { "@azure-tools/cadl-apiview": { ...options, "output-file": outPath } }, + emitters: { "@azure-tools/typespec-apiview": { ...options, "output-file": outPath } }, miscOptions: { "disable-linter": true }, }); return diagnostics; @@ -50,7 +50,7 @@ export async function apiViewFor(code: string, options: ApiViewEmitterOptions): const outPath = resolvePath("/apiview.json"); await runner.compile(code, { noEmit: false, - emitters: { "@azure-tools/cadl-apiview": { ...options, "output-file": outPath } }, + emitters: { "@azure-tools/typespec-apiview": { ...options, "output-file": outPath } }, miscOptions: { "disable-linter": true }, }); diff --git a/tools/apiview/emitters/cadl-apiview/tsconfig.json b/tools/apiview/emitters/typespec-apiview/tsconfig.json similarity index 100% rename from tools/apiview/emitters/cadl-apiview/tsconfig.json rename to tools/apiview/emitters/typespec-apiview/tsconfig.json