diff --git a/.github/workflows/nightly.sh b/.github/workflows/nightly.sh
deleted file mode 100755
index 15ae36a..0000000
--- a/.github/workflows/nightly.sh
+++ /dev/null
@@ -1,23 +0,0 @@
-#!/bin/bash
-
-# Switch to nightly
-
-# Calculate version
-VERSION=`git log -1 --format=%cd --date="format:%Y.%-m.%-d%H"`
-COMMIT=`git log -1 --format=%H`
-
-# Change parameters in package.json
-(cat package.json | jq --indent 4 --arg VERSION "${VERSION}" '
-.version=$VERSION |
-.preview=true |
-.name="vscode-tlaplus-nightly" |
-.displayName="TLA+ Nightly" |
-.description="TLA+ language support (Nightly)" |
-.icon="resources/images/tlaplus-nightly.png"
-') > /tmp/package.json.nightly && mv /tmp/package.json.nightly package.json
-
-# Add version info to CHANGELOG.md
-printf "## ${VERSION}\n\nCommit ${COMMIT}\n\n" | cat - CHANGELOG.md > /tmp/CHANGELOG.md.nightly && mv /tmp/CHANGELOG.md.nightly CHANGELOG.md
-
-# Add header to README.md
-tail -n +2 README.md | cat README-nightly.md - > /tmp/README.md.nightly && mv /tmp/README.md.nightly README.md
diff --git a/.github/workflows/pre-release.yml b/.github/workflows/pre-release.yml
deleted file mode 100644
index ac2b18c..0000000
--- a/.github/workflows/pre-release.yml
+++ /dev/null
@@ -1,53 +0,0 @@
-name: Pre-Release
-
-on:
- workflow_dispatch:
- inputs:
- suffix:
- description: 'Version suffix'
- required: true
- default: 'alpha.X'
-
-jobs:
- build:
- runs-on: macOS-latest
- steps:
- - uses: actions/checkout@v1
- - uses: actions/setup-node@v1
- with:
- node-version: '18.19'
- - name: Get current version
- id: version
- run: echo "::set-output name=version::$(jq -r .version package.json)"
- - name: Install dependencies
- run: |
- npm install
- npm install -g vsce
- - name: Build
- run: |
- npm run vscode:prepublish
- vsce package
- - name: Check
- run: |
- npm run lint
- npm test --silent
- - name: Create Pre-Release
- id: create_pre_release
- uses: actions/create-release@v1
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- with:
- tag_name: v${{ steps.version.outputs.version }}-${{ github.event.inputs.suffix }}
- release_name: v${{ steps.version.outputs.version }}-${{ github.event.inputs.suffix }}
- draft: false
- prerelease: true
- - name: Upload Release Asset
- id: upload-release-asset
- uses: actions/upload-release-asset@v1.0.1
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- with:
- upload_url: ${{ steps.create_pre_release.outputs.upload_url }}
- asset_path: vscode-tlaplus-${{ steps.version.outputs.version }}.vsix
- asset_name: vscode-tlaplus-${{ steps.version.outputs.version }}.vsix
- asset_content_type: application/zip
diff --git a/.github/workflows/release-nightly.yml b/.github/workflows/release-nightly.yml
deleted file mode 100644
index b9dd048..0000000
--- a/.github/workflows/release-nightly.yml
+++ /dev/null
@@ -1,65 +0,0 @@
-name: Release Nightly
-
-on:
- schedule:
- - cron: "0 6 * * *"
- repository_dispatch:
- workflow_dispatch:
-
-jobs:
- checksecret:
- name: check if VSCODE_MARKETPLACE_TOKEN is set in github secrets
- runs-on: ubuntu-latest
- outputs:
- is_MY_SECRET_set: ${{ steps.checksecret_job.outputs.is_MY_SECRET_set }}
- steps:
- - name: Check secret present
- id: checksecret_job
- env:
- MY_SECRET: ${{ secrets.VSCODE_MARKETPLACE_TOKEN }}
- run: |
- echo "is_MY_SECRET_set: ${{ env.MY_SECRET != '' }}"
- echo "::set-output name=is_MY_SECRET_set::${{ env.MY_SECRET != '' }}"
-
- build:
- ## Do not run this action without the marketplace token present,
- ## e.g., in a fork of this repo.
- needs: [checksecret]
- if: needs.checksecret.outputs.is_MY_SECRET_set == 'true'
- runs-on: macOS-latest
- steps:
- - uses: actions/checkout@v1
- - uses: actions/setup-node@v1
- with:
- node-version: '18.19'
- - name: Get (nightly) TLC
- run: wget https://nightly.tlapl.us/dist/tla2tools.jar -O tools/tla2tools.jar
- - name: Get (nightly) CommunityModules
- run: wget https://github.com/tlaplus/CommunityModules/releases/latest/download/CommunityModules-deps.jar -O tools/CommunityModules-deps.jar
- - name: Prepare nightly
- run: |
- git add tools/*.jar -f
- git commit -m "Snapshot latest CommunityModules and TLA+ tools"
- .github/workflows/nightly.sh
- git diff package.json
- - name: Get current version
- id: version
- run: echo "::set-output name=version::$(jq -r .version package.json)"
- - name: Install dependencies
- run: |
- npm install
- npm install -g vsce
- - name: Build
- run: |
- npm run vscode:prepublish
- vsce package
- - name: Check
- run: |
- npm run lint
- npm test --silent
- - name: Publish to Marketplace
- run: vsce publish --pat "${{ secrets.VSCODE_MARKETPLACE_TOKEN }}"
- ## Continue publishing to the ovsx marketplace even if publication to the VSCode marketplace fails.
- continue-on-error: true
- - name: Publish to Open VSX
- run: npx ovsx publish "vscode-tlaplus-nightly-${{ steps.version.outputs.version }}.vsix" -p "${{ secrets.OPEN_VSX_TOKEN }}"
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
index 6ad95c2..bddb529 100644
--- a/.github/workflows/release.yml
+++ b/.github/workflows/release.yml
@@ -1,18 +1,47 @@
name: Release
-on: workflow_dispatch
+on:
+ repository_dispatch:
+ workflow_dispatch:
jobs:
+ checksecret:
+ name: check if VSCODE_MARKETPLACE_TLAPLUS_TOKEN is set in github secrets
+ runs-on: ubuntu-latest
+ outputs:
+ is_MY_SECRET_set: ${{ steps.checksecret_job.outputs.is_MY_SECRET_set }}
+ steps:
+ - name: Check secret present
+ id: checksecret_job
+ env:
+ MY_SECRET: ${{ secrets.VSCODE_MARKETPLACE_TLAPLUS_TOKEN }}
+ run: |
+ echo "is_MY_SECRET_set: ${{ env.MY_SECRET != '' }}"
+ echo "::set-output name=is_MY_SECRET_set::${{ env.MY_SECRET != '' }}"
+
build:
+ ## Do not run this action without the marketplace token present,
+ ## e.g., in a fork of this repo.
+ needs: [checksecret]
+ if: needs.checksecret.outputs.is_MY_SECRET_set == 'true'
runs-on: macOS-latest
steps:
- uses: actions/checkout@v1
- uses: actions/setup-node@v1
with:
node-version: '18.19'
+ - name: Get (latest) TLC
+ run: wget https://nightly.tlapl.us/dist/tla2tools.jar -O tools/tla2tools.jar
+ - name: Get (latest) CommunityModules
+ run: wget https://github.com/tlaplus/CommunityModules/releases/latest/download/CommunityModules-deps.jar -O tools/CommunityModules-deps.jar
+ - name: Prepare Release
+ run: |
+ ## Create a git commit to use its date as the extension's version number below.
+ git add tools/*.jar -f
+ git commit -m "Latest CommunityModules and TLA+ tools"
- name: Get current version
id: version
- run: echo "::set-output name=version::$(jq -r .version package.json)"
+ run: echo "::set-output name=version::$(git log -1 --format=%cd --date="format:%Y.%-m.%-d%H%M")"
- name: Install dependencies
run: |
npm install
@@ -26,26 +55,5 @@ jobs:
npm run lint
npm test --silent
- name: Publish to Marketplace
- run: vsce publish --pat "${{ secrets.VSCODE_MARKETPLACE_TOKEN }}"
- - name: Publish to Open VSX
- run: npx ovsx publish "vscode-tlaplus-${{ steps.version.outputs.version }}.vsix" -p "${{ secrets.OPEN_VSX_TOKEN }}"
- - name: Create Release
- id: create_release
- uses: actions/create-release@v1
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- with:
- tag_name: v${{ steps.version.outputs.version }}
- release_name: v${{ steps.version.outputs.version }}
- draft: false
- prerelease: false
- - name: Upload Release Asset
- id: upload-release-asset
- uses: actions/upload-release-asset@v1.0.1
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- with:
- upload_url: ${{ steps.create_release.outputs.upload_url }}
- asset_path: vscode-tlaplus-${{ steps.version.outputs.version }}.vsix
- asset_name: vscode-tlaplus-${{ steps.version.outputs.version }}.vsix
- asset_content_type: application/zip
+ run: |
+ vsce publish $(git log -1 --format=%cd --date="format:%Y.%-m.%-d%H%M") --pat "${{ secrets.VSCODE_MARKETPLACE_TLAPLUS_TOKEN }}"
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 3f2f9b4..4003436 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -15,7 +15,7 @@ For those, who want to write some code, here's a short guide.
Clone the repository:
```
-git clone https://github.com/alygin/vscode-tlaplus.git
+git clone https://github.com/tlaplus/vscode-tlaplus.git
cd vscode-tlaplus
```
@@ -158,7 +158,7 @@ The extension consists of the following components:
3. The implementation of the Check Result View panel that visualizes TLC output and allows to analyze it easily.
4. The `tla2tools.jar` file from the [official TLA+ project](https://github.com/tlaplus/tlaplus). All the specification syntax verifications, PlusCal translations and TLC checks are actually performed by this Java library.
-The extension also requires a Java Virtual Machine (JVM) to be installed. [More information](https://github.com/alygin/vscode-tlaplus/wiki/Installing-Java).
+The extension also requires a Java Virtual Machine (JVM) to be installed. [More information](https://github.com/tlaplus/vscode-tlaplus/wiki/Installing-Java).
# Project Layout
diff --git a/LICENSE b/LICENSE
index bd35d49..3d4f397 100644
--- a/LICENSE
+++ b/LICENSE
@@ -1,6 +1,8 @@
MIT License
Copyright (c) 2019 Andrew Lygin
+Copyright (c) 2020 TLA+ Foundation
+
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
diff --git a/README-nightly.md b/README-nightly.md
deleted file mode 100644
index 7d98b94..0000000
--- a/README-nightly.md
+++ /dev/null
@@ -1,10 +0,0 @@
-# TLA+ Nightly for Visual Studio Code
-
-> **ATTENTION:** This is the preview version of the [TLA+ for Visual Studio Code](https://marketplace.visualstudio.com/items?itemName=alygin.vscode-tlaplus) extension, used for early feedback and testing.
->
-> **ATTENTION:** Both the stable and nightly versions cannot be used at the same time. You must [disable](https://code.visualstudio.com/docs/editor/extension-marketplace#_disable-an-extension) or [uninstall](https://code.visualstudio.com/docs/editor/extension-marketplace#_uninstall-an-extension) one of them.
-
-> TLA+ Nightly:
-> * Is released more frequently.
-> * Includes features and bug fixes that may not have been tested yed.
-> * May include nightly builds of the TLA+ tools.
diff --git a/README.md b/README.md
index d1a2f85..fa217c7 100644
--- a/README.md
+++ b/README.md
@@ -1,6 +1,6 @@
# TLA+ for Visual Studio Code
-[![Build Status](https://img.shields.io/github/actions/workflow/status/tlaplus/vscode-tlaplus/ci.yml?branch=master)](https://github.com/tlaplus/vscode-tlaplus/actions?query=workflow%3ACI) [![VS Code extension version](https://img.shields.io/visual-studio-marketplace/i/alygin.vscode-tlaplus?color=blue&label=Stable%20Release&style=flat-square)](https://marketplace.visualstudio.com/items?itemName=alygin.vscode-tlaplus) [![VS Code extension version nightly](https://img.shields.io/visual-studio-marketplace/i/alygin.vscode-tlaplus-nightly?color=blue&label=Nightly%20Build&style=flat-square)](https://marketplace.visualstudio.com/items?itemName=alygin.vscode-tlaplus-nightly)
+[![Build Status](https://img.shields.io/github/actions/workflow/status/tlaplus/vscode-tlaplus/ci.yml?branch=master)](https://github.com/tlaplus/vscode-tlaplus/actions?query=workflow%3ACI) [![VS Code extension version](https://img.shields.io/visual-studio-marketplace/i/tlaplus-lang?color=blue&label=Stable%20Release&style=flat-square)](https://marketplace.visualstudio.com/items?itemName=tlaplus-lang.tlaplus-lang)
This extension adds support for the [TLA+ formal specification language](http://research.microsoft.com/en-us/um/people/lamport/tla/tla.html) to VS Code. It also supports running the TLC model checker on TLA+ specifications.
@@ -40,10 +40,10 @@ If you decide to pitch in and write some code, this document will provide you wi
If you're not familiar with TLA+, but want to get a grasp on it, the following list of resources is a good starting point:
-* [TLA+ Home Page](http://research.microsoft.com/en-us/um/people/lamport/tla/tla.html) on Leslie Lamport's website.
+* [TLA+ Home Page](http://www.tlapl.us) on Leslie Lamport's website.
+* [A collection of TLA+ specification examples](https://github.com/tlaplus/Examples) in the TLA+ repository.
* [Introduction to TLA+ and PlusCal](https://learntla.com) by Hillel Wayne.
* [TLA+ in Practice and Theory](https://pron.github.io/posts/tlaplus_part1) by Ron Pressler.
-* [A collection of TLA+ specification examples](https://github.com/tlaplus/Examples) in the TLA+ repository.
## License
diff --git a/package-lock.json b/package-lock.json
index 00256f0..41ef317 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,12 +1,12 @@
{
- "name": "vscode-tlaplus",
- "version": "1.6.0",
+ "name": "tlaplus-lang",
+ "version": "1.7.0",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
- "name": "vscode-tlaplus",
- "version": "1.6.0",
+ "name": "tlaplus-lang",
+ "version": "1.7.0",
"license": "MIT",
"dependencies": {
"@cocalc/ansi-to-react": "^7.0.0",
diff --git a/package.json b/package.json
index 012b77a..39565f1 100644
--- a/package.json
+++ b/package.json
@@ -1,12 +1,12 @@
{
- "name": "vscode-tlaplus",
- "displayName": "TLA+",
- "version": "1.6.0",
+ "name": "tlaplus-lang",
+ "displayName": "TLA+ (Temporal Logic of Actions)",
+ "version": "1.7.0",
"description": "TLA+ language support",
- "publisher": "alygin",
+ "publisher": "tlaplus-lang",
"license": "MIT",
"author": {
- "name": "Andrew Lygin"
+ "name": "TLA+ Community"
},
"engines": {
"vscode": "^1.82.0"
@@ -20,10 +20,10 @@
],
"repository": {
"type": "git",
- "url": "https://github.com/alygin/vscode-tlaplus.git"
+ "url": "https://github.com/tlaplus/vscode-tlaplus.git"
},
"bugs": {
- "url": "https://github.com/alygin/vscode-tlaplus/issues"
+ "url": "https://github.com/tlaplus/vscode-tlaplus/issues"
},
"icon": "resources/images/tlaplus.png",
"keywords": [
@@ -334,7 +334,7 @@
"type": "string",
"scope": "window",
"default": "",
- "markdownDescription": "Java options to use when running TLA+ tools. [How it works.](https://github.com/alygin/vscode-tlaplus/wiki/Java-Options)",
+ "markdownDescription": "Java options to use when running TLA+ tools. [How it works.](https://github.com/tlaplus/vscode-tlaplus/wiki/Java-Options)",
"maxLength": 1000
},
"tlaplus.pluscal.options": {
diff --git a/src/commands/checkModel.ts b/src/commands/checkModel.ts
index fc8fc90..d6fcc2c 100644
--- a/src/commands/checkModel.ts
+++ b/src/commands/checkModel.ts
@@ -85,7 +85,7 @@ export async function checkModelCustom(
return;
}
// Accept .tla files here because TLC configs and TLA+ modules can share the same file:
- // https://github.com/alygin/vscode-tlaplus/issues/220
+ // https://github.com/tlaplus/vscode-tlaplus/issues/220
const configFiles = await listFiles(path.dirname(doc.uri.fsPath),
(fName) => fName.endsWith('.cfg') || fName.endsWith('.tla'));
configFiles.sort();
diff --git a/src/debugger/debugging.ts b/src/debugger/debugging.ts
index 9b66aee..e194936 100644
--- a/src/debugger/debugging.ts
+++ b/src/debugger/debugging.ts
@@ -94,7 +94,7 @@ export async function checkAndDebugSpecCustom(
return;
}
// Accept .tla files here because TLC configs and TLA+ modules can share the same file:
- // https://github.com/alygin/vscode-tlaplus/issues/220
+ // https://github.com/tlaplus/vscode-tlaplus/issues/220
const configFiles = await listFiles(path.dirname(targetResource.fsPath),
(fName) => fName.endsWith('.cfg') || fName.endsWith('.tla'));
configFiles.sort();
diff --git a/src/main.ts b/src/main.ts
index 1dc3e4c..edd745c 100644
--- a/src/main.ts
+++ b/src/main.ts
@@ -33,7 +33,7 @@ import { ModuleSearchPathsTreeDataProvider } from './panels/moduleSearchPathsTre
const TLAPLUS_FILE_SELECTOR: vscode.DocumentSelector = { scheme: 'file', language: LANG_TLAPLUS };
const TLAPLUS_CFG_FILE_SELECTOR: vscode.DocumentSelector = { scheme: 'file', language: LANG_TLAPLUS_CFG };
-const CHANGELOG_URL = vscode.Uri.parse('https://github.com/alygin/vscode-tlaplus/blob/master/CHANGELOG.md#change-log');
+const CHANGELOG_URL = vscode.Uri.parse('https://github.com/tlaplus/vscode-tlaplus/blob/master/CHANGELOG.md#change-log');
const tlaDocInfos = new TlaDocumentInfos();
@@ -150,7 +150,7 @@ export function activate(context: vscode.ExtensionContext): void {
// 393ee2b2443e270bacd9f11fa219c39a88fc987d/src/extension.ts#L63-L84
// Also see wordPattern in tlaplus-lang-config.json that drops "@"
// and "'" compared to VSCode's standard wordPattern.
- // https://github.com/alygin/vscode-tlaplus/issues/200
+ // https://github.com/tlaplus/vscode-tlaplus/issues/200
provideEvaluatableExpression(document: vscode.TextDocument, position: vscode.Position):
vscode.ProviderResult {
const wordRange = document.getWordRangeAtPosition(position);
diff --git a/src/tla2tools.ts b/src/tla2tools.ts
index 28005f8..5d2250b 100644
--- a/src/tla2tools.ts
+++ b/src/tla2tools.ts
@@ -10,7 +10,7 @@ import { ToolOutputChannel } from './outputChannels';
import { JavaVersionParser } from './parsers/javaVersion';
// CFG_EXTENSION can be used to fetch all the settings for this extension
-const CFG_EXTENSION = '@ext:alygin.vscode-tlaplus';
+const CFG_EXTENSION = '@ext:tlaplus-lang.tlaplus-lang';
const CFG_JAVA_HOME = 'tlaplus.java.home';
const CFG_JAVA_OPTIONS = 'tlaplus.java.options';
diff --git a/tests/suite/parsers/tlc.test.ts b/tests/suite/parsers/tlc.test.ts
index 64332c9..1373d8f 100644
--- a/tests/suite/parsers/tlc.test.ts
+++ b/tests/suite/parsers/tlc.test.ts
@@ -405,7 +405,7 @@ suite('TLC Output Parser Test Suite', () => {
});
test('Handles no-line-break message switch', () => {
- // https://github.com/alygin/vscode-tlaplus/issues/47
+ // https://github.com/tlaplus/vscode-tlaplus/issues/47
return assertOutput('no-line-break-switch.out', TEST_SPEC_FILES,
new CheckResultBuilder('no-line-break-switch.out', CheckState.Success, CheckStatus.Finished)
.addDColFilePath('/Users/bob/example.tla')