mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-16 10:58:30 -05:00
Merge from vscode e3c4990c67c40213af168300d1cfeb71d680f877 (#16569)
This commit is contained in:
@@ -1,14 +1,14 @@
|
|||||||
# Code - OSS Development Container
|
# Code - OSS Development Container
|
||||||
|
|
||||||
This repository includes configuration for a development container for working with Code - OSS in an isolated local container or using [GitHub Codespaces](https://github.com/features/codespaces).
|
This repository includes configuration for a development container for working with Code - OSS in a local container or using [GitHub Codespaces](https://github.com/features/codespaces).
|
||||||
|
|
||||||
> **Tip:** The default VNC password is `vscode`. The VNC server runs on port `5901` with a web client at `6080`. For better performance, we recommend using a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/). Applications like the macOS Screen Sharing app will not perform as well.
|
> **Tip:** The default VNC password is `vscode`. The VNC server runs on port `5901` and a web client is available on port `6080`.
|
||||||
|
|
||||||
## Quick start - local
|
## Quick start - local
|
||||||
|
|
||||||
1. Install Docker Desktop or Docker for Linux on your local machine. (See [docs](https://aka.ms/vscode-remote/containers/getting-started) for additional details.)
|
1. Install Docker Desktop or Docker for Linux on your local machine. (See [docs](https://aka.ms/vscode-remote/containers/getting-started) for additional details.)
|
||||||
|
|
||||||
2. **Important**: Docker needs at least **4 Cores and 6 GB of RAM (8 GB recommended)** to run full build. If you on macOS, or using the old Hyper-V engine for Windows, update these values for Docker Desktop by right-clicking on the Docker status bar item, going to **Preferences/Settings > Resources > Advanced**.
|
2. **Important**: Docker needs at least **4 Cores and 6 GB of RAM (8 GB recommended)** to run a full build. If you are on macOS, or are using the old Hyper-V engine for Windows, update these values for Docker Desktop by right-clicking on the Docker status bar item and going to **Preferences/Settings > Resources > Advanced**.
|
||||||
|
|
||||||
> **Note:** The [Resource Monitor](https://marketplace.visualstudio.com/items?itemName=mutantdino.resourcemonitor) extension is included in the container so you can keep an eye on CPU/Memory in the status bar.
|
> **Note:** The [Resource Monitor](https://marketplace.visualstudio.com/items?itemName=mutantdino.resourcemonitor) extension is included in the container so you can keep an eye on CPU/Memory in the status bar.
|
||||||
|
|
||||||
@@ -16,53 +16,56 @@ This repository includes configuration for a development container for working w
|
|||||||
|
|
||||||

|

|
||||||
|
|
||||||
> Note that the Remote - Containers extension requires the Visual Studio Code distribution of Code - OSS. See the [FAQ](https://aka.ms/vscode-remote/faq/license) for details.
|
> **Note:** The Remote - Containers extension requires the Visual Studio Code distribution of Code - OSS. See the [FAQ](https://aka.ms/vscode-remote/faq/license) for details.
|
||||||
|
|
||||||
4. Press <kbd>Ctrl/Cmd</kbd> + <kbd>Shift</kbd> + <kbd>P</kbd> and select **Remote - Containers: Open Repository in Container...**.
|
4. Press <kbd>Ctrl/Cmd</kbd> + <kbd>Shift</kbd> + <kbd>P</kbd> or <kbd>F1</kbd> and select **Remote-Containers: Clone Repository in Container Volume...**.
|
||||||
|
|
||||||
> **Tip:** While you can use your local source tree instead, operations like `yarn install` can be slow on macOS or using the Hyper-V engine on Windows. We recommend the "open repository" approach instead since it uses "named volume" rather than the local filesystem.
|
> **Tip:** While you can use your local source tree instead, operations like `yarn install` can be slow on macOS or when using the Hyper-V engine on Windows. We recommend the "clone repository in container" approach instead since it uses "named volume" rather than the local filesystem.
|
||||||
|
|
||||||
5. Type `https://github.com/microsoft/vscode` (or a branch or PR URL) in the input box and press <kbd>Enter</kbd>.
|
5. Type `https://github.com/microsoft/vscode` (or a branch or PR URL) in the input box and press <kbd>Enter</kbd>.
|
||||||
|
|
||||||
6. After the container is running, open a web browser and go to [http://localhost:6080](http://localhost:6080) or use a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/) to connect to `localhost:5901` and enter `vscode` as the password.
|
6. After the container is running, open a web browser and go to [http://localhost:6080](http://localhost:6080), or use a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/) to connect to `localhost:5901` and enter `vscode` as the password.
|
||||||
|
|
||||||
Anything you start in VS Code or the integrated terminal will appear here.
|
Anything you start in VS Code, or the integrated terminal, will appear here.
|
||||||
|
|
||||||
Next: **[Try it out!](#try-it)**
|
Next: **[Try it out!](#try-it)**
|
||||||
|
|
||||||
## Quick start - GitHub Codespaces
|
## Quick start - GitHub Codespaces
|
||||||
|
|
||||||
> **IMPORTANT:** You need to use a "Standard" sized codespace or larger (4-core, 8GB) since VS Code needs 6GB of RAM to compile. This is now the default for GitHub Codespaces, but do not downgrade to "Basic" unless you do not intend to compile.
|
1. From the [microsoft/vscode GitHub repository](https://github.com/microsoft/vscode), click on the **Code** dropdown, select **Open with Codespaces**, and then click on **New codespace**. If prompted, select the **Standard** machine size (which is also the default).
|
||||||
|
|
||||||
1. From the [microsoft/vscode GitHub repository](https://github.com/microsoft/vscode), click on the **Code** dropdown, select **Open with Codespaces**, and the **New codespace**
|
> **Note:** You will not see these options within GitHub if you are not in the Codespaces beta.
|
||||||
|
|
||||||
> Note that you will not see these options if you are not in the beta yet.
|
2. After the codespace is up and running in your browser, press <kbd>Ctrl/Cmd</kbd> + <kbd>Shift</kbd> + <kbd>P</kbd> or <kbd>F1</kbd> and select **Ports: Focus on Ports View**.
|
||||||
|
|
||||||
2. After the codespace is up and running in your browser, press <kbd>F1</kbd> and select **Ports: Focus on Ports View**.
|
3. You should see **VNC web client (6080)** under in the list of ports. Select the line and click on the globe icon to open it in a browser tab.
|
||||||
|
|
||||||
3. You should see port `6080` under **Forwarded Ports**. Select the line and click on the globe icon to open it in a browser tab.
|
> **Tip:** If you do not see the port, <kbd>Ctrl/Cmd</kbd> + <kbd>Shift</kbd> + <kbd>P</kbd> or <kbd>F1</kbd>, select **Forward a Port** and enter port `6080`.
|
||||||
|
|
||||||
> If you do not see port `6080`, press <kbd>F1</kbd>, select **Forward a Port** and enter port `6080`.
|
|
||||||
|
|
||||||
4. In the new tab, you should see noVNC. Click **Connect** and enter `vscode` as the password.
|
4. In the new tab, you should see noVNC. Click **Connect** and enter `vscode` as the password.
|
||||||
|
|
||||||
Anything you start in VS Code or the integrated terminal will appear here.
|
Anything you start in VS Code, or the integrated terminal, will appear here.
|
||||||
|
|
||||||
Next: **[Try it out!](#try-it)**
|
Next: **[Try it out!](#try-it)**
|
||||||
|
|
||||||
### Using VS Code with GitHub Codespaces
|
### Using VS Code with GitHub Codespaces
|
||||||
|
|
||||||
You will likely see better performance when accessing the codespace you created from VS Code since you can use a[VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/). Here's how to do it.
|
You may see improved VNC responsiveness when accessing a codespace from VS Code client since you can use a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/). Here's how to do it.
|
||||||
|
|
||||||
1. [Create a codespace](#quick-start---github-codespaces) if you have not already.
|
1. Install [Visual Studio Code Stable](https://code.visualstudio.com/) or [Insiders](https://code.visualstudio.com/insiders/) and the the [GitHub Codespaces extension](https://marketplace.visualstudio.com/items?itemName=GitHub.codespaces).
|
||||||
|
|
||||||
2. Set up [VS Code for use with GitHub Codespaces](https://docs.github.com/github/developing-online-with-codespaces/using-codespaces-in-visual-studio-code)
|
> **Note:** The GitHub Codespaces extension requires the Visual Studio Code distribution of Code - OSS.
|
||||||
|
|
||||||
3. After the VS Code is up and running, press <kbd>F1</kbd>, choose **Codespaces: Connect to Codespace**, and select the codespace you created.
|
2. After the VS Code is up and running, press <kbd>Ctrl/Cmd</kbd> + <kbd>Shift</kbd> + <kbd>P</kbd> or <kbd>F1</kbd>, choose **Codespaces: Create New Codespace**, and use the following settings:
|
||||||
|
- `microsoft/vscode` for the repository.
|
||||||
|
- Select any branch (e.g. **main**) - you select a different one later.
|
||||||
|
- Choose **Standard** (4-core, 8GB) as the size.
|
||||||
|
|
||||||
4. After you've connected to the codespace, use a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/) to connect to `localhost:5901` and enter `vscode` as the password.
|
4. After you have connected to the codespace, you can use a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/) to connect to `localhost:5901` and enter `vscode` as the password.
|
||||||
|
|
||||||
5. Anything you start in VS Code or the integrated terminal will appear here.
|
> **Tip:** You may also need change your VNC client's **Picture Quaility** setting to **High** to get a full color desktop.
|
||||||
|
|
||||||
|
5. Anything you start in VS Code, or the integrated terminal, will appear here.
|
||||||
|
|
||||||
Next: **[Try it out!](#try-it)**
|
Next: **[Try it out!](#try-it)**
|
||||||
|
|
||||||
@@ -70,20 +73,18 @@ Next: **[Try it out!](#try-it)**
|
|||||||
|
|
||||||
This container uses the [Fluxbox](http://fluxbox.org/) window manager to keep things lean. **Right-click on the desktop** to see menu options. It works with GNOME and GTK applications, so other tools can be installed if needed.
|
This container uses the [Fluxbox](http://fluxbox.org/) window manager to keep things lean. **Right-click on the desktop** to see menu options. It works with GNOME and GTK applications, so other tools can be installed if needed.
|
||||||
|
|
||||||
Note you can also set the resolution from the command line by typing `set-resolution`.
|
> **Note:** You can also set the resolution from the command line by typing `set-resolution`.
|
||||||
|
|
||||||
To start working with Code - OSS, follow these steps:
|
To start working with Code - OSS, follow these steps:
|
||||||
|
|
||||||
1. In your local VS Code, open a terminal (<kbd>Ctrl/Cmd</kbd> + <kbd>Shift</kbd> + <kbd>\`</kbd>) and type the following commands:
|
1. In your local VS Code client, open a terminal (<kbd>Ctrl/Cmd</kbd> + <kbd>Shift</kbd> + <kbd>\`</kbd>) and type the following commands:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
yarn install
|
yarn install
|
||||||
bash scripts/code.sh
|
bash scripts/code.sh
|
||||||
```
|
```
|
||||||
|
|
||||||
Note that a previous run of `yarn install` will already be cached, so this step should simply pick up any recent differences.
|
2. After the build is complete, open a web browser or a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/) to connect to the desktop environment as described in the quick start and enter `vscode` as the password.
|
||||||
|
|
||||||
2. After the build is complete, open a web browser or a [VNC Viewer](https://www.realvnc.com/en/connect/download/viewer/) to the desktop environnement as described in the quick start and enter `vscode` as the password.
|
|
||||||
|
|
||||||
3. You should now see Code - OSS!
|
3. You should now see Code - OSS!
|
||||||
|
|
||||||
@@ -91,7 +92,7 @@ Next, let's try debugging.
|
|||||||
|
|
||||||
1. Shut down Code - OSS by clicking the box in the upper right corner of the Code - OSS window through your browser or VNC viewer.
|
1. Shut down Code - OSS by clicking the box in the upper right corner of the Code - OSS window through your browser or VNC viewer.
|
||||||
|
|
||||||
2. Go to your local VS Code client, and use Run / Debug view to launch the **VS Code** configuration. (Typically the default, so you can likely just press <kbd>F5</kbd>).
|
2. Go to your local VS Code client, and use the **Run / Debug** view to launch the **VS Code** configuration. (Typically the default, so you can likely just press <kbd>F5</kbd>).
|
||||||
|
|
||||||
> **Note:** If launching times out, you can increase the value of `timeout` in the "VS Code", "Attach Main Process", "Attach Extension Host", and "Attach to Shared Process" configurations in [launch.json](../.vscode/launch.json). However, running `scripts/code.sh` first will set up Electron which will usually solve timeout issues.
|
> **Note:** If launching times out, you can increase the value of `timeout` in the "VS Code", "Attach Main Process", "Attach Extension Host", and "Attach to Shared Process" configurations in [launch.json](../.vscode/launch.json). However, running `scripts/code.sh` first will set up Electron which will usually solve timeout issues.
|
||||||
|
|
||||||
|
|||||||
@@ -3,20 +3,26 @@
|
|||||||
|
|
||||||
// Image contents: https://github.com/microsoft/vscode-dev-containers/blob/master/repository-containers/images/github.com/microsoft/vscode/.devcontainer/base.Dockerfile
|
// Image contents: https://github.com/microsoft/vscode-dev-containers/blob/master/repository-containers/images/github.com/microsoft/vscode/.devcontainer/base.Dockerfile
|
||||||
"image": "mcr.microsoft.com/vscode/devcontainers/repos/microsoft/vscode:branch-main",
|
"image": "mcr.microsoft.com/vscode/devcontainers/repos/microsoft/vscode:branch-main",
|
||||||
|
|
||||||
"workspaceMount": "source=${localWorkspaceFolder},target=/home/node/workspace/vscode,type=bind,consistency=cached",
|
|
||||||
"workspaceFolder": "/home/node/workspace/vscode",
|
|
||||||
"overrideCommand": false,
|
"overrideCommand": false,
|
||||||
"runArgs": [ "--init", "--security-opt", "seccomp=unconfined"],
|
"runArgs": [ "--init", "--security-opt", "seccomp=unconfined"],
|
||||||
|
|
||||||
"settings": {
|
"settings": {
|
||||||
"terminal.integrated.shell.linux": "/bin/bash",
|
|
||||||
"resmon.show.battery": false,
|
"resmon.show.battery": false,
|
||||||
"resmon.show.cpufreq": false
|
"resmon.show.cpufreq": false
|
||||||
},
|
},
|
||||||
|
|
||||||
// noVNC, VNC, debug ports
|
// noVNC, VNC
|
||||||
"forwardPorts": [6080, 5901, 9222],
|
"forwardPorts": [6080, 5901],
|
||||||
|
"portsAttributes": {
|
||||||
|
"6080": {
|
||||||
|
"label": "VNC web client (noVNC)",
|
||||||
|
"onAutoForward": "silent"
|
||||||
|
},
|
||||||
|
"5901": {
|
||||||
|
"label": "VNC TCP port",
|
||||||
|
"onAutoForward": "silent"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
"extensions": [
|
"extensions": [
|
||||||
"dbaeumer.vscode-eslint",
|
"dbaeumer.vscode-eslint",
|
||||||
|
|||||||
@@ -104,6 +104,7 @@
|
|||||||
"restrictions": [
|
"restrictions": [
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/common/**",
|
"**/{vs,sql}/base/common/**",
|
||||||
"**/{vs,sql}/base/test/common/**"
|
"**/{vs,sql}/base/test/common/**"
|
||||||
@@ -141,6 +142,7 @@
|
|||||||
"restrictions": [
|
"restrictions": [
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/{common,browser}/**",
|
"**/{vs,sql}/base/{common,browser}/**",
|
||||||
"**/{vs,sql}/base/test/{common,browser}/**",
|
"**/{vs,sql}/base/test/{common,browser}/**",
|
||||||
@@ -220,6 +222,7 @@
|
|||||||
"assert",
|
"assert",
|
||||||
"typemoq",
|
"typemoq",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"azdata",
|
"azdata",
|
||||||
"**/{vs,sql}/base/common/**",
|
"**/{vs,sql}/base/common/**",
|
||||||
@@ -292,6 +295,7 @@
|
|||||||
"typemoq",
|
"typemoq",
|
||||||
"sinon",
|
"sinon",
|
||||||
"azdata",
|
"azdata",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/{common,browser}/**",
|
"**/{vs,sql}/base/{common,browser}/**",
|
||||||
"**/{vs,sql}/base/test/{common,browser}/**",
|
"**/{vs,sql}/base/test/{common,browser}/**",
|
||||||
@@ -315,6 +319,7 @@
|
|||||||
"restrictions": [
|
"restrictions": [
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/common/**",
|
"**/{vs,sql}/base/common/**",
|
||||||
"**/{vs,sql}/platform/*/common/**",
|
"**/{vs,sql}/platform/*/common/**",
|
||||||
@@ -338,6 +343,7 @@
|
|||||||
"restrictions": [
|
"restrictions": [
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/{common,browser}/**",
|
"**/{vs,sql}/base/{common,browser}/**",
|
||||||
"**/{vs,sql}/platform/*/{common,browser}/**",
|
"**/{vs,sql}/platform/*/{common,browser}/**",
|
||||||
@@ -361,6 +367,7 @@
|
|||||||
"restrictions": [
|
"restrictions": [
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/common/**",
|
"**/{vs,sql}/base/common/**",
|
||||||
"**/{vs,sql}/platform/*/common/**",
|
"**/{vs,sql}/platform/*/common/**",
|
||||||
@@ -387,6 +394,7 @@
|
|||||||
"restrictions": [
|
"restrictions": [
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/{common,browser}/**",
|
"**/{vs,sql}/base/{common,browser}/**",
|
||||||
"**/{vs,sql}/platform/*/{common,browser}/**",
|
"**/{vs,sql}/platform/*/{common,browser}/**",
|
||||||
@@ -401,6 +409,7 @@
|
|||||||
"restrictions": [
|
"restrictions": [
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"vs/nls",
|
"vs/nls",
|
||||||
"**/{vs,sql}/base/{common,browser}/**",
|
"**/{vs,sql}/base/{common,browser}/**",
|
||||||
"**/{vs,sql}/base/test/{common,browser}/**",
|
"**/{vs,sql}/base/test/{common,browser}/**",
|
||||||
@@ -523,7 +532,7 @@
|
|||||||
"**/{vs,sql}/platform/**",
|
"**/{vs,sql}/platform/**",
|
||||||
"**/{vs,sql}/editor/**",
|
"**/{vs,sql}/editor/**",
|
||||||
"**/{vs,sql}/workbench/{common,browser,node,electron-sandbox,electron-browser}/**",
|
"**/{vs,sql}/workbench/{common,browser,node,electron-sandbox,electron-browser}/**",
|
||||||
"vs/workbench/contrib/files/common/editors/fileEditorInput",
|
"vs/workbench/contrib/files/browser/editors/fileEditorInput",
|
||||||
"**/{vs,sql}/workbench/services/**",
|
"**/{vs,sql}/workbench/services/**",
|
||||||
"**/{vs,sql}/workbench/test/**",
|
"**/{vs,sql}/workbench/test/**",
|
||||||
"*" // node modules
|
"*" // node modules
|
||||||
@@ -958,6 +967,7 @@
|
|||||||
"**/{vs,sql}/**",
|
"**/{vs,sql}/**",
|
||||||
"assert",
|
"assert",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"crypto",
|
"crypto",
|
||||||
"vscode",
|
"vscode",
|
||||||
"typemoq",
|
"typemoq",
|
||||||
@@ -993,6 +1003,7 @@
|
|||||||
"assert",
|
"assert",
|
||||||
"typemoq",
|
"typemoq",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"crypto",
|
"crypto",
|
||||||
"xterm*",
|
"xterm*",
|
||||||
"azdata"
|
"azdata"
|
||||||
@@ -1005,6 +1016,7 @@
|
|||||||
"assert",
|
"assert",
|
||||||
"typemoq",
|
"typemoq",
|
||||||
"sinon",
|
"sinon",
|
||||||
|
"sinon-test",
|
||||||
"crypto",
|
"crypto",
|
||||||
"xterm*"
|
"xterm*"
|
||||||
]
|
]
|
||||||
@@ -1042,6 +1054,7 @@
|
|||||||
"vscode-dts-cancellation": "warn",
|
"vscode-dts-cancellation": "warn",
|
||||||
"vscode-dts-use-thenable": "warn",
|
"vscode-dts-use-thenable": "warn",
|
||||||
"vscode-dts-region-comments": "warn",
|
"vscode-dts-region-comments": "warn",
|
||||||
|
"vscode-dts-vscode-in-comments": "warn",
|
||||||
"vscode-dts-provider-naming": [
|
"vscode-dts-provider-naming": [
|
||||||
"warn",
|
"warn",
|
||||||
{
|
{
|
||||||
|
|||||||
3
.github/subscribers.json
vendored
3
.github/subscribers.json
vendored
@@ -4,6 +4,7 @@
|
|||||||
"rchiodo",
|
"rchiodo",
|
||||||
"greazer",
|
"greazer",
|
||||||
"donjayamanne",
|
"donjayamanne",
|
||||||
"jilljac"
|
"jilljac",
|
||||||
|
"IanMatthewHuff"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
4
.github/workflows/ci.yml
vendored
4
.github/workflows/ci.yml
vendored
@@ -243,7 +243,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
path: "**/node_modules"
|
path: "**/node_modules"
|
||||||
key: ${{ runner.os }}-cacheNodeModules13-${{ steps.nodeModulesCacheKey.outputs.value }}
|
key: ${{ runner.os }}-cacheNodeModules13-${{ steps.nodeModulesCacheKey.outputs.value }}
|
||||||
restore-keys: ${{ runner.os }}-cacheNodeModules13-
|
|
||||||
- name: Get yarn cache directory path
|
- name: Get yarn cache directory path
|
||||||
id: yarnCacheDirPath
|
id: yarnCacheDirPath
|
||||||
if: ${{ steps.cacheNodeModules.outputs.cache-hit != 'true' }}
|
if: ${{ steps.cacheNodeModules.outputs.cache-hit != 'true' }}
|
||||||
@@ -279,6 +278,9 @@ jobs:
|
|||||||
# - name: Run Monaco Editor Checks {{SQL CARBON EDIT}} Remove Monaco checks
|
# - name: Run Monaco Editor Checks {{SQL CARBON EDIT}} Remove Monaco checks
|
||||||
# run: yarn monaco-compile-check
|
# run: yarn monaco-compile-check
|
||||||
|
|
||||||
|
- name: Compile /build/
|
||||||
|
run: yarn --cwd build compile
|
||||||
|
|
||||||
- name: Run Trusted Types Checks
|
- name: Run Trusted Types Checks
|
||||||
run: yarn tsec-compile-check
|
run: yarn tsec-compile-check
|
||||||
|
|
||||||
|
|||||||
18
.vscode/notebooks/api.github-issues
vendored
18
.vscode/notebooks/api.github-issues
vendored
@@ -2,37 +2,31 @@
|
|||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "#### Config",
|
"value": "#### Config"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repo=repo:microsoft/vscode\n$milestone=milestone:\"April 2021\"",
|
"value": "$repo=repo:microsoft/vscode\n$milestone=milestone:\"June 2021\""
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "### Finalization",
|
"value": "### Finalization"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repo $milestone label:api-finalization",
|
"value": "$repo $milestone label:api-finalization"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "### Proposals",
|
"value": "### Proposals"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repo $milestone is:open label:api-proposal ",
|
"value": "$repo $milestone is:open label:api-proposal "
|
||||||
"editable": true
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
2
.vscode/notebooks/endgame.github-issues
vendored
2
.vscode/notebooks/endgame.github-issues
vendored
@@ -7,7 +7,7 @@
|
|||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$REPOS=repo:microsoft/vscode repo:microsoft/vscode-internalbacklog repo:microsoft/vscode-js-debug repo:microsoft/vscode-remote-release repo:microsoft/vscode-pull-request-github repo:microsoft/vscode-settings-sync-server repo:microsoft/vscode-emmet-helper repo:microsoft/vscode-remotehub\n\n$MILESTONE=milestone:\"April 2021\""
|
"value": "$REPOS=repo:microsoft/vscode repo:microsoft/vscode-internalbacklog repo:microsoft/vscode-js-debug repo:microsoft/vscode-remote-release repo:microsoft/vscode-pull-request-github repo:microsoft/vscode-settings-sync-server repo:microsoft/vscode-emmet-helper repo:microsoft/vscode-remotehub\n\n$MILESTONE=milestone:\"May 2021\""
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
|
|||||||
4
.vscode/notebooks/my-endgame.github-issues
vendored
4
.vscode/notebooks/my-endgame.github-issues
vendored
@@ -7,7 +7,7 @@
|
|||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$REPOS=repo:microsoft/vscode repo:microsoft/vscode-internalbacklog repo:microsoft/vscode-js-debug repo:microsoft/vscode-remote-release repo:microsoft/vscode-pull-request-github repo:microsoft/vscode-settings-sync-server repo:microsoft/vscode-remotehub\n\n$MILESTONE=milestone:\"April 2021\"\n\n$MINE=assignee:@me"
|
"value": "$REPOS=repo:microsoft/vscode repo:microsoft/vscode-internalbacklog repo:microsoft/vscode-js-debug repo:microsoft/vscode-remote-release repo:microsoft/vscode-pull-request-github repo:microsoft/vscode-settings-sync-server repo:microsoft/vscode-remotehub\n\n$MILESTONE=milestone:\"May 2021\"\n\n$MINE=assignee:@me"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
@@ -157,7 +157,7 @@
|
|||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$REPOS $MILESTONE -$MINE is:issue is:closed sort:updated-asc label:bug -label:verified -label:z-author-verified -label:on-testplan -label:*duplicate -label:duplicate -label:invalid -label:*as-designed -label:error-telemetry -label:verification-steps-needed -label:verification-found -author:aeschli -author:alexdima -author:alexr00 -author:AmandaSilver -author:bamurtaugh -author:bpasero -author:btholt -author:chrisdias -author:chrmarti -author:Chuxel -author:connor4312 -author:dbaeumer -author:deepak1556 -author:devinvalenciano -author:digitarald -author:eamodio -author:egamma -author:fiveisprime -author:gregvanl -author:isidorn -author:ItalyPaleAle -author:JacksonKearl -author:joaomoreno -author:jrieken -author:kieferrm -author:lszomoru -author:meganrogge -author:misolori -author:mjbvz -author:ornellaalt -author:orta -author:rebornix -author:RMacfarlane -author:roblourens -author:rzhao271 -author:sana-ajani -author:sandy081 -author:sbatten -author:stevencl -author:Tyriar -author:weinand -author:TylerLeonhardt -author:lramos15"
|
"value": "$REPOS $MILESTONE -$MINE is:issue is:closed sort:updated-asc label:bug -label:verified -label:z-author-verified -label:on-testplan -label:*duplicate -label:duplicate -label:invalid -label:*as-designed -label:error-telemetry -label:verification-steps-needed -label:verification-found -author:aeschli -author:alexdima -author:alexr00 -author:AmandaSilver -author:bamurtaugh -author:bpasero -author:btholt -author:chrisdias -author:chrmarti -author:Chuxel -author:connor4312 -author:dbaeumer -author:deepak1556 -author:devinvalenciano -author:digitarald -author:eamodio -author:egamma -author:fiveisprime -author:gregvanl -author:isidorn -author:ItalyPaleAle -author:JacksonKearl -author:joaomoreno -author:jrieken -author:kieferrm -author:lszomoru -author:meganrogge -author:misolori -author:mjbvz -author:ornellaalt -author:orta -author:rebornix -author:RMacfarlane -author:roblourens -author:rzhao271 -author:sana-ajani -author:sandy081 -author:sbatten -author:stevencl -author:Tyriar -author:weinand -author:TylerLeonhardt -author:lramos15 -author:hediet"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
|
|||||||
52
.vscode/notebooks/my-work.github-issues
vendored
52
.vscode/notebooks/my-work.github-issues
vendored
@@ -2,20 +2,17 @@
|
|||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "##### `Config`: This should be changed every month/milestone",
|
"value": "##### `Config`: This should be changed every month/milestone"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "// list of repos we work in\n$repos=repo:microsoft/vscode repo:microsoft/vscode-remote-release repo:microsoft/vscode-js-debug repo:microsoft/vscode-pull-request-github repo:microsoft/vscode-github-issue-notebooks repo:microsoft/vscode-internalbacklog\n\n// current milestone name\n$milestone=milestone:\"April 2021\"",
|
"value": "// list of repos we work in\n$repos=repo:microsoft/vscode repo:microsoft/vscode-remote-release repo:microsoft/vscode-js-debug repo:microsoft/vscode-pull-request-github repo:microsoft/vscode-github-issue-notebooks repo:microsoft/vscode-internalbacklog\n\n// current milestone name\n$milestone=milestone:\"June 2021\""
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "github-issues",
|
"language": "markdown",
|
||||||
"value": "## Milestone Work",
|
"value": "## Milestone Work"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
@@ -25,57 +22,48 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "github-issues",
|
"language": "markdown",
|
||||||
"value": "## Bugs, Debt, Features...",
|
"value": "## Bugs, Debt, Features..."
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "#### My Bugs",
|
"value": "#### My Bugs"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repos assignee:@me is:open label:bug",
|
"value": "$repos assignee:@me is:open label:bug"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "#### Debt & Engineering",
|
"value": "#### Debt & Engineering"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repos assignee:@me is:open label:debt OR $repos assignee:@me is:open label:engineering",
|
"value": "$repos assignee:@me is:open label:debt OR $repos assignee:@me is:open label:engineering"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "#### Performance 🐌 🔜 🏎",
|
"value": "#### Performance 🐌 🔜 🏎"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repos assignee:@me is:open label:perf OR $repos assignee:@me is:open label:perf-startup OR $repos assignee:@me is:open label:perf-bloat OR $repos assignee:@me is:open label:freeze-slow-crash-leak",
|
"value": "$repos assignee:@me is:open label:perf OR $repos assignee:@me is:open label:perf-startup OR $repos assignee:@me is:open label:perf-bloat OR $repos assignee:@me is:open label:freeze-slow-crash-leak"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "#### Feature Requests",
|
"value": "#### Feature Requests"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repos assignee:@me is:open label:feature-request milestone:Backlog sort:reactions-+1-desc",
|
"value": "$repos assignee:@me is:open label:feature-request milestone:Backlog sort:reactions-+1-desc"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
@@ -86,26 +74,22 @@
|
|||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "### Personal Inbox\n",
|
"value": "### Personal Inbox\n"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "\n#### Missing Type label",
|
"value": "\n#### Missing Type label"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
"language": "github-issues",
|
"language": "github-issues",
|
||||||
"value": "$repos assignee:@me is:open type:issue -label:bug -label:\"needs more info\" -label:feature-request -label:under-discussion -label:debt -label:plan-item -label:upstream",
|
"value": "$repos assignee:@me is:open type:issue -label:bug -label:\"needs more info\" -label:feature-request -label:under-discussion -label:debt -label:plan-item -label:upstream"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 1,
|
"kind": 1,
|
||||||
"language": "markdown",
|
"language": "markdown",
|
||||||
"value": "#### Not Actionable",
|
"value": "#### Not Actionable"
|
||||||
"editable": true
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"kind": 2,
|
"kind": 2,
|
||||||
|
|||||||
53
.vscode/tasks.json
vendored
53
.vscode/tasks.json
vendored
@@ -55,39 +55,11 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"type": "npm",
|
|
||||||
"script": "watch-extension-mediad",
|
|
||||||
"label": "Ext Media - Build",
|
|
||||||
"isBackground": true,
|
|
||||||
"presentation": {
|
|
||||||
"reveal": "never",
|
|
||||||
"group": "buildWatchers"
|
|
||||||
},
|
|
||||||
"problemMatcher": {
|
|
||||||
"owner": "typescript",
|
|
||||||
"applyTo": "closedDocuments",
|
|
||||||
"fileLocation": [
|
|
||||||
"absolute"
|
|
||||||
],
|
|
||||||
"pattern": {
|
|
||||||
"regexp": "Error: ([^(]+)\\((\\d+|\\d+,\\d+|\\d+,\\d+,\\d+,\\d+)\\): (.*)$",
|
|
||||||
"file": 1,
|
|
||||||
"location": 2,
|
|
||||||
"message": 3
|
|
||||||
},
|
|
||||||
"background": {
|
|
||||||
"beginsPattern": "Starting compilation",
|
|
||||||
"endsPattern": "Finished compilation"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"label": "VS Code - Build",
|
"label": "VS Code - Build",
|
||||||
"dependsOn": [
|
"dependsOn": [
|
||||||
"Core - Build",
|
"Core - Build",
|
||||||
"Ext - Build",
|
"Ext - Build"
|
||||||
"Ext Media - Build",
|
|
||||||
],
|
],
|
||||||
"group": {
|
"group": {
|
||||||
"kind": "build",
|
"kind": "build",
|
||||||
@@ -102,7 +74,8 @@
|
|||||||
"group": "build",
|
"group": "build",
|
||||||
"presentation": {
|
"presentation": {
|
||||||
"reveal": "never",
|
"reveal": "never",
|
||||||
"group": "buildKillers"
|
"group": "buildKillers",
|
||||||
|
"close": true
|
||||||
},
|
},
|
||||||
"problemMatcher": "$tsc"
|
"problemMatcher": "$tsc"
|
||||||
},
|
},
|
||||||
@@ -113,18 +86,8 @@
|
|||||||
"group": "build",
|
"group": "build",
|
||||||
"presentation": {
|
"presentation": {
|
||||||
"reveal": "never",
|
"reveal": "never",
|
||||||
"group": "buildKillers"
|
"group": "buildKillers",
|
||||||
},
|
"close": true
|
||||||
"problemMatcher": "$tsc"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "npm",
|
|
||||||
"script": "kill-watch-extension-mediad",
|
|
||||||
"label": "Kill Ext Media - Build",
|
|
||||||
"group": "build",
|
|
||||||
"presentation": {
|
|
||||||
"reveal": "never",
|
|
||||||
"group": "buildKillers"
|
|
||||||
},
|
},
|
||||||
"problemMatcher": "$tsc"
|
"problemMatcher": "$tsc"
|
||||||
},
|
},
|
||||||
@@ -132,8 +95,7 @@
|
|||||||
"label": "Kill VS Code - Build",
|
"label": "Kill VS Code - Build",
|
||||||
"dependsOn": [
|
"dependsOn": [
|
||||||
"Kill Core - Build",
|
"Kill Core - Build",
|
||||||
"Kill Ext - Build",
|
"Kill Ext - Build"
|
||||||
"Kill Ext Media - Build",
|
|
||||||
],
|
],
|
||||||
"group": "build",
|
"group": "build",
|
||||||
"problemMatcher": []
|
"problemMatcher": []
|
||||||
@@ -252,7 +214,8 @@
|
|||||||
"command": "node build/lib/preLaunch.js",
|
"command": "node build/lib/preLaunch.js",
|
||||||
"label": "Ensure Prelaunch Dependencies",
|
"label": "Ensure Prelaunch Dependencies",
|
||||||
"presentation": {
|
"presentation": {
|
||||||
"reveal": "silent"
|
"reveal": "silent",
|
||||||
|
"close": true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|||||||
2
.yarnrc
2
.yarnrc
@@ -1,3 +1,3 @@
|
|||||||
disturl "https://electronjs.org/headers"
|
disturl "https://electronjs.org/headers"
|
||||||
target "12.0.7"
|
target "12.0.9"
|
||||||
runtime "electron"
|
runtime "electron"
|
||||||
|
|||||||
@@ -86,6 +86,125 @@ expressly granted herein, whether by implication, estoppel or otherwise.
|
|||||||
|
|
||||||
Microsoft PROSE SDK: https://microsoft.github.io/prose
|
Microsoft PROSE SDK: https://microsoft.github.io/prose
|
||||||
|
|
||||||
|
atom/language-clojure version 0.22.7 (https://github.com/atom/language-clojure)
|
||||||
|
atom/language-coffee-script version 0.49.3 (https://github.com/atom/language-coffee-script)
|
||||||
|
atom/language-css version 0.44.4 (https://github.com/atom/language-css)
|
||||||
|
atom/language-java version 0.32.1 (https://github.com/atom/language-java)
|
||||||
|
atom/language-sass version 0.62.1 (https://github.com/atom/language-sass)
|
||||||
|
atom/language-shellscript version 0.26.0 (https://github.com/atom/language-shellscript)
|
||||||
|
atom/language-xml version 0.35.2 (https://github.com/atom/language-xml)
|
||||||
|
better-go-syntax version 1.0.0 (https://github.com/jeff-hykin/better-go-syntax/ )
|
||||||
|
Colorsublime-Themes version 0.1.0 (https://github.com/Colorsublime/Colorsublime-Themes)
|
||||||
|
daaain/Handlebars version 1.8.0 (https://github.com/daaain/Handlebars)
|
||||||
|
dart-lang/dart-syntax-highlight (https://github.com/dart-lang/dart-syntax-highlight)
|
||||||
|
davidrios/pug-tmbundle (https://github.com/davidrios/pug-tmbundle)
|
||||||
|
definitelytyped (https://github.com/DefinitelyTyped/DefinitelyTyped)
|
||||||
|
demyte/language-cshtml version 0.3.0 (https://github.com/demyte/language-cshtml)
|
||||||
|
Document Object Model version 4.0.0 (https://www.w3.org/DOM/)
|
||||||
|
dotnet/csharp-tmLanguage version 0.1.0 (https://github.com/dotnet/csharp-tmLanguage)
|
||||||
|
expand-abbreviation version 0.5.8 (https://github.com/emmetio/expand-abbreviation)
|
||||||
|
fadeevab/make.tmbundle (https://github.com/fadeevab/make.tmbundle)
|
||||||
|
freebroccolo/atom-language-swift (https://github.com/freebroccolo/atom-language-swift)
|
||||||
|
HTML 5.1 W3C Working Draft version 08 October 2015 (http://www.w3.org/TR/2015/WD-html51-20151008/)
|
||||||
|
Ikuyadeu/vscode-R version 1.3.0 (https://github.com/Ikuyadeu/vscode-R)
|
||||||
|
insane version 2.6.2 (https://github.com/bevacqua/insane)
|
||||||
|
Ionic documentation version 1.2.4 (https://github.com/ionic-team/ionic-site)
|
||||||
|
ionide/ionide-fsgrammar (https://github.com/ionide/ionide-fsgrammar)
|
||||||
|
jeff-hykin/cpp-textmate-grammar version 1.12.11 (https://github.com/jeff-hykin/cpp-textmate-grammar)
|
||||||
|
jeff-hykin/cpp-textmate-grammar version 1.15.5 (https://github.com/jeff-hykin/cpp-textmate-grammar)
|
||||||
|
js-beautify version 1.6.8 (https://github.com/beautify-web/js-beautify)
|
||||||
|
JuliaEditorSupport/atom-language-julia version 0.21.0 (https://github.com/JuliaEditorSupport/atom-language-julia)
|
||||||
|
Jxck/assert version 1.0.0 (https://github.com/Jxck/assert)
|
||||||
|
language-docker (https://github.com/moby/moby)
|
||||||
|
language-less version 0.34.2 (https://github.com/atom/language-less)
|
||||||
|
language-php version 0.46.2 (https://github.com/atom/language-php)
|
||||||
|
MagicStack/MagicPython version 1.1.1 (https://github.com/MagicStack/MagicPython)
|
||||||
|
marked version 1.1.0 (https://github.com/markedjs/marked)
|
||||||
|
mdn-data version 1.1.12 (https://github.com/mdn/data)
|
||||||
|
microsoft/TypeScript-TmLanguage version 0.0.1 (https://github.com/microsoft/TypeScript-TmLanguage)
|
||||||
|
microsoft/vscode-JSON.tmLanguage (https://github.com/microsoft/vscode-JSON.tmLanguage)
|
||||||
|
microsoft/vscode-markdown-tm-grammar version 1.0.0 (https://github.com/microsoft/vscode-markdown-tm-grammar)
|
||||||
|
microsoft/vscode-mssql version 1.9.0 (https://github.com/microsoft/vscode-mssql)
|
||||||
|
mmims/language-batchfile version 0.7.6 (https://github.com/mmims/language-batchfile)
|
||||||
|
NVIDIA/cuda-cpp-grammar (https://github.com/NVIDIA/cuda-cpp-grammar)
|
||||||
|
PowerShell/EditorSyntax version 1.0.0 (https://github.com/PowerShell/EditorSyntax)
|
||||||
|
rust-syntax version 0.4.3 (https://github.com/dustypomerleau/rust-syntax)
|
||||||
|
seti-ui version 0.1.0 (https://github.com/jesseweed/seti-ui)
|
||||||
|
shaders-tmLanguage version 0.1.0 (https://github.com/tgjones/shaders-tmLanguage)
|
||||||
|
textmate/asp.vb.net.tmbundle (https://github.com/textmate/asp.vb.net.tmbundle)
|
||||||
|
textmate/c.tmbundle (https://github.com/textmate/c.tmbundle)
|
||||||
|
textmate/diff.tmbundle (https://github.com/textmate/diff.tmbundle)
|
||||||
|
textmate/git.tmbundle (https://github.com/textmate/git.tmbundle)
|
||||||
|
textmate/groovy.tmbundle (https://github.com/textmate/groovy.tmbundle)
|
||||||
|
textmate/html.tmbundle (https://github.com/textmate/html.tmbundle)
|
||||||
|
textmate/ini.tmbundle (https://github.com/textmate/ini.tmbundle)
|
||||||
|
textmate/javascript.tmbundle (https://github.com/textmate/javascript.tmbundle)
|
||||||
|
textmate/lua.tmbundle (https://github.com/textmate/lua.tmbundle)
|
||||||
|
textmate/markdown.tmbundle (https://github.com/textmate/markdown.tmbundle)
|
||||||
|
textmate/perl.tmbundle (https://github.com/textmate/perl.tmbundle)
|
||||||
|
textmate/ruby.tmbundle (https://github.com/textmate/ruby.tmbundle)
|
||||||
|
textmate/yaml.tmbundle (https://github.com/textmate/yaml.tmbundle)
|
||||||
|
TypeScript-TmLanguage version 0.1.8 (https://github.com/microsoft/TypeScript-TmLanguage)
|
||||||
|
TypeScript-TmLanguage version 1.0.0 (https://github.com/microsoft/TypeScript-TmLanguage)
|
||||||
|
Unicode version 12.0.0 (https://home.unicode.org/)
|
||||||
|
vscode-codicons version 0.0.14 (https://github.com/microsoft/vscode-codicons)
|
||||||
|
vscode-logfile-highlighter version 2.11.0 (https://github.com/emilast/vscode-logfile-highlighter)
|
||||||
|
vscode-swift version 0.0.1 (https://github.com/owensd/vscode-swift)
|
||||||
|
Web Background Synchronization (https://github.com/WICG/background-sync)
|
||||||
|
|
||||||
|
|
||||||
|
%% atom/language-clojure NOTICES AND INFORMATION BEGIN HERE
|
||||||
|
=========================================
|
||||||
|
Copyright (c) 2014 GitHub Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
|
||||||
|
This package was derived from a TextMate bundle located at
|
||||||
|
https://github.com/mmcgrana/textmate-clojure and distributed under the
|
||||||
|
following license, located in `LICENSE.md`:
|
||||||
|
|
||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2010- Mark McGranaghan
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
|
=========================================
|
||||||
|
END OF atom/language-clojure NOTICES AND INFORMATION
|
||||||
|
|
||||||
%% angular NOTICES AND INFORMATION BEGIN HERE
|
%% angular NOTICES AND INFORMATION BEGIN HERE
|
||||||
|
|
||||||
Copyright (c) 2014-2017 Google, Inc. http://angular.io
|
Copyright (c) 2014-2017 Google, Inc. http://angular.io
|
||||||
@@ -560,6 +679,63 @@ THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLI
|
|||||||
=========================================
|
=========================================
|
||||||
END OF http-proxy-agent NOTICES AND INFORMATION
|
END OF http-proxy-agent NOTICES AND INFORMATION
|
||||||
|
|
||||||
|
%% dart-lang/dart-syntax-highlight NOTICES AND INFORMATION BEGIN HERE
|
||||||
|
=========================================
|
||||||
|
Copyright 2020, the Dart project authors.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are
|
||||||
|
met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer.
|
||||||
|
* Redistributions in binary form must reproduce the above
|
||||||
|
copyright notice, this list of conditions and the following
|
||||||
|
disclaimer in the documentation and/or other materials provided
|
||||||
|
with the distribution.
|
||||||
|
* Neither the name of Google LLC nor the names of its
|
||||||
|
contributors may be used to endorse or promote products derived
|
||||||
|
from this software without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
=========================================
|
||||||
|
END OF dart-lang/dart-syntax-highlight NOTICES AND INFORMATION
|
||||||
|
|
||||||
|
%% davidrios/pug-tmbundle NOTICES AND INFORMATION BEGIN HERE
|
||||||
|
=========================================
|
||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2016 David Rios
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
|
subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
=========================================
|
||||||
|
END OF davidrios/pug-tmbundle NOTICES AND INFORMATION
|
||||||
|
|
||||||
%% iconv-lite NOTICES AND INFORMATION BEGIN HERE
|
%% iconv-lite NOTICES AND INFORMATION BEGIN HERE
|
||||||
=========================================
|
=========================================
|
||||||
Copyright (c) 2011 Alexander Shtuchkin
|
Copyright (c) 2011 Alexander Shtuchkin
|
||||||
@@ -1486,6 +1662,61 @@ THE SOFTWARE.
|
|||||||
=========================================
|
=========================================
|
||||||
END OF node-pty NOTICES AND INFORMATION
|
END OF node-pty NOTICES AND INFORMATION
|
||||||
|
|
||||||
|
%% JuliaEditorSupport/atom-language-julia NOTICES AND INFORMATION BEGIN HERE
|
||||||
|
=========================================
|
||||||
|
The atom-language-julia package is licensed under the MIT "Expat" License:
|
||||||
|
|
||||||
|
> Copyright (c) 2015
|
||||||
|
>
|
||||||
|
> Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
> a copy of this software and associated documentation files (the
|
||||||
|
> "Software"), to deal in the Software without restriction, including
|
||||||
|
> without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
> distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
> permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
> the following conditions:
|
||||||
|
>
|
||||||
|
> The above copyright notice and this permission notice shall be
|
||||||
|
> included in all copies or substantial portions of the Software.
|
||||||
|
>
|
||||||
|
> THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
> EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
> MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
> IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||||
|
> CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
> TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
|
> SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
=========================================
|
||||||
|
END OF JuliaEditorSupport/atom-language-julia NOTICES AND INFORMATION
|
||||||
|
|
||||||
|
%% Jxck/assert NOTICES AND INFORMATION BEGIN HERE
|
||||||
|
=========================================
|
||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2011 Jxck
|
||||||
|
|
||||||
|
Originally from node.js (http://nodejs.org)
|
||||||
|
Copyright Joyent, Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
=========================================
|
||||||
|
END OF Jxck/assert NOTICES AND INFORMATION
|
||||||
|
|
||||||
%% nsfw NOTICES AND INFORMATION BEGIN HERE
|
%% nsfw NOTICES AND INFORMATION BEGIN HERE
|
||||||
=========================================
|
=========================================
|
||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
2021-04-07T03:52:18.011Z
|
2021-08-23T03:52:18.011Z
|
||||||
|
|||||||
@@ -5,15 +5,101 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
|
const url = require("url");
|
||||||
const crypto = require("crypto");
|
const crypto = require("crypto");
|
||||||
const azure = require("azure-storage");
|
const azure = require("azure-storage");
|
||||||
const mime = require("mime");
|
const mime = require("mime");
|
||||||
const cosmos_1 = require("@azure/cosmos");
|
const cosmos_1 = require("@azure/cosmos");
|
||||||
const retry_1 = require("./retry");
|
const retry_1 = require("./retry");
|
||||||
if (process.argv.length !== 6) {
|
if (process.argv.length !== 8) {
|
||||||
console.error('Usage: node createAsset.js PLATFORM TYPE NAME FILE');
|
console.error('Usage: node createAsset.js PRODUCT OS ARCH TYPE NAME FILE');
|
||||||
process.exit(-1);
|
process.exit(-1);
|
||||||
}
|
}
|
||||||
|
// Contains all of the logic for mapping details to our actual product names in CosmosDB
|
||||||
|
function getPlatform(product, os, arch, type) {
|
||||||
|
switch (os) {
|
||||||
|
case 'win32':
|
||||||
|
switch (product) {
|
||||||
|
case 'client':
|
||||||
|
const asset = arch === 'ia32' ? 'win32' : `win32-${arch}`;
|
||||||
|
switch (type) {
|
||||||
|
case 'archive':
|
||||||
|
return `${asset}-archive`;
|
||||||
|
case 'setup':
|
||||||
|
return asset;
|
||||||
|
case 'user-setup':
|
||||||
|
return `${asset}-user`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'server':
|
||||||
|
if (arch === 'arm64') {
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
return arch === 'ia32' ? 'server-win32' : `server-win32-${arch}`;
|
||||||
|
case 'web':
|
||||||
|
if (arch === 'arm64') {
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
return arch === 'ia32' ? 'server-win32-web' : `server-win32-${arch}-web`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'linux':
|
||||||
|
switch (type) {
|
||||||
|
case 'snap':
|
||||||
|
return `linux-snap-${arch}`;
|
||||||
|
case 'archive-unsigned':
|
||||||
|
switch (product) {
|
||||||
|
case 'client':
|
||||||
|
return `linux-${arch}`;
|
||||||
|
case 'server':
|
||||||
|
return `server-linux-${arch}`;
|
||||||
|
case 'web':
|
||||||
|
return arch === 'standalone' ? 'web-standalone' : `server-linux-${arch}-web`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'deb-package':
|
||||||
|
return `linux-deb-${arch}`;
|
||||||
|
case 'rpm-package':
|
||||||
|
return `linux-rpm-${arch}`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'darwin':
|
||||||
|
switch (product) {
|
||||||
|
case 'client':
|
||||||
|
if (arch === 'x64') {
|
||||||
|
return 'darwin';
|
||||||
|
}
|
||||||
|
return `darwin-${arch}`;
|
||||||
|
case 'server':
|
||||||
|
return 'server-darwin';
|
||||||
|
case 'web':
|
||||||
|
if (arch !== 'x64') {
|
||||||
|
throw `What should the platform be?: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
return 'server-darwin-web';
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Contains all of the logic for mapping types to our actual types in CosmosDB
|
||||||
|
function getRealType(type) {
|
||||||
|
switch (type) {
|
||||||
|
case 'user-setup':
|
||||||
|
return 'setup';
|
||||||
|
case 'deb-package':
|
||||||
|
case 'rpm-package':
|
||||||
|
return 'package';
|
||||||
|
default:
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
}
|
||||||
function hashStream(hashName, stream) {
|
function hashStream(hashName, stream) {
|
||||||
return new Promise((c, e) => {
|
return new Promise((c, e) => {
|
||||||
const shasum = crypto.createHash(hashName);
|
const shasum = crypto.createHash(hashName);
|
||||||
@@ -45,7 +131,10 @@ function getEnv(name) {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
async function main() {
|
async function main() {
|
||||||
const [, , platform, type, fileName, filePath] = process.argv;
|
const [, , product, os, arch, unprocessedType, fileName, filePath] = process.argv;
|
||||||
|
// getPlatform needs the unprocessedType
|
||||||
|
const platform = getPlatform(product, os, arch, unprocessedType);
|
||||||
|
const type = getRealType(unprocessedType);
|
||||||
const quality = getEnv('VSCODE_QUALITY');
|
const quality = getEnv('VSCODE_QUALITY');
|
||||||
const commit = getEnv('BUILD_SOURCEVERSION');
|
const commit = getEnv('BUILD_SOURCEVERSION');
|
||||||
console.log('Creating asset...');
|
console.log('Creating asset...');
|
||||||
@@ -65,14 +154,27 @@ async function main() {
|
|||||||
console.log(`Blob ${quality}, ${blobName} already exists, not publishing again.`);
|
console.log(`Blob ${quality}, ${blobName} already exists, not publishing again.`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
console.log('Uploading blobs to Azure storage...');
|
const mooncakeBlobService = azure.createBlobService(storageAccount, process.env['MOONCAKE_STORAGE_ACCESS_KEY'], `${storageAccount}.blob.core.chinacloudapi.cn`)
|
||||||
await uploadBlob(blobService, quality, blobName, filePath, fileName);
|
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
||||||
|
// mooncake is fussy and far away, this is needed!
|
||||||
|
blobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
||||||
|
mooncakeBlobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
||||||
|
console.log('Uploading blobs to Azure storage and Mooncake Azure storage...');
|
||||||
|
await retry_1.retry(() => Promise.all([
|
||||||
|
uploadBlob(blobService, quality, blobName, filePath, fileName),
|
||||||
|
uploadBlob(mooncakeBlobService, quality, blobName, filePath, fileName)
|
||||||
|
]));
|
||||||
console.log('Blobs successfully uploaded.');
|
console.log('Blobs successfully uploaded.');
|
||||||
|
// TODO: Understand if blobName and blobPath are the same and replace blobPath with blobName if so.
|
||||||
|
const assetUrl = `${process.env['AZURE_CDN_URL']}/${quality}/${blobName}`;
|
||||||
|
const blobPath = url.parse(assetUrl).path;
|
||||||
|
const mooncakeUrl = `${process.env['MOONCAKE_CDN_URL']}${blobPath}`;
|
||||||
const asset = {
|
const asset = {
|
||||||
platform,
|
platform,
|
||||||
type,
|
type,
|
||||||
url: `${process.env['AZURE_CDN_URL']}/${quality}/${blobName}`,
|
url: assetUrl,
|
||||||
hash: sha1hash,
|
hash: sha1hash,
|
||||||
|
mooncakeUrl,
|
||||||
sha256hash,
|
sha256hash,
|
||||||
size
|
size
|
||||||
};
|
};
|
||||||
@@ -83,7 +185,8 @@ async function main() {
|
|||||||
console.log('Asset:', JSON.stringify(asset, null, ' '));
|
console.log('Asset:', JSON.stringify(asset, null, ' '));
|
||||||
const client = new cosmos_1.CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT'], key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
const client = new cosmos_1.CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT'], key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
||||||
const scripts = client.database('builds').container(quality).scripts;
|
const scripts = client.database('builds').container(quality).scripts;
|
||||||
await (0, retry_1.retry)(() => scripts.storedProcedure('createAsset').execute('', [commit, asset, true]));
|
await retry_1.retry(() => scripts.storedProcedure('createAsset').execute('', [commit, asset, true]));
|
||||||
|
console.log(` Done ✔️`);
|
||||||
}
|
}
|
||||||
main().then(() => {
|
main().then(() => {
|
||||||
console.log('Asset successfully created');
|
console.log('Asset successfully created');
|
||||||
|
|||||||
@@ -6,6 +6,7 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
|
import * as url from 'url';
|
||||||
import { Readable } from 'stream';
|
import { Readable } from 'stream';
|
||||||
import * as crypto from 'crypto';
|
import * as crypto from 'crypto';
|
||||||
import * as azure from 'azure-storage';
|
import * as azure from 'azure-storage';
|
||||||
@@ -24,11 +25,98 @@ interface Asset {
|
|||||||
supportsFastUpdate?: boolean;
|
supportsFastUpdate?: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.argv.length !== 6) {
|
if (process.argv.length !== 8) {
|
||||||
console.error('Usage: node createAsset.js PLATFORM TYPE NAME FILE');
|
console.error('Usage: node createAsset.js PRODUCT OS ARCH TYPE NAME FILE');
|
||||||
process.exit(-1);
|
process.exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Contains all of the logic for mapping details to our actual product names in CosmosDB
|
||||||
|
function getPlatform(product: string, os: string, arch: string, type: string): string {
|
||||||
|
switch (os) {
|
||||||
|
case 'win32':
|
||||||
|
switch (product) {
|
||||||
|
case 'client':
|
||||||
|
const asset = arch === 'ia32' ? 'win32' : `win32-${arch}`;
|
||||||
|
switch (type) {
|
||||||
|
case 'archive':
|
||||||
|
return `${asset}-archive`;
|
||||||
|
case 'setup':
|
||||||
|
return asset;
|
||||||
|
case 'user-setup':
|
||||||
|
return `${asset}-user`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'server':
|
||||||
|
if (arch === 'arm64') {
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
return arch === 'ia32' ? 'server-win32' : `server-win32-${arch}`;
|
||||||
|
case 'web':
|
||||||
|
if (arch === 'arm64') {
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
return arch === 'ia32' ? 'server-win32-web' : `server-win32-${arch}-web`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'linux':
|
||||||
|
switch (type) {
|
||||||
|
case 'snap':
|
||||||
|
return `linux-snap-${arch}`;
|
||||||
|
case 'archive-unsigned':
|
||||||
|
switch (product) {
|
||||||
|
case 'client':
|
||||||
|
return `linux-${arch}`;
|
||||||
|
case 'server':
|
||||||
|
return `server-linux-${arch}`;
|
||||||
|
case 'web':
|
||||||
|
return arch === 'standalone' ? 'web-standalone' : `server-linux-${arch}-web`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'deb-package':
|
||||||
|
return `linux-deb-${arch}`;
|
||||||
|
case 'rpm-package':
|
||||||
|
return `linux-rpm-${arch}`;
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
case 'darwin':
|
||||||
|
switch (product) {
|
||||||
|
case 'client':
|
||||||
|
if (arch === 'x64') {
|
||||||
|
return 'darwin';
|
||||||
|
}
|
||||||
|
return `darwin-${arch}`;
|
||||||
|
case 'server':
|
||||||
|
return 'server-darwin';
|
||||||
|
case 'web':
|
||||||
|
if (arch !== 'x64') {
|
||||||
|
throw `What should the platform be?: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
return 'server-darwin-web';
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
throw `Unrecognized: ${product} ${os} ${arch} ${type}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Contains all of the logic for mapping types to our actual types in CosmosDB
|
||||||
|
function getRealType(type: string) {
|
||||||
|
switch (type) {
|
||||||
|
case 'user-setup':
|
||||||
|
return 'setup';
|
||||||
|
case 'deb-package':
|
||||||
|
case 'rpm-package':
|
||||||
|
return 'package';
|
||||||
|
default:
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function hashStream(hashName: string, stream: Readable): Promise<string> {
|
function hashStream(hashName: string, stream: Readable): Promise<string> {
|
||||||
return new Promise<string>((c, e) => {
|
return new Promise<string>((c, e) => {
|
||||||
const shasum = crypto.createHash(hashName);
|
const shasum = crypto.createHash(hashName);
|
||||||
@@ -68,7 +156,10 @@ function getEnv(name: string): string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function main(): Promise<void> {
|
async function main(): Promise<void> {
|
||||||
const [, , platform, type, fileName, filePath] = process.argv;
|
const [, , product, os, arch, unprocessedType, fileName, filePath] = process.argv;
|
||||||
|
// getPlatform needs the unprocessedType
|
||||||
|
const platform = getPlatform(product, os, arch, unprocessedType);
|
||||||
|
const type = getRealType(unprocessedType);
|
||||||
const quality = getEnv('VSCODE_QUALITY');
|
const quality = getEnv('VSCODE_QUALITY');
|
||||||
const commit = getEnv('BUILD_SOURCEVERSION');
|
const commit = getEnv('BUILD_SOURCEVERSION');
|
||||||
|
|
||||||
@@ -98,17 +189,33 @@ async function main(): Promise<void> {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('Uploading blobs to Azure storage...');
|
const mooncakeBlobService = azure.createBlobService(storageAccount, process.env['MOONCAKE_STORAGE_ACCESS_KEY']!, `${storageAccount}.blob.core.chinacloudapi.cn`)
|
||||||
|
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
||||||
|
|
||||||
await uploadBlob(blobService, quality, blobName, filePath, fileName);
|
// mooncake is fussy and far away, this is needed!
|
||||||
|
blobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
||||||
|
mooncakeBlobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
||||||
|
|
||||||
|
console.log('Uploading blobs to Azure storage and Mooncake Azure storage...');
|
||||||
|
|
||||||
|
await retry(() => Promise.all([
|
||||||
|
uploadBlob(blobService, quality, blobName, filePath, fileName),
|
||||||
|
uploadBlob(mooncakeBlobService, quality, blobName, filePath, fileName)
|
||||||
|
]));
|
||||||
|
|
||||||
console.log('Blobs successfully uploaded.');
|
console.log('Blobs successfully uploaded.');
|
||||||
|
|
||||||
|
// TODO: Understand if blobName and blobPath are the same and replace blobPath with blobName if so.
|
||||||
|
const assetUrl = `${process.env['AZURE_CDN_URL']}/${quality}/${blobName}`;
|
||||||
|
const blobPath = url.parse(assetUrl).path;
|
||||||
|
const mooncakeUrl = `${process.env['MOONCAKE_CDN_URL']}${blobPath}`;
|
||||||
|
|
||||||
const asset: Asset = {
|
const asset: Asset = {
|
||||||
platform,
|
platform,
|
||||||
type,
|
type,
|
||||||
url: `${process.env['AZURE_CDN_URL']}/${quality}/${blobName}`,
|
url: assetUrl,
|
||||||
hash: sha1hash,
|
hash: sha1hash,
|
||||||
|
mooncakeUrl,
|
||||||
sha256hash,
|
sha256hash,
|
||||||
size
|
size
|
||||||
};
|
};
|
||||||
@@ -123,6 +230,8 @@ async function main(): Promise<void> {
|
|||||||
const client = new CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT']!, key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
const client = new CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT']!, key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
||||||
const scripts = client.database('builds').container(quality).scripts;
|
const scripts = client.database('builds').container(quality).scripts;
|
||||||
await retry(() => scripts.storedProcedure('createAsset').execute('', [commit, asset, true]));
|
await retry(() => scripts.storedProcedure('createAsset').execute('', [commit, asset, true]));
|
||||||
|
|
||||||
|
console.log(` Done ✔️`);
|
||||||
}
|
}
|
||||||
|
|
||||||
main().then(() => {
|
main().then(() => {
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ async function main() {
|
|||||||
};
|
};
|
||||||
const client = new cosmos_1.CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT'], key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
const client = new cosmos_1.CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT'], key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
||||||
const scripts = client.database('builds').container(quality).scripts;
|
const scripts = client.database('builds').container(quality).scripts;
|
||||||
await (0, retry_1.retry)(() => scripts.storedProcedure('createBuild').execute('', [Object.assign(Object.assign({}, build), { _partitionKey: '' })]));
|
await retry_1.retry(() => scripts.storedProcedure('createBuild').execute('', [Object.assign(Object.assign({}, build), { _partitionKey: '' })]));
|
||||||
}
|
}
|
||||||
main().then(() => {
|
main().then(() => {
|
||||||
console.log('Build successfully created');
|
console.log('Build successfully created');
|
||||||
|
|||||||
@@ -4,12 +4,12 @@ set -e
|
|||||||
cd $BUILD_STAGINGDIRECTORY
|
cd $BUILD_STAGINGDIRECTORY
|
||||||
mkdir extraction
|
mkdir extraction
|
||||||
cd extraction
|
cd extraction
|
||||||
git clone --depth 1 https://github.com/Microsoft/vscode-extension-telemetry.git
|
git clone --depth 1 https://github.com/microsoft/vscode-extension-telemetry.git
|
||||||
git clone --depth 1 https://github.com/Microsoft/vscode-chrome-debug-core.git
|
git clone --depth 1 https://github.com/microsoft/vscode-chrome-debug-core.git
|
||||||
git clone --depth 1 https://github.com/Microsoft/vscode-node-debug2.git
|
git clone --depth 1 https://github.com/microsoft/vscode-node-debug2.git
|
||||||
git clone --depth 1 https://github.com/Microsoft/vscode-node-debug.git
|
git clone --depth 1 https://github.com/microsoft/vscode-node-debug.git
|
||||||
git clone --depth 1 https://github.com/Microsoft/vscode-html-languageservice.git
|
git clone --depth 1 https://github.com/microsoft/vscode-html-languageservice.git
|
||||||
git clone --depth 1 https://github.com/Microsoft/vscode-json-languageservice.git
|
git clone --depth 1 https://github.com/microsoft/vscode-json-languageservice.git
|
||||||
node $BUILD_SOURCESDIRECTORY/node_modules/.bin/vscode-telemetry-extractor --sourceDir $BUILD_SOURCESDIRECTORY --excludedDir $BUILD_SOURCESDIRECTORY/extensions --outputDir . --applyEndpoints
|
node $BUILD_SOURCESDIRECTORY/node_modules/.bin/vscode-telemetry-extractor --sourceDir $BUILD_SOURCESDIRECTORY --excludedDir $BUILD_SOURCESDIRECTORY/extensions --outputDir . --applyEndpoints
|
||||||
node $BUILD_SOURCESDIRECTORY/node_modules/.bin/vscode-telemetry-extractor --config $BUILD_SOURCESDIRECTORY/build/azure-pipelines/common/telemetry-config.json -o .
|
node $BUILD_SOURCESDIRECTORY/node_modules/.bin/vscode-telemetry-extractor --config $BUILD_SOURCESDIRECTORY/build/azure-pipelines/common/telemetry-config.json -o .
|
||||||
mkdir -p $BUILD_SOURCESDIRECTORY/.build/telemetry
|
mkdir -p $BUILD_SOURCESDIRECTORY/.build/telemetry
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ async function publish(commit, files) {
|
|||||||
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
||||||
await assertContainer(blobService, commit);
|
await assertContainer(blobService, commit);
|
||||||
for (const file of files) {
|
for (const file of files) {
|
||||||
const blobName = (0, path_1.basename)(file);
|
const blobName = path_1.basename(file);
|
||||||
const blobExists = await doesBlobExist(blobService, commit, blobName);
|
const blobExists = await doesBlobExist(blobService, commit, blobName);
|
||||||
if (blobExists) {
|
if (blobExists) {
|
||||||
console.log(`Blob ${commit}, ${blobName} already exists, not publishing again.`);
|
console.log(`Blob ${commit}, ${blobName} already exists, not publishing again.`);
|
||||||
@@ -58,7 +58,7 @@ function main() {
|
|||||||
}
|
}
|
||||||
const opts = minimist(process.argv.slice(2));
|
const opts = minimist(process.argv.slice(2));
|
||||||
const [directory] = opts._;
|
const [directory] = opts._;
|
||||||
const files = fileNames.map(fileName => (0, path_1.join)(directory, fileName));
|
const files = fileNames.map(fileName => path_1.join(directory, fileName));
|
||||||
publish(commit, files).catch(err => {
|
publish(commit, files).catch(err => {
|
||||||
console.error(err);
|
console.error(err);
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ async function main() {
|
|||||||
}
|
}
|
||||||
console.log(`Releasing build ${commit}...`);
|
console.log(`Releasing build ${commit}...`);
|
||||||
const scripts = client.database('builds').container(quality).scripts;
|
const scripts = client.database('builds').container(quality).scripts;
|
||||||
await (0, retry_1.retry)(() => scripts.storedProcedure('releaseBuild').execute('', [commit]));
|
await retry_1.retry(() => scripts.storedProcedure('releaseBuild').execute('', [commit]));
|
||||||
}
|
}
|
||||||
main().then(() => {
|
main().then(() => {
|
||||||
console.log('Build successfully released');
|
console.log('Build successfully released');
|
||||||
|
|||||||
@@ -1,87 +0,0 @@
|
|||||||
/*---------------------------------------------------------------------------------------------
|
|
||||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
||||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
||||||
*--------------------------------------------------------------------------------------------*/
|
|
||||||
'use strict';
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const url = require("url");
|
|
||||||
const azure = require("azure-storage");
|
|
||||||
const mime = require("mime");
|
|
||||||
const cosmos_1 = require("@azure/cosmos");
|
|
||||||
const retry_1 = require("./retry");
|
|
||||||
function log(...args) {
|
|
||||||
console.log(...[`[${new Date().toISOString()}]`, ...args]);
|
|
||||||
}
|
|
||||||
function error(...args) {
|
|
||||||
console.error(...[`[${new Date().toISOString()}]`, ...args]);
|
|
||||||
}
|
|
||||||
if (process.argv.length < 3) {
|
|
||||||
error('Usage: node sync-mooncake.js <quality>');
|
|
||||||
process.exit(-1);
|
|
||||||
}
|
|
||||||
async function sync(commit, quality) {
|
|
||||||
log(`Synchronizing Mooncake assets for ${quality}, ${commit}...`);
|
|
||||||
const client = new cosmos_1.CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT'], key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
|
||||||
const container = client.database('builds').container(quality);
|
|
||||||
const query = `SELECT TOP 1 * FROM c WHERE c.id = "${commit}"`;
|
|
||||||
const res = await container.items.query(query, {}).fetchAll();
|
|
||||||
if (res.resources.length !== 1) {
|
|
||||||
throw new Error(`No builds found for ${commit}`);
|
|
||||||
}
|
|
||||||
const build = res.resources[0];
|
|
||||||
log(`Found build for ${commit}, with ${build.assets.length} assets`);
|
|
||||||
const storageAccount = process.env['AZURE_STORAGE_ACCOUNT_2'];
|
|
||||||
const blobService = azure.createBlobService(storageAccount, process.env['AZURE_STORAGE_ACCESS_KEY_2'])
|
|
||||||
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
|
||||||
const mooncakeBlobService = azure.createBlobService(storageAccount, process.env['MOONCAKE_STORAGE_ACCESS_KEY'], `${storageAccount}.blob.core.chinacloudapi.cn`)
|
|
||||||
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
|
||||||
// mooncake is fussy and far away, this is needed!
|
|
||||||
blobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
|
||||||
mooncakeBlobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
|
||||||
for (const asset of build.assets) {
|
|
||||||
try {
|
|
||||||
const blobPath = url.parse(asset.url).path;
|
|
||||||
if (!blobPath) {
|
|
||||||
throw new Error(`Failed to parse URL: ${asset.url}`);
|
|
||||||
}
|
|
||||||
const blobName = blobPath.replace(/^\/\w+\//, '');
|
|
||||||
log(`Found ${blobName}`);
|
|
||||||
if (asset.mooncakeUrl) {
|
|
||||||
log(` Already in Mooncake ✔️`);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
const readStream = blobService.createReadStream(quality, blobName, undefined);
|
|
||||||
const blobOptions = {
|
|
||||||
contentSettings: {
|
|
||||||
contentType: mime.lookup(blobPath),
|
|
||||||
cacheControl: 'max-age=31536000, public'
|
|
||||||
}
|
|
||||||
};
|
|
||||||
const writeStream = mooncakeBlobService.createWriteStreamToBlockBlob(quality, blobName, blobOptions, undefined);
|
|
||||||
log(` Uploading to Mooncake...`);
|
|
||||||
await new Promise((c, e) => readStream.pipe(writeStream).on('finish', c).on('error', e));
|
|
||||||
log(` Updating build in DB...`);
|
|
||||||
const mooncakeUrl = `${process.env['MOONCAKE_CDN_URL']}${blobPath}`;
|
|
||||||
await (0, retry_1.retry)(() => container.scripts.storedProcedure('setAssetMooncakeUrl')
|
|
||||||
.execute('', [commit, asset.platform, asset.type, mooncakeUrl]));
|
|
||||||
log(` Done ✔️`);
|
|
||||||
}
|
|
||||||
catch (err) {
|
|
||||||
error(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
log(`All done ✔️`);
|
|
||||||
}
|
|
||||||
function main() {
|
|
||||||
const commit = process.env['BUILD_SOURCEVERSION'];
|
|
||||||
if (!commit) {
|
|
||||||
error('Skipping publish due to missing BUILD_SOURCEVERSION');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const quality = process.argv[2];
|
|
||||||
sync(commit, quality).catch(err => {
|
|
||||||
error(err);
|
|
||||||
process.exit(1);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
main();
|
|
||||||
@@ -1,131 +0,0 @@
|
|||||||
/*---------------------------------------------------------------------------------------------
|
|
||||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
||||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
||||||
*--------------------------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
import * as url from 'url';
|
|
||||||
import * as azure from 'azure-storage';
|
|
||||||
import * as mime from 'mime';
|
|
||||||
import { CosmosClient } from '@azure/cosmos';
|
|
||||||
import { retry } from './retry';
|
|
||||||
|
|
||||||
function log(...args: any[]) {
|
|
||||||
console.log(...[`[${new Date().toISOString()}]`, ...args]);
|
|
||||||
}
|
|
||||||
|
|
||||||
function error(...args: any[]) {
|
|
||||||
console.error(...[`[${new Date().toISOString()}]`, ...args]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (process.argv.length < 3) {
|
|
||||||
error('Usage: node sync-mooncake.js <quality>');
|
|
||||||
process.exit(-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Build {
|
|
||||||
assets: Asset[];
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Asset {
|
|
||||||
platform: string;
|
|
||||||
type: string;
|
|
||||||
url: string;
|
|
||||||
mooncakeUrl: string;
|
|
||||||
hash: string;
|
|
||||||
sha256hash: string;
|
|
||||||
size: number;
|
|
||||||
supportsFastUpdate?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
async function sync(commit: string, quality: string): Promise<void> {
|
|
||||||
log(`Synchronizing Mooncake assets for ${quality}, ${commit}...`);
|
|
||||||
|
|
||||||
const client = new CosmosClient({ endpoint: process.env['AZURE_DOCUMENTDB_ENDPOINT']!, key: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
|
||||||
const container = client.database('builds').container(quality);
|
|
||||||
|
|
||||||
const query = `SELECT TOP 1 * FROM c WHERE c.id = "${commit}"`;
|
|
||||||
const res = await container.items.query<Build>(query, {}).fetchAll();
|
|
||||||
|
|
||||||
if (res.resources.length !== 1) {
|
|
||||||
throw new Error(`No builds found for ${commit}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
const build = res.resources[0];
|
|
||||||
|
|
||||||
log(`Found build for ${commit}, with ${build.assets.length} assets`);
|
|
||||||
|
|
||||||
const storageAccount = process.env['AZURE_STORAGE_ACCOUNT_2']!;
|
|
||||||
|
|
||||||
const blobService = azure.createBlobService(storageAccount, process.env['AZURE_STORAGE_ACCESS_KEY_2']!)
|
|
||||||
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
|
||||||
|
|
||||||
const mooncakeBlobService = azure.createBlobService(storageAccount, process.env['MOONCAKE_STORAGE_ACCESS_KEY']!, `${storageAccount}.blob.core.chinacloudapi.cn`)
|
|
||||||
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
|
||||||
|
|
||||||
// mooncake is fussy and far away, this is needed!
|
|
||||||
blobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
|
||||||
mooncakeBlobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
|
||||||
|
|
||||||
for (const asset of build.assets) {
|
|
||||||
try {
|
|
||||||
const blobPath = url.parse(asset.url).path;
|
|
||||||
|
|
||||||
if (!blobPath) {
|
|
||||||
throw new Error(`Failed to parse URL: ${asset.url}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
const blobName = blobPath.replace(/^\/\w+\//, '');
|
|
||||||
|
|
||||||
log(`Found ${blobName}`);
|
|
||||||
|
|
||||||
if (asset.mooncakeUrl) {
|
|
||||||
log(` Already in Mooncake ✔️`);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
const readStream = blobService.createReadStream(quality, blobName, undefined!);
|
|
||||||
const blobOptions: azure.BlobService.CreateBlockBlobRequestOptions = {
|
|
||||||
contentSettings: {
|
|
||||||
contentType: mime.lookup(blobPath),
|
|
||||||
cacheControl: 'max-age=31536000, public'
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const writeStream = mooncakeBlobService.createWriteStreamToBlockBlob(quality, blobName, blobOptions, undefined);
|
|
||||||
|
|
||||||
log(` Uploading to Mooncake...`);
|
|
||||||
await new Promise((c, e) => readStream.pipe(writeStream).on('finish', c).on('error', e));
|
|
||||||
|
|
||||||
log(` Updating build in DB...`);
|
|
||||||
const mooncakeUrl = `${process.env['MOONCAKE_CDN_URL']}${blobPath}`;
|
|
||||||
await retry(() => container.scripts.storedProcedure('setAssetMooncakeUrl')
|
|
||||||
.execute('', [commit, asset.platform, asset.type, mooncakeUrl]));
|
|
||||||
|
|
||||||
log(` Done ✔️`);
|
|
||||||
} catch (err) {
|
|
||||||
error(err);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
log(`All done ✔️`);
|
|
||||||
}
|
|
||||||
|
|
||||||
function main(): void {
|
|
||||||
const commit = process.env['BUILD_SOURCEVERSION'];
|
|
||||||
|
|
||||||
if (!commit) {
|
|
||||||
error('Skipping publish due to missing BUILD_SOURCEVERSION');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const quality = process.argv[2];
|
|
||||||
|
|
||||||
sync(commit, quality).catch(err => {
|
|
||||||
error(err);
|
|
||||||
process.exit(1);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
main();
|
|
||||||
@@ -35,13 +35,13 @@ steps:
|
|||||||
displayName: Restore modules for just build folder and compile it
|
displayName: Restore modules for just build folder and compile it
|
||||||
|
|
||||||
- download: current
|
- download: current
|
||||||
artifact: vscode-darwin-$(VSCODE_ARCH)
|
artifact: unsigned_vscode_client_darwin_$(VSCODE_ARCH)_archive
|
||||||
displayName: Download $(VSCODE_ARCH) artifact
|
displayName: Download $(VSCODE_ARCH) artifact
|
||||||
|
|
||||||
- script: |
|
- script: |
|
||||||
set -e
|
set -e
|
||||||
unzip $(Pipeline.Workspace)/vscode-darwin-$(VSCODE_ARCH)/VSCode-darwin-$(VSCODE_ARCH).zip -d $(agent.builddirectory)/VSCode-darwin-$(VSCODE_ARCH)
|
unzip $(Pipeline.Workspace)/unsigned_vscode_client_darwin_$(VSCODE_ARCH)_archive/VSCode-darwin-$(VSCODE_ARCH).zip -d $(agent.builddirectory)/VSCode-darwin-$(VSCODE_ARCH)
|
||||||
mv $(Pipeline.Workspace)/vscode-darwin-$(VSCODE_ARCH)/VSCode-darwin-$(VSCODE_ARCH).zip $(agent.builddirectory)/VSCode-darwin-$(VSCODE_ARCH).zip
|
mv $(Pipeline.Workspace)/unsigned_vscode_client_darwin_$(VSCODE_ARCH)_archive/VSCode-darwin-$(VSCODE_ARCH).zip $(agent.builddirectory)/VSCode-darwin-$(VSCODE_ARCH).zip
|
||||||
displayName: Unzip & move
|
displayName: Unzip & move
|
||||||
|
|
||||||
- task: SFP.build-tasks.custom-build-task-1.EsrpCodeSigning@1
|
- task: SFP.build-tasks.custom-build-task-1.EsrpCodeSigning@1
|
||||||
@@ -108,22 +108,18 @@ steps:
|
|||||||
condition: and(succeeded(), ne(variables['VSCODE_ARCH'], 'arm64'))
|
condition: and(succeeded(), ne(variables['VSCODE_ARCH'], 'arm64'))
|
||||||
|
|
||||||
- script: |
|
- script: |
|
||||||
set -e
|
|
||||||
|
|
||||||
# For legacy purposes, arch for x64 is just 'darwin'
|
# For legacy purposes, arch for x64 is just 'darwin'
|
||||||
case $VSCODE_ARCH in
|
case $VSCODE_ARCH in
|
||||||
x64) ASSET_ID="darwin" ;;
|
x64) ASSET_ID="darwin" ;;
|
||||||
arm64) ASSET_ID="darwin-arm64" ;;
|
arm64) ASSET_ID="darwin-arm64" ;;
|
||||||
universal) ASSET_ID="darwin-universal" ;;
|
universal) ASSET_ID="darwin-universal" ;;
|
||||||
esac
|
esac
|
||||||
|
echo "##vso[task.setvariable variable=ASSET_ID]$ASSET_ID"
|
||||||
|
displayName: Set asset id variable
|
||||||
|
|
||||||
VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)" \
|
- script: mv $(agent.builddirectory)/VSCode-darwin-x64.zip $(agent.builddirectory)/VSCode-darwin.zip
|
||||||
AZURE_DOCUMENTDB_MASTERKEY="$(builds-docdb-key-readwrite)" \
|
displayName: Rename x64 build to it's legacy name
|
||||||
AZURE_STORAGE_ACCESS_KEY="$(ticino-storage-key)" \
|
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'))
|
||||||
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
|
||||||
node build/azure-pipelines/common/createAsset.js \
|
- publish: $(Agent.BuildDirectory)/VSCode-$(ASSET_ID).zip
|
||||||
"$ASSET_ID" \
|
artifact: vscode_client_darwin_$(VSCODE_ARCH)_archive
|
||||||
archive \
|
|
||||||
"VSCode-$ASSET_ID.zip" \
|
|
||||||
../VSCode-darwin-$(VSCODE_ARCH).zip
|
|
||||||
displayName: Publish Clients
|
|
||||||
|
|||||||
@@ -138,19 +138,19 @@ steps:
|
|||||||
condition: and(succeeded(), ne(variables['VSCODE_ARCH'], 'universal'), eq(variables['VSCODE_STEP_ON_IT'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_ARCH'], 'universal'), eq(variables['VSCODE_STEP_ON_IT'], 'false'))
|
||||||
|
|
||||||
- download: current
|
- download: current
|
||||||
artifact: vscode-darwin-x64
|
artifact: unsigned_vscode_client_darwin_x64_archive
|
||||||
displayName: Download x64 artifact
|
displayName: Download x64 artifact
|
||||||
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'universal'))
|
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'universal'))
|
||||||
|
|
||||||
- download: current
|
- download: current
|
||||||
artifact: vscode-darwin-arm64
|
artifact: unsigned_vscode_client_darwin_arm64_archive
|
||||||
displayName: Download arm64 artifact
|
displayName: Download arm64 artifact
|
||||||
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'universal'))
|
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'universal'))
|
||||||
|
|
||||||
- script: |
|
- script: |
|
||||||
set -e
|
set -e
|
||||||
cp $(Pipeline.Workspace)/vscode-darwin-x64/VSCode-darwin-x64.zip $(agent.builddirectory)/VSCode-darwin-x64.zip
|
cp $(Pipeline.Workspace)/unsigned_vscode_client_darwin_x64_archive/VSCode-darwin-x64.zip $(agent.builddirectory)/VSCode-darwin-x64.zip
|
||||||
cp $(Pipeline.Workspace)/vscode-darwin-arm64/VSCode-darwin-arm64.zip $(agent.builddirectory)/VSCode-darwin-arm64.zip
|
cp $(Pipeline.Workspace)/unsigned_vscode_client_darwin_arm64_archive/VSCode-darwin-arm64.zip $(agent.builddirectory)/VSCode-darwin-arm64.zip
|
||||||
unzip $(agent.builddirectory)/VSCode-darwin-x64.zip -d $(agent.builddirectory)/VSCode-darwin-x64
|
unzip $(agent.builddirectory)/VSCode-darwin-x64.zip -d $(agent.builddirectory)/VSCode-darwin-x64
|
||||||
unzip $(agent.builddirectory)/VSCode-darwin-arm64.zip -d $(agent.builddirectory)/VSCode-darwin-arm64
|
unzip $(agent.builddirectory)/VSCode-darwin-arm64.zip -d $(agent.builddirectory)/VSCode-darwin-arm64
|
||||||
DEBUG=* node build/darwin/create-universal-app.js
|
DEBUG=* node build/darwin/create-universal-app.js
|
||||||
@@ -280,26 +280,27 @@ steps:
|
|||||||
|
|
||||||
- script: |
|
- script: |
|
||||||
set -e
|
set -e
|
||||||
VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)" \
|
|
||||||
AZURE_DOCUMENTDB_MASTERKEY="$(builds-docdb-key-readwrite)" \
|
# package Remote Extension Host
|
||||||
AZURE_STORAGE_ACCESS_KEY="$(ticino-storage-key)" \
|
pushd .. && mv vscode-reh-darwin vscode-server-darwin && zip -Xry vscode-server-darwin.zip vscode-server-darwin && popd
|
||||||
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
|
||||||
VSCODE_ARCH="$(VSCODE_ARCH)" ./build/azure-pipelines/darwin/publish-server.sh
|
# package Remote Extension Host (Web)
|
||||||
displayName: Publish Servers
|
pushd .. && mv vscode-reh-web-darwin vscode-server-darwin-web && zip -Xry vscode-server-darwin-web.zip vscode-server-darwin-web && popd
|
||||||
|
displayName: Prepare to publish servers
|
||||||
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/VSCode-darwin-$(VSCODE_ARCH).zip
|
- publish: $(Agent.BuildDirectory)/VSCode-darwin-$(VSCODE_ARCH).zip
|
||||||
artifact: vscode-darwin-$(VSCODE_ARCH)
|
artifact: unsigned_vscode_client_darwin_$(VSCODE_ARCH)_archive
|
||||||
displayName: Publish client archive
|
displayName: Publish client archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/vscode-server-darwin.zip
|
- publish: $(Agent.BuildDirectory)/vscode-server-darwin.zip
|
||||||
artifact: vscode-server-darwin-$(VSCODE_ARCH)
|
artifact: vscode_server_darwin_$(VSCODE_ARCH)_archive-unsigned
|
||||||
displayName: Publish server archive
|
displayName: Publish server archive
|
||||||
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/vscode-server-darwin-web.zip
|
- publish: $(Agent.BuildDirectory)/vscode-server-darwin-web.zip
|
||||||
artifact: vscode-server-darwin-$(VSCODE_ARCH)-web
|
artifact: vscode_web_darwin_$(VSCODE_ARCH)_archive-unsigned
|
||||||
displayName: Publish web server archive
|
displayName: Publish web server archive
|
||||||
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
@@ -308,5 +309,5 @@ steps:
|
|||||||
VSCODE_ARCH="$(VSCODE_ARCH)" \
|
VSCODE_ARCH="$(VSCODE_ARCH)" \
|
||||||
yarn gulp upload-vscode-configuration
|
yarn gulp upload-vscode-configuration
|
||||||
displayName: Upload configuration (for Bing settings search)
|
displayName: Upload configuration (for Bing settings search)
|
||||||
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'))
|
condition: and(succeeded(), eq(variables['VSCODE_ARCH'], 'x64'), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
continueOnError: true
|
continueOnError: true
|
||||||
|
|||||||
@@ -1,14 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
|
|
||||||
if [ "$VSCODE_ARCH" == "x64" ]; then
|
|
||||||
# package Remote Extension Host
|
|
||||||
pushd .. && mv vscode-reh-darwin vscode-server-darwin && zip -Xry vscode-server-darwin.zip vscode-server-darwin && popd
|
|
||||||
|
|
||||||
# publish Remote Extension Host
|
|
||||||
node build/azure-pipelines/common/createAsset.js \
|
|
||||||
server-darwin \
|
|
||||||
archive-unsigned \
|
|
||||||
"vscode-server-darwin.zip" \
|
|
||||||
../vscode-server-darwin.zip
|
|
||||||
fi
|
|
||||||
@@ -1,28 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
REPO="$(pwd)"
|
|
||||||
ROOT="$REPO/.."
|
|
||||||
|
|
||||||
PLATFORM_LINUX="linux-alpine"
|
|
||||||
|
|
||||||
# Publish Remote Extension Host
|
|
||||||
LEGACY_SERVER_BUILD_NAME="vscode-reh-$PLATFORM_LINUX"
|
|
||||||
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX"
|
|
||||||
SERVER_TARBALL_FILENAME="vscode-server-$PLATFORM_LINUX.tar.gz"
|
|
||||||
SERVER_TARBALL_PATH="$ROOT/$SERVER_TARBALL_FILENAME"
|
|
||||||
|
|
||||||
rm -rf $ROOT/vscode-server-*.tar.*
|
|
||||||
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js "server-$PLATFORM_LINUX" archive-unsigned "$SERVER_TARBALL_FILENAME" "$SERVER_TARBALL_PATH"
|
|
||||||
|
|
||||||
# Publish Remote Extension Host (Web)
|
|
||||||
LEGACY_SERVER_BUILD_NAME="vscode-reh-web-$PLATFORM_LINUX"
|
|
||||||
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX-web"
|
|
||||||
SERVER_TARBALL_FILENAME="vscode-server-$PLATFORM_LINUX-web.tar.gz"
|
|
||||||
SERVER_TARBALL_PATH="$ROOT/$SERVER_TARBALL_FILENAME"
|
|
||||||
|
|
||||||
rm -rf $ROOT/vscode-server-*-web.tar.*
|
|
||||||
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js "server-$PLATFORM_LINUX-web" archive-unsigned "$SERVER_TARBALL_FILENAME" "$SERVER_TARBALL_PATH"
|
|
||||||
@@ -13,8 +13,6 @@ TARBALL_PATH="$ROOT/$TARBALL_FILENAME"
|
|||||||
rm -rf $ROOT/code-*.tar.*
|
rm -rf $ROOT/code-*.tar.*
|
||||||
(cd $ROOT && tar -czf $TARBALL_PATH $BUILDNAME)
|
(cd $ROOT && tar -czf $TARBALL_PATH $BUILDNAME)
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js "$PLATFORM_LINUX" archive-unsigned "$TARBALL_FILENAME" "$TARBALL_PATH"
|
|
||||||
|
|
||||||
# Publish Remote Extension Host
|
# Publish Remote Extension Host
|
||||||
LEGACY_SERVER_BUILD_NAME="vscode-reh-$PLATFORM_LINUX"
|
LEGACY_SERVER_BUILD_NAME="vscode-reh-$PLATFORM_LINUX"
|
||||||
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX"
|
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX"
|
||||||
@@ -24,8 +22,6 @@ SERVER_TARBALL_PATH="$ROOT/$SERVER_TARBALL_FILENAME"
|
|||||||
rm -rf $ROOT/vscode-server-*.tar.*
|
rm -rf $ROOT/vscode-server-*.tar.*
|
||||||
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js "server-$PLATFORM_LINUX" archive-unsigned "$SERVER_TARBALL_FILENAME" "$SERVER_TARBALL_PATH"
|
|
||||||
|
|
||||||
# Publish Remote Extension Host (Web)
|
# Publish Remote Extension Host (Web)
|
||||||
LEGACY_SERVER_BUILD_NAME="vscode-reh-web-$PLATFORM_LINUX"
|
LEGACY_SERVER_BUILD_NAME="vscode-reh-web-$PLATFORM_LINUX"
|
||||||
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX-web"
|
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX-web"
|
||||||
@@ -35,8 +31,6 @@ SERVER_TARBALL_PATH="$ROOT/$SERVER_TARBALL_FILENAME"
|
|||||||
rm -rf $ROOT/vscode-server-*-web.tar.*
|
rm -rf $ROOT/vscode-server-*-web.tar.*
|
||||||
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js "server-$PLATFORM_LINUX-web" archive-unsigned "$SERVER_TARBALL_FILENAME" "$SERVER_TARBALL_PATH"
|
|
||||||
|
|
||||||
# Publish DEB
|
# Publish DEB
|
||||||
case $VSCODE_ARCH in
|
case $VSCODE_ARCH in
|
||||||
x64) DEB_ARCH="amd64" ;;
|
x64) DEB_ARCH="amd64" ;;
|
||||||
@@ -47,8 +41,6 @@ PLATFORM_DEB="linux-deb-$VSCODE_ARCH"
|
|||||||
DEB_FILENAME="$(ls $REPO/.build/linux/deb/$DEB_ARCH/deb/)"
|
DEB_FILENAME="$(ls $REPO/.build/linux/deb/$DEB_ARCH/deb/)"
|
||||||
DEB_PATH="$REPO/.build/linux/deb/$DEB_ARCH/deb/$DEB_FILENAME"
|
DEB_PATH="$REPO/.build/linux/deb/$DEB_ARCH/deb/$DEB_FILENAME"
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js "$PLATFORM_DEB" package "$DEB_FILENAME" "$DEB_PATH"
|
|
||||||
|
|
||||||
# Publish RPM
|
# Publish RPM
|
||||||
case $VSCODE_ARCH in
|
case $VSCODE_ARCH in
|
||||||
x64) RPM_ARCH="x86_64" ;;
|
x64) RPM_ARCH="x86_64" ;;
|
||||||
@@ -61,8 +53,6 @@ PLATFORM_RPM="linux-rpm-$VSCODE_ARCH"
|
|||||||
RPM_FILENAME="$(ls $REPO/.build/linux/rpm/$RPM_ARCH/ | grep .rpm)"
|
RPM_FILENAME="$(ls $REPO/.build/linux/rpm/$RPM_ARCH/ | grep .rpm)"
|
||||||
RPM_PATH="$REPO/.build/linux/rpm/$RPM_ARCH/$RPM_FILENAME"
|
RPM_PATH="$REPO/.build/linux/rpm/$RPM_ARCH/$RPM_FILENAME"
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js "$PLATFORM_RPM" package "$RPM_FILENAME" "$RPM_PATH"
|
|
||||||
|
|
||||||
# Publish Snap
|
# Publish Snap
|
||||||
# Pack snap tarball artifact, in order to preserve file perms
|
# Pack snap tarball artifact, in order to preserve file perms
|
||||||
mkdir -p $REPO/.build/linux/snap-tarball
|
mkdir -p $REPO/.build/linux/snap-tarball
|
||||||
@@ -73,3 +63,4 @@ rm -rf $SNAP_TARBALL_PATH
|
|||||||
# Export DEB_PATH, RPM_PATH
|
# Export DEB_PATH, RPM_PATH
|
||||||
echo "##vso[task.setvariable variable=DEB_PATH]$DEB_PATH"
|
echo "##vso[task.setvariable variable=DEB_PATH]$DEB_PATH"
|
||||||
echo "##vso[task.setvariable variable=RPM_PATH]$RPM_PATH"
|
echo "##vso[task.setvariable variable=RPM_PATH]$RPM_PATH"
|
||||||
|
echo "##vso[task.setvariable variable=TARBALL_PATH]$TARBALL_PATH"
|
||||||
@@ -117,19 +117,37 @@ steps:
|
|||||||
|
|
||||||
- script: |
|
- script: |
|
||||||
set -e
|
set -e
|
||||||
AZURE_DOCUMENTDB_MASTERKEY="$(builds-docdb-key-readwrite)" \
|
REPO="$(pwd)"
|
||||||
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
ROOT="$REPO/.."
|
||||||
VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)" \
|
|
||||||
./build/azure-pipelines/linux/alpine/publish.sh
|
PLATFORM_LINUX="linux-alpine"
|
||||||
displayName: Publish
|
|
||||||
|
# Publish Remote Extension Host
|
||||||
|
LEGACY_SERVER_BUILD_NAME="vscode-reh-$PLATFORM_LINUX"
|
||||||
|
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX"
|
||||||
|
SERVER_TARBALL_FILENAME="vscode-server-$PLATFORM_LINUX.tar.gz"
|
||||||
|
SERVER_TARBALL_PATH="$ROOT/$SERVER_TARBALL_FILENAME"
|
||||||
|
|
||||||
|
rm -rf $ROOT/vscode-server-*.tar.*
|
||||||
|
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
||||||
|
|
||||||
|
# Publish Remote Extension Host (Web)
|
||||||
|
LEGACY_SERVER_BUILD_NAME="vscode-reh-web-$PLATFORM_LINUX"
|
||||||
|
SERVER_BUILD_NAME="vscode-server-$PLATFORM_LINUX-web"
|
||||||
|
SERVER_TARBALL_FILENAME="vscode-server-$PLATFORM_LINUX-web.tar.gz"
|
||||||
|
SERVER_TARBALL_PATH="$ROOT/$SERVER_TARBALL_FILENAME"
|
||||||
|
|
||||||
|
rm -rf $ROOT/vscode-server-*-web.tar.*
|
||||||
|
(cd $ROOT && mv $LEGACY_SERVER_BUILD_NAME $SERVER_BUILD_NAME && tar --owner=0 --group=0 -czf $SERVER_TARBALL_PATH $SERVER_BUILD_NAME)
|
||||||
|
displayName: Prepare for publish
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/vscode-server-linux-alpine.tar.gz
|
- publish: $(Agent.BuildDirectory)/vscode-server-linux-alpine.tar.gz
|
||||||
artifact: vscode-server-linux-alpine
|
artifact: vscode_server_linux_alpine_archive-unsigned
|
||||||
displayName: Publish server archive
|
displayName: Publish server archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/vscode-server-linux-alpine-web.tar.gz
|
- publish: $(Agent.BuildDirectory)/vscode-server-linux-alpine-web.tar.gz
|
||||||
artifact: vscode-server-linux-alpine-web
|
artifact: vscode_web_linux_alpine_archive-unsigned
|
||||||
displayName: Publish web server archive
|
displayName: Publish web server archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|||||||
@@ -245,27 +245,32 @@ steps:
|
|||||||
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
||||||
VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)" \
|
VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)" \
|
||||||
VSCODE_ARCH="$(VSCODE_ARCH)" \
|
VSCODE_ARCH="$(VSCODE_ARCH)" \
|
||||||
./build/azure-pipelines/linux/publish.sh
|
./build/azure-pipelines/linux/prepare-publish.sh
|
||||||
displayName: Publish
|
displayName: Prepare for Publish
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(DEB_PATH)
|
- publish: $(DEB_PATH)
|
||||||
artifact: vscode-linux-deb-$(VSCODE_ARCH)
|
artifact: vscode_client_linux_$(VSCODE_ARCH)_deb-package
|
||||||
displayName: Publish deb package
|
displayName: Publish deb package
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(RPM_PATH)
|
- publish: $(RPM_PATH)
|
||||||
artifact: vscode-linux-rpm-$(VSCODE_ARCH)
|
artifact: vscode_client_linux_$(VSCODE_ARCH)_rpm-package
|
||||||
displayName: Publish rpm package
|
displayName: Publish rpm package
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
|
- publish: $(TARBALL_PATH)
|
||||||
|
artifact: vscode_client_linux_$(VSCODE_ARCH)_archive-unsigned
|
||||||
|
displayName: Publish client archive
|
||||||
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/vscode-server-linux-$(VSCODE_ARCH).tar.gz
|
- publish: $(Agent.BuildDirectory)/vscode-server-linux-$(VSCODE_ARCH).tar.gz
|
||||||
artifact: vscode-server-linux-$(VSCODE_ARCH)
|
artifact: vscode_server_linux_$(VSCODE_ARCH)_archive-unsigned
|
||||||
displayName: Publish server archive
|
displayName: Publish server archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/vscode-server-linux-$(VSCODE_ARCH)-web.tar.gz
|
- publish: $(Agent.BuildDirectory)/vscode-server-linux-$(VSCODE_ARCH)-web.tar.gz
|
||||||
artifact: vscode-server-linux-$(VSCODE_ARCH)-web
|
artifact: vscode_web_linux_$(VSCODE_ARCH)_archive-unsigned
|
||||||
displayName: Publish web server archive
|
displayName: Publish web server archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
|
|||||||
@@ -50,15 +50,11 @@ steps:
|
|||||||
esac
|
esac
|
||||||
(cd $SNAP_ROOT/code-* && sudo --preserve-env snapcraft prime $SNAPCRAFT_TARGET_ARGS && snap pack prime --compression=lzo --filename="$SNAP_PATH")
|
(cd $SNAP_ROOT/code-* && sudo --preserve-env snapcraft prime $SNAPCRAFT_TARGET_ARGS && snap pack prime --compression=lzo --filename="$SNAP_PATH")
|
||||||
|
|
||||||
# Publish snap package
|
|
||||||
AZURE_DOCUMENTDB_MASTERKEY="$(builds-docdb-key-readwrite)" \
|
|
||||||
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
|
||||||
node build/azure-pipelines/common/createAsset.js "linux-snap-$(VSCODE_ARCH)" package "$SNAP_FILENAME" "$SNAP_PATH"
|
|
||||||
|
|
||||||
# Export SNAP_PATH
|
# Export SNAP_PATH
|
||||||
echo "##vso[task.setvariable variable=SNAP_PATH]$SNAP_PATH"
|
echo "##vso[task.setvariable variable=SNAP_PATH]$SNAP_PATH"
|
||||||
|
displayName: Prepare for publish
|
||||||
|
|
||||||
- publish: $(SNAP_PATH)
|
- publish: $(SNAP_PATH)
|
||||||
artifact: vscode-linux-snap-$(VSCODE_ARCH)
|
artifact: vscode_client_linux_$(VSCODE_ARCH)_snap
|
||||||
displayName: Publish snap package
|
displayName: Publish snap package
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|||||||
@@ -86,6 +86,8 @@ variables:
|
|||||||
value: ${{ eq(parameters.ENABLE_TERRAPIN, true) }}
|
value: ${{ eq(parameters.ENABLE_TERRAPIN, true) }}
|
||||||
- name: VSCODE_QUALITY
|
- name: VSCODE_QUALITY
|
||||||
value: ${{ parameters.VSCODE_QUALITY }}
|
value: ${{ parameters.VSCODE_QUALITY }}
|
||||||
|
- name: VSCODE_RELEASE
|
||||||
|
value: ${{ parameters.VSCODE_RELEASE }}
|
||||||
- name: VSCODE_BUILD_STAGE_WINDOWS
|
- name: VSCODE_BUILD_STAGE_WINDOWS
|
||||||
value: ${{ or(eq(parameters.VSCODE_BUILD_WIN32, true), eq(parameters.VSCODE_BUILD_WIN32_32BIT, true), eq(parameters.VSCODE_BUILD_WIN32_ARM64, true)) }}
|
value: ${{ or(eq(parameters.VSCODE_BUILD_WIN32, true), eq(parameters.VSCODE_BUILD_WIN32_32BIT, true), eq(parameters.VSCODE_BUILD_WIN32_ARM64, true)) }}
|
||||||
- name: VSCODE_BUILD_STAGE_LINUX
|
- name: VSCODE_BUILD_STAGE_LINUX
|
||||||
@@ -301,37 +303,30 @@ stages:
|
|||||||
steps:
|
steps:
|
||||||
- template: darwin/product-build-darwin-sign.yml
|
- template: darwin/product-build-darwin-sign.yml
|
||||||
|
|
||||||
- ${{ if and(eq(variables['VSCODE_PUBLISH'], true), eq(parameters.VSCODE_COMPILE_ONLY, false)) }}:
|
- ${{ if and(eq(parameters.VSCODE_COMPILE_ONLY, false), ne(variables['VSCODE_PUBLISH'], 'false')) }}:
|
||||||
- stage: Mooncake
|
- stage: Publish
|
||||||
dependsOn:
|
dependsOn:
|
||||||
- ${{ if eq(variables['VSCODE_BUILD_STAGE_WINDOWS'], true) }}:
|
- Compile
|
||||||
- Windows
|
|
||||||
- ${{ if eq(variables['VSCODE_BUILD_STAGE_LINUX'], true) }}:
|
|
||||||
- Linux
|
|
||||||
- ${{ if eq(variables['VSCODE_BUILD_STAGE_MACOS'], true) }}:
|
|
||||||
- macOS
|
|
||||||
condition: succeededOrFailed()
|
|
||||||
pool:
|
pool:
|
||||||
vmImage: "Ubuntu-18.04"
|
vmImage: "Ubuntu-18.04"
|
||||||
|
variables:
|
||||||
|
- name: BUILDS_API_URL
|
||||||
|
value: $(System.CollectionUri)$(System.TeamProject)/_apis/build/builds/$(Build.BuildId)/
|
||||||
jobs:
|
jobs:
|
||||||
- job: SyncMooncake
|
- job: PublishBuild
|
||||||
displayName: Sync Mooncake
|
timeoutInMinutes: 180
|
||||||
|
displayName: Publish Build
|
||||||
steps:
|
steps:
|
||||||
- template: sync-mooncake.yml
|
- template: product-publish.yml
|
||||||
|
|
||||||
- ${{ if and(eq(parameters.VSCODE_COMPILE_ONLY, false), or(eq(parameters.VSCODE_RELEASE, true), and(in(parameters.VSCODE_QUALITY, 'insider', 'exploration'), eq(variables['VSCODE_SCHEDULEDBUILD'], true)))) }}:
|
- ${{ if or(eq(parameters.VSCODE_RELEASE, true), and(in(parameters.VSCODE_QUALITY, 'insider', 'exploration'), eq(variables['VSCODE_SCHEDULEDBUILD'], true))) }}:
|
||||||
- stage: Release
|
- stage: Release
|
||||||
dependsOn:
|
dependsOn:
|
||||||
- ${{ if eq(variables['VSCODE_BUILD_STAGE_WINDOWS'], true) }}:
|
- Publish
|
||||||
- Windows
|
pool:
|
||||||
- ${{ if eq(variables['VSCODE_BUILD_STAGE_LINUX'], true) }}:
|
vmImage: "Ubuntu-18.04"
|
||||||
- Linux
|
jobs:
|
||||||
- ${{ if eq(variables['VSCODE_BUILD_STAGE_MACOS'], true) }}:
|
- job: ReleaseBuild
|
||||||
- macOS
|
displayName: Release Build
|
||||||
pool:
|
steps:
|
||||||
vmImage: "Ubuntu-18.04"
|
- template: product-release.yml
|
||||||
jobs:
|
|
||||||
- job: ReleaseBuild
|
|
||||||
displayName: Release Build
|
|
||||||
steps:
|
|
||||||
- template: release.yml
|
|
||||||
|
|||||||
@@ -118,14 +118,6 @@ steps:
|
|||||||
displayName: Publish Webview
|
displayName: Publish Webview
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- script: |
|
|
||||||
set -e
|
|
||||||
VERSION=`node -p "require(\"./package.json\").version"`
|
|
||||||
AZURE_DOCUMENTDB_MASTERKEY="$(builds-docdb-key-readwrite)" \
|
|
||||||
node build/azure-pipelines/common/createBuild.js $VERSION
|
|
||||||
displayName: Create build
|
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
|
||||||
|
|
||||||
# we gotta tarball everything in order to preserve file permissions
|
# we gotta tarball everything in order to preserve file permissions
|
||||||
- script: |
|
- script: |
|
||||||
set -e
|
set -e
|
||||||
|
|||||||
114
build/azure-pipelines/product-publish.ps1
Normal file
114
build/azure-pipelines/product-publish.ps1
Normal file
@@ -0,0 +1,114 @@
|
|||||||
|
. build/azure-pipelines/win32/exec.ps1
|
||||||
|
$ErrorActionPreference = 'Stop'
|
||||||
|
$ProgressPreference = 'SilentlyContinue'
|
||||||
|
$ARTIFACT_PROCESSED_WILDCARD_PATH = "$env:PIPELINE_WORKSPACE/artifacts_processed_*/artifacts_processed_*"
|
||||||
|
$ARTIFACT_PROCESSED_FILE_PATH = "$env:PIPELINE_WORKSPACE/artifacts_processed_$env:SYSTEM_STAGEATTEMPT/artifacts_processed_$env:SYSTEM_STAGEATTEMPT.txt"
|
||||||
|
|
||||||
|
function Get-PipelineArtifact {
|
||||||
|
param($Name = '*')
|
||||||
|
try {
|
||||||
|
$res = Invoke-RestMethod "$($env:BUILDS_API_URL)artifacts?api-version=6.0" -Headers @{
|
||||||
|
Authorization = "Bearer $env:SYSTEM_ACCESSTOKEN"
|
||||||
|
} -MaximumRetryCount 5 -RetryIntervalSec 1
|
||||||
|
|
||||||
|
if (!$res) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
$res.value | Where-Object { $_.name -Like $Name }
|
||||||
|
} catch {
|
||||||
|
Write-Warning $_
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# This set will keep track of which artifacts have already been processed
|
||||||
|
$set = [System.Collections.Generic.HashSet[string]]::new()
|
||||||
|
|
||||||
|
if (Test-Path $ARTIFACT_PROCESSED_WILDCARD_PATH) {
|
||||||
|
# Grab the latest artifact_processed text file and load all assets already processed from that.
|
||||||
|
# This means that the latest artifact_processed_*.txt file has all of the contents of the previous ones.
|
||||||
|
# Note: The kusto-like syntax only works in PS7+ and only in scripts, not at the REPL.
|
||||||
|
Get-ChildItem $ARTIFACT_PROCESSED_WILDCARD_PATH
|
||||||
|
| Sort-Object
|
||||||
|
| Select-Object -Last 1
|
||||||
|
| Get-Content
|
||||||
|
| ForEach-Object {
|
||||||
|
$set.Add($_) | Out-Null
|
||||||
|
Write-Host "Already processed artifact: $_"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Create the artifact file that will be used for this run
|
||||||
|
New-Item -Path $ARTIFACT_PROCESSED_FILE_PATH -Force | Out-Null
|
||||||
|
|
||||||
|
# Determine which stages we need to watch
|
||||||
|
$stages = @(
|
||||||
|
if ($env:VSCODE_BUILD_STAGE_WINDOWS -eq 'True') { 'Windows' }
|
||||||
|
if ($env:VSCODE_BUILD_STAGE_LINUX -eq 'True') { 'Linux' }
|
||||||
|
if ($env:VSCODE_BUILD_STAGE_MACOS -eq 'True') { 'macOS' }
|
||||||
|
)
|
||||||
|
|
||||||
|
do {
|
||||||
|
Start-Sleep -Seconds 10
|
||||||
|
|
||||||
|
$artifacts = Get-PipelineArtifact -Name 'vscode_*'
|
||||||
|
if (!$artifacts) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
$artifacts | ForEach-Object {
|
||||||
|
$artifactName = $_.name
|
||||||
|
if($set.Add($artifactName)) {
|
||||||
|
Write-Host "Processing artifact: '$artifactName. Downloading from: $($_.resource.downloadUrl)"
|
||||||
|
|
||||||
|
try {
|
||||||
|
Invoke-RestMethod $_.resource.downloadUrl -OutFile "$env:AGENT_TEMPDIRECTORY/$artifactName.zip" -Headers @{
|
||||||
|
Authorization = "Bearer $env:SYSTEM_ACCESSTOKEN"
|
||||||
|
} -MaximumRetryCount 5 -RetryIntervalSec 1 | Out-Null
|
||||||
|
|
||||||
|
Expand-Archive -Path "$env:AGENT_TEMPDIRECTORY/$artifactName.zip" -DestinationPath $env:AGENT_TEMPDIRECTORY | Out-Null
|
||||||
|
} catch {
|
||||||
|
Write-Warning $_
|
||||||
|
$set.Remove($artifactName) | Out-Null
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
$null,$product,$os,$arch,$type = $artifactName -split '_'
|
||||||
|
$asset = Get-ChildItem -rec "$env:AGENT_TEMPDIRECTORY/$artifactName"
|
||||||
|
Write-Host "Processing artifact with the following values:"
|
||||||
|
# turning in into an object just to log nicely
|
||||||
|
@{
|
||||||
|
product = $product
|
||||||
|
os = $os
|
||||||
|
arch = $arch
|
||||||
|
type = $type
|
||||||
|
asset = $asset.Name
|
||||||
|
} | Format-Table
|
||||||
|
|
||||||
|
exec { node build/azure-pipelines/common/createAsset.js $product $os $arch $type $asset.Name $asset.FullName }
|
||||||
|
$artifactName >> $ARTIFACT_PROCESSED_FILE_PATH
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Get the timeline and see if it says the other stage completed
|
||||||
|
try {
|
||||||
|
$timeline = Invoke-RestMethod "$($env:BUILDS_API_URL)timeline?api-version=6.0" -Headers @{
|
||||||
|
Authorization = "Bearer $env:SYSTEM_ACCESSTOKEN"
|
||||||
|
} -MaximumRetryCount 5 -RetryIntervalSec 1
|
||||||
|
} catch {
|
||||||
|
Write-Warning $_
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($stage in $stages) {
|
||||||
|
$otherStageFinished = $timeline.records | Where-Object { $_.name -eq $stage -and $_.type -eq 'stage' -and $_.state -eq 'completed' }
|
||||||
|
if (!$otherStageFinished) {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$artifacts = Get-PipelineArtifact -Name 'vscode_*'
|
||||||
|
$artifactsStillToProcess = $artifacts.Count -ne $set.Count
|
||||||
|
} while (!$otherStageFinished -or $artifactsStillToProcess)
|
||||||
|
|
||||||
|
Write-Host "Processed $($set.Count) artifacts."
|
||||||
89
build/azure-pipelines/product-publish.yml
Normal file
89
build/azure-pipelines/product-publish.yml
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
steps:
|
||||||
|
- task: NodeTool@0
|
||||||
|
inputs:
|
||||||
|
versionSpec: "12.x"
|
||||||
|
|
||||||
|
- task: geeklearningio.gl-vsts-tasks-yarn.yarn-installer-task.YarnInstaller@2
|
||||||
|
inputs:
|
||||||
|
versionSpec: "1.x"
|
||||||
|
|
||||||
|
- task: AzureKeyVault@1
|
||||||
|
displayName: "Azure Key Vault: Get Secrets"
|
||||||
|
inputs:
|
||||||
|
azureSubscription: "vscode-builds-subscription"
|
||||||
|
KeyVaultName: vscode
|
||||||
|
|
||||||
|
- pwsh: |
|
||||||
|
. build/azure-pipelines/win32/exec.ps1
|
||||||
|
cd build
|
||||||
|
exec { yarn }
|
||||||
|
displayName: Install dependencies
|
||||||
|
|
||||||
|
- download: current
|
||||||
|
patterns: '**/artifacts_processed_*.txt'
|
||||||
|
displayName: Download all artifacts_processed text files
|
||||||
|
|
||||||
|
- pwsh: |
|
||||||
|
. build/azure-pipelines/win32/exec.ps1
|
||||||
|
|
||||||
|
if (Test-Path "$(Pipeline.Workspace)/artifacts_processed_*/artifacts_processed_*.txt") {
|
||||||
|
Write-Host "Artifacts already processed so a build must have already been created."
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
$env:AZURE_DOCUMENTDB_MASTERKEY = "$(builds-docdb-key-readwrite)"
|
||||||
|
$VERSION = node -p "require('./package.json').version"
|
||||||
|
Write-Host "Creating build with version: $VERSION"
|
||||||
|
exec { node build/azure-pipelines/common/createBuild.js $VERSION }
|
||||||
|
displayName: Create build if it hasn't been created before
|
||||||
|
|
||||||
|
- pwsh: |
|
||||||
|
$env:VSCODE_MIXIN_PASSWORD = "$(github-distro-mixin-password)"
|
||||||
|
$env:AZURE_DOCUMENTDB_MASTERKEY = "$(builds-docdb-key-readwrite)"
|
||||||
|
$env:AZURE_STORAGE_ACCESS_KEY = "$(ticino-storage-key)"
|
||||||
|
$env:AZURE_STORAGE_ACCESS_KEY_2 = "$(vscode-storage-key)"
|
||||||
|
$env:MOONCAKE_STORAGE_ACCESS_KEY = "$(vscode-mooncake-storage-key)"
|
||||||
|
build/azure-pipelines/product-publish.ps1
|
||||||
|
env:
|
||||||
|
SYSTEM_ACCESSTOKEN: $(System.AccessToken)
|
||||||
|
displayName: Process artifacts
|
||||||
|
|
||||||
|
- publish: $(Pipeline.Workspace)/artifacts_processed_$(System.StageAttempt)/artifacts_processed_$(System.StageAttempt).txt
|
||||||
|
artifact: artifacts_processed_$(System.StageAttempt)
|
||||||
|
displayName: Publish what artifacts were published for this stage attempt
|
||||||
|
|
||||||
|
- pwsh: |
|
||||||
|
$ErrorActionPreference = 'Stop'
|
||||||
|
|
||||||
|
# Determine which stages we need to watch
|
||||||
|
$stages = @(
|
||||||
|
if ($env:VSCODE_BUILD_STAGE_WINDOWS -eq 'True') { 'Windows' }
|
||||||
|
if ($env:VSCODE_BUILD_STAGE_LINUX -eq 'True') { 'Linux' }
|
||||||
|
if ($env:VSCODE_BUILD_STAGE_MACOS -eq 'True') { 'macOS' }
|
||||||
|
)
|
||||||
|
Write-Host "Stages to check: $stages"
|
||||||
|
|
||||||
|
# Get the timeline and see if it says the other stage completed
|
||||||
|
$timeline = Invoke-RestMethod "$($env:BUILDS_API_URL)timeline?api-version=6.0" -Headers @{
|
||||||
|
Authorization = "Bearer $env:SYSTEM_ACCESSTOKEN"
|
||||||
|
} -MaximumRetryCount 5 -RetryIntervalSec 1
|
||||||
|
|
||||||
|
$failedStages = @()
|
||||||
|
foreach ($stage in $stages) {
|
||||||
|
$didStageFail = $timeline.records | Where-Object {
|
||||||
|
$_.name -eq $stage -and $_.type -eq 'stage' -and $_.result -ne 'succeeded' -and $_.result -ne 'succeededWithIssues'
|
||||||
|
}
|
||||||
|
|
||||||
|
if($didStageFail) {
|
||||||
|
$failedStages += $stage
|
||||||
|
} else {
|
||||||
|
Write-Host "'$stage' did not fail."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($failedStages.Length) {
|
||||||
|
throw "Failed stages: $($failedStages -join ', '). This stage will now fail so that it is easier to retry failed jobs."
|
||||||
|
}
|
||||||
|
env:
|
||||||
|
SYSTEM_ACCESSTOKEN: $(System.AccessToken)
|
||||||
|
displayName: Determine if stage should succeed
|
||||||
@@ -63,8 +63,8 @@ function getNewFileHeader(tag) {
|
|||||||
``,
|
``,
|
||||||
`/*---------------------------------------------------------------------------------------------`,
|
`/*---------------------------------------------------------------------------------------------`,
|
||||||
` * Copyright (c) Microsoft Corporation. All rights reserved.`,
|
` * Copyright (c) Microsoft Corporation. All rights reserved.`,
|
||||||
` * Licensed under the MIT License.`,
|
` * Licensed under the Source EULA.`,
|
||||||
` * See https://github.com/Microsoft/azuredatastudio/blob/main/LICENSE.txt for license information.`,
|
` * See https://github.com/microsoft/azuredatastudio/blob/main/LICENSE.txt for license information.`,
|
||||||
` *--------------------------------------------------------------------------------------------*/`,
|
` *--------------------------------------------------------------------------------------------*/`,
|
||||||
``,
|
``,
|
||||||
`/**`,
|
`/**`,
|
||||||
|
|||||||
@@ -75,8 +75,8 @@ function getNewFileHeader(tag: string) {
|
|||||||
``,
|
``,
|
||||||
`/*---------------------------------------------------------------------------------------------`,
|
`/*---------------------------------------------------------------------------------------------`,
|
||||||
` * Copyright (c) Microsoft Corporation. All rights reserved.`,
|
` * Copyright (c) Microsoft Corporation. All rights reserved.`,
|
||||||
` * Licensed under the MIT License.`,
|
` * Licensed under the Source EULA.`,
|
||||||
` * See https://github.com/Microsoft/azuredatastudio/blob/main/LICENSE.txt for license information.`,
|
` * See https://github.com/microsoft/azuredatastudio/blob/main/LICENSE.txt for license information.`,
|
||||||
` *--------------------------------------------------------------------------------------------*/`,
|
` *--------------------------------------------------------------------------------------------*/`,
|
||||||
``,
|
``,
|
||||||
`/**`,
|
`/**`,
|
||||||
|
|||||||
@@ -1,24 +0,0 @@
|
|||||||
steps:
|
|
||||||
- task: NodeTool@0
|
|
||||||
inputs:
|
|
||||||
versionSpec: "14.x"
|
|
||||||
|
|
||||||
- task: geeklearningio.gl-vsts-tasks-yarn.yarn-installer-task.YarnInstaller@2
|
|
||||||
inputs:
|
|
||||||
versionSpec: "1.x"
|
|
||||||
|
|
||||||
- task: AzureKeyVault@1
|
|
||||||
displayName: "Azure Key Vault: Get Secrets"
|
|
||||||
inputs:
|
|
||||||
azureSubscription: "vscode-builds-subscription"
|
|
||||||
KeyVaultName: vscode
|
|
||||||
|
|
||||||
- script: |
|
|
||||||
set -e
|
|
||||||
|
|
||||||
(cd build ; yarn)
|
|
||||||
|
|
||||||
AZURE_DOCUMENTDB_MASTERKEY="$(builds-docdb-key-readwrite)" \
|
|
||||||
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
|
||||||
MOONCAKE_STORAGE_ACCESS_KEY="$(vscode-mooncake-storage-key)" \
|
|
||||||
node build/azure-pipelines/common/sync-mooncake.js "$VSCODE_QUALITY"
|
|
||||||
@@ -119,13 +119,19 @@ steps:
|
|||||||
|
|
||||||
- script: |
|
- script: |
|
||||||
set -e
|
set -e
|
||||||
AZURE_DOCUMENTDB_MASTERKEY="$(builds-docdb-key-readwrite)" \
|
REPO="$(pwd)"
|
||||||
AZURE_STORAGE_ACCESS_KEY_2="$(vscode-storage-key)" \
|
ROOT="$REPO/.."
|
||||||
VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)" \
|
|
||||||
./build/azure-pipelines/web/publish.sh
|
WEB_BUILD_NAME="vscode-web"
|
||||||
displayName: Publish
|
WEB_TARBALL_FILENAME="vscode-web.tar.gz"
|
||||||
|
WEB_TARBALL_PATH="$ROOT/$WEB_TARBALL_FILENAME"
|
||||||
|
|
||||||
|
rm -rf $ROOT/vscode-web.tar.*
|
||||||
|
|
||||||
|
cd $ROOT && tar --owner=0 --group=0 -czf $WEB_TARBALL_PATH $WEB_BUILD_NAME
|
||||||
|
displayName: Prepare for publish
|
||||||
|
|
||||||
- publish: $(Agent.BuildDirectory)/vscode-web.tar.gz
|
- publish: $(Agent.BuildDirectory)/vscode-web.tar.gz
|
||||||
artifact: vscode-web-standalone
|
artifact: vscode_web_linux_standalone_archive-unsigned
|
||||||
displayName: Publish web archive
|
displayName: Publish web archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|||||||
@@ -1,15 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
set -e
|
|
||||||
REPO="$(pwd)"
|
|
||||||
ROOT="$REPO/.."
|
|
||||||
|
|
||||||
# Publish Web Client
|
|
||||||
WEB_BUILD_NAME="vscode-web"
|
|
||||||
WEB_TARBALL_FILENAME="vscode-web.tar.gz"
|
|
||||||
WEB_TARBALL_PATH="$ROOT/$WEB_TARBALL_FILENAME"
|
|
||||||
|
|
||||||
rm -rf $ROOT/vscode-web.tar.*
|
|
||||||
|
|
||||||
(cd $ROOT && tar --owner=0 --group=0 -czf $WEB_TARBALL_PATH $WEB_BUILD_NAME)
|
|
||||||
|
|
||||||
node build/azure-pipelines/common/createAsset.js web-standalone archive-unsigned "$WEB_TARBALL_FILENAME" "$WEB_TARBALL_PATH"
|
|
||||||
@@ -13,24 +13,31 @@ $Zip = "$Repo\.build\win32-$Arch\archive\VSCode-win32-$Arch.zip"
|
|||||||
$LegacyServer = "$Root\vscode-reh-win32-$Arch"
|
$LegacyServer = "$Root\vscode-reh-win32-$Arch"
|
||||||
$Server = "$Root\vscode-server-win32-$Arch"
|
$Server = "$Root\vscode-server-win32-$Arch"
|
||||||
$ServerZip = "$Repo\.build\vscode-server-win32-$Arch.zip"
|
$ServerZip = "$Repo\.build\vscode-server-win32-$Arch.zip"
|
||||||
|
$LegacyWeb = "$Root\vscode-reh-web-win32-$Arch"
|
||||||
|
$Web = "$Root\vscode-server-win32-$Arch-web"
|
||||||
|
$WebZip = "$Repo\.build\vscode-server-win32-$Arch-web.zip"
|
||||||
$Build = "$Root\VSCode-win32-$Arch"
|
$Build = "$Root\VSCode-win32-$Arch"
|
||||||
|
|
||||||
# Create server archive
|
# Create server archive
|
||||||
if ("$Arch" -ne "arm64") {
|
if ("$Arch" -ne "arm64") {
|
||||||
exec { xcopy $LegacyServer $Server /H /E /I }
|
exec { xcopy $LegacyServer $Server /H /E /I }
|
||||||
exec { .\node_modules\7zip\7zip-lite\7z.exe a -tzip $ServerZip $Server -r }
|
exec { .\node_modules\7zip\7zip-lite\7z.exe a -tzip $ServerZip $Server -r }
|
||||||
|
exec { xcopy $LegacyWeb $Web /H /E /I }
|
||||||
|
exec { .\node_modules\7zip\7zip-lite\7z.exe a -tzip $WebZip $Web -r }
|
||||||
}
|
}
|
||||||
|
|
||||||
# get version
|
# get version
|
||||||
$PackageJson = Get-Content -Raw -Path "$Build\resources\app\package.json" | ConvertFrom-Json
|
$PackageJson = Get-Content -Raw -Path "$Build\resources\app\package.json" | ConvertFrom-Json
|
||||||
$Version = $PackageJson.version
|
$Version = $PackageJson.version
|
||||||
|
|
||||||
$AssetPlatform = if ("$Arch" -eq "ia32") { "win32" } else { "win32-$Arch" }
|
$ARCHIVE_NAME = "VSCode-win32-$Arch-$Version.zip"
|
||||||
|
$SYSTEM_SETUP_NAME = "VSCodeSetup-$Arch-$Version.exe"
|
||||||
|
$USER_SETUP_NAME = "VSCodeUserSetup-$Arch-$Version.exe"
|
||||||
|
|
||||||
exec { node build/azure-pipelines/common/createAsset.js "$AssetPlatform-archive" archive "VSCode-win32-$Arch-$Version.zip" $Zip }
|
# Set variables for upload
|
||||||
exec { node build/azure-pipelines/common/createAsset.js "$AssetPlatform" setup "VSCodeSetup-$Arch-$Version.exe" $SystemExe }
|
Move-Item $Zip "$Repo\.build\win32-$Arch\archive\$ARCHIVE_NAME"
|
||||||
exec { node build/azure-pipelines/common/createAsset.js "$AssetPlatform-user" setup "VSCodeUserSetup-$Arch-$Version.exe" $UserExe }
|
Write-Host "##vso[task.setvariable variable=ARCHIVE_NAME]$ARCHIVE_NAME"
|
||||||
|
Move-Item $SystemExe "$Repo\.build\win32-$Arch\system-setup\$SYSTEM_SETUP_NAME"
|
||||||
if ("$Arch" -ne "arm64") {
|
Write-Host "##vso[task.setvariable variable=SYSTEM_SETUP_NAME]$SYSTEM_SETUP_NAME"
|
||||||
exec { node build/azure-pipelines/common/createAsset.js "server-$AssetPlatform" archive "vscode-server-win32-$Arch.zip" $ServerZip }
|
Move-Item $UserExe "$Repo\.build\win32-$Arch\user-setup\$USER_SETUP_NAME"
|
||||||
}
|
Write-Host "##vso[task.setvariable variable=USER_SETUP_NAME]$USER_SETUP_NAME"
|
||||||
@@ -295,31 +295,31 @@ steps:
|
|||||||
$env:AZURE_STORAGE_ACCESS_KEY_2 = "$(vscode-storage-key)"
|
$env:AZURE_STORAGE_ACCESS_KEY_2 = "$(vscode-storage-key)"
|
||||||
$env:AZURE_DOCUMENTDB_MASTERKEY = "$(builds-docdb-key-readwrite)"
|
$env:AZURE_DOCUMENTDB_MASTERKEY = "$(builds-docdb-key-readwrite)"
|
||||||
$env:VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)"
|
$env:VSCODE_MIXIN_PASSWORD="$(github-distro-mixin-password)"
|
||||||
.\build\azure-pipelines\win32\publish.ps1
|
.\build\azure-pipelines\win32\prepare-publish.ps1
|
||||||
displayName: Publish
|
displayName: Publish
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(System.DefaultWorkingDirectory)\.build\win32-$(VSCODE_ARCH)\archive\VSCode-win32-$(VSCODE_ARCH).zip
|
- publish: $(System.DefaultWorkingDirectory)\.build\win32-$(VSCODE_ARCH)\archive\$(ARCHIVE_NAME)
|
||||||
artifact: vscode-win32-$(VSCODE_ARCH)
|
artifact: vscode_client_win32_$(VSCODE_ARCH)_archive
|
||||||
displayName: Publish archive
|
displayName: Publish archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(System.DefaultWorkingDirectory)\.build\win32-$(VSCODE_ARCH)\system-setup\VSCodeSetup.exe
|
- publish: $(System.DefaultWorkingDirectory)\.build\win32-$(VSCODE_ARCH)\system-setup\$(SYSTEM_SETUP_NAME)
|
||||||
artifact: vscode-win32-$(VSCODE_ARCH)-setup
|
artifact: vscode_client_win32_$(VSCODE_ARCH)_setup
|
||||||
displayName: Publish system setup
|
displayName: Publish system setup
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(System.DefaultWorkingDirectory)\.build\win32-$(VSCODE_ARCH)\user-setup\VSCodeSetup.exe
|
- publish: $(System.DefaultWorkingDirectory)\.build\win32-$(VSCODE_ARCH)\user-setup\$(USER_SETUP_NAME)
|
||||||
artifact: vscode-win32-$(VSCODE_ARCH)-user-setup
|
artifact: vscode_client_win32_$(VSCODE_ARCH)_user-setup
|
||||||
displayName: Publish user setup
|
displayName: Publish user setup
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'))
|
||||||
|
|
||||||
- publish: $(System.DefaultWorkingDirectory)\.build\vscode-server-win32-$(VSCODE_ARCH).zip
|
- publish: $(System.DefaultWorkingDirectory)\.build\vscode-server-win32-$(VSCODE_ARCH).zip
|
||||||
artifact: vscode-server-win32-$(VSCODE_ARCH)
|
artifact: vscode_server_win32_$(VSCODE_ARCH)_archive
|
||||||
displayName: Publish server archive
|
displayName: Publish server archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'), ne(variables['VSCODE_ARCH'], 'arm64'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'), ne(variables['VSCODE_ARCH'], 'arm64'))
|
||||||
|
|
||||||
- publish: $(System.DefaultWorkingDirectory)\.build\vscode-server-win32-$(VSCODE_ARCH)-web.zip
|
- publish: $(System.DefaultWorkingDirectory)\.build\vscode-server-win32-$(VSCODE_ARCH)-web.zip
|
||||||
artifact: vscode-server-win32-$(VSCODE_ARCH)-web
|
artifact: vscode_web_win32_$(VSCODE_ARCH)_archive
|
||||||
displayName: Publish web server archive
|
displayName: Publish web server archive
|
||||||
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'), ne(variables['VSCODE_ARCH'], 'arm64'))
|
condition: and(succeeded(), ne(variables['VSCODE_PUBLISH'], 'false'), ne(variables['VSCODE_ARCH'], 'arm64'))
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ async function main() {
|
|||||||
const outAppPath = path.join(buildDir, `VSCode-darwin-${arch}`, appName);
|
const outAppPath = path.join(buildDir, `VSCode-darwin-${arch}`, appName);
|
||||||
const productJsonPath = path.resolve(outAppPath, 'Contents', 'Resources', 'app', 'product.json');
|
const productJsonPath = path.resolve(outAppPath, 'Contents', 'Resources', 'app', 'product.json');
|
||||||
const infoPlistPath = path.resolve(outAppPath, 'Contents', 'Info.plist');
|
const infoPlistPath = path.resolve(outAppPath, 'Contents', 'Info.plist');
|
||||||
await (0, vscode_universal_1.makeUniversalApp)({
|
await vscode_universal_1.makeUniversalApp({
|
||||||
x64AppPath,
|
x64AppPath,
|
||||||
arm64AppPath,
|
arm64AppPath,
|
||||||
x64AsarPath,
|
x64AsarPath,
|
||||||
|
|||||||
@@ -51,7 +51,7 @@ module.exports.indentationFilter = [
|
|||||||
'!test/monaco/out/**',
|
'!test/monaco/out/**',
|
||||||
'!test/smoke/out/**',
|
'!test/smoke/out/**',
|
||||||
'!extensions/typescript-language-features/test-workspace/**',
|
'!extensions/typescript-language-features/test-workspace/**',
|
||||||
'!extensions/notebook-markdown-extensions/notebook-out/**',
|
'!extensions/markdown-math/notebook-out/**',
|
||||||
'!extensions/vscode-api-tests/testWorkspace/**',
|
'!extensions/vscode-api-tests/testWorkspace/**',
|
||||||
'!extensions/vscode-api-tests/testWorkspace2/**',
|
'!extensions/vscode-api-tests/testWorkspace2/**',
|
||||||
'!extensions/vscode-custom-editor-tests/test-workspace/**',
|
'!extensions/vscode-custom-editor-tests/test-workspace/**',
|
||||||
@@ -89,7 +89,7 @@ module.exports.indentationFilter = [
|
|||||||
'!**/*.dockerfile',
|
'!**/*.dockerfile',
|
||||||
'!extensions/markdown-language-features/media/*.js',
|
'!extensions/markdown-language-features/media/*.js',
|
||||||
'!extensions/markdown-language-features/notebook-out/*.js',
|
'!extensions/markdown-language-features/notebook-out/*.js',
|
||||||
'!extensions/notebook-markdown-extensions/notebook-out/*.js',
|
'!extensions/markdown-math/notebook-out/*.js',
|
||||||
'!extensions/simple-browser/media/*.js',
|
'!extensions/simple-browser/media/*.js',
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -119,7 +119,7 @@ module.exports.copyrightFilter = [
|
|||||||
'!resources/completions/**',
|
'!resources/completions/**',
|
||||||
'!extensions/configuration-editing/build/inline-allOf.ts',
|
'!extensions/configuration-editing/build/inline-allOf.ts',
|
||||||
'!extensions/markdown-language-features/media/highlight.css',
|
'!extensions/markdown-language-features/media/highlight.css',
|
||||||
'!extensions/notebook-markdown-extensions/notebook-out/**',
|
'!extensions/markdown-math/notebook-out/**',
|
||||||
'!extensions/html-language-features/server/src/modes/typescript/*',
|
'!extensions/html-language-features/server/src/modes/typescript/*',
|
||||||
'!extensions/*/server/bin/*',
|
'!extensions/*/server/bin/*',
|
||||||
'!src/vs/editor/test/node/classification/typescript-test.ts',
|
'!src/vs/editor/test/node/classification/typescript-test.ts',
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ const i18n = require('./lib/i18n');
|
|||||||
const standalone = require('./lib/standalone');
|
const standalone = require('./lib/standalone');
|
||||||
const cp = require('child_process');
|
const cp = require('child_process');
|
||||||
const compilation = require('./lib/compilation');
|
const compilation = require('./lib/compilation');
|
||||||
const monacoapi = require('./monaco/api');
|
const monacoapi = require('./lib/monaco-api');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
|
|
||||||
let root = path.dirname(__dirname);
|
let root = path.dirname(__dirname);
|
||||||
@@ -49,7 +49,7 @@ let BUNDLED_FILE_HEADER = [
|
|||||||
' * Copyright (c) Microsoft Corporation. All rights reserved.',
|
' * Copyright (c) Microsoft Corporation. All rights reserved.',
|
||||||
' * Version: ' + headerVersion,
|
' * Version: ' + headerVersion,
|
||||||
' * Released under the Source EULA',
|
' * Released under the Source EULA',
|
||||||
' * https://github.com/Microsoft/vscode/blob/master/LICENSE.txt',
|
' * https://github.com/microsoft/vscode/blob/main/LICENSE.txt',
|
||||||
' *-----------------------------------------------------------*/',
|
' *-----------------------------------------------------------*/',
|
||||||
''
|
''
|
||||||
].join('\n');
|
].join('\n');
|
||||||
@@ -279,7 +279,7 @@ const finalEditorResourcesTask = task.define('final-editor-resources', () => {
|
|||||||
// version.txt
|
// version.txt
|
||||||
gulp.src('build/monaco/version.txt')
|
gulp.src('build/monaco/version.txt')
|
||||||
.pipe(es.through(function (data) {
|
.pipe(es.through(function (data) {
|
||||||
data.contents = Buffer.from(`monaco-editor-core: https://github.com/Microsoft/vscode/tree/${sha1}`);
|
data.contents = Buffer.from(`monaco-editor-core: https://github.com/microsoft/vscode/tree/${sha1}`);
|
||||||
this.emit('data', data);
|
this.emit('data', data);
|
||||||
}))
|
}))
|
||||||
.pipe(gulp.dest('out-monaco-editor-core')),
|
.pipe(gulp.dest('out-monaco-editor-core')),
|
||||||
|
|||||||
@@ -8,7 +8,6 @@ require('events').EventEmitter.defaultMaxListeners = 100;
|
|||||||
|
|
||||||
const gulp = require('gulp');
|
const gulp = require('gulp');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const child_process = require('child_process');
|
|
||||||
const nodeUtil = require('util');
|
const nodeUtil = require('util');
|
||||||
const es = require('event-stream');
|
const es = require('event-stream');
|
||||||
const filter = require('gulp-filter');
|
const filter = require('gulp-filter');
|
||||||
@@ -20,8 +19,6 @@ const glob = require('glob');
|
|||||||
const root = path.dirname(__dirname);
|
const root = path.dirname(__dirname);
|
||||||
const commit = util.getVersion(root);
|
const commit = util.getVersion(root);
|
||||||
const plumber = require('gulp-plumber');
|
const plumber = require('gulp-plumber');
|
||||||
const fancyLog = require('fancy-log');
|
|
||||||
const ansiColors = require('ansi-colors');
|
|
||||||
const ext = require('./lib/extensions');
|
const ext = require('./lib/extensions');
|
||||||
|
|
||||||
const extensionsPath = path.join(path.dirname(__dirname), 'extensions');
|
const extensionsPath = path.join(path.dirname(__dirname), 'extensions');
|
||||||
@@ -59,6 +56,7 @@ const compilations = glob.sync('**/tsconfig.json', {
|
|||||||
// 'json-language-features/server/tsconfig.json',
|
// 'json-language-features/server/tsconfig.json',
|
||||||
// 'markdown-language-features/preview-src/tsconfig.json',
|
// 'markdown-language-features/preview-src/tsconfig.json',
|
||||||
// 'markdown-language-features/tsconfig.json',
|
// 'markdown-language-features/tsconfig.json',
|
||||||
|
// 'markdown-math/tsconfig.json',
|
||||||
// 'merge-conflict/tsconfig.json',
|
// 'merge-conflict/tsconfig.json',
|
||||||
// 'microsoft-authentication/tsconfig.json',
|
// 'microsoft-authentication/tsconfig.json',
|
||||||
// 'npm/tsconfig.json',
|
// 'npm/tsconfig.json',
|
||||||
@@ -207,45 +205,17 @@ gulp.task(compileExtensionsBuildLegacyTask);
|
|||||||
|
|
||||||
//#region Extension media
|
//#region Extension media
|
||||||
|
|
||||||
// Additional projects to webpack. These typically build code for webviews
|
const compileExtensionMediaTask = task.define('compile-extension-media', () => ext.buildExtensionMedia(false));
|
||||||
const webpackMediaConfigFiles = [
|
|
||||||
'markdown-language-features/webpack.config.js',
|
|
||||||
'simple-browser/webpack.config.js',
|
|
||||||
];
|
|
||||||
|
|
||||||
// Additional projects to run esbuild on. These typically build code for webviews
|
|
||||||
const esbuildMediaScripts = [
|
|
||||||
'markdown-language-features/esbuild.js',
|
|
||||||
'notebook-markdown-extensions/esbuild.js',
|
|
||||||
];
|
|
||||||
|
|
||||||
const compileExtensionMediaTask = task.define('compile-extension-media', () => buildExtensionMedia(false));
|
|
||||||
gulp.task(compileExtensionMediaTask);
|
gulp.task(compileExtensionMediaTask);
|
||||||
exports.compileExtensionMediaTask = compileExtensionMediaTask;
|
exports.compileExtensionMediaTask = compileExtensionMediaTask;
|
||||||
|
|
||||||
const watchExtensionMedia = task.define('watch-extension-media', () => buildExtensionMedia(true));
|
const watchExtensionMedia = task.define('watch-extension-media', () => ext.buildExtensionMedia(true));
|
||||||
gulp.task(watchExtensionMedia);
|
gulp.task(watchExtensionMedia);
|
||||||
exports.watchExtensionMedia = watchExtensionMedia;
|
exports.watchExtensionMedia = watchExtensionMedia;
|
||||||
|
|
||||||
const compileExtensionMediaBuildTask = task.define('compile-extension-media-build', () => buildExtensionMedia(false, '.build/extensions'));
|
const compileExtensionMediaBuildTask = task.define('compile-extension-media-build', () => ext.buildExtensionMedia(false, '.build/extensions'));
|
||||||
gulp.task(compileExtensionMediaBuildTask);
|
gulp.task(compileExtensionMediaBuildTask);
|
||||||
|
|
||||||
async function buildExtensionMedia(isWatch, outputRoot) {
|
|
||||||
const webpackConfigLocations = webpackMediaConfigFiles.map(p => {
|
|
||||||
return {
|
|
||||||
configPath: path.join(extensionsPath, p),
|
|
||||||
outputRoot: outputRoot ? path.join(root, outputRoot, path.dirname(p)) : undefined
|
|
||||||
};
|
|
||||||
});
|
|
||||||
return Promise.all([
|
|
||||||
webpackExtensions('webpacking extension media', isWatch, webpackConfigLocations),
|
|
||||||
esbuildExtensions('esbuilding extension media', isWatch, esbuildMediaScripts.map(p => ({
|
|
||||||
script: path.join(extensionsPath, p),
|
|
||||||
outputRoot: outputRoot ? path.join(root, outputRoot, path.dirname(p)) : undefined
|
|
||||||
}))),
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
//#region Azure Pipelines
|
//#region Azure Pipelines
|
||||||
@@ -320,121 +290,5 @@ async function buildWebExtensions(isWatch) {
|
|||||||
path.join(extensionsPath, '**', 'extension-browser.webpack.config.js'),
|
path.join(extensionsPath, '**', 'extension-browser.webpack.config.js'),
|
||||||
{ ignore: ['**/node_modules'] }
|
{ ignore: ['**/node_modules'] }
|
||||||
);
|
);
|
||||||
return webpackExtensions('packaging web extension', isWatch, webpackConfigLocations.map(configPath => ({ configPath })));
|
return ext.webpackExtensions('packaging web extension', isWatch, webpackConfigLocations.map(configPath => ({ configPath })));
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {string} taskName
|
|
||||||
* @param {boolean} isWatch
|
|
||||||
* @param {{ configPath: string, outputRoot?: boolean}} webpackConfigLocations
|
|
||||||
*/
|
|
||||||
async function webpackExtensions(taskName, isWatch, webpackConfigLocations) {
|
|
||||||
const webpack = require('webpack');
|
|
||||||
|
|
||||||
const webpackConfigs = [];
|
|
||||||
|
|
||||||
for (const { configPath, outputRoot } of webpackConfigLocations) {
|
|
||||||
const configOrFnOrArray = require(configPath);
|
|
||||||
function addConfig(configOrFn) {
|
|
||||||
let config;
|
|
||||||
if (typeof configOrFn === 'function') {
|
|
||||||
config = configOrFn({}, {});
|
|
||||||
webpackConfigs.push(config);
|
|
||||||
} else {
|
|
||||||
config = configOrFn;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (outputRoot) {
|
|
||||||
config.output.path = path.join(outputRoot, path.relative(path.dirname(configPath), config.output.path));
|
|
||||||
}
|
|
||||||
|
|
||||||
webpackConfigs.push(configOrFn);
|
|
||||||
}
|
|
||||||
addConfig(configOrFnOrArray);
|
|
||||||
}
|
|
||||||
function reporter(fullStats) {
|
|
||||||
if (Array.isArray(fullStats.children)) {
|
|
||||||
for (const stats of fullStats.children) {
|
|
||||||
const outputPath = stats.outputPath;
|
|
||||||
if (outputPath) {
|
|
||||||
const relativePath = path.relative(extensionsPath, outputPath).replace(/\\/g, '/');
|
|
||||||
const match = relativePath.match(/[^\/]+(\/server|\/client)?/);
|
|
||||||
fancyLog(`Finished ${ansiColors.green(taskName)} ${ansiColors.cyan(match[0])} with ${stats.errors.length} errors.`);
|
|
||||||
}
|
|
||||||
if (Array.isArray(stats.errors)) {
|
|
||||||
stats.errors.forEach(error => {
|
|
||||||
fancyLog.error(error);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (Array.isArray(stats.warnings)) {
|
|
||||||
stats.warnings.forEach(warning => {
|
|
||||||
fancyLog.warn(warning);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
if (isWatch) {
|
|
||||||
webpack(webpackConfigs).watch({}, (err, stats) => {
|
|
||||||
if (err) {
|
|
||||||
reject();
|
|
||||||
} else {
|
|
||||||
reporter(stats.toJson());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
webpack(webpackConfigs).run((err, stats) => {
|
|
||||||
if (err) {
|
|
||||||
fancyLog.error(err);
|
|
||||||
reject();
|
|
||||||
} else {
|
|
||||||
reporter(stats.toJson());
|
|
||||||
resolve();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {string} taskName
|
|
||||||
* @param {boolean} isWatch
|
|
||||||
* @param {{ script: string, outputRoot?: string }}} scripts
|
|
||||||
*/
|
|
||||||
async function esbuildExtensions(taskName, isWatch, scripts) {
|
|
||||||
function reporter(/** @type {string} */ stdError, /** @type {string} */script) {
|
|
||||||
const matches = (stdError || '').match(/\> (.+): error: (.+)?/g);
|
|
||||||
fancyLog(`Finished ${ansiColors.green(taskName)} ${script} with ${matches ? matches.length : 0} errors.`);
|
|
||||||
for (const match of matches || []) {
|
|
||||||
fancyLog.error(match);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const tasks = scripts.map(({ script, outputRoot }) => {
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
const args = [script];
|
|
||||||
if (isWatch) {
|
|
||||||
args.push('--watch');
|
|
||||||
}
|
|
||||||
if (outputRoot) {
|
|
||||||
args.push('--outputRoot', outputRoot);
|
|
||||||
}
|
|
||||||
const proc = child_process.execFile(process.argv[0], args, {}, (error, _stdout, stderr) => {
|
|
||||||
if (error) {
|
|
||||||
return reject(error);
|
|
||||||
}
|
|
||||||
reporter(stderr, script);
|
|
||||||
if (stderr) {
|
|
||||||
return reject();
|
|
||||||
}
|
|
||||||
return resolve();
|
|
||||||
});
|
|
||||||
|
|
||||||
proc.stdout.on('data', (data) => {
|
|
||||||
fancyLog(`${ansiColors.green(taskName)}: ${data.toString('utf8')}`);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
return Promise.all(tasks);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -283,7 +283,14 @@ function packageTask(platform, arch, sourceFolderName, destinationFolderName, op
|
|||||||
.pipe(jsFilter)
|
.pipe(jsFilter)
|
||||||
.pipe(util.rewriteSourceMappingURL(sourceMappingURLBase))
|
.pipe(util.rewriteSourceMappingURL(sourceMappingURLBase))
|
||||||
.pipe(jsFilter.restore)
|
.pipe(jsFilter.restore)
|
||||||
.pipe(createAsar(path.join(process.cwd(), 'node_modules'), ['**/*.node', '**/vscode-ripgrep/bin/*', '**/node-pty/build/Release/*', '**/*.wasm'], 'node_modules.asar'));
|
.pipe(createAsar(path.join(process.cwd(), 'node_modules'), [
|
||||||
|
'**/*.node',
|
||||||
|
'**/vscode-ripgrep/bin/*',
|
||||||
|
'**/node-pty/build/Release/*',
|
||||||
|
'**/node-pty/lib/worker/conoutSocketWorker.js',
|
||||||
|
'**/node-pty/lib/shared/conout.js',
|
||||||
|
'**/*.wasm'
|
||||||
|
], 'node_modules.asar'));
|
||||||
|
|
||||||
let all = es.merge(
|
let all = es.merge(
|
||||||
packageJsonStream,
|
packageJsonStream,
|
||||||
@@ -439,8 +446,6 @@ BUILD_TARGETS.forEach(buildTarget => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Transifex Localizations
|
|
||||||
|
|
||||||
const innoSetupConfig = {
|
const innoSetupConfig = {
|
||||||
'zh-cn': { codePage: 'CP936', defaultInfo: { name: 'Simplified Chinese', id: '$0804', } },
|
'zh-cn': { codePage: 'CP936', defaultInfo: { name: 'Simplified Chinese', id: '$0804', } },
|
||||||
'zh-tw': { codePage: 'CP950', defaultInfo: { name: 'Traditional Chinese', id: '$0404' } },
|
'zh-tw': { codePage: 'CP950', defaultInfo: { name: 'Traditional Chinese', id: '$0404' } },
|
||||||
@@ -456,6 +461,8 @@ const innoSetupConfig = {
|
|||||||
'tr': { codePage: 'CP1254' }
|
'tr': { codePage: 'CP1254' }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Transifex Localizations
|
||||||
|
|
||||||
const apiHostname = process.env.TRANSIFEX_API_URL;
|
const apiHostname = process.env.TRANSIFEX_API_URL;
|
||||||
const apiName = process.env.TRANSIFEX_API_NAME;
|
const apiName = process.env.TRANSIFEX_API_NAME;
|
||||||
const apiToken = process.env.TRANSIFEX_API_TOKEN;
|
const apiToken = process.env.TRANSIFEX_API_TOKEN;
|
||||||
@@ -491,7 +498,7 @@ const vscodeTranslationsExport = task.define(
|
|||||||
function () {
|
function () {
|
||||||
const pathToMetadata = './out-vscode/nls.metadata.json';
|
const pathToMetadata = './out-vscode/nls.metadata.json';
|
||||||
const pathToExtensions = '.build/extensions/*';
|
const pathToExtensions = '.build/extensions/*';
|
||||||
const pathToSetup = 'build/win32/**/{Default.isl,messages.en.isl}';
|
const pathToSetup = 'build/win32/i18n/messages.en.isl';
|
||||||
|
|
||||||
return es.merge(
|
return es.merge(
|
||||||
gulp.src(pathToMetadata).pipe(i18n.createXlfFilesForCoreBundle()),
|
gulp.src(pathToMetadata).pipe(i18n.createXlfFilesForCoreBundle()),
|
||||||
|
|||||||
@@ -18,8 +18,8 @@ const ansiColors = require("ansi-colors");
|
|||||||
const mkdirp = require('mkdirp');
|
const mkdirp = require('mkdirp');
|
||||||
const root = path.dirname(path.dirname(__dirname));
|
const root = path.dirname(path.dirname(__dirname));
|
||||||
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
||||||
const builtInExtensions = productjson.builtInExtensions;
|
const builtInExtensions = productjson.builtInExtensions || [];
|
||||||
const webBuiltInExtensions = productjson.webBuiltInExtensions;
|
const webBuiltInExtensions = productjson.webBuiltInExtensions || [];
|
||||||
const controlFilePath = path.join(os.homedir(), '.vscode-oss-dev', 'extensions', 'control.json');
|
const controlFilePath = path.join(os.homedir(), '.vscode-oss-dev', 'extensions', 'control.json');
|
||||||
const ENABLE_LOGGING = !process.env['VSCODE_BUILD_BUILTIN_EXTENSIONS_SILENCE_PLEASE'];
|
const ENABLE_LOGGING = !process.env['VSCODE_BUILD_BUILTIN_EXTENSIONS_SILENCE_PLEASE'];
|
||||||
function log(...messages) {
|
function log(...messages) {
|
||||||
|
|||||||
@@ -36,8 +36,8 @@ export interface IExtensionDefinition {
|
|||||||
|
|
||||||
const root = path.dirname(path.dirname(__dirname));
|
const root = path.dirname(path.dirname(__dirname));
|
||||||
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
||||||
const builtInExtensions = <IExtensionDefinition[]>productjson.builtInExtensions;
|
const builtInExtensions = <IExtensionDefinition[]>productjson.builtInExtensions || [];
|
||||||
const webBuiltInExtensions = <IExtensionDefinition[]>productjson.webBuiltInExtensions;
|
const webBuiltInExtensions = <IExtensionDefinition[]>productjson.webBuiltInExtensions || [];
|
||||||
const controlFilePath = path.join(os.homedir(), '.vscode-oss-dev', 'extensions', 'control.json');
|
const controlFilePath = path.join(os.homedir(), '.vscode-oss-dev', 'extensions', 'control.json');
|
||||||
const ENABLE_LOGGING = !process.env['VSCODE_BUILD_BUILTIN_EXTENSIONS_SILENCE_PLEASE'];
|
const ENABLE_LOGGING = !process.env['VSCODE_BUILD_BUILTIN_EXTENSIONS_SILENCE_PLEASE'];
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
/*---------------------------------------------------------------------------------------------
|
/*---------------------------------------------------------------------------------------------
|
||||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||||
* Licensed under the MIT License. See License.txt in the project root for license information.
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
const got_1 = require("got");
|
const got_1 = require("got");
|
||||||
@@ -12,8 +12,8 @@ const ansiColors = require("ansi-colors");
|
|||||||
const root = path.dirname(path.dirname(__dirname));
|
const root = path.dirname(path.dirname(__dirname));
|
||||||
const rootCG = path.join(root, 'extensionsCG');
|
const rootCG = path.join(root, 'extensionsCG');
|
||||||
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
||||||
const builtInExtensions = productjson.builtInExtensions;
|
const builtInExtensions = productjson.builtInExtensions || [];
|
||||||
const webBuiltInExtensions = productjson.webBuiltInExtensions;
|
const webBuiltInExtensions = productjson.webBuiltInExtensions || [];
|
||||||
const token = process.env['VSCODE_MIXIN_PASSWORD'] || process.env['GITHUB_TOKEN'] || undefined;
|
const token = process.env['VSCODE_MIXIN_PASSWORD'] || process.env['GITHUB_TOKEN'] || undefined;
|
||||||
const contentBasePath = 'raw.githubusercontent.com';
|
const contentBasePath = 'raw.githubusercontent.com';
|
||||||
const contentFileNames = ['package.json', 'package-lock.json', 'yarn.lock'];
|
const contentFileNames = ['package.json', 'package-lock.json', 'yarn.lock'];
|
||||||
@@ -25,7 +25,7 @@ async function downloadExtensionDetails(extension) {
|
|||||||
const promises = [];
|
const promises = [];
|
||||||
for (const fileName of contentFileNames) {
|
for (const fileName of contentFileNames) {
|
||||||
promises.push(new Promise(resolve => {
|
promises.push(new Promise(resolve => {
|
||||||
(0, got_1.default)(`${repositoryContentBaseUrl}/${fileName}`)
|
got_1.default(`${repositoryContentBaseUrl}/${fileName}`)
|
||||||
.then(response => {
|
.then(response => {
|
||||||
resolve({ fileName, body: response.rawBody });
|
resolve({ fileName, body: response.rawBody });
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
/*---------------------------------------------------------------------------------------------
|
/*---------------------------------------------------------------------------------------------
|
||||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||||
* Licensed under the MIT License. See License.txt in the project root for license information.
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
import got from 'got';
|
import got from 'got';
|
||||||
@@ -13,8 +13,8 @@ import { IExtensionDefinition } from './builtInExtensions';
|
|||||||
const root = path.dirname(path.dirname(__dirname));
|
const root = path.dirname(path.dirname(__dirname));
|
||||||
const rootCG = path.join(root, 'extensionsCG');
|
const rootCG = path.join(root, 'extensionsCG');
|
||||||
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
const productjson = JSON.parse(fs.readFileSync(path.join(__dirname, '../../product.json'), 'utf8'));
|
||||||
const builtInExtensions = <IExtensionDefinition[]>productjson.builtInExtensions;
|
const builtInExtensions = <IExtensionDefinition[]>productjson.builtInExtensions || [];
|
||||||
const webBuiltInExtensions = <IExtensionDefinition[]>productjson.webBuiltInExtensions;
|
const webBuiltInExtensions = <IExtensionDefinition[]>productjson.webBuiltInExtensions || [];
|
||||||
const token = process.env['VSCODE_MIXIN_PASSWORD'] || process.env['GITHUB_TOKEN'] || undefined;
|
const token = process.env['VSCODE_MIXIN_PASSWORD'] || process.env['GITHUB_TOKEN'] || undefined;
|
||||||
|
|
||||||
const contentBasePath = 'raw.githubusercontent.com';
|
const contentBasePath = 'raw.githubusercontent.com';
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ const es = require("event-stream");
|
|||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const monacodts = require("../monaco/api");
|
const monacodts = require("./monaco-api");
|
||||||
const nls = require("./nls");
|
const nls = require("./nls");
|
||||||
const reporter_1 = require("./reporter");
|
const reporter_1 = require("./reporter");
|
||||||
const util = require("./util");
|
const util = require("./util");
|
||||||
@@ -17,7 +17,7 @@ const fancyLog = require("fancy-log");
|
|||||||
const ansiColors = require("ansi-colors");
|
const ansiColors = require("ansi-colors");
|
||||||
const os = require("os");
|
const os = require("os");
|
||||||
const watch = require('./watch');
|
const watch = require('./watch');
|
||||||
const reporter = (0, reporter_1.createReporter)();
|
const reporter = reporter_1.createReporter();
|
||||||
function getTypeScriptCompilerOptions(src) {
|
function getTypeScriptCompilerOptions(src) {
|
||||||
const rootDir = path.join(__dirname, `../../${src}`);
|
const rootDir = path.join(__dirname, `../../${src}`);
|
||||||
let options = {};
|
let options = {};
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ import * as es from 'event-stream';
|
|||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
import * as gulp from 'gulp';
|
import * as gulp from 'gulp';
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as monacodts from '../monaco/api';
|
import * as monacodts from './monaco-api';
|
||||||
import * as nls from './nls';
|
import * as nls from './nls';
|
||||||
import { createReporter } from './reporter';
|
import { createReporter } from './reporter';
|
||||||
import * as util from './util';
|
import * as util from './util';
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ module.exports = new class {
|
|||||||
const configs = context.options;
|
const configs = context.options;
|
||||||
for (const config of configs) {
|
for (const config of configs) {
|
||||||
if (minimatch(context.getFilename(), config.target)) {
|
if (minimatch(context.getFilename(), config.target)) {
|
||||||
return (0, utils_1.createImportRuleListener)((node, value) => this._checkImport(context, config, node, value));
|
return utils_1.createImportRuleListener((node, value) => this._checkImport(context, config, node, value));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return {};
|
return {};
|
||||||
@@ -29,7 +29,7 @@ module.exports = new class {
|
|||||||
_checkImport(context, config, node, path) {
|
_checkImport(context, config, node, path) {
|
||||||
// resolve relative paths
|
// resolve relative paths
|
||||||
if (path[0] === '.') {
|
if (path[0] === '.') {
|
||||||
path = (0, path_1.join)(context.getFilename(), path);
|
path = path_1.join(context.getFilename(), path);
|
||||||
}
|
}
|
||||||
let restrictions;
|
let restrictions;
|
||||||
if (typeof config.restrictions === 'string') {
|
if (typeof config.restrictions === 'string') {
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ module.exports = new class {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
create(context) {
|
create(context) {
|
||||||
const fileDirname = (0, path_1.dirname)(context.getFilename());
|
const fileDirname = path_1.dirname(context.getFilename());
|
||||||
const parts = fileDirname.split(/\\|\//);
|
const parts = fileDirname.split(/\\|\//);
|
||||||
const ruleArgs = context.options[0];
|
const ruleArgs = context.options[0];
|
||||||
let config;
|
let config;
|
||||||
@@ -39,11 +39,11 @@ module.exports = new class {
|
|||||||
// nothing
|
// nothing
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
return (0, utils_1.createImportRuleListener)((node, path) => {
|
return utils_1.createImportRuleListener((node, path) => {
|
||||||
if (path[0] === '.') {
|
if (path[0] === '.') {
|
||||||
path = (0, path_1.join)((0, path_1.dirname)(context.getFilename()), path);
|
path = path_1.join(path_1.dirname(context.getFilename()), path);
|
||||||
}
|
}
|
||||||
const parts = (0, path_1.dirname)(path).split(/\\|\//);
|
const parts = path_1.dirname(path).split(/\\|\//);
|
||||||
for (let i = parts.length - 1; i >= 0; i--) {
|
for (let i = parts.length - 1; i >= 0; i--) {
|
||||||
const part = parts[i];
|
const part = parts[i];
|
||||||
if (config.allowed.has(part)) {
|
if (config.allowed.has(part)) {
|
||||||
|
|||||||
@@ -20,10 +20,10 @@ module.exports = new class NoNlsInStandaloneEditorRule {
|
|||||||
|| /vs(\/|\\)editor(\/|\\)editor.api/.test(fileName)
|
|| /vs(\/|\\)editor(\/|\\)editor.api/.test(fileName)
|
||||||
|| /vs(\/|\\)editor(\/|\\)editor.main/.test(fileName)
|
|| /vs(\/|\\)editor(\/|\\)editor.main/.test(fileName)
|
||||||
|| /vs(\/|\\)editor(\/|\\)editor.worker/.test(fileName)) {
|
|| /vs(\/|\\)editor(\/|\\)editor.worker/.test(fileName)) {
|
||||||
return (0, utils_1.createImportRuleListener)((node, path) => {
|
return utils_1.createImportRuleListener((node, path) => {
|
||||||
// resolve relative paths
|
// resolve relative paths
|
||||||
if (path[0] === '.') {
|
if (path[0] === '.') {
|
||||||
path = (0, path_1.join)(context.getFilename(), path);
|
path = path_1.join(context.getFilename(), path);
|
||||||
}
|
}
|
||||||
if (/vs(\/|\\)nls/.test(path)) {
|
if (/vs(\/|\\)nls/.test(path)) {
|
||||||
context.report({
|
context.report({
|
||||||
|
|||||||
@@ -21,10 +21,10 @@ module.exports = new class NoNlsInStandaloneEditorRule {
|
|||||||
// the vs/editor folder is allowed to use the standalone editor
|
// the vs/editor folder is allowed to use the standalone editor
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
return (0, utils_1.createImportRuleListener)((node, path) => {
|
return utils_1.createImportRuleListener((node, path) => {
|
||||||
// resolve relative paths
|
// resolve relative paths
|
||||||
if (path[0] === '.') {
|
if (path[0] === '.') {
|
||||||
path = (0, path_1.join)(context.getFilename(), path);
|
path = path_1.join(context.getFilename(), path);
|
||||||
}
|
}
|
||||||
if (/vs(\/|\\)editor(\/|\\)standalone(\/|\\)/.test(path)
|
if (/vs(\/|\\)editor(\/|\\)standalone(\/|\\)/.test(path)
|
||||||
|| /vs(\/|\\)editor(\/|\\)common(\/|\\)standalone(\/|\\)/.test(path)
|
|| /vs(\/|\\)editor(\/|\\)common(\/|\\)standalone(\/|\\)/.test(path)
|
||||||
|
|||||||
@@ -2,144 +2,124 @@
|
|||||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
// FORKED FROM https://github.com/eslint/eslint/blob/b23ad0d789a909baf8d7c41a35bc53df932eaf30/lib/rules/no-unused-expressions.js
|
// FORKED FROM https://github.com/eslint/eslint/blob/b23ad0d789a909baf8d7c41a35bc53df932eaf30/lib/rules/no-unused-expressions.js
|
||||||
// and added support for `OptionalCallExpression`, see https://github.com/facebook/create-react-app/issues/8107 and https://github.com/eslint/eslint/issues/12642
|
// and added support for `OptionalCallExpression`, see https://github.com/facebook/create-react-app/issues/8107 and https://github.com/eslint/eslint/issues/12642
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @fileoverview Flag expressions in statement position that do not side effect
|
* @fileoverview Flag expressions in statement position that do not side effect
|
||||||
* @author Michael Ficarra
|
* @author Michael Ficarra
|
||||||
*/
|
*/
|
||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// Rule Definition
|
// Rule Definition
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
meta: {
|
meta: {
|
||||||
type: 'suggestion',
|
type: 'suggestion',
|
||||||
|
docs: {
|
||||||
docs: {
|
description: 'disallow unused expressions',
|
||||||
description: 'disallow unused expressions',
|
category: 'Best Practices',
|
||||||
category: 'Best Practices',
|
recommended: false,
|
||||||
recommended: false,
|
url: 'https://eslint.org/docs/rules/no-unused-expressions'
|
||||||
url: 'https://eslint.org/docs/rules/no-unused-expressions'
|
},
|
||||||
},
|
schema: [
|
||||||
|
{
|
||||||
schema: [
|
type: 'object',
|
||||||
{
|
properties: {
|
||||||
type: 'object',
|
allowShortCircuit: {
|
||||||
properties: {
|
type: 'boolean',
|
||||||
allowShortCircuit: {
|
default: false
|
||||||
type: 'boolean',
|
},
|
||||||
default: false
|
allowTernary: {
|
||||||
},
|
type: 'boolean',
|
||||||
allowTernary: {
|
default: false
|
||||||
type: 'boolean',
|
},
|
||||||
default: false
|
allowTaggedTemplates: {
|
||||||
},
|
type: 'boolean',
|
||||||
allowTaggedTemplates: {
|
default: false
|
||||||
type: 'boolean',
|
}
|
||||||
default: false
|
},
|
||||||
}
|
additionalProperties: false
|
||||||
},
|
}
|
||||||
additionalProperties: false
|
]
|
||||||
}
|
},
|
||||||
]
|
create(context) {
|
||||||
},
|
const config = context.options[0] || {},
|
||||||
|
allowShortCircuit = config.allowShortCircuit || false,
|
||||||
create(context) {
|
allowTernary = config.allowTernary || false,
|
||||||
const config = context.options[0] || {},
|
allowTaggedTemplates = config.allowTaggedTemplates || false;
|
||||||
allowShortCircuit = config.allowShortCircuit || false,
|
// eslint-disable-next-line jsdoc/require-description
|
||||||
allowTernary = config.allowTernary || false,
|
|
||||||
allowTaggedTemplates = config.allowTaggedTemplates || false;
|
|
||||||
|
|
||||||
// eslint-disable-next-line jsdoc/require-description
|
|
||||||
/**
|
/**
|
||||||
* @param {ASTNode} node any node
|
* @param node any node
|
||||||
* @returns {boolean} whether the given node structurally represents a directive
|
* @returns whether the given node structurally represents a directive
|
||||||
*/
|
*/
|
||||||
function looksLikeDirective(node) {
|
function looksLikeDirective(node) {
|
||||||
return node.type === 'ExpressionStatement' &&
|
return node.type === 'ExpressionStatement' &&
|
||||||
node.expression.type === 'Literal' && typeof node.expression.value === 'string';
|
node.expression.type === 'Literal' && typeof node.expression.value === 'string';
|
||||||
}
|
}
|
||||||
|
// eslint-disable-next-line jsdoc/require-description
|
||||||
// eslint-disable-next-line jsdoc/require-description
|
|
||||||
/**
|
/**
|
||||||
* @param {Function} predicate ([a] -> Boolean) the function used to make the determination
|
* @param predicate ([a] -> Boolean) the function used to make the determination
|
||||||
* @param {a[]} list the input list
|
* @param list the input list
|
||||||
* @returns {a[]} the leading sequence of members in the given list that pass the given predicate
|
* @returns the leading sequence of members in the given list that pass the given predicate
|
||||||
*/
|
*/
|
||||||
function takeWhile(predicate, list) {
|
function takeWhile(predicate, list) {
|
||||||
for (let i = 0; i < list.length; ++i) {
|
for (let i = 0; i < list.length; ++i) {
|
||||||
if (!predicate(list[i])) {
|
if (!predicate(list[i])) {
|
||||||
return list.slice(0, i);
|
return list.slice(0, i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return list.slice();
|
return list.slice();
|
||||||
}
|
}
|
||||||
|
// eslint-disable-next-line jsdoc/require-description
|
||||||
// eslint-disable-next-line jsdoc/require-description
|
|
||||||
/**
|
/**
|
||||||
* @param {ASTNode} node a Program or BlockStatement node
|
* @param node a Program or BlockStatement node
|
||||||
* @returns {ASTNode[]} the leading sequence of directive nodes in the given node's body
|
* @returns the leading sequence of directive nodes in the given node's body
|
||||||
*/
|
*/
|
||||||
function directives(node) {
|
function directives(node) {
|
||||||
return takeWhile(looksLikeDirective, node.body);
|
return takeWhile(looksLikeDirective, node.body);
|
||||||
}
|
}
|
||||||
|
// eslint-disable-next-line jsdoc/require-description
|
||||||
// eslint-disable-next-line jsdoc/require-description
|
|
||||||
/**
|
/**
|
||||||
* @param {ASTNode} node any node
|
* @param node any node
|
||||||
* @param {ASTNode[]} ancestors the given node's ancestors
|
* @param ancestors the given node's ancestors
|
||||||
* @returns {boolean} whether the given node is considered a directive in its current position
|
* @returns whether the given node is considered a directive in its current position
|
||||||
*/
|
*/
|
||||||
function isDirective(node, ancestors) {
|
function isDirective(node, ancestors) {
|
||||||
const parent = ancestors[ancestors.length - 1],
|
const parent = ancestors[ancestors.length - 1], grandparent = ancestors[ancestors.length - 2];
|
||||||
grandparent = ancestors[ancestors.length - 2];
|
return (parent.type === 'Program' || parent.type === 'BlockStatement' &&
|
||||||
|
(/Function/u.test(grandparent.type))) &&
|
||||||
return (parent.type === 'Program' || parent.type === 'BlockStatement' &&
|
directives(parent).indexOf(node) >= 0;
|
||||||
(/Function/u.test(grandparent.type))) &&
|
}
|
||||||
directives(parent).indexOf(node) >= 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Determines whether or not a given node is a valid expression. Recurses on short circuit eval and ternary nodes if enabled by flags.
|
* Determines whether or not a given node is a valid expression. Recurses on short circuit eval and ternary nodes if enabled by flags.
|
||||||
* @param {ASTNode} node any node
|
* @param node any node
|
||||||
* @returns {boolean} whether the given node is a valid expression
|
* @returns whether the given node is a valid expression
|
||||||
*/
|
*/
|
||||||
function isValidExpression(node) {
|
function isValidExpression(node) {
|
||||||
if (allowTernary) {
|
if (allowTernary) {
|
||||||
|
// Recursive check for ternary and logical expressions
|
||||||
// Recursive check for ternary and logical expressions
|
if (node.type === 'ConditionalExpression') {
|
||||||
if (node.type === 'ConditionalExpression') {
|
return isValidExpression(node.consequent) && isValidExpression(node.alternate);
|
||||||
return isValidExpression(node.consequent) && isValidExpression(node.alternate);
|
}
|
||||||
}
|
}
|
||||||
}
|
if (allowShortCircuit) {
|
||||||
|
if (node.type === 'LogicalExpression') {
|
||||||
if (allowShortCircuit) {
|
return isValidExpression(node.right);
|
||||||
if (node.type === 'LogicalExpression') {
|
}
|
||||||
return isValidExpression(node.right);
|
}
|
||||||
}
|
if (allowTaggedTemplates && node.type === 'TaggedTemplateExpression') {
|
||||||
}
|
return true;
|
||||||
|
}
|
||||||
if (allowTaggedTemplates && node.type === 'TaggedTemplateExpression') {
|
return /^(?:Assignment|OptionalCall|Call|New|Update|Yield|Await)Expression$/u.test(node.type) ||
|
||||||
return true;
|
(node.type === 'UnaryExpression' && ['delete', 'void'].indexOf(node.operator) >= 0);
|
||||||
}
|
}
|
||||||
|
return {
|
||||||
return /^(?:Assignment|OptionalCall|Call|New|Update|Yield|Await)Expression$/u.test(node.type) ||
|
ExpressionStatement(node) {
|
||||||
(node.type === 'UnaryExpression' && ['delete', 'void'].indexOf(node.operator) >= 0);
|
if (!isValidExpression(node.expression) && !isDirective(node, context.getAncestors())) {
|
||||||
}
|
context.report({ node: node, message: 'Expected an assignment or function call and instead saw an expression.' });
|
||||||
|
}
|
||||||
return {
|
}
|
||||||
ExpressionStatement(node) {
|
};
|
||||||
if (!isValidExpression(node.expression) && !isDirective(node, context.getAncestors())) {
|
}
|
||||||
context.report({ node, message: 'Expected an assignment or function call and instead saw an expression.' });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ module.exports = new (_a = class TranslationRemind {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
create(context) {
|
create(context) {
|
||||||
return (0, utils_1.createImportRuleListener)((node, path) => this._checkImport(context, node, path));
|
return utils_1.createImportRuleListener((node, path) => this._checkImport(context, node, path));
|
||||||
}
|
}
|
||||||
_checkImport(context, node, path) {
|
_checkImport(context, node, path) {
|
||||||
if (path !== TranslationRemind.NLS_MODULE) {
|
if (path !== TranslationRemind.NLS_MODULE) {
|
||||||
@@ -31,7 +31,7 @@ module.exports = new (_a = class TranslationRemind {
|
|||||||
let resourceDefined = false;
|
let resourceDefined = false;
|
||||||
let json;
|
let json;
|
||||||
try {
|
try {
|
||||||
json = (0, fs_1.readFileSync)('./build/lib/i18n.resources.json', 'utf8');
|
json = fs_1.readFileSync('./build/lib/i18n.resources.json', 'utf8');
|
||||||
}
|
}
|
||||||
catch (e) {
|
catch (e) {
|
||||||
console.error('[translation-remind rule]: File with resources to pull from Transifex was not found. Aborting translation resource check for newly defined workbench part/service.');
|
console.error('[translation-remind rule]: File with resources to pull from Transifex was not found. Aborting translation resource check for newly defined workbench part/service.');
|
||||||
|
|||||||
45
build/lib/eslint/vscode-dts-vscode-in-comments.js
Normal file
45
build/lib/eslint/vscode-dts-vscode-in-comments.js
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
"use strict";
|
||||||
|
/*---------------------------------------------------------------------------------------------
|
||||||
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||||
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
||||||
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
module.exports = new class ApiVsCodeInComments {
|
||||||
|
constructor() {
|
||||||
|
this.meta = {
|
||||||
|
messages: {
|
||||||
|
comment: `Don't use the term 'vs code' in comments`
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
create(context) {
|
||||||
|
const sourceCode = context.getSourceCode();
|
||||||
|
return {
|
||||||
|
['Program']: (_node) => {
|
||||||
|
for (const comment of sourceCode.getAllComments()) {
|
||||||
|
if (comment.type !== 'Block') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!comment.range) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
const startIndex = comment.range[0] + '/*'.length;
|
||||||
|
const re = /vs code/ig;
|
||||||
|
let match;
|
||||||
|
while ((match = re.exec(comment.value))) {
|
||||||
|
// Allow using 'VS Code' in quotes
|
||||||
|
if (comment.value[match.index - 1] === `'` && comment.value[match.index + match[0].length] === `'`) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// Types for eslint seem incorrect
|
||||||
|
const start = sourceCode.getLocFromIndex(startIndex + match.index);
|
||||||
|
const end = sourceCode.getLocFromIndex(startIndex + match.index + match[0].length);
|
||||||
|
context.report({
|
||||||
|
messageId: 'comment',
|
||||||
|
loc: { start, end }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
};
|
||||||
53
build/lib/eslint/vscode-dts-vscode-in-comments.ts
Normal file
53
build/lib/eslint/vscode-dts-vscode-in-comments.ts
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
/*---------------------------------------------------------------------------------------------
|
||||||
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||||
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||||
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
import * as eslint from 'eslint';
|
||||||
|
import type * as estree from 'estree';
|
||||||
|
|
||||||
|
export = new class ApiVsCodeInComments implements eslint.Rule.RuleModule {
|
||||||
|
|
||||||
|
readonly meta: eslint.Rule.RuleMetaData = {
|
||||||
|
messages: {
|
||||||
|
comment: `Don't use the term 'vs code' in comments`
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
create(context: eslint.Rule.RuleContext): eslint.Rule.RuleListener {
|
||||||
|
|
||||||
|
const sourceCode = context.getSourceCode();
|
||||||
|
|
||||||
|
return {
|
||||||
|
['Program']: (_node: any) => {
|
||||||
|
|
||||||
|
for (const comment of sourceCode.getAllComments()) {
|
||||||
|
if (comment.type !== 'Block') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (!comment.range) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
const startIndex = comment.range[0] + '/*'.length;
|
||||||
|
const re = /vs code/ig;
|
||||||
|
let match: RegExpExecArray | null;
|
||||||
|
while ((match = re.exec(comment.value))) {
|
||||||
|
// Allow using 'VS Code' in quotes
|
||||||
|
if (comment.value[match.index - 1] === `'` && comment.value[match.index + match[0].length] === `'`) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Types for eslint seem incorrect
|
||||||
|
const start = sourceCode.getLocFromIndex(startIndex + match.index) as any as estree.Position;
|
||||||
|
const end = sourceCode.getLocFromIndex(startIndex + match.index + match[0].length) as any as estree.Position;
|
||||||
|
context.report({
|
||||||
|
messageId: 'comment',
|
||||||
|
loc: { start, end }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -4,9 +4,10 @@
|
|||||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.translatePackageJSON = exports.packageRebuildExtensionsStream = exports.cleanRebuildExtensions = exports.packageExternalExtensionsStream = exports.scanBuiltinExtensions = exports.packageMarketplaceExtensionsStream = exports.packageLocalExtensionsStream = exports.vscodeExternalExtensions = exports.fromMarketplace = exports.fromLocalNormal = exports.fromLocal = void 0;
|
exports.buildExtensionMedia = exports.webpackExtensions = exports.translatePackageJSON = exports.packageRebuildExtensionsStream = exports.cleanRebuildExtensions = exports.packageExternalExtensionsStream = exports.scanBuiltinExtensions = exports.packageMarketplaceExtensionsStream = exports.packageLocalExtensionsStream = exports.vscodeExternalExtensions = exports.fromMarketplace = exports.fromLocalNormal = exports.fromLocal = void 0;
|
||||||
const es = require("event-stream");
|
const es = require("event-stream");
|
||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
|
const cp = require("child_process");
|
||||||
const glob = require("glob");
|
const glob = require("glob");
|
||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
@@ -23,7 +24,7 @@ const jsoncParser = require("jsonc-parser");
|
|||||||
const util = require('./util');
|
const util = require('./util');
|
||||||
const root = path.dirname(path.dirname(__dirname));
|
const root = path.dirname(path.dirname(__dirname));
|
||||||
const commit = util.getVersion(root);
|
const commit = util.getVersion(root);
|
||||||
const sourceMappingURLBase = `https://sqlopsbuilds.blob.core.windows.net/sourcemaps/${commit}`;
|
const sourceMappingURLBase = `https://sqlopsbuilds.blob.core.windows.net/sourcemaps/${commit}`; // {{SQL CARBON EDIT}}
|
||||||
function minifyExtensionResources(input) {
|
function minifyExtensionResources(input) {
|
||||||
const jsonFilter = filter(['**/*.json', '**/*.code-snippets'], { restore: true });
|
const jsonFilter = filter(['**/*.json', '**/*.code-snippets'], { restore: true });
|
||||||
return input
|
return input
|
||||||
@@ -144,7 +145,7 @@ function fromLocalWebpack(extensionPath, webpackConfigFileName) {
|
|||||||
console.error(packagedDependencies);
|
console.error(packagedDependencies);
|
||||||
result.emit('error', err);
|
result.emit('error', err);
|
||||||
});
|
});
|
||||||
return result.pipe((0, stats_1.createStatsStream)(path.basename(extensionPath)));
|
return result.pipe(stats_1.createStatsStream(path.basename(extensionPath)));
|
||||||
}
|
}
|
||||||
function fromLocalNormal(extensionPath) {
|
function fromLocalNormal(extensionPath) {
|
||||||
const result = es.through();
|
const result = es.through();
|
||||||
@@ -162,7 +163,7 @@ function fromLocalNormal(extensionPath) {
|
|||||||
es.readArray(files).pipe(result);
|
es.readArray(files).pipe(result);
|
||||||
})
|
})
|
||||||
.catch(err => result.emit('error', err));
|
.catch(err => result.emit('error', err));
|
||||||
return result.pipe((0, stats_1.createStatsStream)(path.basename(extensionPath)));
|
return result.pipe(stats_1.createStatsStream(path.basename(extensionPath)));
|
||||||
}
|
}
|
||||||
exports.fromLocalNormal = fromLocalNormal;
|
exports.fromLocalNormal = fromLocalNormal;
|
||||||
const baseHeaders = {
|
const baseHeaders = {
|
||||||
@@ -174,7 +175,7 @@ function fromMarketplace(extensionName, version, metadata) {
|
|||||||
const remote = require('gulp-remote-retry-src');
|
const remote = require('gulp-remote-retry-src');
|
||||||
const json = require('gulp-json-editor');
|
const json = require('gulp-json-editor');
|
||||||
const [, name] = extensionName.split('.');
|
const [, name] = extensionName.split('.');
|
||||||
const url = `https://sqlopsextensions.blob.core.windows.net/extensions/${name}/${name}-${version}.vsix`;
|
const url = `https://sqlopsextensions.blob.core.windows.net/extensions/${name}/${name}-${version}.vsix`; // {{SQL CARBON EDIT}}
|
||||||
fancyLog('Downloading extension:', ansiColors.yellow(`${extensionName}@${version}`), '...');
|
fancyLog('Downloading extension:', ansiColors.yellow(`${extensionName}@${version}`), '...');
|
||||||
const options = {
|
const options = {
|
||||||
base: url,
|
base: url,
|
||||||
@@ -346,6 +347,7 @@ function scanBuiltinExtensions(extensionsRoot, exclude = []) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.scanBuiltinExtensions = scanBuiltinExtensions;
|
exports.scanBuiltinExtensions = scanBuiltinExtensions;
|
||||||
|
// {{SQL CARBON EDIT}} start
|
||||||
function packageExternalExtensionsStream() {
|
function packageExternalExtensionsStream() {
|
||||||
const extenalExtensionDescriptions = glob.sync('extensions/*/package.json')
|
const extenalExtensionDescriptions = glob.sync('extensions/*/package.json')
|
||||||
.map(manifestPath => {
|
.map(manifestPath => {
|
||||||
@@ -361,7 +363,6 @@ function packageExternalExtensionsStream() {
|
|||||||
return es.merge(builtExtensions);
|
return es.merge(builtExtensions);
|
||||||
}
|
}
|
||||||
exports.packageExternalExtensionsStream = packageExternalExtensionsStream;
|
exports.packageExternalExtensionsStream = packageExternalExtensionsStream;
|
||||||
// {{SQL CARBON EDIT}} start
|
|
||||||
function cleanRebuildExtensions(root) {
|
function cleanRebuildExtensions(root) {
|
||||||
return Promise.all(rebuildExtensions.map(async (e) => {
|
return Promise.all(rebuildExtensions.map(async (e) => {
|
||||||
await util2.rimraf(path.join(root, e))();
|
await util2.rimraf(path.join(root, e))();
|
||||||
@@ -408,3 +409,132 @@ function translatePackageJSON(packageJSON, packageNLSPath) {
|
|||||||
return packageJSON;
|
return packageJSON;
|
||||||
}
|
}
|
||||||
exports.translatePackageJSON = translatePackageJSON;
|
exports.translatePackageJSON = translatePackageJSON;
|
||||||
|
const extensionsPath = path.join(root, 'extensions');
|
||||||
|
// Additional projects to webpack. These typically build code for webviews
|
||||||
|
const webpackMediaConfigFiles = [
|
||||||
|
'markdown-language-features/webpack.config.js',
|
||||||
|
'simple-browser/webpack.config.js',
|
||||||
|
];
|
||||||
|
// Additional projects to run esbuild on. These typically build code for webviews
|
||||||
|
const esbuildMediaScripts = [
|
||||||
|
'markdown-language-features/esbuild.js',
|
||||||
|
'markdown-math/esbuild.js',
|
||||||
|
];
|
||||||
|
async function webpackExtensions(taskName, isWatch, webpackConfigLocations) {
|
||||||
|
const webpack = require('webpack');
|
||||||
|
const webpackConfigs = [];
|
||||||
|
for (const { configPath, outputRoot } of webpackConfigLocations) {
|
||||||
|
const configOrFnOrArray = require(configPath);
|
||||||
|
function addConfig(configOrFn) {
|
||||||
|
let config;
|
||||||
|
if (typeof configOrFn === 'function') {
|
||||||
|
config = configOrFn({}, {});
|
||||||
|
webpackConfigs.push(config);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
config = configOrFn;
|
||||||
|
}
|
||||||
|
if (outputRoot) {
|
||||||
|
config.output.path = path.join(outputRoot, path.relative(path.dirname(configPath), config.output.path));
|
||||||
|
}
|
||||||
|
webpackConfigs.push(configOrFn);
|
||||||
|
}
|
||||||
|
addConfig(configOrFnOrArray);
|
||||||
|
}
|
||||||
|
function reporter(fullStats) {
|
||||||
|
if (Array.isArray(fullStats.children)) {
|
||||||
|
for (const stats of fullStats.children) {
|
||||||
|
const outputPath = stats.outputPath;
|
||||||
|
if (outputPath) {
|
||||||
|
const relativePath = path.relative(extensionsPath, outputPath).replace(/\\/g, '/');
|
||||||
|
const match = relativePath.match(/[^\/]+(\/server|\/client)?/);
|
||||||
|
fancyLog(`Finished ${ansiColors.green(taskName)} ${ansiColors.cyan(match[0])} with ${stats.errors.length} errors.`);
|
||||||
|
}
|
||||||
|
if (Array.isArray(stats.errors)) {
|
||||||
|
stats.errors.forEach((error) => {
|
||||||
|
fancyLog.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (Array.isArray(stats.warnings)) {
|
||||||
|
stats.warnings.forEach((warning) => {
|
||||||
|
fancyLog.warn(warning);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
if (isWatch) {
|
||||||
|
webpack(webpackConfigs).watch({}, (err, stats) => {
|
||||||
|
if (err) {
|
||||||
|
reject();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
reporter(stats.toJson());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
webpack(webpackConfigs).run((err, stats) => {
|
||||||
|
if (err) {
|
||||||
|
fancyLog.error(err);
|
||||||
|
reject();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
reporter(stats.toJson());
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
exports.webpackExtensions = webpackExtensions;
|
||||||
|
async function esbuildExtensions(taskName, isWatch, scripts) {
|
||||||
|
function reporter(stdError, script) {
|
||||||
|
const matches = (stdError || '').match(/\> (.+): error: (.+)?/g);
|
||||||
|
fancyLog(`Finished ${ansiColors.green(taskName)} ${script} with ${matches ? matches.length : 0} errors.`);
|
||||||
|
for (const match of matches || []) {
|
||||||
|
fancyLog.error(match);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const tasks = scripts.map(({ script, outputRoot }) => {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
const args = [script];
|
||||||
|
if (isWatch) {
|
||||||
|
args.push('--watch');
|
||||||
|
}
|
||||||
|
if (outputRoot) {
|
||||||
|
args.push('--outputRoot', outputRoot);
|
||||||
|
}
|
||||||
|
const proc = cp.execFile(process.argv[0], args, {}, (error, _stdout, stderr) => {
|
||||||
|
if (error) {
|
||||||
|
return reject(error);
|
||||||
|
}
|
||||||
|
reporter(stderr, script);
|
||||||
|
if (stderr) {
|
||||||
|
return reject();
|
||||||
|
}
|
||||||
|
return resolve();
|
||||||
|
});
|
||||||
|
proc.stdout.on('data', (data) => {
|
||||||
|
fancyLog(`${ansiColors.green(taskName)}: ${data.toString('utf8')}`);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return Promise.all(tasks);
|
||||||
|
}
|
||||||
|
async function buildExtensionMedia(isWatch, outputRoot) {
|
||||||
|
return Promise.all([
|
||||||
|
webpackExtensions('webpacking extension media', isWatch, webpackMediaConfigFiles.map(p => {
|
||||||
|
return {
|
||||||
|
configPath: path.join(extensionsPath, p),
|
||||||
|
outputRoot: outputRoot ? path.join(root, outputRoot, path.dirname(p)) : undefined
|
||||||
|
};
|
||||||
|
})),
|
||||||
|
esbuildExtensions('esbuilding extension media', isWatch, esbuildMediaScripts.map(p => ({
|
||||||
|
script: path.join(extensionsPath, p),
|
||||||
|
outputRoot: outputRoot ? path.join(root, outputRoot, path.dirname(p)) : undefined
|
||||||
|
}))),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
exports.buildExtensionMedia = buildExtensionMedia;
|
||||||
|
|||||||
@@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
import * as es from 'event-stream';
|
import * as es from 'event-stream';
|
||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
|
import * as cp from 'child_process';
|
||||||
import * as glob from 'glob';
|
import * as glob from 'glob';
|
||||||
import * as gulp from 'gulp';
|
import * as gulp from 'gulp';
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
@@ -19,10 +20,11 @@ import * as fancyLog from 'fancy-log';
|
|||||||
import * as ansiColors from 'ansi-colors';
|
import * as ansiColors from 'ansi-colors';
|
||||||
const buffer = require('gulp-buffer');
|
const buffer = require('gulp-buffer');
|
||||||
import * as jsoncParser from 'jsonc-parser';
|
import * as jsoncParser from 'jsonc-parser';
|
||||||
|
import webpack = require('webpack');
|
||||||
const util = require('./util');
|
const util = require('./util');
|
||||||
const root = path.dirname(path.dirname(__dirname));
|
const root = path.dirname(path.dirname(__dirname));
|
||||||
const commit = util.getVersion(root);
|
const commit = util.getVersion(root);
|
||||||
const sourceMappingURLBase = `https://sqlopsbuilds.blob.core.windows.net/sourcemaps/${commit}`;
|
const sourceMappingURLBase = `https://sqlopsbuilds.blob.core.windows.net/sourcemaps/${commit}`; // {{SQL CARBON EDIT}}
|
||||||
|
|
||||||
function minifyExtensionResources(input: Stream): Stream {
|
function minifyExtensionResources(input: Stream): Stream {
|
||||||
const jsonFilter = filter(['**/*.json', '**/*.code-snippets'], { restore: true });
|
const jsonFilter = filter(['**/*.json', '**/*.code-snippets'], { restore: true });
|
||||||
@@ -205,7 +207,7 @@ export function fromMarketplace(extensionName: string, version: string, metadata
|
|||||||
const json = require('gulp-json-editor') as typeof import('gulp-json-editor');
|
const json = require('gulp-json-editor') as typeof import('gulp-json-editor');
|
||||||
|
|
||||||
const [, name] = extensionName.split('.');
|
const [, name] = extensionName.split('.');
|
||||||
const url = `https://sqlopsextensions.blob.core.windows.net/extensions/${name}/${name}-${version}.vsix`;
|
const url = `https://sqlopsextensions.blob.core.windows.net/extensions/${name}/${name}-${version}.vsix`; // {{SQL CARBON EDIT}}
|
||||||
|
|
||||||
fancyLog('Downloading extension:', ansiColors.yellow(`${extensionName}@${version}`), '...');
|
fancyLog('Downloading extension:', ansiColors.yellow(`${extensionName}@${version}`), '...');
|
||||||
|
|
||||||
@@ -424,6 +426,7 @@ export function scanBuiltinExtensions(extensionsRoot: string, exclude: string[]
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// {{SQL CARBON EDIT}} start
|
||||||
export function packageExternalExtensionsStream(): NodeJS.ReadWriteStream {
|
export function packageExternalExtensionsStream(): NodeJS.ReadWriteStream {
|
||||||
const extenalExtensionDescriptions = (<string[]>glob.sync('extensions/*/package.json'))
|
const extenalExtensionDescriptions = (<string[]>glob.sync('extensions/*/package.json'))
|
||||||
.map(manifestPath => {
|
.map(manifestPath => {
|
||||||
@@ -441,7 +444,6 @@ export function packageExternalExtensionsStream(): NodeJS.ReadWriteStream {
|
|||||||
return es.merge(builtExtensions);
|
return es.merge(builtExtensions);
|
||||||
}
|
}
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}} start
|
|
||||||
export function cleanRebuildExtensions(root: string): Promise<void> {
|
export function cleanRebuildExtensions(root: string): Promise<void> {
|
||||||
return Promise.all(rebuildExtensions.map(async e => {
|
return Promise.all(rebuildExtensions.map(async e => {
|
||||||
await util2.rimraf(path.join(root, e))();
|
await util2.rimraf(path.join(root, e))();
|
||||||
@@ -487,3 +489,138 @@ export function translatePackageJSON(packageJSON: string, packageNLSPath: string
|
|||||||
translate(packageJSON);
|
translate(packageJSON);
|
||||||
return packageJSON;
|
return packageJSON;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const extensionsPath = path.join(root, 'extensions');
|
||||||
|
|
||||||
|
// Additional projects to webpack. These typically build code for webviews
|
||||||
|
const webpackMediaConfigFiles = [
|
||||||
|
'markdown-language-features/webpack.config.js',
|
||||||
|
'simple-browser/webpack.config.js',
|
||||||
|
];
|
||||||
|
|
||||||
|
// Additional projects to run esbuild on. These typically build code for webviews
|
||||||
|
const esbuildMediaScripts = [
|
||||||
|
'markdown-language-features/esbuild.js',
|
||||||
|
'markdown-math/esbuild.js',
|
||||||
|
];
|
||||||
|
|
||||||
|
export async function webpackExtensions(taskName: string, isWatch: boolean, webpackConfigLocations: { configPath: string, outputRoot?: string }[]) {
|
||||||
|
const webpack = require('webpack') as typeof import('webpack');
|
||||||
|
|
||||||
|
const webpackConfigs: webpack.Configuration[] = [];
|
||||||
|
|
||||||
|
for (const { configPath, outputRoot } of webpackConfigLocations) {
|
||||||
|
const configOrFnOrArray = require(configPath);
|
||||||
|
function addConfig(configOrFn: webpack.Configuration | Function) {
|
||||||
|
let config;
|
||||||
|
if (typeof configOrFn === 'function') {
|
||||||
|
config = configOrFn({}, {});
|
||||||
|
webpackConfigs.push(config);
|
||||||
|
} else {
|
||||||
|
config = configOrFn;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (outputRoot) {
|
||||||
|
config.output.path = path.join(outputRoot, path.relative(path.dirname(configPath), config.output.path));
|
||||||
|
}
|
||||||
|
|
||||||
|
webpackConfigs.push(configOrFn);
|
||||||
|
}
|
||||||
|
addConfig(configOrFnOrArray);
|
||||||
|
}
|
||||||
|
function reporter(fullStats: any) {
|
||||||
|
if (Array.isArray(fullStats.children)) {
|
||||||
|
for (const stats of fullStats.children) {
|
||||||
|
const outputPath = stats.outputPath;
|
||||||
|
if (outputPath) {
|
||||||
|
const relativePath = path.relative(extensionsPath, outputPath).replace(/\\/g, '/');
|
||||||
|
const match = relativePath.match(/[^\/]+(\/server|\/client)?/);
|
||||||
|
fancyLog(`Finished ${ansiColors.green(taskName)} ${ansiColors.cyan(match![0])} with ${stats.errors.length} errors.`);
|
||||||
|
}
|
||||||
|
if (Array.isArray(stats.errors)) {
|
||||||
|
stats.errors.forEach((error: any) => {
|
||||||
|
fancyLog.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (Array.isArray(stats.warnings)) {
|
||||||
|
stats.warnings.forEach((warning: any) => {
|
||||||
|
fancyLog.warn(warning);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new Promise<void>((resolve, reject) => {
|
||||||
|
if (isWatch) {
|
||||||
|
webpack(webpackConfigs).watch({}, (err, stats) => {
|
||||||
|
if (err) {
|
||||||
|
reject();
|
||||||
|
} else {
|
||||||
|
reporter(stats.toJson());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
webpack(webpackConfigs).run((err, stats) => {
|
||||||
|
if (err) {
|
||||||
|
fancyLog.error(err);
|
||||||
|
reject();
|
||||||
|
} else {
|
||||||
|
reporter(stats.toJson());
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async function esbuildExtensions(taskName: string, isWatch: boolean, scripts: { script: string, outputRoot?: string }[]) {
|
||||||
|
function reporter(stdError: string, script: string) {
|
||||||
|
const matches = (stdError || '').match(/\> (.+): error: (.+)?/g);
|
||||||
|
fancyLog(`Finished ${ansiColors.green(taskName)} ${script} with ${matches ? matches.length : 0} errors.`);
|
||||||
|
for (const match of matches || []) {
|
||||||
|
fancyLog.error(match);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const tasks = scripts.map(({ script, outputRoot }) => {
|
||||||
|
return new Promise<void>((resolve, reject) => {
|
||||||
|
const args = [script];
|
||||||
|
if (isWatch) {
|
||||||
|
args.push('--watch');
|
||||||
|
}
|
||||||
|
if (outputRoot) {
|
||||||
|
args.push('--outputRoot', outputRoot);
|
||||||
|
}
|
||||||
|
const proc = cp.execFile(process.argv[0], args, {}, (error, _stdout, stderr) => {
|
||||||
|
if (error) {
|
||||||
|
return reject(error);
|
||||||
|
}
|
||||||
|
reporter(stderr, script);
|
||||||
|
if (stderr) {
|
||||||
|
return reject();
|
||||||
|
}
|
||||||
|
return resolve();
|
||||||
|
});
|
||||||
|
|
||||||
|
proc.stdout!.on('data', (data) => {
|
||||||
|
fancyLog(`${ansiColors.green(taskName)}: ${data.toString('utf8')}`);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return Promise.all(tasks);
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function buildExtensionMedia(isWatch: boolean, outputRoot?: string) {
|
||||||
|
return Promise.all([
|
||||||
|
webpackExtensions('webpacking extension media', isWatch, webpackMediaConfigFiles.map(p => {
|
||||||
|
return {
|
||||||
|
configPath: path.join(extensionsPath, p),
|
||||||
|
outputRoot: outputRoot ? path.join(root, outputRoot, path.dirname(p)) : undefined
|
||||||
|
};
|
||||||
|
})),
|
||||||
|
esbuildExtensions('esbuilding extension media', isWatch, esbuildMediaScripts.map(p => ({
|
||||||
|
script: path.join(extensionsPath, p),
|
||||||
|
outputRoot: outputRoot ? path.join(root, outputRoot, path.dirname(p)) : undefined
|
||||||
|
}))),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|||||||
@@ -4,14 +4,13 @@
|
|||||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.prepareIslFiles = exports.prepareI18nPackFiles = exports.pullI18nPackFiles = exports.i18nPackVersion = exports.createI18nFile = exports.prepareI18nFiles = exports.pullSetupXlfFiles = exports.pullCoreAndExtensionsXlfFiles = exports.findObsoleteResources = exports.pushXlfFiles = exports.createXlfFilesForIsl = exports.createXlfFilesForExtensions = exports.createXlfFilesForCoreBundle = exports.getResource = exports.processNlsFiles = exports.Limiter = exports.XLF = exports.Line = exports.externalExtensionsWithTranslations = exports.extraLanguages = exports.defaultLanguages = void 0;
|
exports.prepareIslFiles = exports.prepareI18nPackFiles = exports.i18nPackVersion = exports.createI18nFile = exports.prepareI18nFiles = exports.pullSetupXlfFiles = exports.findObsoleteResources = exports.pushXlfFiles = exports.createXlfFilesForIsl = exports.createXlfFilesForExtensions = exports.createXlfFilesForCoreBundle = exports.getResource = exports.processNlsFiles = exports.Limiter = exports.XLF = exports.Line = exports.externalExtensionsWithTranslations = exports.extraLanguages = exports.defaultLanguages = void 0;
|
||||||
const path = require("path");
|
const path = require("path");
|
||||||
const fs = require("fs");
|
const fs = require("fs");
|
||||||
const event_stream_1 = require("event-stream");
|
const event_stream_1 = require("event-stream");
|
||||||
const File = require("vinyl");
|
const File = require("vinyl");
|
||||||
const Is = require("is");
|
const Is = require("is");
|
||||||
const xml2js = require("xml2js");
|
const xml2js = require("xml2js");
|
||||||
const glob = require("glob");
|
|
||||||
const https = require("https");
|
const https = require("https");
|
||||||
const gulp = require("gulp");
|
const gulp = require("gulp");
|
||||||
const fancyLog = require("fancy-log");
|
const fancyLog = require("fancy-log");
|
||||||
@@ -110,12 +109,16 @@ class XLF {
|
|||||||
}
|
}
|
||||||
toString() {
|
toString() {
|
||||||
this.appendHeader();
|
this.appendHeader();
|
||||||
for (let file in this.files) {
|
const files = Object.keys(this.files).sort();
|
||||||
|
for (const file of files) {
|
||||||
this.appendNewLine(`<file original="${file}" source-language="en" datatype="plaintext"><body>`, 2);
|
this.appendNewLine(`<file original="${file}" source-language="en" datatype="plaintext"><body>`, 2);
|
||||||
for (let item of this.files[file]) {
|
const items = this.files[file].sort((a, b) => {
|
||||||
|
return a.id < b.id ? -1 : a.id > b.id ? 1 : 0;
|
||||||
|
});
|
||||||
|
for (const item of items) {
|
||||||
this.addStringItem(file, item);
|
this.addStringItem(file, item);
|
||||||
}
|
}
|
||||||
this.appendNewLine('</body></file>', 2);
|
this.appendNewLine('</body></file>');
|
||||||
}
|
}
|
||||||
this.appendFooter();
|
this.appendFooter();
|
||||||
return this.buffer.join('\r\n');
|
return this.buffer.join('\r\n');
|
||||||
@@ -463,7 +466,7 @@ function processCoreBundleFormat(fileHeader, languages, json, emitter) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
function processNlsFiles(opts) {
|
function processNlsFiles(opts) {
|
||||||
return (0, event_stream_1.through)(function (file) {
|
return event_stream_1.through(function (file) {
|
||||||
let fileName = path.basename(file.path);
|
let fileName = path.basename(file.path);
|
||||||
if (fileName === 'nls.metadata.json') {
|
if (fileName === 'nls.metadata.json') {
|
||||||
let json = null;
|
let json = null;
|
||||||
@@ -521,7 +524,7 @@ function getResource(sourceFile) {
|
|||||||
}
|
}
|
||||||
exports.getResource = getResource;
|
exports.getResource = getResource;
|
||||||
function createXlfFilesForCoreBundle() {
|
function createXlfFilesForCoreBundle() {
|
||||||
return (0, event_stream_1.through)(function (file) {
|
return event_stream_1.through(function (file) {
|
||||||
const basename = path.basename(file.path);
|
const basename = path.basename(file.path);
|
||||||
if (basename === 'nls.metadata.json') {
|
if (basename === 'nls.metadata.json') {
|
||||||
if (file.isBuffer()) {
|
if (file.isBuffer()) {
|
||||||
@@ -576,7 +579,7 @@ function createXlfFilesForExtensions() {
|
|||||||
let counter = 0;
|
let counter = 0;
|
||||||
let folderStreamEnded = false;
|
let folderStreamEnded = false;
|
||||||
let folderStreamEndEmitted = false;
|
let folderStreamEndEmitted = false;
|
||||||
return (0, event_stream_1.through)(function (extensionFolder) {
|
return event_stream_1.through(function (extensionFolder) {
|
||||||
const folderStream = this;
|
const folderStream = this;
|
||||||
const stat = fs.statSync(extensionFolder.path);
|
const stat = fs.statSync(extensionFolder.path);
|
||||||
if (!stat.isDirectory()) {
|
if (!stat.isDirectory()) {
|
||||||
@@ -594,7 +597,7 @@ function createXlfFilesForExtensions() {
|
|||||||
}
|
}
|
||||||
return _xlf;
|
return _xlf;
|
||||||
}
|
}
|
||||||
gulp.src([`.build/extensions/${extensionName}/package.nls.json`, `.build/extensions/${extensionName}/**/nls.metadata.json`], { allowEmpty: true }).pipe((0, event_stream_1.through)(function (file) {
|
gulp.src([`.build/extensions/${extensionName}/package.nls.json`, `.build/extensions/${extensionName}/**/nls.metadata.json`], { allowEmpty: true }).pipe(event_stream_1.through(function (file) {
|
||||||
if (file.isBuffer()) {
|
if (file.isBuffer()) {
|
||||||
const buffer = file.contents;
|
const buffer = file.contents;
|
||||||
const basename = path.basename(file.path);
|
const basename = path.basename(file.path);
|
||||||
@@ -653,15 +656,14 @@ function createXlfFilesForExtensions() {
|
|||||||
}
|
}
|
||||||
exports.createXlfFilesForExtensions = createXlfFilesForExtensions;
|
exports.createXlfFilesForExtensions = createXlfFilesForExtensions;
|
||||||
function createXlfFilesForIsl() {
|
function createXlfFilesForIsl() {
|
||||||
return (0, event_stream_1.through)(function (file) {
|
return event_stream_1.through(function (file) {
|
||||||
let projectName, resourceFile;
|
let projectName, resourceFile;
|
||||||
if (path.basename(file.path) === 'Default.isl') {
|
if (path.basename(file.path) === 'messages.en.isl') {
|
||||||
projectName = setupProject;
|
projectName = setupProject;
|
||||||
resourceFile = 'setup_default.xlf';
|
resourceFile = 'messages.xlf';
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
projectName = workbenchProject;
|
throw new Error(`Unknown input file ${file.path}`);
|
||||||
resourceFile = 'setup_messages.xlf';
|
|
||||||
}
|
}
|
||||||
let xlf = new XLF(projectName), keys = [], messages = [];
|
let xlf = new XLF(projectName), keys = [], messages = [];
|
||||||
let model = new TextModel(file.contents.toString());
|
let model = new TextModel(file.contents.toString());
|
||||||
@@ -707,7 +709,7 @@ exports.createXlfFilesForIsl = createXlfFilesForIsl;
|
|||||||
function pushXlfFiles(apiHostname, username, password) {
|
function pushXlfFiles(apiHostname, username, password) {
|
||||||
let tryGetPromises = [];
|
let tryGetPromises = [];
|
||||||
let updateCreatePromises = [];
|
let updateCreatePromises = [];
|
||||||
return (0, event_stream_1.through)(function (file) {
|
return event_stream_1.through(function (file) {
|
||||||
const project = path.dirname(file.relative);
|
const project = path.dirname(file.relative);
|
||||||
const fileName = path.basename(file.path);
|
const fileName = path.basename(file.path);
|
||||||
const slug = fileName.substr(0, fileName.length - '.xlf'.length);
|
const slug = fileName.substr(0, fileName.length - '.xlf'.length);
|
||||||
@@ -769,7 +771,7 @@ function getAllResources(project, apiHostname, username, password) {
|
|||||||
function findObsoleteResources(apiHostname, username, password) {
|
function findObsoleteResources(apiHostname, username, password) {
|
||||||
let resourcesByProject = Object.create(null);
|
let resourcesByProject = Object.create(null);
|
||||||
resourcesByProject[extensionsProject] = [].concat(exports.externalExtensionsWithTranslations); // clone
|
resourcesByProject[extensionsProject] = [].concat(exports.externalExtensionsWithTranslations); // clone
|
||||||
return (0, event_stream_1.through)(function (file) {
|
return event_stream_1.through(function (file) {
|
||||||
const project = path.dirname(file.relative);
|
const project = path.dirname(file.relative);
|
||||||
const fileName = path.basename(file.path);
|
const fileName = path.basename(file.path);
|
||||||
const slug = fileName.substr(0, fileName.length - '.xlf'.length);
|
const slug = fileName.substr(0, fileName.length - '.xlf'.length);
|
||||||
@@ -909,31 +911,6 @@ function updateResource(project, slug, xlfFile, apiHostname, credentials) {
|
|||||||
request.end();
|
request.end();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
// cache resources
|
|
||||||
let _coreAndExtensionResources;
|
|
||||||
function pullCoreAndExtensionsXlfFiles(apiHostname, username, password, language, externalExtensions) {
|
|
||||||
if (!_coreAndExtensionResources) {
|
|
||||||
_coreAndExtensionResources = [];
|
|
||||||
// editor and workbench
|
|
||||||
const json = JSON.parse(fs.readFileSync('./build/lib/i18n.resources.json', 'utf8'));
|
|
||||||
_coreAndExtensionResources.push(...json.editor);
|
|
||||||
_coreAndExtensionResources.push(...json.workbench);
|
|
||||||
// extensions
|
|
||||||
let extensionsToLocalize = Object.create(null);
|
|
||||||
glob.sync('.build/extensions/**/*.nls.json').forEach(extension => extensionsToLocalize[extension.split('/')[2]] = true);
|
|
||||||
glob.sync('.build/extensions/*/node_modules/vscode-nls').forEach(extension => extensionsToLocalize[extension.split('/')[2]] = true);
|
|
||||||
Object.keys(extensionsToLocalize).forEach(extension => {
|
|
||||||
_coreAndExtensionResources.push({ name: extension, project: extensionsProject });
|
|
||||||
});
|
|
||||||
if (externalExtensions) {
|
|
||||||
for (let resourceName in externalExtensions) {
|
|
||||||
_coreAndExtensionResources.push({ name: resourceName, project: extensionsProject });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return pullXlfFiles(apiHostname, username, password, language, _coreAndExtensionResources);
|
|
||||||
}
|
|
||||||
exports.pullCoreAndExtensionsXlfFiles = pullCoreAndExtensionsXlfFiles;
|
|
||||||
function pullSetupXlfFiles(apiHostname, username, password, language, includeDefault) {
|
function pullSetupXlfFiles(apiHostname, username, password, language, includeDefault) {
|
||||||
let setupResources = [{ name: 'setup_messages', project: workbenchProject }];
|
let setupResources = [{ name: 'setup_messages', project: workbenchProject }];
|
||||||
if (includeDefault) {
|
if (includeDefault) {
|
||||||
@@ -946,7 +923,7 @@ function pullXlfFiles(apiHostname, username, password, language, resources) {
|
|||||||
const credentials = `${username}:${password}`;
|
const credentials = `${username}:${password}`;
|
||||||
let expectedTranslationsCount = resources.length;
|
let expectedTranslationsCount = resources.length;
|
||||||
let translationsRetrieved = 0, called = false;
|
let translationsRetrieved = 0, called = false;
|
||||||
return (0, event_stream_1.readable)(function (_count, callback) {
|
return event_stream_1.readable(function (_count, callback) {
|
||||||
// Mark end of stream when all resources were retrieved
|
// Mark end of stream when all resources were retrieved
|
||||||
if (translationsRetrieved === expectedTranslationsCount) {
|
if (translationsRetrieved === expectedTranslationsCount) {
|
||||||
return this.emit('end');
|
return this.emit('end');
|
||||||
@@ -1004,7 +981,7 @@ function retrieveResource(language, resource, apiHostname, credentials) {
|
|||||||
}
|
}
|
||||||
function prepareI18nFiles() {
|
function prepareI18nFiles() {
|
||||||
let parsePromises = [];
|
let parsePromises = [];
|
||||||
return (0, event_stream_1.through)(function (xlf) {
|
return event_stream_1.through(function (xlf) {
|
||||||
let stream = this;
|
let stream = this;
|
||||||
let parsePromise = XLF.parse(xlf.contents.toString());
|
let parsePromise = XLF.parse(xlf.contents.toString());
|
||||||
parsePromises.push(parsePromise);
|
parsePromises.push(parsePromise);
|
||||||
@@ -1044,20 +1021,16 @@ function createI18nFile(originalFilePath, messages) {
|
|||||||
}
|
}
|
||||||
exports.createI18nFile = createI18nFile;
|
exports.createI18nFile = createI18nFile;
|
||||||
exports.i18nPackVersion = '1.0.0'; // {{SQL CARBON EDIT}} Needed in locfunc.
|
exports.i18nPackVersion = '1.0.0'; // {{SQL CARBON EDIT}} Needed in locfunc.
|
||||||
function pullI18nPackFiles(apiHostname, username, password, language, resultingTranslationPaths) {
|
|
||||||
return pullCoreAndExtensionsXlfFiles(apiHostname, username, password, language, exports.externalExtensionsWithTranslations)
|
|
||||||
.pipe(prepareI18nPackFiles(exports.externalExtensionsWithTranslations, resultingTranslationPaths, language.id === 'ps'));
|
|
||||||
}
|
|
||||||
exports.pullI18nPackFiles = pullI18nPackFiles;
|
|
||||||
function prepareI18nPackFiles(externalExtensions, resultingTranslationPaths, pseudo = false) {
|
function prepareI18nPackFiles(externalExtensions, resultingTranslationPaths, pseudo = false) {
|
||||||
let parsePromises = [];
|
let parsePromises = [];
|
||||||
let mainPack = { version: exports.i18nPackVersion, contents: {} };
|
let mainPack = { version: exports.i18nPackVersion, contents: {} };
|
||||||
let extensionsPacks = {};
|
let extensionsPacks = {};
|
||||||
let errors = [];
|
let errors = [];
|
||||||
return (0, event_stream_1.through)(function (xlf) {
|
return event_stream_1.through(function (xlf) {
|
||||||
let project = path.basename(path.dirname(xlf.relative));
|
let project = path.basename(path.dirname(path.dirname(xlf.relative)));
|
||||||
let resource = path.basename(xlf.relative, '.xlf');
|
let resource = path.basename(xlf.relative, '.xlf');
|
||||||
let contents = xlf.contents.toString();
|
let contents = xlf.contents.toString();
|
||||||
|
log(`Found ${project}: ${resource}`);
|
||||||
let parsePromise = pseudo ? XLF.parsePseudo(contents) : XLF.parse(contents);
|
let parsePromise = pseudo ? XLF.parsePseudo(contents) : XLF.parse(contents);
|
||||||
parsePromises.push(parsePromise);
|
parsePromises.push(parsePromise);
|
||||||
parsePromise.then(resolvedFiles => {
|
parsePromise.then(resolvedFiles => {
|
||||||
@@ -1115,15 +1088,12 @@ function prepareI18nPackFiles(externalExtensions, resultingTranslationPaths, pse
|
|||||||
exports.prepareI18nPackFiles = prepareI18nPackFiles;
|
exports.prepareI18nPackFiles = prepareI18nPackFiles;
|
||||||
function prepareIslFiles(language, innoSetupConfig) {
|
function prepareIslFiles(language, innoSetupConfig) {
|
||||||
let parsePromises = [];
|
let parsePromises = [];
|
||||||
return (0, event_stream_1.through)(function (xlf) {
|
return event_stream_1.through(function (xlf) {
|
||||||
let stream = this;
|
let stream = this;
|
||||||
let parsePromise = XLF.parse(xlf.contents.toString());
|
let parsePromise = XLF.parse(xlf.contents.toString());
|
||||||
parsePromises.push(parsePromise);
|
parsePromises.push(parsePromise);
|
||||||
parsePromise.then(resolvedFiles => {
|
parsePromise.then(resolvedFiles => {
|
||||||
resolvedFiles.forEach(file => {
|
resolvedFiles.forEach(file => {
|
||||||
if (path.basename(file.originalFilePath) === 'Default' && !innoSetupConfig.defaultInfo) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let translatedFile = createIslFile(file.originalFilePath, file.messages, language, innoSetupConfig);
|
let translatedFile = createIslFile(file.originalFilePath, file.messages, language, innoSetupConfig);
|
||||||
stream.queue(translatedFile);
|
stream.queue(translatedFile);
|
||||||
});
|
});
|
||||||
@@ -1159,20 +1129,9 @@ function createIslFile(originalFilePath, messages, language, innoSetup) {
|
|||||||
let key = sections[0];
|
let key = sections[0];
|
||||||
let translated = line;
|
let translated = line;
|
||||||
if (key) {
|
if (key) {
|
||||||
if (key === 'LanguageName') {
|
let translatedMessage = messages[key];
|
||||||
translated = `${key}=${innoSetup.defaultInfo.name}`;
|
if (translatedMessage) {
|
||||||
}
|
translated = `${key}=${translatedMessage}`;
|
||||||
else if (key === 'LanguageID') {
|
|
||||||
translated = `${key}=${innoSetup.defaultInfo.id}`;
|
|
||||||
}
|
|
||||||
else if (key === 'LanguageCodePage') {
|
|
||||||
translated = `${key}=${innoSetup.codePage.substr(2)}`;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
let translatedMessage = messages[key];
|
|
||||||
if (translatedMessage) {
|
|
||||||
translated = `${key}=${translatedMessage}`;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
content.push(translated);
|
content.push(translated);
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ import { through, readable, ThroughStream } from 'event-stream';
|
|||||||
import * as File from 'vinyl';
|
import * as File from 'vinyl';
|
||||||
import * as Is from 'is';
|
import * as Is from 'is';
|
||||||
import * as xml2js from 'xml2js';
|
import * as xml2js from 'xml2js';
|
||||||
import * as glob from 'glob';
|
|
||||||
import * as https from 'https';
|
import * as https from 'https';
|
||||||
import * as gulp from 'gulp';
|
import * as gulp from 'gulp';
|
||||||
import * as fancyLog from 'fancy-log';
|
import * as fancyLog from 'fancy-log';
|
||||||
@@ -31,10 +30,6 @@ export interface Language {
|
|||||||
|
|
||||||
export interface InnoSetup {
|
export interface InnoSetup {
|
||||||
codePage: string; //code page for encoding (http://www.jrsoftware.org/ishelp/index.php?topic=langoptionssection)
|
codePage: string; //code page for encoding (http://www.jrsoftware.org/ishelp/index.php?topic=langoptionssection)
|
||||||
defaultInfo?: {
|
|
||||||
name: string; // inno setup language name
|
|
||||||
id: string; // locale identifier (https://msdn.microsoft.com/en-us/library/dd318693.aspx)
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export const defaultLanguages: Language[] = [
|
export const defaultLanguages: Language[] = [
|
||||||
@@ -198,14 +193,17 @@ export class XLF {
|
|||||||
public toString(): string {
|
public toString(): string {
|
||||||
this.appendHeader();
|
this.appendHeader();
|
||||||
|
|
||||||
for (let file in this.files) {
|
const files = Object.keys(this.files).sort();
|
||||||
|
for (const file of files) {
|
||||||
this.appendNewLine(`<file original="${file}" source-language="en" datatype="plaintext"><body>`, 2);
|
this.appendNewLine(`<file original="${file}" source-language="en" datatype="plaintext"><body>`, 2);
|
||||||
for (let item of this.files[file]) {
|
const items = this.files[file].sort((a: Item, b: Item) => {
|
||||||
|
return a.id < b.id ? -1 : a.id > b.id ? 1 : 0;
|
||||||
|
});
|
||||||
|
for (const item of items) {
|
||||||
this.addStringItem(file, item);
|
this.addStringItem(file, item);
|
||||||
}
|
}
|
||||||
this.appendNewLine('</body></file>', 2);
|
this.appendNewLine('</body></file>');
|
||||||
}
|
}
|
||||||
|
|
||||||
this.appendFooter();
|
this.appendFooter();
|
||||||
return this.buffer.join('\r\n');
|
return this.buffer.join('\r\n');
|
||||||
}
|
}
|
||||||
@@ -775,12 +773,11 @@ export function createXlfFilesForIsl(): ThroughStream {
|
|||||||
return through(function (this: ThroughStream, file: File) {
|
return through(function (this: ThroughStream, file: File) {
|
||||||
let projectName: string,
|
let projectName: string,
|
||||||
resourceFile: string;
|
resourceFile: string;
|
||||||
if (path.basename(file.path) === 'Default.isl') {
|
if (path.basename(file.path) === 'messages.en.isl') {
|
||||||
projectName = setupProject;
|
projectName = setupProject;
|
||||||
resourceFile = 'setup_default.xlf';
|
resourceFile = 'messages.xlf';
|
||||||
} else {
|
} else {
|
||||||
projectName = workbenchProject;
|
throw new Error(`Unknown input file ${file.path}`);
|
||||||
resourceFile = 'setup_messages.xlf';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let xlf = new XLF(projectName),
|
let xlf = new XLF(projectName),
|
||||||
@@ -1048,35 +1045,6 @@ function updateResource(project: string, slug: string, xlfFile: File, apiHostnam
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// cache resources
|
|
||||||
let _coreAndExtensionResources: Resource[];
|
|
||||||
|
|
||||||
export function pullCoreAndExtensionsXlfFiles(apiHostname: string, username: string, password: string, language: Language, externalExtensions?: Map<string>): NodeJS.ReadableStream {
|
|
||||||
if (!_coreAndExtensionResources) {
|
|
||||||
_coreAndExtensionResources = [];
|
|
||||||
// editor and workbench
|
|
||||||
const json = JSON.parse(fs.readFileSync('./build/lib/i18n.resources.json', 'utf8'));
|
|
||||||
_coreAndExtensionResources.push(...json.editor);
|
|
||||||
_coreAndExtensionResources.push(...json.workbench);
|
|
||||||
|
|
||||||
// extensions
|
|
||||||
let extensionsToLocalize = Object.create(null);
|
|
||||||
glob.sync('.build/extensions/**/*.nls.json').forEach(extension => extensionsToLocalize[extension.split('/')[2]] = true);
|
|
||||||
glob.sync('.build/extensions/*/node_modules/vscode-nls').forEach(extension => extensionsToLocalize[extension.split('/')[2]] = true);
|
|
||||||
|
|
||||||
Object.keys(extensionsToLocalize).forEach(extension => {
|
|
||||||
_coreAndExtensionResources.push({ name: extension, project: extensionsProject });
|
|
||||||
});
|
|
||||||
|
|
||||||
if (externalExtensions) {
|
|
||||||
for (let resourceName in externalExtensions) {
|
|
||||||
_coreAndExtensionResources.push({ name: resourceName, project: extensionsProject });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return pullXlfFiles(apiHostname, username, password, language, _coreAndExtensionResources);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function pullSetupXlfFiles(apiHostname: string, username: string, password: string, language: Language, includeDefault: boolean): NodeJS.ReadableStream {
|
export function pullSetupXlfFiles(apiHostname: string, username: string, password: string, language: Language, includeDefault: boolean): NodeJS.ReadableStream {
|
||||||
let setupResources = [{ name: 'setup_messages', project: workbenchProject }];
|
let setupResources = [{ name: 'setup_messages', project: workbenchProject }];
|
||||||
if (includeDefault) {
|
if (includeDefault) {
|
||||||
@@ -1208,20 +1176,16 @@ export interface TranslationPath {
|
|||||||
resourceName: string;
|
resourceName: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function pullI18nPackFiles(apiHostname: string, username: string, password: string, language: Language, resultingTranslationPaths: TranslationPath[]): NodeJS.ReadableStream {
|
|
||||||
return pullCoreAndExtensionsXlfFiles(apiHostname, username, password, language, externalExtensionsWithTranslations)
|
|
||||||
.pipe(prepareI18nPackFiles(externalExtensionsWithTranslations, resultingTranslationPaths, language.id === 'ps'));
|
|
||||||
}
|
|
||||||
|
|
||||||
export function prepareI18nPackFiles(externalExtensions: Map<string>, resultingTranslationPaths: TranslationPath[], pseudo = false): NodeJS.ReadWriteStream {
|
export function prepareI18nPackFiles(externalExtensions: Map<string>, resultingTranslationPaths: TranslationPath[], pseudo = false): NodeJS.ReadWriteStream {
|
||||||
let parsePromises: Promise<ParsedXLF[]>[] = [];
|
let parsePromises: Promise<ParsedXLF[]>[] = [];
|
||||||
let mainPack: I18nPack = { version: i18nPackVersion, contents: {} };
|
let mainPack: I18nPack = { version: i18nPackVersion, contents: {} };
|
||||||
let extensionsPacks: Map<I18nPack> = {};
|
let extensionsPacks: Map<I18nPack> = {};
|
||||||
let errors: any[] = [];
|
let errors: any[] = [];
|
||||||
return through(function (this: ThroughStream, xlf: File) {
|
return through(function (this: ThroughStream, xlf: File) {
|
||||||
let project = path.basename(path.dirname(xlf.relative));
|
let project = path.basename(path.dirname(path.dirname(xlf.relative)));
|
||||||
let resource = path.basename(xlf.relative, '.xlf');
|
let resource = path.basename(xlf.relative, '.xlf');
|
||||||
let contents = xlf.contents.toString();
|
let contents = xlf.contents.toString();
|
||||||
|
log(`Found ${project}: ${resource}`);
|
||||||
let parsePromise = pseudo ? XLF.parsePseudo(contents) : XLF.parse(contents);
|
let parsePromise = pseudo ? XLF.parsePseudo(contents) : XLF.parse(contents);
|
||||||
parsePromises.push(parsePromise);
|
parsePromises.push(parsePromise);
|
||||||
parsePromise.then(
|
parsePromise.then(
|
||||||
@@ -1290,9 +1254,6 @@ export function prepareIslFiles(language: Language, innoSetupConfig: InnoSetup):
|
|||||||
parsePromise.then(
|
parsePromise.then(
|
||||||
resolvedFiles => {
|
resolvedFiles => {
|
||||||
resolvedFiles.forEach(file => {
|
resolvedFiles.forEach(file => {
|
||||||
if (path.basename(file.originalFilePath) === 'Default' && !innoSetupConfig.defaultInfo) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let translatedFile = createIslFile(file.originalFilePath, file.messages, language, innoSetupConfig);
|
let translatedFile = createIslFile(file.originalFilePath, file.messages, language, innoSetupConfig);
|
||||||
stream.queue(translatedFile);
|
stream.queue(translatedFile);
|
||||||
});
|
});
|
||||||
@@ -1327,17 +1288,9 @@ function createIslFile(originalFilePath: string, messages: Map<string>, language
|
|||||||
let key = sections[0];
|
let key = sections[0];
|
||||||
let translated = line;
|
let translated = line;
|
||||||
if (key) {
|
if (key) {
|
||||||
if (key === 'LanguageName') {
|
let translatedMessage = messages[key];
|
||||||
translated = `${key}=${innoSetup.defaultInfo!.name}`;
|
if (translatedMessage) {
|
||||||
} else if (key === 'LanguageID') {
|
translated = `${key}=${translatedMessage}`;
|
||||||
translated = `${key}=${innoSetup.defaultInfo!.id}`;
|
|
||||||
} else if (key === 'LanguageCodePage') {
|
|
||||||
translated = `${key}=${innoSetup.codePage.substr(2)}`;
|
|
||||||
} else {
|
|
||||||
let translatedMessage = messages[key];
|
|
||||||
if (translatedMessage) {
|
|
||||||
translated = `${key}=${translatedMessage}`;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -199,7 +199,7 @@ const RULES = [
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
const TS_CONFIG_PATH = (0, path_1.join)(__dirname, '../../', 'src', 'tsconfig.json');
|
const TS_CONFIG_PATH = path_1.join(__dirname, '../../', 'src', 'tsconfig.json');
|
||||||
let hasErrors = false;
|
let hasErrors = false;
|
||||||
function checkFile(program, sourceFile, rule) {
|
function checkFile(program, sourceFile, rule) {
|
||||||
checkNode(sourceFile);
|
checkNode(sourceFile);
|
||||||
@@ -250,8 +250,8 @@ function checkFile(program, sourceFile, rule) {
|
|||||||
}
|
}
|
||||||
function createProgram(tsconfigPath) {
|
function createProgram(tsconfigPath) {
|
||||||
const tsConfig = ts.readConfigFile(tsconfigPath, ts.sys.readFile);
|
const tsConfig = ts.readConfigFile(tsconfigPath, ts.sys.readFile);
|
||||||
const configHostParser = { fileExists: fs_1.existsSync, readDirectory: ts.sys.readDirectory, readFile: file => (0, fs_1.readFileSync)(file, 'utf8'), useCaseSensitiveFileNames: process.platform === 'linux' };
|
const configHostParser = { fileExists: fs_1.existsSync, readDirectory: ts.sys.readDirectory, readFile: file => fs_1.readFileSync(file, 'utf8'), useCaseSensitiveFileNames: process.platform === 'linux' };
|
||||||
const tsConfigParsed = ts.parseJsonConfigFileContent(tsConfig.config, configHostParser, (0, path_1.resolve)((0, path_1.dirname)(tsconfigPath)), { noEmit: true });
|
const tsConfigParsed = ts.parseJsonConfigFileContent(tsConfig.config, configHostParser, path_1.resolve(path_1.dirname(tsconfigPath)), { noEmit: true });
|
||||||
const compilerHost = ts.createCompilerHost(tsConfigParsed.options, true);
|
const compilerHost = ts.createCompilerHost(tsConfigParsed.options, true);
|
||||||
return ts.createProgram(tsConfigParsed.fileNames, tsConfigParsed.options, compilerHost);
|
return ts.createProgram(tsConfigParsed.fileNames, tsConfigParsed.options, compilerHost);
|
||||||
}
|
}
|
||||||
@@ -261,7 +261,7 @@ function createProgram(tsconfigPath) {
|
|||||||
const program = createProgram(TS_CONFIG_PATH);
|
const program = createProgram(TS_CONFIG_PATH);
|
||||||
for (const sourceFile of program.getSourceFiles()) {
|
for (const sourceFile of program.getSourceFiles()) {
|
||||||
for (const rule of RULES) {
|
for (const rule of RULES) {
|
||||||
if ((0, minimatch_1.match)([sourceFile.fileName], rule.target).length > 0) {
|
if (minimatch_1.match([sourceFile.fileName], rule.target).length > 0) {
|
||||||
if (!rule.skip) {
|
if (!rule.skip) {
|
||||||
checkFile(program, sourceFile, rule);
|
checkFile(program, sourceFile, rule);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -96,7 +96,7 @@ function modifyI18nPackFiles(existingTranslationFolder, resultingTranslationPath
|
|||||||
let mainPack = { version: i18n.i18nPackVersion, contents: {} };
|
let mainPack = { version: i18n.i18nPackVersion, contents: {} };
|
||||||
let extensionsPacks = {};
|
let extensionsPacks = {};
|
||||||
let errors = [];
|
let errors = [];
|
||||||
return (0, event_stream_1.through)(function (xlf) {
|
return event_stream_1.through(function (xlf) {
|
||||||
let rawResource = path.basename(xlf.relative, '.xlf');
|
let rawResource = path.basename(xlf.relative, '.xlf');
|
||||||
let resource = rawResource.substring(0, rawResource.lastIndexOf('.'));
|
let resource = rawResource.substring(0, rawResource.lastIndexOf('.'));
|
||||||
let contents = xlf.contents.toString();
|
let contents = xlf.contents.toString();
|
||||||
|
|||||||
@@ -53,8 +53,8 @@ define([], [${wrap + lines.map(l => indent + l).join(',\n') + wrap}]);`;
|
|||||||
* Returns a stream containing the patched JavaScript and source maps.
|
* Returns a stream containing the patched JavaScript and source maps.
|
||||||
*/
|
*/
|
||||||
function nls() {
|
function nls() {
|
||||||
const input = (0, event_stream_1.through)();
|
const input = event_stream_1.through();
|
||||||
const output = input.pipe((0, event_stream_1.through)(function (f) {
|
const output = input.pipe(event_stream_1.through(function (f) {
|
||||||
if (!f.sourceMap) {
|
if (!f.sourceMap) {
|
||||||
return this.emit('error', new Error(`File ${f.relative} does not have sourcemaps.`));
|
return this.emit('error', new Error(`File ${f.relative} does not have sourcemaps.`));
|
||||||
}
|
}
|
||||||
@@ -72,7 +72,7 @@ function nls() {
|
|||||||
}
|
}
|
||||||
_nls.patchFiles(f, typescript).forEach(f => this.emit('data', f));
|
_nls.patchFiles(f, typescript).forEach(f => this.emit('data', f));
|
||||||
}));
|
}));
|
||||||
return (0, event_stream_1.duplex)(input, output);
|
return event_stream_1.duplex(input, output);
|
||||||
}
|
}
|
||||||
exports.nls = nls;
|
exports.nls = nls;
|
||||||
function isImportNode(ts, node) {
|
function isImportNode(ts, node) {
|
||||||
|
|||||||
@@ -98,7 +98,7 @@ function toConcatStream(src, bundledFileHeader, sources, dest, fileContentMapper
|
|||||||
return es.readArray(treatedSources)
|
return es.readArray(treatedSources)
|
||||||
.pipe(useSourcemaps ? util.loadSourcemaps() : es.through())
|
.pipe(useSourcemaps ? util.loadSourcemaps() : es.through())
|
||||||
.pipe(concat(dest))
|
.pipe(concat(dest))
|
||||||
.pipe((0, stats_1.createStatsStream)(dest));
|
.pipe(stats_1.createStatsStream(dest));
|
||||||
}
|
}
|
||||||
function toBundleStream(src, bundledFileHeader, bundles, fileContentMapper) {
|
function toBundleStream(src, bundledFileHeader, bundles, fileContentMapper) {
|
||||||
return es.merge(bundles.map(function (bundle) {
|
return es.merge(bundles.map(function (bundle) {
|
||||||
@@ -155,7 +155,7 @@ function optimizeTask(opts) {
|
|||||||
addComment: true,
|
addComment: true,
|
||||||
includeContent: true
|
includeContent: true
|
||||||
}))
|
}))
|
||||||
.pipe(opts.languages && opts.languages.length ? (0, i18n_1.processNlsFiles)({
|
.pipe(opts.languages && opts.languages.length ? i18n_1.processNlsFiles({
|
||||||
fileHeader: bundledFileHeader,
|
fileHeader: bundledFileHeader,
|
||||||
languages: opts.languages
|
languages: opts.languages
|
||||||
}) : es.through())
|
}) : es.through())
|
||||||
@@ -179,7 +179,7 @@ function minifyTask(src, sourceMapBaseUrl) {
|
|||||||
sourcemap: 'external',
|
sourcemap: 'external',
|
||||||
outdir: '.',
|
outdir: '.',
|
||||||
platform: 'node',
|
platform: 'node',
|
||||||
target: ['node12.18'],
|
target: ['node14.16'],
|
||||||
write: false
|
write: false
|
||||||
}).then(res => {
|
}).then(res => {
|
||||||
const jsFile = res.outputFiles.find(f => /\.js$/.test(f.path));
|
const jsFile = res.outputFiles.find(f => /\.js$/.test(f.path));
|
||||||
|
|||||||
@@ -256,7 +256,7 @@ export function minifyTask(src: string, sourceMapBaseUrl?: string): (cb: any) =>
|
|||||||
sourcemap: 'external',
|
sourcemap: 'external',
|
||||||
outdir: '.',
|
outdir: '.',
|
||||||
platform: 'node',
|
platform: 'node',
|
||||||
target: ['node12.18'],
|
target: ['node14.16'],
|
||||||
write: false
|
write: false
|
||||||
}).then(res => {
|
}).then(res => {
|
||||||
const jsFile = res.outputFiles.find(f => /\.js$/.test(f.path))!;
|
const jsFile = res.outputFiles.find(f => /\.js$/.test(f.path))!;
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ const yarn = process.platform === 'win32' ? 'yarn.cmd' : 'yarn';
|
|||||||
const rootDir = path.resolve(__dirname, '..', '..');
|
const rootDir = path.resolve(__dirname, '..', '..');
|
||||||
function runProcess(command, args = []) {
|
function runProcess(command, args = []) {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
const child = (0, child_process_1.spawn)(command, args, { cwd: rootDir, stdio: 'inherit', env: process.env });
|
const child = child_process_1.spawn(command, args, { cwd: rootDir, stdio: 'inherit', env: process.env });
|
||||||
child.on('exit', err => !err ? resolve() : process.exit(err !== null && err !== void 0 ? err : 1));
|
child.on('exit', err => !err ? resolve() : process.exit(err !== null && err !== void 0 ? err : 1));
|
||||||
child.on('error', reject);
|
child.on('error', reject);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -260,7 +260,7 @@ function transportCSS(module, enqueue, write) {
|
|||||||
}
|
}
|
||||||
const filename = path.join(SRC_DIR, module);
|
const filename = path.join(SRC_DIR, module);
|
||||||
const fileContents = fs.readFileSync(filename).toString();
|
const fileContents = fs.readFileSync(filename).toString();
|
||||||
const inlineResources = 'base64'; // see https://github.com/Microsoft/monaco-editor/issues/148
|
const inlineResources = 'base64'; // see https://github.com/microsoft/monaco-editor/issues/148
|
||||||
const newContents = _rewriteOrInlineUrls(fileContents, inlineResources === 'base64');
|
const newContents = _rewriteOrInlineUrls(fileContents, inlineResources === 'base64');
|
||||||
write(module, newContents);
|
write(module, newContents);
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -302,7 +302,7 @@ function transportCSS(module: string, enqueue: (module: string) => void, write:
|
|||||||
|
|
||||||
const filename = path.join(SRC_DIR, module);
|
const filename = path.join(SRC_DIR, module);
|
||||||
const fileContents = fs.readFileSync(filename).toString();
|
const fileContents = fs.readFileSync(filename).toString();
|
||||||
const inlineResources = 'base64'; // see https://github.com/Microsoft/monaco-editor/issues/148
|
const inlineResources = 'base64'; // see https://github.com/microsoft/monaco-editor/issues/148
|
||||||
|
|
||||||
const newContents = _rewriteOrInlineUrls(fileContents, inlineResources === 'base64');
|
const newContents = _rewriteOrInlineUrls(fileContents, inlineResources === 'base64');
|
||||||
write(module, newContents);
|
write(module, newContents);
|
||||||
|
|||||||
@@ -241,6 +241,9 @@ function nodeOrChildIsBlack(node) {
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
function isSymbolWithDeclarations(symbol) {
|
||||||
|
return !!(symbol && symbol.declarations);
|
||||||
|
}
|
||||||
function markNodes(ts, languageService, options) {
|
function markNodes(ts, languageService, options) {
|
||||||
const program = languageService.getProgram();
|
const program = languageService.getProgram();
|
||||||
if (!program) {
|
if (!program) {
|
||||||
@@ -413,7 +416,7 @@ function markNodes(ts, languageService, options) {
|
|||||||
if (symbolImportNode) {
|
if (symbolImportNode) {
|
||||||
setColor(symbolImportNode, 2 /* Black */);
|
setColor(symbolImportNode, 2 /* Black */);
|
||||||
}
|
}
|
||||||
if (symbol && !nodeIsInItsOwnDeclaration(nodeSourceFile, node, symbol)) {
|
if (isSymbolWithDeclarations(symbol) && !nodeIsInItsOwnDeclaration(nodeSourceFile, node, symbol)) {
|
||||||
for (let i = 0, len = symbol.declarations.length; i < len; i++) { // {{SQL CARBON EDIT}} Compile fixes
|
for (let i = 0, len = symbol.declarations.length; i < len; i++) { // {{SQL CARBON EDIT}} Compile fixes
|
||||||
const declaration = symbol.declarations[i]; // {{SQL CARBON EDIT}} Compile fixes
|
const declaration = symbol.declarations[i]; // {{SQL CARBON EDIT}} Compile fixes
|
||||||
if (ts.isSourceFile(declaration)) {
|
if (ts.isSourceFile(declaration)) {
|
||||||
@@ -686,7 +689,7 @@ function getRealNodeSymbol(ts, checker, node) {
|
|||||||
// get the aliased symbol instead. This allows for goto def on an import e.g.
|
// get the aliased symbol instead. This allows for goto def on an import e.g.
|
||||||
// import {A, B} from "mod";
|
// import {A, B} from "mod";
|
||||||
// to jump to the implementation directly.
|
// to jump to the implementation directly.
|
||||||
if (symbol && symbol.flags & ts.SymbolFlags.Alias && shouldSkipAlias(node, symbol.declarations[0])) { // {{SQL CARBON EDIT}} Compile fixes
|
if (symbol && symbol.flags & ts.SymbolFlags.Alias && symbol.declarations && shouldSkipAlias(node, symbol.declarations[0])) { // {{SQL CARBON EDIT}} Compile fixes
|
||||||
const aliased = checker.getAliasedSymbol(symbol);
|
const aliased = checker.getAliasedSymbol(symbol);
|
||||||
if (aliased.declarations) {
|
if (aliased.declarations) {
|
||||||
// We should mark the import as visited
|
// We should mark the import as visited
|
||||||
|
|||||||
@@ -323,6 +323,10 @@ function nodeOrChildIsBlack(node: ts.Node): boolean {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isSymbolWithDeclarations(symbol: ts.Symbol | undefined | null): symbol is ts.Symbol & { declarations: ts.Declaration[] } {
|
||||||
|
return !!(symbol && symbol.declarations);
|
||||||
|
}
|
||||||
|
|
||||||
function markNodes(ts: typeof import('typescript'), languageService: ts.LanguageService, options: ITreeShakingOptions) {
|
function markNodes(ts: typeof import('typescript'), languageService: ts.LanguageService, options: ITreeShakingOptions) {
|
||||||
const program = languageService.getProgram();
|
const program = languageService.getProgram();
|
||||||
if (!program) {
|
if (!program) {
|
||||||
@@ -530,7 +534,7 @@ function markNodes(ts: typeof import('typescript'), languageService: ts.Language
|
|||||||
setColor(symbolImportNode, NodeColor.Black);
|
setColor(symbolImportNode, NodeColor.Black);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (symbol && !nodeIsInItsOwnDeclaration(nodeSourceFile, node, symbol)) {
|
if (isSymbolWithDeclarations(symbol) && !nodeIsInItsOwnDeclaration(nodeSourceFile, node, symbol)) {
|
||||||
for (let i = 0, len = symbol.declarations!.length; i < len; i++) { // {{SQL CARBON EDIT}} Compile fixes
|
for (let i = 0, len = symbol.declarations!.length; i < len; i++) { // {{SQL CARBON EDIT}} Compile fixes
|
||||||
const declaration = symbol.declarations![i]; // {{SQL CARBON EDIT}} Compile fixes
|
const declaration = symbol.declarations![i]; // {{SQL CARBON EDIT}} Compile fixes
|
||||||
if (ts.isSourceFile(declaration)) {
|
if (ts.isSourceFile(declaration)) {
|
||||||
@@ -595,7 +599,7 @@ function markNodes(ts: typeof import('typescript'), languageService: ts.Language
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function nodeIsInItsOwnDeclaration(nodeSourceFile: ts.SourceFile, node: ts.Node, symbol: ts.Symbol): boolean {
|
function nodeIsInItsOwnDeclaration(nodeSourceFile: ts.SourceFile, node: ts.Node, symbol: ts.Symbol & { declarations: ts.Declaration[] }): boolean {
|
||||||
for (let i = 0, len = symbol.declarations!.length; i < len; i++) { // {{SQL CARBON EDIT}} Compile fixes
|
for (let i = 0, len = symbol.declarations!.length; i < len; i++) { // {{SQL CARBON EDIT}} Compile fixes
|
||||||
const declaration = symbol.declarations![i]; // {{SQL CARBON EDIT}} Compile fixes
|
const declaration = symbol.declarations![i]; // {{SQL CARBON EDIT}} Compile fixes
|
||||||
const declarationSourceFile = declaration.getSourceFile();
|
const declarationSourceFile = declaration.getSourceFile();
|
||||||
@@ -838,7 +842,7 @@ function getRealNodeSymbol(ts: typeof import('typescript'), checker: ts.TypeChec
|
|||||||
// get the aliased symbol instead. This allows for goto def on an import e.g.
|
// get the aliased symbol instead. This allows for goto def on an import e.g.
|
||||||
// import {A, B} from "mod";
|
// import {A, B} from "mod";
|
||||||
// to jump to the implementation directly.
|
// to jump to the implementation directly.
|
||||||
if (symbol && symbol.flags & ts.SymbolFlags.Alias && shouldSkipAlias(node, symbol.declarations![0])) { // {{SQL CARBON EDIT}} Compile fixes
|
if (symbol && symbol.flags & ts.SymbolFlags.Alias && symbol.declarations && shouldSkipAlias(node, symbol.declarations![0])) { // {{SQL CARBON EDIT}} Compile fixes
|
||||||
const aliased = checker.getAliasedSymbol(symbol);
|
const aliased = checker.getAliasedSymbol(symbol);
|
||||||
if (aliased.declarations) {
|
if (aliased.declarations) {
|
||||||
// We should mark the import as visited
|
// We should mark the import as visited
|
||||||
|
|||||||
2
build/lib/typings/gulp-bom.d.ts
vendored
2
build/lib/typings/gulp-bom.d.ts
vendored
@@ -4,7 +4,7 @@ declare module "gulp-bom" {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* This is required as per:
|
* This is required as per:
|
||||||
* https://github.com/Microsoft/TypeScript/issues/5073
|
* https://github.com/microsoft/TypeScript/issues/5073
|
||||||
*/
|
*/
|
||||||
namespace f {}
|
namespace f {}
|
||||||
|
|
||||||
|
|||||||
4
build/lib/typings/gulp-flatmap.d.ts
vendored
4
build/lib/typings/gulp-flatmap.d.ts
vendored
@@ -4,9 +4,9 @@ declare module 'gulp-flatmap' {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* This is required as per:
|
* This is required as per:
|
||||||
* https://github.com/Microsoft/TypeScript/issues/5073
|
* https://github.com/microsoft/TypeScript/issues/5073
|
||||||
*/
|
*/
|
||||||
namespace f {}
|
namespace f {}
|
||||||
|
|
||||||
export = f;
|
export = f;
|
||||||
}
|
}
|
||||||
|
|||||||
4
build/lib/typings/vinyl.d.ts
vendored
4
build/lib/typings/vinyl.d.ts
vendored
@@ -103,10 +103,10 @@ declare module "vinyl" {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* This is required as per:
|
* This is required as per:
|
||||||
* https://github.com/Microsoft/TypeScript/issues/5073
|
* https://github.com/microsoft/TypeScript/issues/5073
|
||||||
*/
|
*/
|
||||||
namespace File {}
|
namespace File {}
|
||||||
|
|
||||||
export = File;
|
export = File;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,9 +9,9 @@
|
|||||||
"module": "./esm/vs/editor/editor.main.js",
|
"module": "./esm/vs/editor/editor.main.js",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/Microsoft/vscode"
|
"url": "https://github.com/microsoft/vscode"
|
||||||
},
|
},
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/Microsoft/vscode/issues"
|
"url": "https://github.com/microsoft/vscode/issues"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,39 +9,52 @@ exports.dirs = [
|
|||||||
'build',
|
'build',
|
||||||
'build/lib/watch',
|
'build/lib/watch',
|
||||||
'extensions',
|
'extensions',
|
||||||
|
// {{SQL CARBON EDIT}} Add ADS extensions and remove VSCode ones
|
||||||
|
'extensions/admin-tool-ext-win',
|
||||||
|
'extensions/agent',
|
||||||
|
'extensions/arc',
|
||||||
|
'extensions/azcli',
|
||||||
|
'extensions/azurecore',
|
||||||
|
'extensions/azurehybridtoolkit',
|
||||||
|
'extensions/azuremonitor',
|
||||||
|
'extensions/big-data-cluster',
|
||||||
|
'extensions/cms',
|
||||||
'extensions/configuration-editing',
|
'extensions/configuration-editing',
|
||||||
'extensions/css-language-features',
|
'extensions/dacpac',
|
||||||
'extensions/css-language-features/server',
|
'extensions/data-workspace',
|
||||||
'extensions/debug-auto-launch',
|
|
||||||
'extensions/debug-server-ready',
|
|
||||||
'extensions/emmet',
|
|
||||||
'extensions/extension-editing',
|
'extensions/extension-editing',
|
||||||
'extensions/git',
|
'extensions/git',
|
||||||
'extensions/github',
|
'extensions/github',
|
||||||
'extensions/github-authentication',
|
'extensions/github-authentication',
|
||||||
'extensions/grunt',
|
|
||||||
'extensions/gulp',
|
|
||||||
'extensions/html-language-features',
|
|
||||||
'extensions/html-language-features/server',
|
|
||||||
'extensions/image-preview',
|
'extensions/image-preview',
|
||||||
'extensions/jake',
|
'extensions/import',
|
||||||
|
'extensions/integration-tests',
|
||||||
'extensions/json-language-features',
|
'extensions/json-language-features',
|
||||||
'extensions/json-language-features/server',
|
'extensions/json-language-features/server',
|
||||||
|
'extensions/kusto',
|
||||||
|
'extensions/liveshare',
|
||||||
|
'extensions/machine-learning',
|
||||||
'extensions/markdown-language-features',
|
'extensions/markdown-language-features',
|
||||||
|
'extensions/markdown-math',
|
||||||
'extensions/merge-conflict',
|
'extensions/merge-conflict',
|
||||||
'extensions/microsoft-authentication',
|
'extensions/microsoft-authentication',
|
||||||
'extensions/notebook-markdown-extensions',
|
'extensions/mssql',
|
||||||
'extensions/npm',
|
'extensions/notebook',
|
||||||
'extensions/php-language-features',
|
'extensions/profiler',
|
||||||
|
'extensions/python',
|
||||||
|
'extensions/query-history',
|
||||||
|
'extensions/resource-deployment',
|
||||||
|
'extensions/schema-compare',
|
||||||
'extensions/search-result',
|
'extensions/search-result',
|
||||||
|
'extensions/server-report',
|
||||||
'extensions/simple-browser',
|
'extensions/simple-browser',
|
||||||
|
'extensions/sql-assessment',
|
||||||
|
'extensions/sql-database-projects',
|
||||||
|
'extensions/sql-migration',
|
||||||
'extensions/testing-editor-contributions',
|
'extensions/testing-editor-contributions',
|
||||||
'extensions/typescript-language-features',
|
|
||||||
'extensions/vscode-api-tests',
|
|
||||||
'extensions/vscode-colorize-tests',
|
|
||||||
'extensions/vscode-custom-editor-tests',
|
|
||||||
'extensions/vscode-notebook-tests',
|
|
||||||
'extensions/vscode-test-resolver',
|
'extensions/vscode-test-resolver',
|
||||||
|
'extensions/xml-language-features',
|
||||||
|
// {{SQL CARBON EDIT}} - End
|
||||||
'remote',
|
'remote',
|
||||||
'remote/web',
|
'remote/web',
|
||||||
'test/automation',
|
'test/automation',
|
||||||
|
|||||||
@@ -6,6 +6,7 @@
|
|||||||
const cp = require('child_process');
|
const cp = require('child_process');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
|
const { dirs } = require('./dirs');
|
||||||
const yarn = process.platform === 'win32' ? 'yarn.cmd' : 'yarn';
|
const yarn = process.platform === 'win32' ? 'yarn.cmd' : 'yarn';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -21,6 +22,10 @@ function yarnInstall(location, opts) {
|
|||||||
const argv = JSON.parse(raw);
|
const argv = JSON.parse(raw);
|
||||||
const original = argv.original || [];
|
const original = argv.original || [];
|
||||||
const args = original.filter(arg => arg === '--ignore-optional' || arg === '--frozen-lockfile');
|
const args = original.filter(arg => arg === '--ignore-optional' || arg === '--frozen-lockfile');
|
||||||
|
if (opts.ignoreEngines) {
|
||||||
|
args.push('--ignore-engines');
|
||||||
|
delete opts.ignoreEngines;
|
||||||
|
}
|
||||||
|
|
||||||
console.log(`Installing dependencies in ${location}...`);
|
console.log(`Installing dependencies in ${location}...`);
|
||||||
console.log(`$ yarn ${args.join(' ')}`);
|
console.log(`$ yarn ${args.join(' ')}`);
|
||||||
@@ -31,24 +36,39 @@ function yarnInstall(location, opts) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
yarnInstall('extensions'); // node modules shared by all extensions
|
for (let dir of dirs) {
|
||||||
|
|
||||||
if (!(process.platform === 'win32' && (process.arch === 'arm64' || process.env['npm_config_arch'] === 'arm64'))) {
|
if (dir === '') {
|
||||||
yarnInstall('remote'); // node modules used by vscode server
|
// `yarn` already executed in root
|
||||||
yarnInstall('remote/web'); // node modules used by vscode web
|
continue;
|
||||||
}
|
|
||||||
|
|
||||||
const allExtensionFolders = fs.readdirSync('extensions');
|
|
||||||
const extensions = allExtensionFolders.filter(e => {
|
|
||||||
try {
|
|
||||||
let packageJSON = JSON.parse(fs.readFileSync(path.join('extensions', e, 'package.json')).toString());
|
|
||||||
return packageJSON && (packageJSON.dependencies || packageJSON.devDependencies);
|
|
||||||
} catch (e) {
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
extensions.forEach(extension => yarnInstall(`extensions/${extension}`));
|
if (/^remote/.test(dir) && process.platform === 'win32' && (process.arch === 'arm64' || process.env['npm_config_arch'] === 'arm64')) {
|
||||||
|
// windows arm: do not execute `yarn` on remote folder
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dir === 'build/lib/watch') {
|
||||||
|
// node modules for watching, specific to host node version, not electron
|
||||||
|
yarnInstallBuildDependencies();
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
let opts;
|
||||||
|
|
||||||
|
if (dir === 'remote') {
|
||||||
|
// node modules used by vscode server
|
||||||
|
const env = { ...process.env };
|
||||||
|
if (process.env['VSCODE_REMOTE_CC']) { env['CC'] = process.env['VSCODE_REMOTE_CC']; }
|
||||||
|
if (process.env['VSCODE_REMOTE_CXX']) { env['CXX'] = process.env['VSCODE_REMOTE_CXX']; }
|
||||||
|
if (process.env['VSCODE_REMOTE_NODE_GYP']) { env['npm_config_node_gyp'] = process.env['VSCODE_REMOTE_NODE_GYP']; }
|
||||||
|
opts = { env };
|
||||||
|
} else if (/^extensions\//.test(dir)) {
|
||||||
|
opts = { ignoreEngines: true };
|
||||||
|
}
|
||||||
|
|
||||||
|
yarnInstall(dir, opts);
|
||||||
|
}
|
||||||
|
|
||||||
function yarnInstallBuildDependencies() {
|
function yarnInstallBuildDependencies() {
|
||||||
// make sure we install the deps of build/lib/watch for the system installed
|
// make sure we install the deps of build/lib/watch for the system installed
|
||||||
@@ -68,10 +88,4 @@ runtime "${runtime}"`;
|
|||||||
yarnInstall(watchPath);
|
yarnInstall(watchPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
yarnInstall(`build`); // node modules required for build
|
|
||||||
yarnInstall('test/automation'); // node modules required for smoketest
|
|
||||||
yarnInstall('test/smoke'); // node modules required for smoketest
|
|
||||||
yarnInstall('test/integration/browser'); // node modules required for integration
|
|
||||||
yarnInstallBuildDependencies(); // node modules for watching, specific to host node version, not electron
|
|
||||||
|
|
||||||
cp.execSync('git config pull.rebase true');
|
cp.execSync('git config pull.rebase true');
|
||||||
|
|||||||
@@ -20,19 +20,12 @@ function update(options) {
|
|||||||
if (!idOrPath) {
|
if (!idOrPath) {
|
||||||
throw new Error('Argument must be the location of the localization extension.');
|
throw new Error('Argument must be the location of the localization extension.');
|
||||||
}
|
}
|
||||||
let transifex = options.transifex;
|
|
||||||
let location = options.location;
|
let location = options.location;
|
||||||
if (transifex === true && location !== undefined) {
|
|
||||||
throw new Error('Either --transifex or --location can be specified, but not both.');
|
|
||||||
}
|
|
||||||
if (!transifex && !location) {
|
|
||||||
transifex = true;
|
|
||||||
}
|
|
||||||
if (location !== undefined && !fs.existsSync(location)) {
|
if (location !== undefined && !fs.existsSync(location)) {
|
||||||
throw new Error(`${location} doesn't exist.`);
|
throw new Error(`${location} doesn't exist.`);
|
||||||
}
|
}
|
||||||
let locExtFolder = idOrPath;
|
let locExtFolder = idOrPath;
|
||||||
if (/^\w{2}(-\w+)?$/.test(idOrPath)) {
|
if (/^\w{2,3}(-\w+)?$/.test(idOrPath)) {
|
||||||
locExtFolder = path.join('..', 'vscode-loc', 'i18n', `vscode-language-pack-${idOrPath}`);
|
locExtFolder = path.join('..', 'vscode-loc', 'i18n', `vscode-language-pack-${idOrPath}`);
|
||||||
}
|
}
|
||||||
let locExtStat = fs.statSync(locExtFolder);
|
let locExtStat = fs.statSync(locExtFolder);
|
||||||
@@ -53,79 +46,55 @@ function update(options) {
|
|||||||
if (!localization.languageId || !localization.languageName || !localization.localizedLanguageName) {
|
if (!localization.languageId || !localization.languageName || !localization.localizedLanguageName) {
|
||||||
throw new Error('Each localization contribution must define "languageId", "languageName" and "localizedLanguageName" properties.');
|
throw new Error('Each localization contribution must define "languageId", "languageName" and "localizedLanguageName" properties.');
|
||||||
}
|
}
|
||||||
let server = localization.server || 'www.transifex.com';
|
let languageId = localization.languageId;
|
||||||
let userName = localization.userName || 'api';
|
|
||||||
let apiToken = process.env.TRANSIFEX_API_TOKEN;
|
|
||||||
let languageId = localization.transifexId || localization.languageId;
|
|
||||||
let translationDataFolder = path.join(locExtFolder, 'translations');
|
let translationDataFolder = path.join(locExtFolder, 'translations');
|
||||||
if (languageId === "zh-cn") {
|
|
||||||
languageId = "zh-hans";
|
switch (languageId) {
|
||||||
}
|
case 'zh-cn':
|
||||||
if (languageId === "zh-tw") {
|
languageId = 'zh-Hans';
|
||||||
languageId = "zh-hant";
|
break;
|
||||||
|
case 'zh-tw':
|
||||||
|
languageId = 'zh-Hant';
|
||||||
|
break;
|
||||||
|
case 'pt-br':
|
||||||
|
languageId = 'pt-BR';
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fs.existsSync(translationDataFolder) && fs.existsSync(path.join(translationDataFolder, 'main.i18n.json'))) {
|
if (fs.existsSync(translationDataFolder) && fs.existsSync(path.join(translationDataFolder, 'main.i18n.json'))) {
|
||||||
console.log('Clearing \'' + translationDataFolder + '\'...');
|
console.log('Clearing \'' + translationDataFolder + '\'...');
|
||||||
rimraf.sync(translationDataFolder);
|
rimraf.sync(translationDataFolder);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (transifex) {
|
console.log(`Importing translations for ${languageId} form '${location}' to '${translationDataFolder}' ...`);
|
||||||
console.log(`Downloading translations for ${languageId} to '${translationDataFolder}' ...`);
|
let translationPaths = [];
|
||||||
let translationPaths = [];
|
gulp.src(path.join(location, '**', languageId, '*.xlf'), { silent: false })
|
||||||
i18n.pullI18nPackFiles(server, userName, apiToken, { id: languageId }, translationPaths)
|
.pipe(i18n.prepareI18nPackFiles(i18n.externalExtensionsWithTranslations, translationPaths, languageId === 'ps'))
|
||||||
.on('error', (error) => {
|
.on('error', (error) => {
|
||||||
console.log(`Error occurred while importing translations:`);
|
console.log(`Error occurred while importing translations:`);
|
||||||
translationPaths = undefined;
|
translationPaths = undefined;
|
||||||
if (Array.isArray(error)) {
|
if (Array.isArray(error)) {
|
||||||
error.forEach(console.log);
|
error.forEach(console.log);
|
||||||
} else if (error) {
|
} else if (error) {
|
||||||
console.log(error);
|
console.log(error);
|
||||||
} else {
|
} else {
|
||||||
console.log('Unknown error');
|
console.log('Unknown error');
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.pipe(vfs.dest(translationDataFolder))
|
||||||
|
.on('end', function () {
|
||||||
|
if (translationPaths !== undefined) {
|
||||||
|
localization.translations = [];
|
||||||
|
for (let tp of translationPaths) {
|
||||||
|
localization.translations.push({ id: tp.id, path: `./translations/${tp.resourceName}` });
|
||||||
}
|
}
|
||||||
})
|
fs.writeFileSync(path.join(locExtFolder, 'package.json'), JSON.stringify(packageJSON, null, '\t') + '\n');
|
||||||
.pipe(vfs.dest(translationDataFolder))
|
}
|
||||||
.on('end', function () {
|
});
|
||||||
if (translationPaths !== undefined) {
|
|
||||||
localization.translations = [];
|
|
||||||
for (let tp of translationPaths) {
|
|
||||||
localization.translations.push({ id: tp.id, path: `./translations/${tp.resourceName}`});
|
|
||||||
}
|
|
||||||
fs.writeFileSync(path.join(locExtFolder, 'package.json'), JSON.stringify(packageJSON, null, '\t'));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
console.log(`Importing translations for ${languageId} form '${location}' to '${translationDataFolder}' ...`);
|
|
||||||
let translationPaths = [];
|
|
||||||
gulp.src(path.join(location, languageId, '**', '*.xlf'))
|
|
||||||
.pipe(i18n.prepareI18nPackFiles(i18n.externalExtensionsWithTranslations, translationPaths, languageId === 'ps'))
|
|
||||||
.on('error', (error) => {
|
|
||||||
console.log(`Error occurred while importing translations:`);
|
|
||||||
translationPaths = undefined;
|
|
||||||
if (Array.isArray(error)) {
|
|
||||||
error.forEach(console.log);
|
|
||||||
} else if (error) {
|
|
||||||
console.log(error);
|
|
||||||
} else {
|
|
||||||
console.log('Unknown error');
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.pipe(vfs.dest(translationDataFolder))
|
|
||||||
.on('end', function () {
|
|
||||||
if (translationPaths !== undefined) {
|
|
||||||
localization.translations = [];
|
|
||||||
for (let tp of translationPaths) {
|
|
||||||
localization.translations.push({ id: tp.id, path: `./translations/${tp.resourceName}`});
|
|
||||||
}
|
|
||||||
fs.writeFileSync(path.join(locExtFolder, 'package.json'), JSON.stringify(packageJSON, null, '\t'));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
if (path.basename(process.argv[1]) === 'update-localization-extension.js') {
|
if (path.basename(process.argv[1]) === 'update-localization-extension.js') {
|
||||||
var options = minimist(process.argv.slice(2), {
|
var options = minimist(process.argv.slice(2), {
|
||||||
boolean: 'transifex',
|
|
||||||
string: 'location'
|
string: 'location'
|
||||||
});
|
});
|
||||||
update(options);
|
update(options);
|
||||||
|
|||||||
@@ -25,7 +25,7 @@
|
|||||||
"@types/minimist": "^1.2.1",
|
"@types/minimist": "^1.2.1",
|
||||||
"@types/mkdirp": "^1.0.1",
|
"@types/mkdirp": "^1.0.1",
|
||||||
"@types/mocha": "^8.2.0",
|
"@types/mocha": "^8.2.0",
|
||||||
"@types/node": "^14.14.37",
|
"@types/node": "14.x",
|
||||||
"@types/p-limit": "^2.2.0",
|
"@types/p-limit": "^2.2.0",
|
||||||
"@types/plist": "^3.0.2",
|
"@types/plist": "^3.0.2",
|
||||||
"@types/pump": "^1.0.1",
|
"@types/pump": "^1.0.1",
|
||||||
@@ -42,7 +42,7 @@
|
|||||||
"byline": "^5.0.0",
|
"byline": "^5.0.0",
|
||||||
"colors": "^1.4.0",
|
"colors": "^1.4.0",
|
||||||
"electron-osx-sign": "^0.4.16",
|
"electron-osx-sign": "^0.4.16",
|
||||||
"esbuild": "^0.8.30",
|
"esbuild": "^0.12.6",
|
||||||
"fs-extra": "^9.1.0",
|
"fs-extra": "^9.1.0",
|
||||||
"documentdb": "1.13.0",
|
"documentdb": "1.13.0",
|
||||||
"got": "11.8.1",
|
"got": "11.8.1",
|
||||||
@@ -56,7 +56,7 @@
|
|||||||
"rollup-plugin-commonjs": "^10.1.0",
|
"rollup-plugin-commonjs": "^10.1.0",
|
||||||
"rollup-plugin-node-resolve": "^5.2.0",
|
"rollup-plugin-node-resolve": "^5.2.0",
|
||||||
"source-map": "0.6.1",
|
"source-map": "0.6.1",
|
||||||
"typescript": "^4.3.0-dev.20210426",
|
"typescript": "^4.4.0-dev.20210607",
|
||||||
"vsce": "1.48.0",
|
"vsce": "1.48.0",
|
||||||
"vscode-universal": "deepak1556/universal#61454d96223b774c53cda10f72c2098c0ce02d58"
|
"vscode-universal": "deepak1556/universal#61454d96223b774c53cda10f72c2098c0ce02d58"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -13,6 +13,8 @@
|
|||||||
"allowJs": true,
|
"allowJs": true,
|
||||||
"checkJs": true,
|
"checkJs": true,
|
||||||
"strict": true,
|
"strict": true,
|
||||||
|
"strictOptionalProperties": false,
|
||||||
|
"useUnknownInCatchVariables": false,
|
||||||
"noUnusedLocals": true,
|
"noUnusedLocals": true,
|
||||||
"noUnusedParameters": true,
|
"noUnusedParameters": true,
|
||||||
"newLine": "lf"
|
"newLine": "lf"
|
||||||
@@ -22,6 +24,6 @@
|
|||||||
],
|
],
|
||||||
"exclude": [
|
"exclude": [
|
||||||
"node_modules/**",
|
"node_modules/**",
|
||||||
"actions/**"
|
"actions/**" // {{SQL CARBON EDIT}}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -383,16 +383,16 @@
|
|||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-8.0.51.tgz#b31d716fb8d58eeb95c068a039b9b6292817d5fb"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-8.0.51.tgz#b31d716fb8d58eeb95c068a039b9b6292817d5fb"
|
||||||
integrity sha512-El3+WJk2D/ppWNd2X05aiP5l2k4EwF7KwheknQZls+I26eSICoWRhRIJ56jGgw2dqNGQ5LtNajmBU2ajS28EvQ==
|
integrity sha512-El3+WJk2D/ppWNd2X05aiP5l2k4EwF7KwheknQZls+I26eSICoWRhRIJ56jGgw2dqNGQ5LtNajmBU2ajS28EvQ==
|
||||||
|
|
||||||
|
"@types/node@14.x":
|
||||||
|
version "14.14.43"
|
||||||
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.14.43.tgz#26bcbb0595b305400e8ceaf9a127a7f905ae49c8"
|
||||||
|
integrity sha512-3pwDJjp1PWacPTpH0LcfhgjvurQvrZFBrC6xxjaUEZ7ifUtT32jtjPxEMMblpqd2Mvx+k8haqQJLQxolyGN/cQ==
|
||||||
|
|
||||||
"@types/node@^14.14.21":
|
"@types/node@^14.14.21":
|
||||||
version "14.14.31"
|
version "14.14.31"
|
||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.14.31.tgz#72286bd33d137aa0d152d47ec7c1762563d34055"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.14.31.tgz#72286bd33d137aa0d152d47ec7c1762563d34055"
|
||||||
integrity sha512-vFHy/ezP5qI0rFgJ7aQnjDXwAMrG0KqqIH7tQG5PPv3BWBayOPIQNBjVc/P6hhdZfMx51REc6tfDNXHUio893g==
|
integrity sha512-vFHy/ezP5qI0rFgJ7aQnjDXwAMrG0KqqIH7tQG5PPv3BWBayOPIQNBjVc/P6hhdZfMx51REc6tfDNXHUio893g==
|
||||||
|
|
||||||
"@types/node@^14.14.37":
|
|
||||||
version "14.14.37"
|
|
||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.14.37.tgz#a3dd8da4eb84a996c36e331df98d82abd76b516e"
|
|
||||||
integrity sha512-XYmBiy+ohOR4Lh5jE379fV2IU+6Jn4g5qASinhitfyO71b/sCo6MKsMLF5tc7Zf2CE8hViVQyYSobJNke8OvUw==
|
|
||||||
|
|
||||||
"@types/p-limit@^2.2.0":
|
"@types/p-limit@^2.2.0":
|
||||||
version "2.2.0"
|
version "2.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/@types/p-limit/-/p-limit-2.2.0.tgz#94a608e9b258a6c6156a13d1a14fd720dba70b97"
|
resolved "https://registry.yarnpkg.com/@types/p-limit/-/p-limit-2.2.0.tgz#94a608e9b258a6c6156a13d1a14fd720dba70b97"
|
||||||
@@ -1038,10 +1038,10 @@ entities@~2.1.0:
|
|||||||
resolved "https://registry.yarnpkg.com/entities/-/entities-2.1.0.tgz#992d3129cf7df6870b96c57858c249a120f8b8b5"
|
resolved "https://registry.yarnpkg.com/entities/-/entities-2.1.0.tgz#992d3129cf7df6870b96c57858c249a120f8b8b5"
|
||||||
integrity sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==
|
integrity sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==
|
||||||
|
|
||||||
esbuild@^0.8.30:
|
esbuild@^0.12.6:
|
||||||
version "0.8.47"
|
version "0.12.6"
|
||||||
resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.8.47.tgz#5d5c59b7dcb8a20dfadf65a985e5e5ca7b24eff2"
|
resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.12.6.tgz#85bc755c7cf3005d4f34b4f10f98049ce0ee67ce"
|
||||||
integrity sha512-4C9pInguP36c9CRDMSb6W1KrMfXrLIQVtI02Vglc43RBV0Dw49ODEnP6985mrz5iqCdQ2Cxmb9i670J/s3DBPA==
|
integrity sha512-RDvVLvAjsq/kIZJoneMiUOH7EE7t2QaW7T3Q7EdQij14+bZbDq5sndb0tTanmHIFSqZVMBMMyqzVHkS3dJobeA==
|
||||||
|
|
||||||
eslint-scope@^5.0.0:
|
eslint-scope@^5.0.0:
|
||||||
version "5.1.1"
|
version "5.1.1"
|
||||||
@@ -2001,10 +2001,10 @@ typescript@^4.1.3:
|
|||||||
resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.1.5.tgz#123a3b214aaff3be32926f0d8f1f6e704eb89a72"
|
resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.1.5.tgz#123a3b214aaff3be32926f0d8f1f6e704eb89a72"
|
||||||
integrity sha512-6OSu9PTIzmn9TCDiovULTnET6BgXtDYL4Gg4szY+cGsc3JP1dQL8qvE8kShTRx1NIw4Q9IBHlwODjkjWEtMUyA==
|
integrity sha512-6OSu9PTIzmn9TCDiovULTnET6BgXtDYL4Gg4szY+cGsc3JP1dQL8qvE8kShTRx1NIw4Q9IBHlwODjkjWEtMUyA==
|
||||||
|
|
||||||
typescript@^4.3.0-dev.20210426:
|
typescript@^4.4.0-dev.20210607:
|
||||||
version "4.3.0-dev.20210426"
|
version "4.4.0-dev.20210607"
|
||||||
resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.3.0-dev.20210426.tgz#00198cb8828f6a04b4e0ae32554a486bf7137a53"
|
resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.4.0-dev.20210607.tgz#ea802e420785ef3b6b9c2e12d1ff4b8d2e52ee19"
|
||||||
integrity sha512-8YTqlzf3w8O8XwnnRlwRV2rswu7V7WEPUnAnH1BPPMrr06thNByMjIadA5SDW3tUJc1MG8Uj3NgZYocU5fWTVg==
|
integrity sha512-tKAp1IL4APSdxD7xHLDU6tIDOEN8yJOTUGG+cSdLunmysl3yOkGrdUbByDaFDmGjKywghGhQvcG8gOqbLUcDcg==
|
||||||
|
|
||||||
uc.micro@^1.0.1, uc.micro@^1.0.5:
|
uc.micro@^1.0.1, uc.micro@^1.0.5:
|
||||||
version "1.0.6"
|
version "1.0.6"
|
||||||
|
|||||||
@@ -19,7 +19,7 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
// Reason: The license at https://github.com/Microsoft/TypeScript/blob/master/LICENSE.txt
|
// Reason: The license at https://github.com/microsoft/TypeScript/blob/master/LICENSE.txt
|
||||||
// does not include a clear Copyright statement.
|
// does not include a clear Copyright statement.
|
||||||
"name": "typescript",
|
"name": "typescript",
|
||||||
"prependLicenseText": [
|
"prependLicenseText": [
|
||||||
@@ -54,35 +54,6 @@
|
|||||||
"Copyright (c) Microsoft Corporation. All rights reserved."
|
"Copyright (c) Microsoft Corporation. All rights reserved."
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
|
||||||
// Reason: The npm package lacks a repoURL field
|
|
||||||
// So the license at https://github.com/floatdrop/pinkie/blob/master/license
|
|
||||||
// cannot be found by the OSS tool automatically.
|
|
||||||
"name": "pinkie",
|
|
||||||
"fullLicenseText": [
|
|
||||||
"The MIT License (MIT)",
|
|
||||||
"",
|
|
||||||
"Copyright (c) Vsevolod Strukchinsky <floatdrop@gmail.com> (github.com/floatdrop)",
|
|
||||||
"",
|
|
||||||
"Permission is hereby granted, free of charge, to any person obtaining a copy",
|
|
||||||
"of this software and associated documentation files (the \"Software\"), to deal",
|
|
||||||
"in the Software without restriction, including without limitation the rights",
|
|
||||||
"to use, copy, modify, merge, publish, distribute, sublicense, and/or sell",
|
|
||||||
"copies of the Software, and to permit persons to whom the Software is",
|
|
||||||
"furnished to do so, subject to the following conditions:",
|
|
||||||
"",
|
|
||||||
"The above copyright notice and this permission notice shall be included in",
|
|
||||||
"all copies or substantial portions of the Software.",
|
|
||||||
"",
|
|
||||||
"THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR",
|
|
||||||
"IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,",
|
|
||||||
"FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE",
|
|
||||||
"AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER",
|
|
||||||
"LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,",
|
|
||||||
"OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN",
|
|
||||||
"THE SOFTWARE."
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "big-integer",
|
"name": "big-integer",
|
||||||
"prependLicenseText": [
|
"prependLicenseText": [
|
||||||
@@ -134,6 +105,7 @@
|
|||||||
{
|
{
|
||||||
// Reason: Repository lacks license text.
|
// Reason: Repository lacks license text.
|
||||||
// https://github.com/LinusU/load-yaml-file/blob/master/package.json declares MIT.
|
// https://github.com/LinusU/load-yaml-file/blob/master/package.json declares MIT.
|
||||||
|
// https://github.com/LinusU/load-yaml-file/issues/2
|
||||||
"name": "load-yaml-file",
|
"name": "load-yaml-file",
|
||||||
"fullLicenseText": [
|
"fullLicenseText": [
|
||||||
"MIT License",
|
"MIT License",
|
||||||
@@ -149,6 +121,7 @@
|
|||||||
{
|
{
|
||||||
// Reason: Repository lacks license text.
|
// Reason: Repository lacks license text.
|
||||||
// https://github.com/othiym23/emitter-listener/blob/master/package.json declares BSD-2-Clause.
|
// https://github.com/othiym23/emitter-listener/blob/master/package.json declares BSD-2-Clause.
|
||||||
|
// https://github.com/othiym23/emitter-listener/issues/3
|
||||||
"name": "emitter-listener",
|
"name": "emitter-listener",
|
||||||
"fullLicenseText": [
|
"fullLicenseText": [
|
||||||
"BSD 2-Clause \"Simplified\" License",
|
"BSD 2-Clause \"Simplified\" License",
|
||||||
@@ -174,19 +147,5 @@
|
|||||||
"(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS",
|
"(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS",
|
||||||
"SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
|
"SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
|
||||||
]
|
]
|
||||||
},
|
|
||||||
{
|
|
||||||
// Reason: Repository has been deleted (package.json declares MIT).
|
|
||||||
"name": "vscode-js-debug-cdp-proxy-api",
|
|
||||||
"fullLicenseText": [
|
|
||||||
"MIT License",
|
|
||||||
"Copyright (c) Manuel Alabor",
|
|
||||||
"",
|
|
||||||
"Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:",
|
|
||||||
"",
|
|
||||||
"The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.",
|
|
||||||
"",
|
|
||||||
"THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE."
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -60,12 +60,12 @@
|
|||||||
"git": {
|
"git": {
|
||||||
"name": "electron",
|
"name": "electron",
|
||||||
"repositoryUrl": "https://github.com/electron/electron",
|
"repositoryUrl": "https://github.com/electron/electron",
|
||||||
"commitHash": "8d55658bfa8b5983e1a90ad079c2e2ac91ee7af0"
|
"commitHash": "30f82dd1cb8140ccb5c6a4960eef8e3b8c15eeba"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"isOnlyProductionDependency": true,
|
"isOnlyProductionDependency": true,
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"version": "12.0.7"
|
"version": "12.0.9"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"component": {
|
"component": {
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
// Copyright (c) Microsoft Corporation.
|
// Copyright (c) Microsoft Corporation.
|
||||||
// Licensed under the MIT License.
|
// Licensed under the Source EULA.
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This file imports all public APIs for this extension and used to generate index.d.ts.
|
* This file imports all public APIs for this extension and used to generate index.d.ts.
|
||||||
|
|||||||
@@ -6,11 +6,11 @@
|
|||||||
"git": {
|
"git": {
|
||||||
"name": "mmims/language-batchfile",
|
"name": "mmims/language-batchfile",
|
||||||
"repositoryUrl": "https://github.com/mmims/language-batchfile",
|
"repositoryUrl": "https://github.com/mmims/language-batchfile",
|
||||||
"commitHash": "95ea8c699f7a8296b15767069868532d52631c46"
|
"commitHash": "6154ae25a24e01ac9329e7bcf958e093cd8733a9"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"version": "0.7.5"
|
"version": "0.7.6"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"version": 1
|
"version": 1
|
||||||
|
|||||||
@@ -4,9 +4,18 @@
|
|||||||
"If you want to provide a fix or improvement, please create a pull request against the original repository.",
|
"If you want to provide a fix or improvement, please create a pull request against the original repository.",
|
||||||
"Once accepted there, we are happy to receive an update request."
|
"Once accepted there, we are happy to receive an update request."
|
||||||
],
|
],
|
||||||
"version": "https://github.com/mmims/language-batchfile/commit/95ea8c699f7a8296b15767069868532d52631c46",
|
"version": "https://github.com/mmims/language-batchfile/commit/6154ae25a24e01ac9329e7bcf958e093cd8733a9",
|
||||||
"name": "Batch File",
|
"name": "Batch File",
|
||||||
"scopeName": "source.batchfile",
|
"scopeName": "source.batchfile",
|
||||||
|
"injections": {
|
||||||
|
"L:meta.block.repeat.batchfile": {
|
||||||
|
"patterns": [
|
||||||
|
{
|
||||||
|
"include": "#repeatParameter"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
"patterns": [
|
"patterns": [
|
||||||
{
|
{
|
||||||
"include": "#commands"
|
"include": "#commands"
|
||||||
@@ -46,7 +55,7 @@
|
|||||||
"commands": {
|
"commands": {
|
||||||
"patterns": [
|
"patterns": [
|
||||||
{
|
{
|
||||||
"match": "(?<=^|[\\s@])(?i:adprep|append|arp|assoc|at|atmadm|attrib|auditpol|autochk|autoconv|autofmt|bcdboot|bcdedit|bdehdcfg|bitsadmin|bootcfg|brea|cacls|cd|certreq|certutil|change|chcp|chdir|chglogon|chgport|chgusr|chkdsk|chkntfs|choice|cipher|clip|cls|clscluadmin|cluster|cmd|cmdkey|cmstp|color|comp|compact|convert|copy|cprofile|cscript|csvde|date|dcdiag|dcgpofix|dcpromo|defra|del|dfscmd|dfsdiag|dfsrmig|diantz|dir|dirquota|diskcomp|diskcopy|diskpart|diskperf|diskraid|diskshadow|dispdiag|doin|dnscmd|doskey|driverquery|dsacls|dsadd|dsamain|dsdbutil|dsget|dsmgmt|dsmod|dsmove|dsquery|dsrm|edit|endlocal|eraseesentutl|eventcreate|eventquery|eventtriggers|evntcmd|expand|extract|fc|filescrn|find|findstr|finger|flattemp|fonde|forfiles|format|freedisk|fsutil|ftp|ftype|fveupdate|getmac|gettype|gpfixup|gpresult|gpupdate|graftabl|hashgen|hep|helpctr|hostname|icacls|iisreset|inuse|ipconfig|ipxroute|irftp|ismserv|jetpack|klist|ksetup|ktmutil|ktpass|label|ldifd|ldp|lodctr|logman|logoff|lpq|lpr|macfile|makecab|manage-bde|mapadmin|md|mkdir|mklink|mmc|mode|more|mount|mountvol|move|mqbup|mqsvc|mqtgsvc|msdt|msg|msiexec|msinfo32|mstsc|nbtstat|net computer|net group|net localgroup|net print|net session|net share|net start|net stop|net use|net user|net view|net|netcfg|netdiag|netdom|netsh|netstat|nfsadmin|nfsshare|nfsstat|nlb|nlbmgr|nltest|nslookup|ntackup|ntcmdprompt|ntdsutil|ntfrsutl|openfiles|pagefileconfig|path|pathping|pause|pbadmin|pentnt|perfmon|ping|pnpunatten|pnputil|popd|powercfg|powershell|powershell_ise|print|prncnfg|prndrvr|prnjobs|prnmngr|prnport|prnqctl|prompt|pubprn|pushd|pushprinterconnections|pwlauncher|qappsrv|qprocess|query|quser|qwinsta|rasdial|rcp|rd|rdpsign|regentc|recover|redircmp|redirusr|reg|regini|regsvr32|relog|ren|rename|rendom|repadmin|repair-bde|replace|reset session|rxec|risetup|rmdir|robocopy|route|rpcinfo|rpcping|rsh|runas|rundll32|rwinsta|scp|sc|schtasks|scwcmd|secedit|serverceipoptin|servrmanagercmd|serverweroptin|setspn|setx|sfc|shadow|shift|showmount|shutdown|sort|ssh|start|storrept|subst|sxstrace|ysocmgr|systeminfo|takeown|tapicfg|taskkill|tasklist|tcmsetup|telnet|tftp|time|timeout|title|tlntadmn|tpmvscmgr|tpmvscmgr|tacerpt|tracert|tree|tscon|tsdiscon|tsecimp|tskill|tsprof|type|typeperf|tzutil|uddiconfig|umount|unlodctr|ver|verifier|verif|vol|vssadmin|w32tm|waitfor|wbadmin|wdsutil|wecutil|wevtutil|where|whoami|winnt|winnt32|winpop|winrm|winrs|winsat|wlbs|mic|wscript|xcopy)(?=$|\\s)",
|
"match": "(?<=^|[\\s@])(?i:adprep|append|arp|assoc|at|atmadm|attrib|auditpol|autochk|autoconv|autofmt|bcdboot|bcdedit|bdehdcfg|bitsadmin|bootcfg|brea|cacls|cd|certreq|certutil|change|chcp|chdir|chglogon|chgport|chgusr|chkdsk|chkntfs|choice|cipher|clip|cls|clscluadmin|cluster|cmd|cmdkey|cmstp|color|comp|compact|convert|copy|cprofile|cscript|csvde|date|dcdiag|dcgpofix|dcpromo|defra|del|dfscmd|dfsdiag|dfsrmig|diantz|dir|dirquota|diskcomp|diskcopy|diskpart|diskperf|diskraid|diskshadow|dispdiag|doin|dnscmd|doskey|driverquery|dsacls|dsadd|dsamain|dsdbutil|dsget|dsmgmt|dsmod|dsmove|dsquery|dsrm|edit|endlocal|eraseesentutl|eventcreate|eventquery|eventtriggers|evntcmd|expand|extract|fc|filescrn|find|findstr|finger|flattemp|fonde|forfiles|format|freedisk|fsutil|ftp|ftype|fveupdate|getmac|gettype|gpfixup|gpresult|gpupdate|graftabl|hashgen|hep|helpctr|hostname|icacls|iisreset|inuse|ipconfig|ipxroute|irftp|ismserv|jetpack|klist|ksetup|ktmutil|ktpass|label|ldifd|ldp|lodctr|logman|logoff|lpq|lpr|macfile|makecab|manage-bde|mapadmin|md|mkdir|mklink|mmc|mode|more|mount|mountvol|move|mqbup|mqsvc|mqtgsvc|msdt|msg|msiexec|msinfo32|mstsc|nbtstat|net computer|net group|net localgroup|net print|net session|net share|net start|net stop|net use|net user|net view|net|netcfg|netdiag|netdom|netsh|netstat|nfsadmin|nfsshare|nfsstat|nlb|nlbmgr|nltest|nslookup|ntackup|ntcmdprompt|ntdsutil|ntfrsutl|openfiles|pagefileconfig|path|pathping|pause|pbadmin|pentnt|perfmon|ping|pnpunatten|pnputil|popd|powercfg|powershell|powershell_ise|print|prncnfg|prndrvr|prnjobs|prnmngr|prnport|prnqctl|prompt|pubprn|pushd|pushprinterconnections|pwlauncher|qappsrv|qprocess|query|quser|qwinsta|rasdial|rcp|rd|rdpsign|regentc|recover|redircmp|redirusr|reg|regini|regsvr32|relog|ren|rename|rendom|repadmin|repair-bde|replace|reset session|rxec|risetup|rmdir|robocopy|route|rpcinfo|rpcping|rsh|runas|rundll32|rwinsta|sc|schtasks|scp|scwcmd|secedit|serverceipoptin|servrmanagercmd|serverweroptin|setspn|setx|sfc|sftp|shadow|shift|showmount|shutdown|sort|ssh|ssh-add|ssh-agent|ssh-keygen|ssh-keyscan|start|storrept|subst|sxstrace|ysocmgr|systeminfo|takeown|tapicfg|taskkill|tasklist|tcmsetup|telnet|tftp|time|timeout|title|tlntadmn|tpmvscmgr|tpmvscmgr|tacerpt|tracert|tree|tscon|tsdiscon|tsecimp|tskill|tsprof|type|typeperf|tzutil|uddiconfig|umount|unlodctr|ver|verifier|verif|vol|vssadmin|w32tm|waitfor|wbadmin|wdsutil|wecutil|wevtutil|where|whoami|winnt|winnt32|winpop|winrm|winrs|winsat|wlbs|wmic|wscript|wsl|xcopy)(?=$|\\s)",
|
||||||
"name": "keyword.command.batchfile"
|
"name": "keyword.command.batchfile"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -285,7 +294,7 @@
|
|||||||
"name": "keyword.operator.logical.batchfile"
|
"name": "keyword.operator.logical.batchfile"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"match": "([^ ][^=]*)(=)",
|
"match": "([^ =]*)(=)",
|
||||||
"captures": {
|
"captures": {
|
||||||
"1": {
|
"1": {
|
||||||
"name": "variable.other.readwrite.batchfile"
|
"name": "variable.other.readwrite.batchfile"
|
||||||
@@ -420,8 +429,38 @@
|
|||||||
"name": "keyword.control.conditional.batchfile"
|
"name": "keyword.control.conditional.batchfile"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"match": "(?<=^|\\s)(?i)for(?=\\s)",
|
"begin": "(?<=^|[\\s(&^])(?i)for(?=\\s)",
|
||||||
"name": "keyword.control.repeat.batchfile"
|
"beginCaptures": {
|
||||||
|
"0": {
|
||||||
|
"name": "keyword.control.repeat.batchfile"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"name": "meta.block.repeat.batchfile",
|
||||||
|
"end": "\\n",
|
||||||
|
"patterns": [
|
||||||
|
{
|
||||||
|
"begin": "(?<=[\\s^])(?i)in(?=\\s)",
|
||||||
|
"beginCaptures": {
|
||||||
|
"0": {
|
||||||
|
"name": "keyword.control.repeat.in.batchfile"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"end": "(?<=[\\s)^])(?i)do(?=\\s)|\\n",
|
||||||
|
"endCaptures": {
|
||||||
|
"0": {
|
||||||
|
"name": "keyword.control.repeat.do.batchfile"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"patterns": [
|
||||||
|
{
|
||||||
|
"include": "$self"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"include": "$self"
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
@@ -436,7 +475,7 @@
|
|||||||
"labels": {
|
"labels": {
|
||||||
"patterns": [
|
"patterns": [
|
||||||
{
|
{
|
||||||
"match": "(?i)(?:^\\s*|(?<=goto)\\s*)(:)([^+=,;:\\s].*)$",
|
"match": "(?i)(?:^\\s*|(?<=call|goto)\\s*)(:)([^+=,;:\\s]\\S*)",
|
||||||
"captures": {
|
"captures": {
|
||||||
"1": {
|
"1": {
|
||||||
"name": "punctuation.separator.batchfile"
|
"name": "punctuation.separator.batchfile"
|
||||||
@@ -512,6 +551,19 @@
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"repeatParameter": {
|
||||||
|
"patterns": [
|
||||||
|
{
|
||||||
|
"match": "(%%)(?:(?i:~[fdpnxsatz]*(?:\\$PATH:)?)?[a-zA-Z])",
|
||||||
|
"captures": {
|
||||||
|
"1": {
|
||||||
|
"name": "punctuation.definition.variable.batchfile"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"name": "variable.parameter.repeat.batchfile"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
"strings": {
|
"strings": {
|
||||||
"patterns": [
|
"patterns": [
|
||||||
{
|
{
|
||||||
@@ -546,15 +598,13 @@
|
|||||||
"variables": {
|
"variables": {
|
||||||
"patterns": [
|
"patterns": [
|
||||||
{
|
{
|
||||||
"match": "(%)((~([fdpnxsatz]|\\$PATH:)*)?\\d|\\*)",
|
"match": "(%)(?:(?i:~[fdpnxsatz]*(?:\\$PATH:)?)?\\d|\\*)",
|
||||||
"captures": {
|
"captures": {
|
||||||
"1": {
|
"1": {
|
||||||
"name": "punctuation.definition.variable.batchfile"
|
"name": "punctuation.definition.variable.batchfile"
|
||||||
},
|
|
||||||
"2": {
|
|
||||||
"name": "variable.parameter.batchfile"
|
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
"name": "variable.parameter.batchfile"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"include": "#variable"
|
"include": "#variable"
|
||||||
|
|||||||
@@ -139,7 +139,7 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/node": "^12.19.9"
|
"@types/node": "14.x"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
|
|||||||
@@ -54,6 +54,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"default": {
|
"default": {
|
||||||
@@ -80,7 +93,13 @@
|
|||||||
"properties": {
|
"properties": {
|
||||||
"onAutoForward": {
|
"onAutoForward": {
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"enum": ["notify", "openBrowser", "openPreview", "silent", "ignore"],
|
"enum": [
|
||||||
|
"notify",
|
||||||
|
"openBrowser",
|
||||||
|
"openPreview",
|
||||||
|
"silent",
|
||||||
|
"ignore"
|
||||||
|
],
|
||||||
"enumDescriptions": [
|
"enumDescriptions": [
|
||||||
"Shows a notification when a port is automatically forwarded.",
|
"Shows a notification when a port is automatically forwarded.",
|
||||||
"Opens the browser when the port is automatically forwarded. Depending on your settings, this could open an embedded browser.",
|
"Opens the browser when the port is automatically forwarded. Depending on your settings, this could open an embedded browser.",
|
||||||
@@ -100,9 +119,28 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"defaultSnippets": [{ "body": { "onAutoForward": "ignore" } }],
|
"defaultSnippets": [
|
||||||
|
{
|
||||||
|
"body": {
|
||||||
|
"onAutoForward": "ignore"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
"markdownDescription": "Set default properties that are applied to all ports that don't get properties from the setting `remote.portsAttributes`. For example:\n\n```\n{\n \"onAutoForward\": \"ignore\"\n}\n```",
|
"markdownDescription": "Set default properties that are applied to all ports that don't get properties from the setting `remote.portsAttributes`. For example:\n\n```\n{\n \"onAutoForward\": \"ignore\"\n}\n```",
|
||||||
"additionalProperties": false
|
"additionalProperties": false
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -162,6 +162,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"default": {
|
"default": {
|
||||||
@@ -215,6 +228,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"defaultSnippets": [
|
"defaultSnippets": [
|
||||||
@@ -246,7 +272,27 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run locally before anything else. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run locally before anything else. This command is run before \"onCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"onCreateCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container. This command is run after \"initializeCommand\" and before \"updateContentCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"updateContentCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container and rerun when the workspace content was updated while creating the container. This command is run after \"onCreateCommand\" and before \"postCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -256,7 +302,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after creating the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after creating the container. This command is run after \"updateContentCommand\" and before \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -266,7 +312,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after starting the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after starting the container. This command is run after \"postCreateCommand\" and before \"postAttachCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -276,11 +322,23 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after attaching to the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run when attaching to the container. This command is run after \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"waitFor": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"initializeCommand",
|
||||||
|
"onCreateCommand",
|
||||||
|
"updateContentCommand",
|
||||||
|
"postCreateCommand",
|
||||||
|
"postStartCommand",
|
||||||
|
"postAttachCommand"
|
||||||
|
],
|
||||||
|
"description": "The user command to wait for before continuing execution in the background while the UI is starting up. The default is \"updateContentCommand\"."
|
||||||
|
},
|
||||||
"devPort": {
|
"devPort": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"description": "The port VS Code can use to connect to its backend."
|
"description": "The port VS Code can use to connect to its backend."
|
||||||
@@ -299,6 +357,28 @@
|
|||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": true,
|
"additionalProperties": true,
|
||||||
"description": "Codespaces-specific configuration."
|
"description": "Codespaces-specific configuration."
|
||||||
|
},
|
||||||
|
"hostRequirements": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "Host hardware requirements.",
|
||||||
|
"properties": {
|
||||||
|
"cpus": {
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 1,
|
||||||
|
"description": "Number of required CPUs."
|
||||||
|
},
|
||||||
|
"memory": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required RAM in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
},
|
||||||
|
"storage": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required disk space in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
@@ -461,6 +541,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"default": {
|
"default": {
|
||||||
@@ -514,6 +607,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"defaultSnippets": [
|
"defaultSnippets": [
|
||||||
@@ -545,7 +651,27 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run locally before anything else. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run locally before anything else. This command is run before \"onCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"onCreateCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container. This command is run after \"initializeCommand\" and before \"updateContentCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"updateContentCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container and rerun when the workspace content was updated while creating the container. This command is run after \"onCreateCommand\" and before \"postCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -555,7 +681,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after creating the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after creating the container. This command is run after \"updateContentCommand\" and before \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -565,7 +691,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after starting the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after starting the container. This command is run after \"postCreateCommand\" and before \"postAttachCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -575,11 +701,23 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after attaching to the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run when attaching to the container. This command is run after \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"waitFor": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"initializeCommand",
|
||||||
|
"onCreateCommand",
|
||||||
|
"updateContentCommand",
|
||||||
|
"postCreateCommand",
|
||||||
|
"postStartCommand",
|
||||||
|
"postAttachCommand"
|
||||||
|
],
|
||||||
|
"description": "The user command to wait for before continuing execution in the background while the UI is starting up. The default is \"updateContentCommand\"."
|
||||||
|
},
|
||||||
"devPort": {
|
"devPort": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"description": "The port VS Code can use to connect to its backend."
|
"description": "The port VS Code can use to connect to its backend."
|
||||||
@@ -598,6 +736,28 @@
|
|||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": true,
|
"additionalProperties": true,
|
||||||
"description": "Codespaces-specific configuration."
|
"description": "Codespaces-specific configuration."
|
||||||
|
},
|
||||||
|
"hostRequirements": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "Host hardware requirements.",
|
||||||
|
"properties": {
|
||||||
|
"cpus": {
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 1,
|
||||||
|
"description": "Number of required CPUs."
|
||||||
|
},
|
||||||
|
"memory": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required RAM in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
},
|
||||||
|
"storage": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required disk space in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
@@ -736,6 +896,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"default": {
|
"default": {
|
||||||
@@ -789,6 +962,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"defaultSnippets": [
|
"defaultSnippets": [
|
||||||
@@ -820,7 +1006,27 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run locally before anything else. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run locally before anything else. This command is run before \"onCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"onCreateCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container. This command is run after \"initializeCommand\" and before \"updateContentCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"updateContentCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container and rerun when the workspace content was updated while creating the container. This command is run after \"onCreateCommand\" and before \"postCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -830,7 +1036,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after creating the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after creating the container. This command is run after \"updateContentCommand\" and before \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -840,7 +1046,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after starting the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after starting the container. This command is run after \"postCreateCommand\" and before \"postAttachCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -850,11 +1056,23 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after attaching to the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run when attaching to the container. This command is run after \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"waitFor": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"initializeCommand",
|
||||||
|
"onCreateCommand",
|
||||||
|
"updateContentCommand",
|
||||||
|
"postCreateCommand",
|
||||||
|
"postStartCommand",
|
||||||
|
"postAttachCommand"
|
||||||
|
],
|
||||||
|
"description": "The user command to wait for before continuing execution in the background while the UI is starting up. The default is \"updateContentCommand\"."
|
||||||
|
},
|
||||||
"devPort": {
|
"devPort": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"description": "The port VS Code can use to connect to its backend."
|
"description": "The port VS Code can use to connect to its backend."
|
||||||
@@ -873,6 +1091,28 @@
|
|||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": true,
|
"additionalProperties": true,
|
||||||
"description": "Codespaces-specific configuration."
|
"description": "Codespaces-specific configuration."
|
||||||
|
},
|
||||||
|
"hostRequirements": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "Host hardware requirements.",
|
||||||
|
"properties": {
|
||||||
|
"cpus": {
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 1,
|
||||||
|
"description": "Number of required CPUs."
|
||||||
|
},
|
||||||
|
"memory": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required RAM in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
},
|
||||||
|
"storage": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required disk space in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
@@ -977,6 +1217,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"default": {
|
"default": {
|
||||||
@@ -1030,6 +1283,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"defaultSnippets": [
|
"defaultSnippets": [
|
||||||
@@ -1061,7 +1327,27 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run locally before anything else. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run locally before anything else. This command is run before \"onCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"onCreateCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container. This command is run after \"initializeCommand\" and before \"updateContentCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"updateContentCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container and rerun when the workspace content was updated while creating the container. This command is run after \"onCreateCommand\" and before \"postCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -1071,7 +1357,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after creating the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after creating the container. This command is run after \"updateContentCommand\" and before \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -1081,7 +1367,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after starting the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after starting the container. This command is run after \"postCreateCommand\" and before \"postAttachCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -1091,11 +1377,23 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after attaching to the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run when attaching to the container. This command is run after \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"waitFor": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"initializeCommand",
|
||||||
|
"onCreateCommand",
|
||||||
|
"updateContentCommand",
|
||||||
|
"postCreateCommand",
|
||||||
|
"postStartCommand",
|
||||||
|
"postAttachCommand"
|
||||||
|
],
|
||||||
|
"description": "The user command to wait for before continuing execution in the background while the UI is starting up. The default is \"updateContentCommand\"."
|
||||||
|
},
|
||||||
"devPort": {
|
"devPort": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"description": "The port VS Code can use to connect to its backend."
|
"description": "The port VS Code can use to connect to its backend."
|
||||||
@@ -1114,6 +1412,28 @@
|
|||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": true,
|
"additionalProperties": true,
|
||||||
"description": "Codespaces-specific configuration."
|
"description": "Codespaces-specific configuration."
|
||||||
|
},
|
||||||
|
"hostRequirements": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "Host hardware requirements.",
|
||||||
|
"properties": {
|
||||||
|
"cpus": {
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 1,
|
||||||
|
"description": "Number of required CPUs."
|
||||||
|
},
|
||||||
|
"memory": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required RAM in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
},
|
||||||
|
"storage": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required disk space in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
@@ -1187,6 +1507,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"default": {
|
"default": {
|
||||||
@@ -1240,6 +1573,19 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"http",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"defaultSnippets": [
|
"defaultSnippets": [
|
||||||
@@ -1271,7 +1617,27 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run locally before anything else. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run locally before anything else. This command is run before \"onCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"onCreateCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container. This command is run after \"initializeCommand\" and before \"updateContentCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"updateContentCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container and rerun when the workspace content was updated while creating the container. This command is run after \"onCreateCommand\" and before \"postCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -1281,7 +1647,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after creating the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after creating the container. This command is run after \"updateContentCommand\" and before \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -1291,7 +1657,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after starting the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after starting the container. This command is run after \"postCreateCommand\" and before \"postAttachCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -1301,11 +1667,23 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after attaching to the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run when attaching to the container. This command is run after \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"waitFor": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"initializeCommand",
|
||||||
|
"onCreateCommand",
|
||||||
|
"updateContentCommand",
|
||||||
|
"postCreateCommand",
|
||||||
|
"postStartCommand",
|
||||||
|
"postAttachCommand"
|
||||||
|
],
|
||||||
|
"description": "The user command to wait for before continuing execution in the background while the UI is starting up. The default is \"updateContentCommand\"."
|
||||||
|
},
|
||||||
"devPort": {
|
"devPort": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"description": "The port VS Code can use to connect to its backend."
|
"description": "The port VS Code can use to connect to its backend."
|
||||||
@@ -1324,6 +1702,28 @@
|
|||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": true,
|
"additionalProperties": true,
|
||||||
"description": "Codespaces-specific configuration."
|
"description": "Codespaces-specific configuration."
|
||||||
|
},
|
||||||
|
"hostRequirements": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "Host hardware requirements.",
|
||||||
|
"properties": {
|
||||||
|
"cpus": {
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 1,
|
||||||
|
"description": "Number of required CPUs."
|
||||||
|
},
|
||||||
|
"memory": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required RAM in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
},
|
||||||
|
"storage": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required disk space in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false
|
"additionalProperties": false
|
||||||
|
|||||||
@@ -68,6 +68,16 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": ["http", "https"],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"default": {
|
"default": {
|
||||||
@@ -120,6 +130,16 @@
|
|||||||
"type": "string",
|
"type": "string",
|
||||||
"description": "Label that will be shown in the UI for this port.",
|
"description": "Label that will be shown in the UI for this port.",
|
||||||
"default": "Application"
|
"default": "Application"
|
||||||
|
},
|
||||||
|
"requireLocalPort": {
|
||||||
|
"type": "boolean",
|
||||||
|
"markdownDescription": "When true, a modal dialog will show if the chosen local port isn't used for forwarding.",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"protocol": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": ["http", "https"],
|
||||||
|
"description": "The protocol to use when forwarding this port."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"defaultSnippets": [
|
"defaultSnippets": [
|
||||||
@@ -151,7 +171,27 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run locally before anything else. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run locally before anything else. This command is run before \"onCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"onCreateCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container. This command is run after \"initializeCommand\" and before \"updateContentCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
|
"items": {
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"updateContentCommand": {
|
||||||
|
"type": [
|
||||||
|
"string",
|
||||||
|
"array"
|
||||||
|
],
|
||||||
|
"description": "A command to run when creating the container and rerun when the workspace content was updated while creating the container. This command is run after \"onCreateCommand\" and before \"postCreateCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -161,7 +201,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after creating the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after creating the container. This command is run after \"updateContentCommand\" and before \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -171,7 +211,7 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after starting the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run after starting the container. This command is run after \"postCreateCommand\" and before \"postAttachCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
@@ -181,11 +221,23 @@
|
|||||||
"string",
|
"string",
|
||||||
"array"
|
"array"
|
||||||
],
|
],
|
||||||
"description": "A command to run after attaching to the container. If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
"description": "A command to run when attaching to the container. This command is run after \"postStartCommand\". If this is a single string, it will be run in a shell. If this is an array of strings, it will be run as a single command without shell.",
|
||||||
"items": {
|
"items": {
|
||||||
"type": "string"
|
"type": "string"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"waitFor": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": [
|
||||||
|
"initializeCommand",
|
||||||
|
"onCreateCommand",
|
||||||
|
"updateContentCommand",
|
||||||
|
"postCreateCommand",
|
||||||
|
"postStartCommand",
|
||||||
|
"postAttachCommand"
|
||||||
|
],
|
||||||
|
"description": "The user command to wait for before continuing execution in the background while the UI is starting up. The default is \"updateContentCommand\"."
|
||||||
|
},
|
||||||
"devPort": {
|
"devPort": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"description": "The port VS Code can use to connect to its backend."
|
"description": "The port VS Code can use to connect to its backend."
|
||||||
@@ -204,6 +256,32 @@
|
|||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": true,
|
"additionalProperties": true,
|
||||||
"description": "Codespaces-specific configuration."
|
"description": "Codespaces-specific configuration."
|
||||||
|
},
|
||||||
|
"hostRequirements": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "Host hardware requirements.",
|
||||||
|
"allOf": [
|
||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"cpus": {
|
||||||
|
"type": "integer",
|
||||||
|
"minimum": 1,
|
||||||
|
"description": "Number of required CPUs."
|
||||||
|
},
|
||||||
|
"memory": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required RAM in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
},
|
||||||
|
"storage": {
|
||||||
|
"type": "string",
|
||||||
|
"pattern": "^\\d+([tgmk]b)?$",
|
||||||
|
"description": "Amount of required disk space in bytes. Supports units tb, gb, mb and kb."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
import * as vscode from 'vscode';
|
import * as vscode from 'vscode';
|
||||||
import { getLocation, Location, parse } from 'jsonc-parser';
|
import { getLocation, Location, parse } from 'jsonc-parser';
|
||||||
import * as nls from 'vscode-nls';
|
import * as nls from 'vscode-nls';
|
||||||
import { provideInstalledExtensionProposals, provideWorkspaceTrustExtensionProposals } from './extensionsProposals';
|
import { provideInstalledExtensionProposals } from './extensionsProposals';
|
||||||
|
|
||||||
const localize = nls.loadMessageBundle();
|
const localize = nls.loadMessageBundle();
|
||||||
|
|
||||||
@@ -60,13 +60,9 @@ export class SettingsDocument {
|
|||||||
return provideInstalledExtensionProposals(alreadyConfigured, `: [\n\t"ui"\n]`, range, true);
|
return provideInstalledExtensionProposals(alreadyConfigured, `: [\n\t"ui"\n]`, range, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// extensions.supportUntrustedWorkspaces
|
// remote.portsAttributes
|
||||||
if (location.path[0] === 'extensions.supportUntrustedWorkspaces' && location.path.length === 2 && location.isAtPropertyKey) {
|
if (location.path[0] === 'remote.portsAttributes' && location.path.length === 2 && location.isAtPropertyKey) {
|
||||||
let alreadyConfigured: string[] = [];
|
return this.providePortsAttributesCompletionItem(range);
|
||||||
try {
|
|
||||||
alreadyConfigured = Object.keys(parse(this.document.getText())['extensions.supportUntrustedWorkspaces']);
|
|
||||||
} catch (e) {/* ignore error */ }
|
|
||||||
return provideWorkspaceTrustExtensionProposals(alreadyConfigured, range);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.provideLanguageOverridesCompletionItems(location, position);
|
return this.provideLanguageOverridesCompletionItems(location, position);
|
||||||
@@ -247,6 +243,31 @@ export class SettingsDocument {
|
|||||||
return Promise.resolve([]);
|
return Promise.resolve([]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private providePortsAttributesCompletionItem(range: vscode.Range): vscode.CompletionItem[] {
|
||||||
|
return [this.newSnippetCompletionItem(
|
||||||
|
{
|
||||||
|
label: '\"3000\"',
|
||||||
|
documentation: 'Single Port Attribute',
|
||||||
|
range,
|
||||||
|
snippet: '\n \"${1:3000}\": {\n \"label\": \"${2:Application}\",\n \"onAutoForward\": \"${3:openPreview}\"\n }\n'
|
||||||
|
}),
|
||||||
|
this.newSnippetCompletionItem(
|
||||||
|
{
|
||||||
|
label: '\"5000-6000\"',
|
||||||
|
documentation: 'Ranged Port Attribute',
|
||||||
|
range,
|
||||||
|
snippet: '\n \"${1:40000-55000}\": {\n \"onAutoForward\": \"${2:ignore}\"\n }\n'
|
||||||
|
}),
|
||||||
|
this.newSnippetCompletionItem(
|
||||||
|
{
|
||||||
|
label: '\".+\\\\/server.js\"',
|
||||||
|
documentation: 'Command Match Port Attribute',
|
||||||
|
range,
|
||||||
|
snippet: '\n \"${1:.+\\\\/server.js\}\": {\n \"label\": \"${2:Application}\",\n \"onAutoForward\": \"${3:openPreview}\"\n }\n'
|
||||||
|
})
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
private newSimpleCompletionItem(text: string, range: vscode.Range, description?: string, insertText?: string): vscode.CompletionItem {
|
private newSimpleCompletionItem(text: string, range: vscode.Range, description?: string, insertText?: string): vscode.CompletionItem {
|
||||||
const item = new vscode.CompletionItem(text);
|
const item = new vscode.CompletionItem(text);
|
||||||
item.kind = vscode.CompletionItemKind.Value;
|
item.kind = vscode.CompletionItemKind.Value;
|
||||||
|
|||||||
@@ -2,10 +2,10 @@
|
|||||||
# yarn lockfile v1
|
# yarn lockfile v1
|
||||||
|
|
||||||
|
|
||||||
"@types/node@^12.19.9":
|
"@types/node@14.x":
|
||||||
version "12.19.9"
|
version "14.14.43"
|
||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-12.19.9.tgz#990ad687ad8b26ef6dcc34a4f69c33d40c95b679"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.14.43.tgz#26bcbb0595b305400e8ceaf9a127a7f905ae49c8"
|
||||||
integrity sha512-yj0DOaQeUrk3nJ0bd3Y5PeDRJ6W0r+kilosLA+dzF3dola/o9hxhMSg2sFvVcA2UHS5JSOsZp4S0c1OEXc4m1Q==
|
integrity sha512-3pwDJjp1PWacPTpH0LcfhgjvurQvrZFBrC6xxjaUEZ7ifUtT32jtjPxEMMblpqd2Mvx+k8haqQJLQxolyGN/cQ==
|
||||||
|
|
||||||
jsonc-parser@^2.2.1:
|
jsonc-parser@^2.2.1:
|
||||||
version "2.2.1"
|
version "2.2.1"
|
||||||
|
|||||||
2
extensions/dart/.vscodeignore
Normal file
2
extensions/dart/.vscodeignore
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
build/**
|
||||||
|
cgmanifest.json
|
||||||
46
extensions/dart/cgmanifest.json
Normal file
46
extensions/dart/cgmanifest.json
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
{
|
||||||
|
"registrations": [
|
||||||
|
{
|
||||||
|
"component": {
|
||||||
|
"type": "git",
|
||||||
|
"git": {
|
||||||
|
"name": "dart-lang/dart-syntax-highlight",
|
||||||
|
"repositoryUrl": "https://github.com/dart-lang/dart-syntax-highlight",
|
||||||
|
"commitHash": "65f211722c85e9fdf0aa658d5663e6ccaf2ebe25"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"licenseDetail": [
|
||||||
|
"Copyright 2020, the Dart project authors.",
|
||||||
|
"",
|
||||||
|
"Redistribution and use in source and binary forms, with or without",
|
||||||
|
"modification, are permitted provided that the following conditions are",
|
||||||
|
"met:",
|
||||||
|
"",
|
||||||
|
" * Redistributions of source code must retain the above copyright",
|
||||||
|
" notice, this list of conditions and the following disclaimer.",
|
||||||
|
" * Redistributions in binary form must reproduce the above",
|
||||||
|
" copyright notice, this list of conditions and the following",
|
||||||
|
" disclaimer in the documentation and/or other materials provided",
|
||||||
|
" with the distribution.",
|
||||||
|
" * Neither the name of Google LLC nor the names of its",
|
||||||
|
" contributors may be used to endorse or promote products derived",
|
||||||
|
" from this software without specific prior written permission.",
|
||||||
|
"",
|
||||||
|
"THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS",
|
||||||
|
"\"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT",
|
||||||
|
"LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR",
|
||||||
|
"A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT",
|
||||||
|
"OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,",
|
||||||
|
"SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT",
|
||||||
|
"LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,",
|
||||||
|
"DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY",
|
||||||
|
"THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT",
|
||||||
|
"(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE",
|
||||||
|
"OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
|
||||||
|
],
|
||||||
|
"license": "BSD",
|
||||||
|
"version": "0.0.0"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"version": 1
|
||||||
|
}
|
||||||
29
extensions/dart/language-configuration.json
Normal file
29
extensions/dart/language-configuration.json
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
{
|
||||||
|
"comments": {
|
||||||
|
"lineComment": "//",
|
||||||
|
"blockComment": [ "/*", "*/" ]
|
||||||
|
},
|
||||||
|
"brackets": [
|
||||||
|
["{", "}"],
|
||||||
|
["[", "]"],
|
||||||
|
["(", ")"]
|
||||||
|
],
|
||||||
|
"autoClosingPairs": [
|
||||||
|
{ "open": "{", "close": "}" },
|
||||||
|
{ "open": "[", "close": "]" },
|
||||||
|
{ "open": "(", "close": ")" },
|
||||||
|
{ "open": "'", "close": "'", "notIn": ["string", "comment"] },
|
||||||
|
{ "open": "\"", "close": "\"", "notIn": ["string"] },
|
||||||
|
{ "open": "`", "close": "`", "notIn": ["string", "comment"] },
|
||||||
|
{ "open": "/**", "close": " */", "notIn": ["string"] }
|
||||||
|
],
|
||||||
|
"surroundingPairs": [
|
||||||
|
["{", "}"],
|
||||||
|
["[", "]"],
|
||||||
|
["(", ")"],
|
||||||
|
["<", ">"],
|
||||||
|
["'", "'"],
|
||||||
|
["\"", "\""],
|
||||||
|
["`", "`"]
|
||||||
|
]
|
||||||
|
}
|
||||||
35
extensions/dart/package.json
Normal file
35
extensions/dart/package.json
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
{
|
||||||
|
"name": "dart",
|
||||||
|
"displayName": "%displayName%",
|
||||||
|
"description": "%description%",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"publisher": "vscode",
|
||||||
|
"license": "MIT",
|
||||||
|
"engines": {
|
||||||
|
"vscode": "0.10.x"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"update-grammar": "node ../node_modules/vscode-grammar-updater/bin dart-lang/dart-syntax-highlight grammars/dart.json ./syntaxes/dart.tmLanguage.json"
|
||||||
|
},
|
||||||
|
"contributes": {
|
||||||
|
"languages": [
|
||||||
|
{
|
||||||
|
"id": "dart",
|
||||||
|
"extensions": [
|
||||||
|
".dart"
|
||||||
|
],
|
||||||
|
"aliases": [
|
||||||
|
"Dart"
|
||||||
|
],
|
||||||
|
"configuration": "./language-configuration.json"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"grammars": [
|
||||||
|
{
|
||||||
|
"language": "dart",
|
||||||
|
"scopeName": "source.dart",
|
||||||
|
"path": "./syntaxes/dart.tmLanguage.json"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
4
extensions/dart/package.nls.json
Normal file
4
extensions/dart/package.nls.json
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"displayName": "Dart Language Basics",
|
||||||
|
"description": "Provides syntax highlighting & bracket matching in Dart files."
|
||||||
|
}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user