mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-19 18:46:52 -05:00
Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8095643ed4 | ||
|
|
96a3ded120 | ||
|
|
bd3aa9c3cf | ||
|
|
b765e5aa90 |
@@ -11,6 +11,6 @@ trim_trailing_whitespace = true
|
|||||||
|
|
||||||
# The indent size used in the `package.json` file cannot be changed
|
# The indent size used in the `package.json` file cannot be changed
|
||||||
# https://github.com/npm/npm/pull/3180#issuecomment-16336516
|
# https://github.com/npm/npm/pull/3180#issuecomment-16336516
|
||||||
[{*.yml,*.yaml,package.json}]
|
[{*.yml,*.yaml,npm-shrinkwrap.json,package.json}]
|
||||||
indent_style = space
|
indent_style = space
|
||||||
indent_size = 2
|
indent_size = 2
|
||||||
|
|||||||
@@ -10,10 +10,5 @@
|
|||||||
"no-extra-semi": "warn",
|
"no-extra-semi": "warn",
|
||||||
"semi": "warn"
|
"semi": "warn"
|
||||||
},
|
},
|
||||||
"extends": "eslint:recommended",
|
"extends": "eslint:recommended"
|
||||||
"parserOptions": {
|
|
||||||
"ecmaFeatures": {
|
|
||||||
"experimentalObjectRestSpread": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
17
.gitignore
vendored
17
.gitignore
vendored
@@ -1,8 +1,22 @@
|
|||||||
.DS_Store
|
.DS_Store
|
||||||
npm-debug.log
|
npm-debug.log
|
||||||
Thumbs.db
|
Thumbs.db
|
||||||
|
.DS_Store
|
||||||
|
*.dat
|
||||||
|
*.db
|
||||||
|
*.exe
|
||||||
|
*.log
|
||||||
|
*.nupkg
|
||||||
|
*.orig
|
||||||
|
*.vsix
|
||||||
|
*BROWSE.VC*
|
||||||
|
sqltoolsservice
|
||||||
|
coverage
|
||||||
|
test-reports
|
||||||
|
.vscode-test
|
||||||
node_modules/
|
node_modules/
|
||||||
.build/
|
.build/
|
||||||
|
.vs/
|
||||||
out/
|
out/
|
||||||
out-build/
|
out-build/
|
||||||
out-editor/
|
out-editor/
|
||||||
@@ -12,5 +26,4 @@ out-vscode/
|
|||||||
out-vscode-min/
|
out-vscode-min/
|
||||||
build/node_modules
|
build/node_modules
|
||||||
coverage/
|
coverage/
|
||||||
test_data/
|
_site
|
||||||
yarn-error.log
|
|
||||||
|
|||||||
24
.travis.yml
24
.travis.yml
@@ -7,13 +7,10 @@ os:
|
|||||||
|
|
||||||
cache:
|
cache:
|
||||||
directories:
|
directories:
|
||||||
- $HOME/.cache/yarn
|
- $HOME/.npm
|
||||||
|
|
||||||
notifications:
|
notifications:
|
||||||
email: false
|
email: false
|
||||||
webhooks:
|
|
||||||
- http://vscode-probot.westus.cloudapp.azure.com:3450/travis/notifications
|
|
||||||
- http://vscode-test-probot.westus.cloudapp.azure.com:3450/travis/notifications
|
|
||||||
|
|
||||||
addons:
|
addons:
|
||||||
apt:
|
apt:
|
||||||
@@ -34,26 +31,23 @@ before_install:
|
|||||||
- git submodule update --init --recursive
|
- git submodule update --init --recursive
|
||||||
- git clone --depth 1 https://github.com/creationix/nvm.git ./.nvm
|
- git clone --depth 1 https://github.com/creationix/nvm.git ./.nvm
|
||||||
- source ./.nvm/nvm.sh
|
- source ./.nvm/nvm.sh
|
||||||
- nvm install 8.9.1
|
- nvm install 7.9.0
|
||||||
- nvm use 8.9.1
|
- nvm use 7.9.0
|
||||||
- npm i -g yarn
|
- npm config set python `which python`
|
||||||
# - npm config set python `which python`
|
- npm install -g gulp
|
||||||
- if [ $TRAVIS_OS_NAME == "linux" ]; then
|
- if [ $TRAVIS_OS_NAME == "linux" ]; then
|
||||||
export CXX="g++-4.9" CC="gcc-4.9" DISPLAY=:99.0;
|
export CXX="g++-4.9" CC="gcc-4.9" DISPLAY=:99.0;
|
||||||
sh -e /etc/init.d/xvfb start;
|
sh -e /etc/init.d/xvfb start;
|
||||||
sleep 3;
|
sleep 3;
|
||||||
fi
|
fi
|
||||||
# Make npm logs less verbose
|
|
||||||
# - npm config set depth 0
|
|
||||||
# - npm config set loglevel warn
|
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- yarn
|
- ./scripts/npm.sh install
|
||||||
|
|
||||||
script:
|
script:
|
||||||
- node_modules/.bin/gulp electron --silent
|
- gulp electron --silent
|
||||||
- node_modules/.bin/gulp compile --silent --max_old_space_size=4096
|
- gulp compile --silent --max_old_space_size=4096
|
||||||
- node_modules/.bin/gulp optimize-vscode --silent --max_old_space_size=4096
|
- gulp optimize-vscode --silent --max_old_space_size=4096
|
||||||
- if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then ./scripts/test.sh --coverage --reporter dot; else ./scripts/test.sh --reporter dot; fi
|
- if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then ./scripts/test.sh --coverage --reporter dot; else ./scripts/test.sh --reporter dot; fi
|
||||||
|
|
||||||
after_success:
|
after_success:
|
||||||
|
|||||||
7
.vscode/launch.json
vendored
7
.vscode/launch.json
vendored
@@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"configurations": [
|
"configurations": [
|
||||||
|
|
||||||
{
|
{
|
||||||
"type": "node",
|
"type": "node",
|
||||||
"request": "launch",
|
"request": "launch",
|
||||||
@@ -8,7 +9,7 @@
|
|||||||
"program": "${workspaceFolder}/node_modules/gulp/bin/gulp.js",
|
"program": "${workspaceFolder}/node_modules/gulp/bin/gulp.js",
|
||||||
"stopOnEntry": true,
|
"stopOnEntry": true,
|
||||||
"args": [
|
"args": [
|
||||||
"hygiene"
|
"watch-extension:json-client"
|
||||||
],
|
],
|
||||||
"cwd": "${workspaceFolder}"
|
"cwd": "${workspaceFolder}"
|
||||||
},
|
},
|
||||||
@@ -86,9 +87,6 @@
|
|||||||
"runtimeArgs": [
|
"runtimeArgs": [
|
||||||
"--inspect=5875"
|
"--inspect=5875"
|
||||||
],
|
],
|
||||||
"skipFiles": [
|
|
||||||
"**/winjs*.js"
|
|
||||||
],
|
|
||||||
"webRoot": "${workspaceFolder}"
|
"webRoot": "${workspaceFolder}"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -106,7 +104,6 @@
|
|||||||
},
|
},
|
||||||
"stopOnEntry": false,
|
"stopOnEntry": false,
|
||||||
"args": [
|
"args": [
|
||||||
"--delay",
|
|
||||||
"--timeout",
|
"--timeout",
|
||||||
"2000"
|
"2000"
|
||||||
],
|
],
|
||||||
|
|||||||
8
.vscode/settings.json
vendored
8
.vscode/settings.json
vendored
@@ -10,9 +10,6 @@
|
|||||||
"when": "$(basename).ts"
|
"when": "$(basename).ts"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"files.associations": {
|
|
||||||
"OSSREADME.json": "jsonc"
|
|
||||||
},
|
|
||||||
"search.exclude": {
|
"search.exclude": {
|
||||||
"**/node_modules": true,
|
"**/node_modules": true,
|
||||||
"**/bower_components": true,
|
"**/bower_components": true,
|
||||||
@@ -37,6 +34,5 @@
|
|||||||
"command": "${workspaceFolder}\\scripts\\test.bat --coverage --run ${file}"
|
"command": "${workspaceFolder}\\scripts\\test.bat --coverage --run ${file}"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
],
|
]
|
||||||
"typescript.tsdk": "node_modules/typescript/lib"
|
}
|
||||||
}
|
|
||||||
6
.vscode/tasks.json
vendored
6
.vscode/tasks.json
vendored
@@ -33,11 +33,11 @@
|
|||||||
"task": "tslint",
|
"task": "tslint",
|
||||||
"label": "Run tslint",
|
"label": "Run tslint",
|
||||||
"problemMatcher": [
|
"problemMatcher": [
|
||||||
"$tslint5"
|
"$tslint4"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"label": "Run tests",
|
"taskName": "Run tests",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"command": "./scripts/test.sh",
|
"command": "./scripts/test.sh",
|
||||||
"windows": {
|
"windows": {
|
||||||
@@ -50,7 +50,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"label": "Run Dev",
|
"taskName": "Run Dev",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"command": "./scripts/code.sh",
|
"command": "./scripts/code.sh",
|
||||||
"windows": {
|
"windows": {
|
||||||
|
|||||||
3
.yarnrc
3
.yarnrc
@@ -1,3 +0,0 @@
|
|||||||
disturl "https://atom.io/download/electron"
|
|
||||||
target "1.7.11"
|
|
||||||
runtime "electron"
|
|
||||||
56
CHANGELOG.md
56
CHANGELOG.md
@@ -1,59 +1,6 @@
|
|||||||
# Change Log
|
# Change Log
|
||||||
|
|
||||||
## Version 0.27.3
|
## Version 0.25.2
|
||||||
* Release date: March 28, 2017
|
|
||||||
* Release status: Public Preview
|
|
||||||
|
|
||||||
## What's new in this version
|
|
||||||
The March Public Preview release enables some key aspects of the SQL Operations
|
|
||||||
Studio extensibility story. Here are some highlights in this release.
|
|
||||||
|
|
||||||
* Enhance the Manage Dashboard extensibility model to support tabbed Insights and Configuration panes
|
|
||||||
* Dashboard Insights extensions for `sp_whoisactive` from [whoisactive.com](http://whoisactive.com)
|
|
||||||
* Extension Manager enables simple acquisition of 1st-party and 3rd-party extensions
|
|
||||||
* Add additional Extensibility APIs for `connection` and `objectexplorer` management
|
|
||||||
* Community Localization open for 10 languages
|
|
||||||
* Continue to fix important customer impacting GitHub issues
|
|
||||||
|
|
||||||
## Version 0.26.7
|
|
||||||
* Release date: February 16, 2017
|
|
||||||
* Release status: Public Preview Hotfix 1
|
|
||||||
|
|
||||||
## What's new in this version
|
|
||||||
* Bug fix for `#717 Selecting partial query and hitting Cmd or Ctrl+C opens terminal with Error message`
|
|
||||||
|
|
||||||
## Version 0.26.6
|
|
||||||
* Release date: February 15, 2017
|
|
||||||
* Release status: Public Preview
|
|
||||||
|
|
||||||
## What's new in this version
|
|
||||||
The February release fixes several important customer reported issues, as well as various feature improvements. We've also introduced auto-update support in February which will simplify keeping updated with the lastest changes.
|
|
||||||
|
|
||||||
Here's some of the highlights in the February release.
|
|
||||||
|
|
||||||
* Support Auto-Update installation on Windows and macOS
|
|
||||||
* Publish RPM and DEB packages to offical Microsoft repos
|
|
||||||
* Fix `#6 Keep connection and selected database when opening new query tabs`
|
|
||||||
* Fix `#22 'Server Name' and 'Database Name' - Can these be drop downs instead of text` boxes?
|
|
||||||
* Fix #481 Add "Check for updates" option.
|
|
||||||
* SQL Editor colorization and auto-completion fixes
|
|
||||||
* `#584 Keyword "FULL" not highlighted by IntelliSense`
|
|
||||||
* `#345 Colorize SQL functions within the editor`
|
|
||||||
* `#300 [#tempData] latest "]" will display green color`
|
|
||||||
* `#225 Keyword color mismatch`
|
|
||||||
* `#60 invalid sql syntax color highlighting when using temporary table in from clause`
|
|
||||||
* Introduce Connection extensibility API
|
|
||||||
* VS Code Editor 1.19 integration
|
|
||||||
* Update JustinPealing/html-query-plan component to pick-up several Query Plan viewer improvements
|
|
||||||
|
|
||||||
## Contributions and "thank you"
|
|
||||||
We would like to thank all our users who raised issues, and in particular the following users who helped contribute fixes:
|
|
||||||
|
|
||||||
* SebastianPfliegel for `Add cursor snippet (#475)`
|
|
||||||
* mikaoelitiana for fix: `revert README and CONTRIBUTING after last VSCode merge (#574)`
|
|
||||||
* alextercete for `Reinstate menu item to install from VSIX (#682)`
|
|
||||||
|
|
||||||
## Version 0.25.4
|
|
||||||
* Release date: January 17, 2017
|
* Release date: January 17, 2017
|
||||||
* Release status: Public Preview
|
* Release status: Public Preview
|
||||||
|
|
||||||
@@ -76,7 +23,6 @@ Here's some of the highlights in the January release.
|
|||||||
We would like to thank all our users who raised issues, and in particular the following users who helped contribute fixes:
|
We would like to thank all our users who raised issues, and in particular the following users who helped contribute fixes:
|
||||||
|
|
||||||
* alextercete for `Fix "No extension gallery service configured" error (#427)`
|
* alextercete for `Fix "No extension gallery service configured" error (#427)`
|
||||||
* SebastianPfliegel for `Add cursor snippet (#475)`
|
|
||||||
|
|
||||||
## Version 0.24.1
|
## Version 0.24.1
|
||||||
* Release date: December 19, 2017
|
* Release date: December 19, 2017
|
||||||
|
|||||||
@@ -771,42 +771,5 @@
|
|||||||
"\"\"\""
|
"\"\"\""
|
||||||
],
|
],
|
||||||
"isProd": true
|
"isProd": true
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "spdlog original",
|
|
||||||
"version": "0.14.0",
|
|
||||||
"repositoryURL": "https://github.com/gabime/spdlog",
|
|
||||||
"license": "MIT",
|
|
||||||
"isProd": true
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"isLicense": true,
|
|
||||||
"name": "spdlog",
|
|
||||||
"version": "0.14.0",
|
|
||||||
"repositoryURL": "https://github.com/gabime/spdlog",
|
|
||||||
"license": "MIT",
|
|
||||||
"licenseDetail": [
|
|
||||||
"MIT License",
|
|
||||||
"",
|
|
||||||
"Copyright (c) Microsoft Corporation. All rights reserved.",
|
|
||||||
"",
|
|
||||||
"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"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|||||||
51
README.md
51
README.md
@@ -1,34 +1,22 @@
|
|||||||
# SQL Operations Studio
|
# SQL Operations Studio
|
||||||
|
|
||||||
[](https://gitter.im/Microsoft/sqlopsstudio?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
|
||||||
|
|
||||||
SQL Operations Studio is a data management tool that enables you to work with SQL Server, Azure SQL DB and SQL DW from Windows, macOS and Linux.
|
SQL Operations Studio is a data management tool that enables you to work with SQL Server, Azure SQL DB and SQL DW from Windows, macOS and Linux.
|
||||||
|
|
||||||
**Download SQL Operations Studio March Public Preview**
|
**Download SQL Operations Studio December Public Preview**
|
||||||
|
|
||||||
Platform | Link
|
Platform | Link
|
||||||
-- | --
|
-- | --
|
||||||
Windows Setup Installer | https://go.microsoft.com/fwlink/?linkid=870837
|
Windows Setup Installer | https://go.microsoft.com/fwlink/?linkid=865305
|
||||||
Windows ZIP | https://go.microsoft.com/fwlink/?linkid=870838
|
Windows ZIP | https://go.microsoft.com/fwlink/?linkid=865304
|
||||||
macOS ZIP | https://go.microsoft.com/fwlink/?linkid=870839
|
macOS ZIP | https://go.microsoft.com/fwlink/?linkid=865306
|
||||||
Linux TAR.GZ | https://go.microsoft.com/fwlink/?linkid=870840
|
Linux TAR.GZ | https://go.microsoft.com/fwlink/?linkid=865307
|
||||||
Linux DEB | https://go.microsoft.com/fwlink/?linkid=870842
|
Linux DEB | https://go.microsoft.com/fwlink/?linkid=865308
|
||||||
Linux RPM | https://go.microsoft.com/fwlink/?linkid=870841
|
Linux RPM | https://go.microsoft.com/fwlink/?linkid=865309
|
||||||
|
|
||||||
Go to our [download page](https://aka.ms/sqlopsstudio) for more specific instructions.
|
Go to our [download page](https://aka.ms/sqlopsstudio) for more specific instructions.
|
||||||
|
|
||||||
Try out the latest insiders build from `master` at https://github.com/Microsoft/sqlopsstudio/releases.
|
Try out the latest insiders build from `master` at https://github.com/Microsoft/sqlopsstudio/releases.
|
||||||
|
|
||||||
See the [change log](https://github.com/Microsoft/sqlopsstudio/blob/master/CHANGELOG.md) for additional details of what's in this release.
|
|
||||||
|
|
||||||
**Design Discussions**
|
|
||||||
|
|
||||||
The SQL Operations Studio team would like to incorporate community feedback earlier in the development process. To facilitate this, we'd like to share our designs while features are actively being built.
|
|
||||||
|
|
||||||
We're currently collecting input on the **SQL Agent** experience and enhancements to the Manage Dashboard that we're calling **"Command Center"**. We'll add additional design feedback requests below as we start work in new feature areas. Please leave comments on these issues to help us understand your requirements and shape feature development.
|
|
||||||
|
|
||||||
* [#750 Seeking community feedback on SQL Agent UX prototype](https://github.com/Microsoft/sqlopsstudio/issues/750)
|
|
||||||
|
|
||||||
**Feature Highlights**
|
**Feature Highlights**
|
||||||
|
|
||||||
- Cross-Platform DB management for Windows, macOS and Linux with simple XCopy deployment
|
- Cross-Platform DB management for Windows, macOS and Linux with simple XCopy deployment
|
||||||
@@ -58,34 +46,9 @@ please see the document [How to Contribute](https://github.com/Microsoft/sqlopss
|
|||||||
|
|
||||||
This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/). For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.
|
This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/). For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.
|
||||||
|
|
||||||
## Localization
|
|
||||||
SQL Operations Studio localization is now open for community contributions. You can contribute to localization for both software and docs. https://aka.ms/SQLOpsStudioLoc
|
|
||||||
|
|
||||||
Localization is now opened for 10 languages: French, Italian, German, Spanish, Simplified Chinese, Traditional Chinese, Japanese, Korean, Russian, and Portuguese (Brazil). Help us make SQL Operations Studio available in your language!
|
|
||||||
|
|
||||||
## Privacy Statement
|
## Privacy Statement
|
||||||
The [Microsoft Enterprise and Developer Privacy Statement](https://privacy.microsoft.com/en-us/privacystatement) describes the privacy statement of this software.
|
The [Microsoft Enterprise and Developer Privacy Statement](https://privacy.microsoft.com/en-us/privacystatement) describes the privacy statement of this software.
|
||||||
|
|
||||||
## Contributions and "thank you"
|
|
||||||
We would like to thank all our users who raised issues, and in particular the following users who helped contribute fixes:
|
|
||||||
|
|
||||||
* westerncj for `Removed duplicate contribution from README.md (#753)`
|
|
||||||
* ntovas for `Fix for duplicate extensions shown in "Save File" dialog. (#779)`
|
|
||||||
* SebastianPfliegel for `Add cursor snippet (#475)`
|
|
||||||
* mikaoelitiana for fix: `revert README and CONTRIBUTING after last VSCode merge (#574)`
|
|
||||||
* alextercete for `Reinstate menu item to install from VSIX (#682)`
|
|
||||||
* alextercete for `Fix "No extension gallery service configured" error (#427)`
|
|
||||||
* mwiedemeyer for `Fix #58: Default sort order for DB size widget (#111)`
|
|
||||||
* AlexTroshkin for `Show disconnect in context menu only when connectionProfile connected (#150)`
|
|
||||||
* AlexTroshkin for `Fix #138: Invalid syntax color highlighting (identity not highlighting) (#140))`
|
|
||||||
* stebet for `Fix #153: Fixing sql snippets that failed on a DB with case-sensitive collation. (#152)`
|
|
||||||
* SebastianPfliegel `Remove sqlExtensionHelp (#312)`
|
|
||||||
* olljanat for `Implemented npm version check (#314)`
|
|
||||||
* Adam Mechanic for helping with the `whoisactive` extension
|
|
||||||
* All community localization contributors *(will get list of individuals next month)*
|
|
||||||
|
|
||||||
And of course we'd like to thank the authors of all upstream dependencies. Please see a full list in the [ThirdPartyNotices.txt](https://raw.githubusercontent.com/Microsoft/sqlopsstudio/master/ThirdPartyNotices.txt)
|
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
Copyright (c) Microsoft Corporation. All rights reserved.
|
Copyright (c) Microsoft Corporation. All rights reserved.
|
||||||
|
|||||||
@@ -3,18 +3,19 @@ environment:
|
|||||||
VSCODE_BUILD_VERBOSE: true
|
VSCODE_BUILD_VERBOSE: true
|
||||||
|
|
||||||
cache:
|
cache:
|
||||||
- '%LOCALAPPDATA%\Yarn\cache'
|
- '%APPDATA%\npm-cache'
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- ps: Install-Product node 8.9.1 x64
|
- ps: Install-Product node 7.9.0 x64
|
||||||
|
- npm install -g npm@4 --silent
|
||||||
|
|
||||||
build_script:
|
build_script:
|
||||||
- yarn
|
- .\scripts\npm.bat install
|
||||||
- .\node_modules\.bin\gulp electron
|
- .\node_modules\.bin\gulp electron
|
||||||
- .\node_modules\.bin\tsc -p .\src\tsconfig.monaco.json --noEmit
|
|
||||||
- npm run compile
|
- npm run compile
|
||||||
|
|
||||||
test_script:
|
test_script:
|
||||||
- node --version
|
- node --version
|
||||||
|
- npm --version
|
||||||
- .\scripts\test.bat
|
- .\scripts\test.bat
|
||||||
- .\scripts\test-integration.bat
|
- .\scripts\test-integration.bat
|
||||||
|
|||||||
@@ -1,12 +0,0 @@
|
|||||||
[
|
|
||||||
{
|
|
||||||
"name": "ms-vscode.node-debug",
|
|
||||||
"version": "1.21.8",
|
|
||||||
"repo": "https://github.com/Microsoft/vscode-node-debug"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "ms-vscode.node-debug2",
|
|
||||||
"version": "1.21.2",
|
|
||||||
"repo": "https://github.com/Microsoft/vscode-node-debug2"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
{
|
|
||||||
"env": {
|
|
||||||
"node": true,
|
|
||||||
"es6": true,
|
|
||||||
"browser": true
|
|
||||||
},
|
|
||||||
"rules": {
|
|
||||||
"no-console": 0,
|
|
||||||
"no-cond-assign": 0,
|
|
||||||
"no-unused-vars": 1,
|
|
||||||
"no-extra-semi": "warn",
|
|
||||||
"semi": "warn"
|
|
||||||
},
|
|
||||||
"extends": "eslint:recommended",
|
|
||||||
"parserOptions": {
|
|
||||||
"ecmaFeatures": {
|
|
||||||
"experimentalObjectRestSpread": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,126 +0,0 @@
|
|||||||
/*---------------------------------------------------------------------------------------------
|
|
||||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
||||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
||||||
*--------------------------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
const fs = require('fs');
|
|
||||||
const path = require('path');
|
|
||||||
const os = require('os');
|
|
||||||
// @ts-ignore review
|
|
||||||
const { remote } = require('electron');
|
|
||||||
const dialog = remote.dialog;
|
|
||||||
|
|
||||||
const builtInExtensionsPath = path.join(__dirname, '..', 'builtInExtensions.json');
|
|
||||||
const controlFilePath = path.join(os.homedir(), '.vscode-oss-dev', 'extensions', 'control.json');
|
|
||||||
|
|
||||||
function readJson(filePath) {
|
|
||||||
return JSON.parse(fs.readFileSync(filePath, { encoding: 'utf8' }));
|
|
||||||
}
|
|
||||||
|
|
||||||
function writeJson(filePath, obj) {
|
|
||||||
fs.writeFileSync(filePath, JSON.stringify(obj, null, 2));
|
|
||||||
}
|
|
||||||
|
|
||||||
function renderOption(form, id, title, value, checked) {
|
|
||||||
const input = document.createElement('input');
|
|
||||||
input.type = 'radio';
|
|
||||||
input.id = id;
|
|
||||||
input.name = 'choice';
|
|
||||||
input.value = value;
|
|
||||||
input.checked = !!checked;
|
|
||||||
form.appendChild(input);
|
|
||||||
|
|
||||||
const label = document.createElement('label');
|
|
||||||
label.setAttribute('for', id);
|
|
||||||
label.textContent = title;
|
|
||||||
form.appendChild(label);
|
|
||||||
|
|
||||||
return input;
|
|
||||||
}
|
|
||||||
|
|
||||||
function render(el, state) {
|
|
||||||
function setState(state) {
|
|
||||||
try {
|
|
||||||
writeJson(controlFilePath, state.control);
|
|
||||||
} catch (err) {
|
|
||||||
console.error(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
el.innerHTML = '';
|
|
||||||
render(el, state);
|
|
||||||
}
|
|
||||||
|
|
||||||
const ul = document.createElement('ul');
|
|
||||||
const { builtin, control } = state;
|
|
||||||
|
|
||||||
for (const ext of builtin) {
|
|
||||||
const controlState = control[ext.name] || 'marketplace';
|
|
||||||
|
|
||||||
const li = document.createElement('li');
|
|
||||||
ul.appendChild(li);
|
|
||||||
|
|
||||||
const name = document.createElement('code');
|
|
||||||
name.textContent = ext.name;
|
|
||||||
li.appendChild(name);
|
|
||||||
|
|
||||||
const form = document.createElement('form');
|
|
||||||
li.appendChild(form);
|
|
||||||
|
|
||||||
const marketplaceInput = renderOption(form, `marketplace-${ext.name}`, 'Marketplace', 'marketplace', controlState === 'marketplace');
|
|
||||||
marketplaceInput.onchange = function () {
|
|
||||||
control[ext.name] = 'marketplace';
|
|
||||||
setState({ builtin, control });
|
|
||||||
};
|
|
||||||
|
|
||||||
const disabledInput = renderOption(form, `disabled-${ext.name}`, 'Disabled', 'disabled', controlState === 'disabled');
|
|
||||||
disabledInput.onchange = function () {
|
|
||||||
control[ext.name] = 'disabled';
|
|
||||||
setState({ builtin, control });
|
|
||||||
};
|
|
||||||
|
|
||||||
let local = undefined;
|
|
||||||
|
|
||||||
if (controlState !== 'marketplace' && controlState !== 'disabled') {
|
|
||||||
local = controlState;
|
|
||||||
}
|
|
||||||
|
|
||||||
const localInput = renderOption(form, `local-${ext.name}`, 'Local', 'local', !!local);
|
|
||||||
localInput.onchange = function () {
|
|
||||||
const result = dialog.showOpenDialog(remote.getCurrentWindow(), {
|
|
||||||
title: 'Choose Folder',
|
|
||||||
properties: ['openDirectory']
|
|
||||||
});
|
|
||||||
|
|
||||||
if (result && result.length >= 1) {
|
|
||||||
control[ext.name] = result[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
setState({ builtin, control });
|
|
||||||
};
|
|
||||||
|
|
||||||
if (local) {
|
|
||||||
const localSpan = document.createElement('code');
|
|
||||||
localSpan.className = 'local';
|
|
||||||
localSpan.textContent = local;
|
|
||||||
form.appendChild(localSpan);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
el.appendChild(ul);
|
|
||||||
}
|
|
||||||
|
|
||||||
function main() {
|
|
||||||
const el = document.getElementById('extensions');
|
|
||||||
const builtin = readJson(builtInExtensionsPath);
|
|
||||||
let control;
|
|
||||||
|
|
||||||
try {
|
|
||||||
control = readJson(controlFilePath);
|
|
||||||
} catch (err) {
|
|
||||||
control = {};
|
|
||||||
}
|
|
||||||
|
|
||||||
render(el, { builtin, control });
|
|
||||||
}
|
|
||||||
|
|
||||||
window.onload = main;
|
|
||||||
@@ -1,46 +0,0 @@
|
|||||||
<!-- Copyright (C) Microsoft Corporation. All rights reserved. -->
|
|
||||||
|
|
||||||
<!DOCTYPE html>
|
|
||||||
<html>
|
|
||||||
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8" />
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
|
||||||
<title>Manage Built-in Extensions</title>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
||||||
<script src="browser-main.js"></script>
|
|
||||||
<style>
|
|
||||||
body {
|
|
||||||
font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
|
|
||||||
font-size: 10pt;
|
|
||||||
}
|
|
||||||
|
|
||||||
code {
|
|
||||||
font-family: 'Menlo', 'Courier New', 'Courier', monospace;
|
|
||||||
}
|
|
||||||
|
|
||||||
ul {
|
|
||||||
padding-left: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
li {
|
|
||||||
list-style: none;
|
|
||||||
padding: 0.3em 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
label {
|
|
||||||
margin-right: 1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
form {
|
|
||||||
padding: 0.3em 0 0.3em 0.3em;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body>
|
|
||||||
<h1>Built-in Extensions</h1>
|
|
||||||
<div id="extensions"></div>
|
|
||||||
</body>
|
|
||||||
|
|
||||||
</html>
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
/*---------------------------------------------------------------------------------------------
|
|
||||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
||||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
||||||
*--------------------------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
const { app, BrowserWindow } = require('electron');
|
|
||||||
const url = require('url');
|
|
||||||
const path = require('path');
|
|
||||||
|
|
||||||
let window = null;
|
|
||||||
|
|
||||||
app.once('ready', () => {
|
|
||||||
window = new BrowserWindow({ width: 800, height: 600 });
|
|
||||||
window.setMenuBarVisibility(false);
|
|
||||||
window.loadURL(url.format({ pathname: path.join(__dirname, 'index.html'), protocol: 'file:', slashes: true }));
|
|
||||||
// window.webContents.openDevTools();
|
|
||||||
window.once('closed', () => window = null);
|
|
||||||
});
|
|
||||||
|
|
||||||
app.on('window-all-closed', () => app.quit());
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "builtin",
|
|
||||||
"version": "0.1.0",
|
|
||||||
"main": "main.js"
|
|
||||||
}
|
|
||||||
@@ -1,74 +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';
|
|
||||||
|
|
||||||
const path = require('path');
|
|
||||||
const parseSemver = require('parse-semver');
|
|
||||||
const cp = require('child_process');
|
|
||||||
const _ = require('underscore');
|
|
||||||
|
|
||||||
function asYarnDependency(prefix, tree) {
|
|
||||||
let parseResult;
|
|
||||||
|
|
||||||
try {
|
|
||||||
parseResult = parseSemver(tree.name);
|
|
||||||
} catch (err) {
|
|
||||||
err.message += `: ${tree.name}`;
|
|
||||||
console.warn(`Could not parse semver: ${tree.name}`);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// not an actual dependency in disk
|
|
||||||
if (parseResult.version !== parseResult.range) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
const name = parseResult.name;
|
|
||||||
const version = parseResult.version;
|
|
||||||
const dependencyPath = path.join(prefix, name);
|
|
||||||
const children = [];
|
|
||||||
|
|
||||||
for (const child of (tree.children || [])) {
|
|
||||||
const dep = asYarnDependency(path.join(prefix, name, 'node_modules'), child);
|
|
||||||
|
|
||||||
if (dep) {
|
|
||||||
children.push(dep);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return { name, version, path: dependencyPath, children };
|
|
||||||
}
|
|
||||||
|
|
||||||
function getYarnProductionDependencies(cwd) {
|
|
||||||
const raw = cp.execSync('yarn list --json', { cwd, encoding: 'utf8', env: { ...process.env, NODE_ENV: 'production' }, stdio: [null, null, 'ignore'] });
|
|
||||||
const match = /^{"type":"tree".*$/m.exec(raw);
|
|
||||||
|
|
||||||
if (!match || match.length !== 1) {
|
|
||||||
throw new Error('Could not parse result of `yarn list --json`');
|
|
||||||
}
|
|
||||||
|
|
||||||
const trees = JSON.parse(match[0]).data.trees;
|
|
||||||
|
|
||||||
return trees
|
|
||||||
.map(tree => asYarnDependency(path.join(cwd, 'node_modules'), tree))
|
|
||||||
.filter(dep => !!dep);
|
|
||||||
}
|
|
||||||
|
|
||||||
function getProductionDependencies(cwd) {
|
|
||||||
const result = [];
|
|
||||||
const deps = getYarnProductionDependencies(cwd);
|
|
||||||
const flatten = dep => { result.push({ name: dep.name, version: dep.version, path: dep.path }); dep.children.forEach(flatten); };
|
|
||||||
deps.forEach(flatten);
|
|
||||||
|
|
||||||
return _.uniq(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports.getProductionDependencies = getProductionDependencies;
|
|
||||||
|
|
||||||
if (require.main === module) {
|
|
||||||
const root = path.dirname(__dirname);
|
|
||||||
console.log(JSON.stringify(getProductionDependencies(root), null, ' '));
|
|
||||||
}
|
|
||||||
@@ -12,7 +12,6 @@ var File = require('vinyl');
|
|||||||
|
|
||||||
var root = path.dirname(__dirname);
|
var root = path.dirname(__dirname);
|
||||||
var sha1 = util.getVersion(root);
|
var sha1 = util.getVersion(root);
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
var semver = require('./monaco/package.json').version;
|
var semver = require('./monaco/package.json').version;
|
||||||
var headerVersion = semver + '(' + sha1 + ')';
|
var headerVersion = semver + '(' + sha1 + ')';
|
||||||
|
|
||||||
@@ -22,14 +21,14 @@ var editorEntryPoints = [
|
|||||||
{
|
{
|
||||||
name: 'vs/editor/editor.main',
|
name: 'vs/editor/editor.main',
|
||||||
include: [],
|
include: [],
|
||||||
exclude: ['vs/css', 'vs/nls'],
|
exclude: [ 'vs/css', 'vs/nls' ],
|
||||||
prepend: ['out-build/vs/css.js', 'out-build/vs/nls.js'],
|
prepend: [ 'out-build/vs/css.js', 'out-build/vs/nls.js' ],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'vs/base/common/worker/simpleWorker',
|
name: 'vs/base/common/worker/simpleWorker',
|
||||||
include: ['vs/editor/common/services/editorSimpleWorker'],
|
include: [ 'vs/editor/common/services/editorSimpleWorker' ],
|
||||||
prepend: ['vs/loader.js'],
|
prepend: [ 'vs/loader.js' ],
|
||||||
append: ['vs/base/worker/workerMain'],
|
append: [ 'vs/base/worker/workerMain' ],
|
||||||
dest: 'vs/base/worker/workerMain.js'
|
dest: 'vs/base/worker/workerMain.js'
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
@@ -80,15 +79,14 @@ gulp.task('optimize-editor', ['clean-optimized-editor', 'compile-client-build'],
|
|||||||
bundleLoader: false,
|
bundleLoader: false,
|
||||||
header: BUNDLED_FILE_HEADER,
|
header: BUNDLED_FILE_HEADER,
|
||||||
bundleInfo: true,
|
bundleInfo: true,
|
||||||
out: 'out-editor',
|
out: 'out-editor'
|
||||||
languages: undefined
|
|
||||||
}));
|
}));
|
||||||
|
|
||||||
gulp.task('clean-minified-editor', util.rimraf('out-editor-min'));
|
gulp.task('clean-minified-editor', util.rimraf('out-editor-min'));
|
||||||
gulp.task('minify-editor', ['clean-minified-editor', 'optimize-editor'], common.minifyTask('out-editor'));
|
gulp.task('minify-editor', ['clean-minified-editor', 'optimize-editor'], common.minifyTask('out-editor'));
|
||||||
|
|
||||||
gulp.task('clean-editor-distro', util.rimraf('out-monaco-editor-core'));
|
gulp.task('clean-editor-distro', util.rimraf('out-monaco-editor-core'));
|
||||||
gulp.task('editor-distro', ['clean-editor-distro', 'minify-editor', 'optimize-editor'], function () {
|
gulp.task('editor-distro', ['clean-editor-distro', 'minify-editor', 'optimize-editor'], function() {
|
||||||
return es.merge(
|
return es.merge(
|
||||||
// other assets
|
// other assets
|
||||||
es.merge(
|
es.merge(
|
||||||
@@ -99,17 +97,17 @@ gulp.task('editor-distro', ['clean-editor-distro', 'minify-editor', 'optimize-ed
|
|||||||
|
|
||||||
// package.json
|
// package.json
|
||||||
gulp.src('build/monaco/package.json')
|
gulp.src('build/monaco/package.json')
|
||||||
.pipe(es.through(function (data) {
|
.pipe(es.through(function(data) {
|
||||||
var json = JSON.parse(data.contents.toString());
|
var json = JSON.parse(data.contents.toString());
|
||||||
json.private = false;
|
json.private = false;
|
||||||
data.contents = Buffer.from(JSON.stringify(json, null, ' '));
|
data.contents = new Buffer(JSON.stringify(json, null, ' '));
|
||||||
this.emit('data', data);
|
this.emit('data', data);
|
||||||
}))
|
}))
|
||||||
.pipe(gulp.dest('out-monaco-editor-core')),
|
.pipe(gulp.dest('out-monaco-editor-core')),
|
||||||
|
|
||||||
// README.md
|
// README.md
|
||||||
gulp.src('build/monaco/README-npm.md')
|
gulp.src('build/monaco/README-npm.md')
|
||||||
.pipe(es.through(function (data) {
|
.pipe(es.through(function(data) {
|
||||||
this.emit('data', new File({
|
this.emit('data', new File({
|
||||||
path: data.path.replace(/README-npm\.md/, 'README.md'),
|
path: data.path.replace(/README-npm\.md/, 'README.md'),
|
||||||
base: data.base,
|
base: data.base,
|
||||||
@@ -126,10 +124,10 @@ gulp.task('editor-distro', ['clean-editor-distro', 'minify-editor', 'optimize-ed
|
|||||||
// min folder
|
// min folder
|
||||||
es.merge(
|
es.merge(
|
||||||
gulp.src('out-editor-min/**/*')
|
gulp.src('out-editor-min/**/*')
|
||||||
).pipe(filterStream(function (path) {
|
).pipe(filterStream(function(path) {
|
||||||
// no map files
|
// no map files
|
||||||
return !/(\.js\.map$)|(nls\.metadata\.json$)|(bundleInfo\.json$)/.test(path);
|
return !/(\.js\.map$)|(nls\.metadata\.json$)|(bundleInfo\.json$)/.test(path);
|
||||||
})).pipe(es.through(function (data) {
|
})).pipe(es.through(function(data) {
|
||||||
// tweak the sourceMappingURL
|
// tweak the sourceMappingURL
|
||||||
if (!/\.js$/.test(data.path)) {
|
if (!/\.js$/.test(data.path)) {
|
||||||
this.emit('data', data);
|
this.emit('data', data);
|
||||||
@@ -142,50 +140,49 @@ gulp.task('editor-distro', ['clean-editor-distro', 'minify-editor', 'optimize-ed
|
|||||||
var newStr = '//# sourceMappingURL=' + relativePathToMap.replace(/\\/g, '/');
|
var newStr = '//# sourceMappingURL=' + relativePathToMap.replace(/\\/g, '/');
|
||||||
strContents = strContents.replace(/\/\/\# sourceMappingURL=[^ ]+$/, newStr);
|
strContents = strContents.replace(/\/\/\# sourceMappingURL=[^ ]+$/, newStr);
|
||||||
|
|
||||||
data.contents = Buffer.from(strContents);
|
data.contents = new Buffer(strContents);
|
||||||
this.emit('data', data);
|
this.emit('data', data);
|
||||||
})).pipe(gulp.dest('out-monaco-editor-core/min')),
|
})).pipe(gulp.dest('out-monaco-editor-core/min')),
|
||||||
|
|
||||||
// min-maps folder
|
// min-maps folder
|
||||||
es.merge(
|
es.merge(
|
||||||
gulp.src('out-editor-min/**/*')
|
gulp.src('out-editor-min/**/*')
|
||||||
).pipe(filterStream(function (path) {
|
).pipe(filterStream(function(path) {
|
||||||
// no map files
|
// no map files
|
||||||
return /\.js\.map$/.test(path);
|
return /\.js\.map$/.test(path);
|
||||||
})).pipe(gulp.dest('out-monaco-editor-core/min-maps'))
|
})).pipe(gulp.dest('out-monaco-editor-core/min-maps'))
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('analyze-editor-distro', function () {
|
gulp.task('analyze-editor-distro', function() {
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
var bundleInfo = require('../out-editor/bundleInfo.json');
|
var bundleInfo = require('../out-editor/bundleInfo.json');
|
||||||
var graph = bundleInfo.graph;
|
var graph = bundleInfo.graph;
|
||||||
var bundles = bundleInfo.bundles;
|
var bundles = bundleInfo.bundles;
|
||||||
|
|
||||||
var inverseGraph = {};
|
var inverseGraph = {};
|
||||||
Object.keys(graph).forEach(function (module) {
|
Object.keys(graph).forEach(function(module) {
|
||||||
var dependencies = graph[module];
|
var dependencies = graph[module];
|
||||||
dependencies.forEach(function (dep) {
|
dependencies.forEach(function(dep) {
|
||||||
inverseGraph[dep] = inverseGraph[dep] || [];
|
inverseGraph[dep] = inverseGraph[dep] || [];
|
||||||
inverseGraph[dep].push(module);
|
inverseGraph[dep].push(module);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
var detailed = {};
|
var detailed = {};
|
||||||
Object.keys(bundles).forEach(function (entryPoint) {
|
Object.keys(bundles).forEach(function(entryPoint) {
|
||||||
var included = bundles[entryPoint];
|
var included = bundles[entryPoint];
|
||||||
var includedMap = {};
|
var includedMap = {};
|
||||||
included.forEach(function (included) {
|
included.forEach(function(included) {
|
||||||
includedMap[included] = true;
|
includedMap[included] = true;
|
||||||
});
|
});
|
||||||
|
|
||||||
var explanation = [];
|
var explanation = [];
|
||||||
included.map(function (included) {
|
included.map(function(included) {
|
||||||
if (included.indexOf('!') >= 0) {
|
if (included.indexOf('!') >= 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var reason = (inverseGraph[included] || []).filter(function (mod) {
|
var reason = (inverseGraph[included]||[]).filter(function(mod) {
|
||||||
return !!includedMap[mod];
|
return !!includedMap[mod];
|
||||||
});
|
});
|
||||||
explanation.push({
|
explanation.push({
|
||||||
@@ -201,7 +198,7 @@ gulp.task('analyze-editor-distro', function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
function filterStream(testFunc) {
|
function filterStream(testFunc) {
|
||||||
return es.through(function (data) {
|
return es.through(function(data) {
|
||||||
if (!testFunc(data.relative)) {
|
if (!testFunc(data.relative)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,7 +20,6 @@ const sourcemaps = require('gulp-sourcemaps');
|
|||||||
const nlsDev = require('vscode-nls-dev');
|
const nlsDev = require('vscode-nls-dev');
|
||||||
const root = path.dirname(__dirname);
|
const root = path.dirname(__dirname);
|
||||||
const commit = util.getVersion(root);
|
const commit = util.getVersion(root);
|
||||||
const i18n = require('./lib/i18n');
|
|
||||||
|
|
||||||
const extensionsPath = path.join(path.dirname(__dirname), 'extensions');
|
const extensionsPath = path.join(path.dirname(__dirname), 'extensions');
|
||||||
|
|
||||||
@@ -30,8 +29,7 @@ const compilations = glob.sync('**/tsconfig.json', {
|
|||||||
});
|
});
|
||||||
|
|
||||||
const getBaseUrl = out => `https://ticino.blob.core.windows.net/sourcemaps/${commit}/${out}`;
|
const getBaseUrl = out => `https://ticino.blob.core.windows.net/sourcemaps/${commit}/${out}`;
|
||||||
|
const languages = ['chs', 'cht', 'jpn', 'kor', 'deu', 'fra', 'esn', 'rus', 'ita'];
|
||||||
const languages = i18n.defaultLanguages.concat(process.env.VSCODE_QUALITY !== 'stable' ? i18n.extraLanguages : []);
|
|
||||||
|
|
||||||
const tasks = compilations.map(function (tsconfigFile) {
|
const tasks = compilations.map(function (tsconfigFile) {
|
||||||
const absolutePath = path.join(extensionsPath, tsconfigFile);
|
const absolutePath = path.join(extensionsPath, tsconfigFile);
|
||||||
@@ -57,25 +55,13 @@ const tasks = compilations.map(function (tsconfigFile) {
|
|||||||
const srcBase = path.join(root, 'src');
|
const srcBase = path.join(root, 'src');
|
||||||
const src = path.join(srcBase, '**');
|
const src = path.join(srcBase, '**');
|
||||||
const out = path.join(root, 'out');
|
const out = path.join(root, 'out');
|
||||||
const i18nPath = path.join(__dirname, '..', 'i18n');
|
const i18n = path.join(__dirname, '..', 'i18n');
|
||||||
const baseUrl = getBaseUrl(out);
|
const baseUrl = getBaseUrl(out);
|
||||||
|
|
||||||
let headerId, headerOut;
|
|
||||||
let index = relativeDirname.indexOf('/');
|
|
||||||
if (index < 0) {
|
|
||||||
headerId = 'vscode.' + relativeDirname;
|
|
||||||
headerOut = 'out';
|
|
||||||
} else {
|
|
||||||
headerId = 'vscode.' + relativeDirname.substr(0, index);
|
|
||||||
headerOut = relativeDirname.substr(index + 1) + '/out';
|
|
||||||
}
|
|
||||||
|
|
||||||
function createPipeline(build, emitError) {
|
function createPipeline(build, emitError) {
|
||||||
const reporter = createReporter();
|
const reporter = createReporter();
|
||||||
|
|
||||||
tsOptions.inlineSources = !!build;
|
tsOptions.inlineSources = !!build;
|
||||||
tsOptions.base = path.dirname(absolutePath);
|
|
||||||
|
|
||||||
const compilation = tsb.create(tsOptions, null, null, err => reporter(err.toString()));
|
const compilation = tsb.create(tsOptions, null, null, err => reporter(err.toString()));
|
||||||
|
|
||||||
return function () {
|
return function () {
|
||||||
@@ -94,9 +80,7 @@ const tasks = compilations.map(function (tsconfigFile) {
|
|||||||
sourceRoot: '../src'
|
sourceRoot: '../src'
|
||||||
}))
|
}))
|
||||||
.pipe(tsFilter.restore)
|
.pipe(tsFilter.restore)
|
||||||
.pipe(build ? nlsDev.createAdditionalLanguageFiles(languages, i18nPath, out) : es.through())
|
.pipe(build ? nlsDev.createAdditionalLanguageFiles(languages, i18n, out) : es.through())
|
||||||
.pipe(build ? nlsDev.bundleMetaDataFiles(headerId, headerOut) : es.through())
|
|
||||||
.pipe(build ? nlsDev.bundleLanguageFiles() : es.through())
|
|
||||||
.pipe(reporter.end(emitError));
|
.pipe(reporter.end(emitError));
|
||||||
|
|
||||||
return es.duplex(input, output);
|
return es.duplex(input, output);
|
||||||
@@ -143,7 +127,7 @@ const tasks = compilations.map(function (tsconfigFile) {
|
|||||||
const watchInput = watcher(src, srcOpts);
|
const watchInput = watcher(src, srcOpts);
|
||||||
|
|
||||||
return watchInput
|
return watchInput
|
||||||
.pipe(util.incremental(() => pipeline(), input))
|
.pipe(util.incremental(() => pipeline(true), input))
|
||||||
.pipe(gulp.dest(out));
|
.pipe(gulp.dest(out));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -12,11 +12,7 @@ const gulptslint = require('gulp-tslint');
|
|||||||
const gulpeslint = require('gulp-eslint');
|
const gulpeslint = require('gulp-eslint');
|
||||||
const tsfmt = require('typescript-formatter');
|
const tsfmt = require('typescript-formatter');
|
||||||
const tslint = require('tslint');
|
const tslint = require('tslint');
|
||||||
const VinylFile = require('vinyl');
|
|
||||||
const vfs = require('vinyl-fs');
|
const vfs = require('vinyl-fs');
|
||||||
const path = require('path');
|
|
||||||
const fs = require('fs');
|
|
||||||
const pall = require('p-all');
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Hygiene works by creating cascading subsets of all our files and
|
* Hygiene works by creating cascading subsets of all our files and
|
||||||
@@ -33,56 +29,53 @@ const all = [
|
|||||||
'extensions/**/*',
|
'extensions/**/*',
|
||||||
'scripts/**/*',
|
'scripts/**/*',
|
||||||
'src/**/*',
|
'src/**/*',
|
||||||
'test/**/*',
|
'test/**/*'
|
||||||
'!**/node_modules/**'
|
];
|
||||||
|
|
||||||
|
const eolFilter = [
|
||||||
|
'**',
|
||||||
|
'!ThirdPartyNotices.txt',
|
||||||
|
'!LICENSE.txt',
|
||||||
|
'!extensions/**/out/**',
|
||||||
|
'!**/node_modules/**',
|
||||||
|
'!**/fixtures/**',
|
||||||
|
'!**/*.{svg,exe,png,bmp,scpt,bat,cmd,cur,ttf,woff,eot}',
|
||||||
|
'!build/{lib,tslintRules}/**/*.js',
|
||||||
|
'!build/monaco/**',
|
||||||
|
'!build/win32/**',
|
||||||
|
'!build/**/*.sh',
|
||||||
|
'!build/tfs/**/*.js',
|
||||||
|
'!**/Dockerfile'
|
||||||
];
|
];
|
||||||
|
|
||||||
const indentationFilter = [
|
const indentationFilter = [
|
||||||
'**',
|
'**',
|
||||||
|
|
||||||
// except specific files
|
|
||||||
'!ThirdPartyNotices.txt',
|
'!ThirdPartyNotices.txt',
|
||||||
'!LICENSE.txt',
|
'!**/*.md',
|
||||||
'!src/vs/nls.js',
|
'!**/*.ps1',
|
||||||
'!src/vs/css.js',
|
'!**/*.template',
|
||||||
'!src/vs/loader.js',
|
'!**/*.yaml',
|
||||||
'!src/vs/base/common/marked/raw.marked.js',
|
'!**/*.yml',
|
||||||
'!src/vs/base/common/winjs.base.raw.js',
|
|
||||||
'!src/vs/base/node/terminateProcess.sh',
|
|
||||||
'!src/vs/base/node/ps-win.ps1',
|
|
||||||
'!test/assert.js',
|
|
||||||
|
|
||||||
// except specific folders
|
|
||||||
'!test/smoke/out/**',
|
|
||||||
'!extensions/vscode-api-tests/testWorkspace/**',
|
|
||||||
'!extensions/vscode-api-tests/testWorkspace2/**',
|
|
||||||
'!build/monaco/**',
|
|
||||||
'!build/win32/**',
|
|
||||||
|
|
||||||
// except multiple specific files
|
|
||||||
'!**/package.json',
|
|
||||||
'!**/yarn.lock',
|
|
||||||
|
|
||||||
// except multiple specific folders
|
|
||||||
'!**/octicons/**',
|
|
||||||
'!**/fixtures/**',
|
|
||||||
'!**/lib/**',
|
'!**/lib/**',
|
||||||
'!extensions/**/out/**',
|
'!extensions/**/*.d.ts',
|
||||||
|
'!src/typings/**/*.d.ts',
|
||||||
|
'!src/vs/*/**/*.d.ts',
|
||||||
|
'!**/*.d.ts.recipe',
|
||||||
|
'!test/assert.js',
|
||||||
|
'!**/package.json',
|
||||||
|
'!**/npm-shrinkwrap.json',
|
||||||
|
'!**/octicons/**',
|
||||||
|
'!**/vs/base/common/marked/raw.marked.js',
|
||||||
|
'!**/vs/base/common/winjs.base.raw.js',
|
||||||
|
'!**/vs/base/node/terminateProcess.sh',
|
||||||
|
'!**/vs/nls.js',
|
||||||
|
'!**/vs/css.js',
|
||||||
|
'!**/vs/loader.js',
|
||||||
'!extensions/**/snippets/**',
|
'!extensions/**/snippets/**',
|
||||||
'!extensions/**/syntaxes/**',
|
'!extensions/**/syntaxes/**',
|
||||||
'!extensions/**/themes/**',
|
'!extensions/**/themes/**',
|
||||||
'!extensions/**/colorize-fixtures/**',
|
'!extensions/**/colorize-fixtures/**',
|
||||||
|
'!extensions/vscode-api-tests/testWorkspace/**'
|
||||||
// except specific file types
|
|
||||||
'!src/vs/*/**/*.d.ts',
|
|
||||||
'!src/typings/**/*.d.ts',
|
|
||||||
'!extensions/**/*.d.ts',
|
|
||||||
'!**/*.{svg,exe,png,bmp,scpt,bat,cmd,cur,ttf,woff,eot,md,ps1,template,yaml,yml,d.ts.recipe}',
|
|
||||||
'!build/{lib,tslintRules}/**/*.js',
|
|
||||||
'!build/**/*.sh',
|
|
||||||
'!build/tfs/**/*.js',
|
|
||||||
'!**/Dockerfile',
|
|
||||||
'!extensions/markdown/media/*.js'
|
|
||||||
];
|
];
|
||||||
|
|
||||||
const copyrightFilter = [
|
const copyrightFilter = [
|
||||||
@@ -100,7 +93,6 @@ const copyrightFilter = [
|
|||||||
'!**/*.xpm',
|
'!**/*.xpm',
|
||||||
'!**/*.opts',
|
'!**/*.opts',
|
||||||
'!**/*.disabled',
|
'!**/*.disabled',
|
||||||
'!**/*.code-workspace',
|
|
||||||
'!build/**/*.init',
|
'!build/**/*.init',
|
||||||
'!resources/linux/snap/snapcraft.yaml',
|
'!resources/linux/snap/snapcraft.yaml',
|
||||||
'!resources/win32/bin/code.js',
|
'!resources/win32/bin/code.js',
|
||||||
@@ -130,9 +122,7 @@ const tslintFilter = [
|
|||||||
'!**/node_modules/**',
|
'!**/node_modules/**',
|
||||||
'!extensions/typescript/test/colorize-fixtures/**',
|
'!extensions/typescript/test/colorize-fixtures/**',
|
||||||
'!extensions/vscode-api-tests/testWorkspace/**',
|
'!extensions/vscode-api-tests/testWorkspace/**',
|
||||||
'!extensions/vscode-api-tests/testWorkspace2/**',
|
'!extensions/**/*.test.ts'
|
||||||
'!extensions/**/*.test.ts',
|
|
||||||
'!extensions/html/server/lib/jquery.d.ts'
|
|
||||||
];
|
];
|
||||||
|
|
||||||
const copyrightHeader = [
|
const copyrightHeader = [
|
||||||
@@ -142,6 +132,17 @@ const copyrightHeader = [
|
|||||||
' *--------------------------------------------------------------------------------------------*/'
|
' *--------------------------------------------------------------------------------------------*/'
|
||||||
].join('\n');
|
].join('\n');
|
||||||
|
|
||||||
|
function reportFailures(failures) {
|
||||||
|
failures.forEach(failure => {
|
||||||
|
const name = failure.name || failure.fileName;
|
||||||
|
const position = failure.startPosition;
|
||||||
|
const line = position.lineAndCharacter ? position.lineAndCharacter.line : position.line;
|
||||||
|
const character = position.lineAndCharacter ? position.lineAndCharacter.character : position.character;
|
||||||
|
|
||||||
|
console.error(`${name}:${line + 1}:${character + 1}:${failure.failure}`);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
gulp.task('eslint', () => {
|
gulp.task('eslint', () => {
|
||||||
return vfs.src(all, { base: '.', follow: true, allowEmpty: true })
|
return vfs.src(all, { base: '.', follow: true, allowEmpty: true })
|
||||||
.pipe(filter(eslintFilter))
|
.pipe(filter(eslintFilter))
|
||||||
@@ -151,23 +152,31 @@ gulp.task('eslint', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('tslint', () => {
|
gulp.task('tslint', () => {
|
||||||
// {{SQL CARBON EDIT}}
|
const options = { summarizeFailureOutput: true };
|
||||||
const options = { emitError: false };
|
|
||||||
|
|
||||||
return vfs.src(all, { base: '.', follow: true, allowEmpty: true })
|
return vfs.src(all, { base: '.', follow: true, allowEmpty: true })
|
||||||
.pipe(filter(tslintFilter))
|
.pipe(filter(tslintFilter))
|
||||||
.pipe(gulptslint.default({ rulesDirectory: 'build/lib/tslint' }))
|
.pipe(gulptslint({ rulesDirectory: 'build/lib/tslint' }))
|
||||||
.pipe(gulptslint.default.report(options));
|
.pipe(gulptslint.report(reportFailures, options));
|
||||||
});
|
});
|
||||||
|
|
||||||
function hygiene(some) {
|
const hygiene = exports.hygiene = (some, options) => {
|
||||||
|
options = options || {};
|
||||||
let errorCount = 0;
|
let errorCount = 0;
|
||||||
|
|
||||||
const indentation = es.through(function (file) {
|
const eol = es.through(function (file) {
|
||||||
const lines = file.contents.toString('utf8').split(/\r\n|\r|\n/);
|
if (/\r\n?/g.test(file.contents.toString('utf8'))) {
|
||||||
file.__lines = lines;
|
console.error(file.relative + ': Bad EOL found');
|
||||||
|
errorCount++;
|
||||||
|
}
|
||||||
|
|
||||||
lines
|
this.emit('data', file);
|
||||||
|
});
|
||||||
|
|
||||||
|
const indentation = es.through(function (file) {
|
||||||
|
file.contents
|
||||||
|
.toString('utf8')
|
||||||
|
.split(/\r\n|\r|\n/)
|
||||||
.forEach((line, i) => {
|
.forEach((line, i) => {
|
||||||
if (/^\s*$/.test(line)) {
|
if (/^\s*$/.test(line)) {
|
||||||
// empty or whitespace lines are OK
|
// empty or whitespace lines are OK
|
||||||
@@ -185,14 +194,9 @@ function hygiene(some) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
const copyrights = es.through(function (file) {
|
const copyrights = es.through(function (file) {
|
||||||
const lines = file.__lines;
|
if (file.contents.toString('utf8').indexOf(copyrightHeader) !== 0) {
|
||||||
|
console.error(file.relative + ': Missing or bad copyright statement');
|
||||||
for (let i = 0; i < copyrightHeaderLines.length; i++) {
|
errorCount++;
|
||||||
if (lines[i] !== copyrightHeaderLines[i]) {
|
|
||||||
console.error(file.relative + ': Missing or bad copyright statement');
|
|
||||||
errorCount++;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this.emit('data', file);
|
this.emit('data', file);
|
||||||
@@ -200,20 +204,12 @@ function hygiene(some) {
|
|||||||
|
|
||||||
const formatting = es.map(function (file, cb) {
|
const formatting = es.map(function (file, cb) {
|
||||||
tsfmt.processString(file.path, file.contents.toString('utf8'), {
|
tsfmt.processString(file.path, file.contents.toString('utf8'), {
|
||||||
verify: false,
|
verify: true,
|
||||||
tsfmt: true,
|
tsfmt: true,
|
||||||
// verbose: true
|
// verbose: true
|
||||||
// keep checkJS happy
|
|
||||||
editorconfig: undefined,
|
|
||||||
replace: undefined,
|
|
||||||
tsconfig: undefined,
|
|
||||||
tslint: undefined
|
|
||||||
}).then(result => {
|
}).then(result => {
|
||||||
let original = result.src.replace(/\r\n/gm, '\n');
|
if (result.error) {
|
||||||
let formatted = result.dest.replace(/\r\n/gm, '\n');
|
console.error(result.message);
|
||||||
|
|
||||||
if (original !== formatted) {
|
|
||||||
console.error('File not formatted:', file.relative);
|
|
||||||
errorCount++;
|
errorCount++;
|
||||||
}
|
}
|
||||||
cb(null, file);
|
cb(null, file);
|
||||||
@@ -223,31 +219,32 @@ function hygiene(some) {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
const tslintConfiguration = tslint.Configuration.findConfiguration('tslint.json', '.');
|
|
||||||
const tslintOptions = { fix: false, formatter: 'json' };
|
|
||||||
const tsLinter = new tslint.Linter(tslintOptions);
|
|
||||||
|
|
||||||
const tsl = es.through(function (file) {
|
const tsl = es.through(function (file) {
|
||||||
|
const configuration = tslint.Configuration.findConfiguration(null, '.');
|
||||||
|
const options = { formatter: 'json', rulesDirectory: 'build/lib/tslint' };
|
||||||
const contents = file.contents.toString('utf8');
|
const contents = file.contents.toString('utf8');
|
||||||
tsLinter.lint(file.relative, contents, tslintConfiguration.results);
|
const linter = new tslint.Linter(options);
|
||||||
|
linter.lint(file.relative, contents, configuration.results);
|
||||||
|
const result = linter.getResult();
|
||||||
|
|
||||||
|
if (result.failureCount > 0) {
|
||||||
|
reportFailures(result.failures);
|
||||||
|
errorCount += result.failureCount;
|
||||||
|
}
|
||||||
|
|
||||||
this.emit('data', file);
|
this.emit('data', file);
|
||||||
});
|
});
|
||||||
|
|
||||||
let input;
|
const result = vfs.src(some || all, { base: '.', follow: true, allowEmpty: true })
|
||||||
|
|
||||||
if (Array.isArray(some) || typeof some === 'string' || !some) {
|
|
||||||
input = vfs.src(some || all, { base: '.', follow: true, allowEmpty: true });
|
|
||||||
} else {
|
|
||||||
input = some;
|
|
||||||
}
|
|
||||||
|
|
||||||
const result = input
|
|
||||||
.pipe(filter(f => !f.stat.isDirectory()))
|
.pipe(filter(f => !f.stat.isDirectory()))
|
||||||
|
.pipe(filter(eolFilter))
|
||||||
|
// {{SQL CARBON EDIT}}
|
||||||
|
//.pipe(options.skipEOL ? es.through() : eol)
|
||||||
.pipe(filter(indentationFilter))
|
.pipe(filter(indentationFilter))
|
||||||
.pipe(indentation)
|
.pipe(indentation)
|
||||||
.pipe(filter(copyrightFilter));
|
.pipe(filter(copyrightFilter))
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
// .pipe(copyrights);
|
//.pipe(copyrights);
|
||||||
|
|
||||||
const typescript = result
|
const typescript = result
|
||||||
.pipe(filter(tslintFilter))
|
.pipe(filter(tslintFilter))
|
||||||
@@ -258,51 +255,22 @@ function hygiene(some) {
|
|||||||
.pipe(filter(eslintFilter))
|
.pipe(filter(eslintFilter))
|
||||||
.pipe(gulpeslint('src/.eslintrc'))
|
.pipe(gulpeslint('src/.eslintrc'))
|
||||||
.pipe(gulpeslint.formatEach('compact'));
|
.pipe(gulpeslint.formatEach('compact'));
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
// .pipe(gulpeslint.failAfterError());
|
// .pipe(gulpeslint.failAfterError());
|
||||||
|
|
||||||
let count = 0;
|
|
||||||
return es.merge(typescript, javascript)
|
return es.merge(typescript, javascript)
|
||||||
.pipe(es.through(function (data) {
|
.pipe(es.through(null, function () {
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
this.emit('end');
|
// if (errorCount > 0) {
|
||||||
|
// this.emit('error', 'Hygiene failed with ' + errorCount + ' errors. Check \'build/gulpfile.hygiene.js\'.');
|
||||||
|
// } else {
|
||||||
|
// this.emit('end');
|
||||||
|
// }
|
||||||
|
this.emit('end');
|
||||||
}));
|
}));
|
||||||
}
|
};
|
||||||
|
|
||||||
function createGitIndexVinyls(paths) {
|
gulp.task('hygiene', () => hygiene(''));
|
||||||
const cp = require('child_process');
|
|
||||||
const repositoryPath = process.cwd();
|
|
||||||
|
|
||||||
const fns = paths.map(relativePath => () => new Promise((c, e) => {
|
|
||||||
const fullPath = path.join(repositoryPath, relativePath);
|
|
||||||
|
|
||||||
fs.stat(fullPath, (err, stat) => {
|
|
||||||
if (err && err.code === 'ENOENT') { // ignore deletions
|
|
||||||
return c(null);
|
|
||||||
} else if (err) {
|
|
||||||
return e(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
cp.exec(`git show :${relativePath}`, { maxBuffer: 2000 * 1024, encoding: 'buffer' }, (err, out) => {
|
|
||||||
if (err) {
|
|
||||||
return e(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
c(new VinylFile({
|
|
||||||
path: fullPath,
|
|
||||||
base: repositoryPath,
|
|
||||||
contents: out,
|
|
||||||
stat
|
|
||||||
}));
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}));
|
|
||||||
|
|
||||||
return pall(fns, { concurrency: 4 })
|
|
||||||
.then(r => r.filter(p => !!p));
|
|
||||||
}
|
|
||||||
|
|
||||||
gulp.task('hygiene', () => hygiene());
|
|
||||||
|
|
||||||
// this allows us to run hygiene as a git pre-commit hook
|
// this allows us to run hygiene as a git pre-commit hook
|
||||||
if (require.main === module) {
|
if (require.main === module) {
|
||||||
@@ -313,38 +281,33 @@ if (require.main === module) {
|
|||||||
process.exit(1);
|
process.exit(1);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (process.argv.length > 2) {
|
cp.exec('git config core.autocrlf', (err, out) => {
|
||||||
hygiene(process.argv.slice(2)).on('error', err => {
|
const skipEOL = out.trim() === 'true';
|
||||||
console.error();
|
|
||||||
console.error(err);
|
if (process.argv.length > 2) {
|
||||||
process.exit(1);
|
return hygiene(process.argv.slice(2), { skipEOL: skipEOL }).on('error', err => {
|
||||||
});
|
console.error();
|
||||||
} else {
|
console.error(err);
|
||||||
|
process.exit(1);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
cp.exec('git diff --cached --name-only', { maxBuffer: 2000 * 1024 }, (err, out) => {
|
cp.exec('git diff --cached --name-only', { maxBuffer: 2000 * 1024 }, (err, out) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.error();
|
console.error();
|
||||||
console.error(err);
|
console.error(err);
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const some = out
|
const some = out
|
||||||
.split(/\r?\n/)
|
.split(/\r?\n/)
|
||||||
.filter(l => !!l);
|
.filter(l => !!l);
|
||||||
|
|
||||||
if (some.length > 0) {
|
hygiene(some, { skipEOL: skipEOL }).on('error', err => {
|
||||||
console.log('Reading git index versions...');
|
console.error();
|
||||||
|
console.error(err);
|
||||||
createGitIndexVinyls(some)
|
process.exit(1);
|
||||||
.then(vinyls => new Promise((c, e) => hygiene(es.readArray(vinyls))
|
});
|
||||||
.on('end', () => c())
|
|
||||||
.on('error', e)))
|
|
||||||
.catch(err => {
|
|
||||||
console.error();
|
|
||||||
console.error(err);
|
|
||||||
process.exit(1);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,18 +14,13 @@ const util = require('./lib/util');
|
|||||||
const remote = require('gulp-remote-src');
|
const remote = require('gulp-remote-src');
|
||||||
const zip = require('gulp-vinyl-zip');
|
const zip = require('gulp-vinyl-zip');
|
||||||
const assign = require('object-assign');
|
const assign = require('object-assign');
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
const jeditor = require('gulp-json-editor');
|
|
||||||
|
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const pkg = require('../package.json');
|
const pkg = require('../package.json');
|
||||||
|
|
||||||
gulp.task('mixin', function () {
|
gulp.task('mixin', function () {
|
||||||
// {{SQL CARBON EDIT}}
|
const repo = process.env['VSCODE_MIXIN_REPO'];
|
||||||
const updateUrl = process.env['SQLOPS_UPDATEURL'];
|
|
||||||
if (!updateUrl) {
|
if (!repo) {
|
||||||
console.log('Missing SQLOPS_UPDATEURL, skipping mixin');
|
console.log('Missing VSCODE_MIXIN_REPO, skipping mixin');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -36,20 +31,39 @@ gulp.task('mixin', function () {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
const url = `https://github.com/${repo}/archive/${pkg.distro}.zip`;
|
||||||
let serviceUrl = 'https://raw.githubusercontent.com/Microsoft/sqlopsstudio/release/extensions/extensionsGallery.json';
|
const opts = { base: url };
|
||||||
if (quality === 'insider') {
|
const username = process.env['VSCODE_MIXIN_USERNAME'];
|
||||||
serviceUrl = `https://raw.githubusercontent.com/Microsoft/sqlopsstudio/release/extensions/extensionsGallery-${quality}.json`;
|
const password = process.env['VSCODE_MIXIN_PASSWORD'];
|
||||||
}
|
|
||||||
let newValues = {
|
|
||||||
"updateUrl": updateUrl,
|
|
||||||
"quality": quality,
|
|
||||||
"extensionsGallery": {
|
|
||||||
"serviceUrl": serviceUrl
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
return gulp.src('./product.json')
|
if (username || password) {
|
||||||
.pipe(jeditor(newValues))
|
opts.auth = { user: username || '', pass: password || '' };
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Mixing in sources from \'' + url + '\':');
|
||||||
|
|
||||||
|
let all = remote('', opts)
|
||||||
|
.pipe(zip.src())
|
||||||
|
.pipe(filter(function (f) { return !f.isDirectory(); }))
|
||||||
|
.pipe(util.rebase(1));
|
||||||
|
|
||||||
|
if (quality) {
|
||||||
|
const productJsonFilter = filter('product.json', { restore: true });
|
||||||
|
const mixin = all
|
||||||
|
.pipe(filter(['quality/' + quality + '/**']))
|
||||||
|
.pipe(util.rebase(2))
|
||||||
|
.pipe(productJsonFilter)
|
||||||
|
.pipe(buffer())
|
||||||
|
.pipe(json(o => assign({}, require('../product.json'), o)))
|
||||||
|
.pipe(productJsonFilter.restore);
|
||||||
|
|
||||||
|
all = es.merge(mixin);
|
||||||
|
}
|
||||||
|
|
||||||
|
return all
|
||||||
|
.pipe(es.mapSync(function (f) {
|
||||||
|
console.log(f.relative);
|
||||||
|
return f;
|
||||||
|
}))
|
||||||
.pipe(gulp.dest('.'));
|
.pipe(gulp.dest('.'));
|
||||||
});
|
});
|
||||||
@@ -13,6 +13,18 @@ const filter = require('gulp-filter');
|
|||||||
|
|
||||||
gulp.task('clean-mssql-extension', util.rimraf('extensions/mssql/node_modules'));
|
gulp.task('clean-mssql-extension', util.rimraf('extensions/mssql/node_modules'));
|
||||||
gulp.task('clean-credentials-extension', util.rimraf('extensions/credentials/node_modules'));
|
gulp.task('clean-credentials-extension', util.rimraf('extensions/credentials/node_modules'));
|
||||||
|
gulp.task('clean-client', util.rimraf('dataprotocol-node/client/node_modules'));
|
||||||
|
gulp.task('clean-jsonrpc', util.rimraf('dataprotocol-node/jsonrpc/node_modules'));
|
||||||
|
gulp.task('clean-server', util.rimraf('dataprotocol-node/server/node_modules'));
|
||||||
|
gulp.task('clean-types', util.rimraf('dataprotocol-node/types/node_modules'));
|
||||||
|
gulp.task('clean-extensions-modules', util.rimraf('extensions-modules/node_modules'));
|
||||||
|
gulp.task('clean-protocol', ['clean-extensions-modules', 'clean-mssql-extension', 'clean-credentials-extension', 'clean-client', 'clean-jsonrpc', 'clean-server', 'clean-types']);
|
||||||
|
|
||||||
|
// Tasks to clean extensions modules
|
||||||
|
gulp.task('clean-mssql-ext-mod', util.rimraf('extensions/mssql/node_modules/extensions-modules'));
|
||||||
|
gulp.task('clean-credentials-ext-mod', util.rimraf('extensions/credentials/node_modules/extensions-modules'));
|
||||||
|
gulp.task('clean-build-ext-mod', util.rimraf('build/node_modules/extensions-modules'));
|
||||||
|
gulp.task('clean-ext-mod', ['clean-mssql-ext-mod', 'clean-credentials-ext-mod', 'clean-build-ext-mod', 'clean-extensions-modules']);
|
||||||
|
|
||||||
gulp.task('fmt', () => formatStagedFiles());
|
gulp.task('fmt', () => formatStagedFiles());
|
||||||
const formatFiles = (some) => {
|
const formatFiles = (some) => {
|
||||||
|
|||||||
@@ -27,26 +27,20 @@ const common = require('./lib/optimize');
|
|||||||
const nlsDev = require('vscode-nls-dev');
|
const nlsDev = require('vscode-nls-dev');
|
||||||
const root = path.dirname(__dirname);
|
const root = path.dirname(__dirname);
|
||||||
const commit = util.getVersion(root);
|
const commit = util.getVersion(root);
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const packageJson = require('../package.json');
|
const packageJson = require('../package.json');
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const product = require('../product.json');
|
const product = require('../product.json');
|
||||||
|
const shrinkwrap = require('../npm-shrinkwrap.json');
|
||||||
const crypto = require('crypto');
|
const crypto = require('crypto');
|
||||||
const i18n = require('./lib/i18n');
|
const i18n = require('./lib/i18n');
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
const serviceDownloader = require('service-downloader').ServiceDownloadProvider;
|
|
||||||
const platformInfo = require('service-downloader/out/platform').PlatformInformation;
|
|
||||||
const glob = require('glob');
|
|
||||||
const deps = require('./dependencies');
|
|
||||||
const getElectronVersion = require('./lib/electron').getElectronVersion;
|
|
||||||
const createAsar = require('./lib/asar').createAsar;
|
|
||||||
|
|
||||||
const productionDependencies = deps.getProductionDependencies(path.dirname(__dirname));
|
|
||||||
// @ts-ignore
|
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
var del = require('del');
|
var del = require('del');
|
||||||
const extensionsRoot = path.join(root, 'extensions');
|
|
||||||
const extensionsProductionDependencies = deps.getProductionDependencies(extensionsRoot);
|
// {{SQL CARBON EDIT}}
|
||||||
|
const serviceInstaller = require('extensions-modules/lib/languageservice/serviceInstallerUtil');
|
||||||
|
const glob = require('glob');
|
||||||
|
|
||||||
|
const productDependencies = Object.keys(product.dependencies || {});
|
||||||
|
const dependencies = Object.keys(shrinkwrap.dependencies)
|
||||||
|
.concat(productDependencies); // additional dependencies from our product configuration
|
||||||
const baseModules = Object.keys(process.binding('natives')).filter(n => !/^_|\//.test(n));
|
const baseModules = Object.keys(process.binding('natives')).filter(n => !/^_|\//.test(n));
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
const nodeModules = [
|
const nodeModules = [
|
||||||
@@ -56,28 +50,19 @@ const nodeModules = [
|
|||||||
'rxjs/Subject',
|
'rxjs/Subject',
|
||||||
'rxjs/Observer',
|
'rxjs/Observer',
|
||||||
'ng2-charts/ng2-charts']
|
'ng2-charts/ng2-charts']
|
||||||
.concat(Object.keys(product.dependencies || {}))
|
.concat(dependencies)
|
||||||
.concat(_.uniq(productionDependencies.map(d => d.name)))
|
|
||||||
.concat(baseModules);
|
.concat(baseModules);
|
||||||
|
|
||||||
|
|
||||||
// Build
|
// Build
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const builtInExtensions = require('./builtInExtensions.json');
|
const builtInExtensions = [
|
||||||
|
{ name: 'ms-vscode.node-debug', version: '1.18.3' },
|
||||||
|
{ name: 'ms-vscode.node-debug2', version: '1.18.5' }
|
||||||
|
];
|
||||||
|
|
||||||
const excludedExtensions = [
|
const excludedExtensions = [
|
||||||
'vscode-api-tests',
|
'vscode-api-tests',
|
||||||
'vscode-colorize-tests',
|
'vscode-colorize-tests'
|
||||||
'ms-vscode.node-debug',
|
|
||||||
'ms-vscode.node-debug2',
|
|
||||||
];
|
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
const vsce = require('vsce');
|
|
||||||
const sqlBuiltInExtensions = [
|
|
||||||
// Add SQL built-in extensions here.
|
|
||||||
// the extension will be excluded from SQLOps package and will have separate vsix packages
|
|
||||||
'agent'
|
|
||||||
];
|
];
|
||||||
|
|
||||||
const vscodeEntryPoints = _.flatten([
|
const vscodeEntryPoints = _.flatten([
|
||||||
@@ -94,8 +79,8 @@ const vscodeResources = [
|
|||||||
'out-build/bootstrap-amd.js',
|
'out-build/bootstrap-amd.js',
|
||||||
'out-build/paths.js',
|
'out-build/paths.js',
|
||||||
'out-build/vs/**/*.{svg,png,cur,html}',
|
'out-build/vs/**/*.{svg,png,cur,html}',
|
||||||
'out-build/vs/base/common/performance.js',
|
'out-build/vs/base/node/startupTimers.js',
|
||||||
'out-build/vs/base/node/{stdForkStart.js,terminateProcess.sh,ps-win.ps1}',
|
'out-build/vs/base/node/{stdForkStart.js,terminateProcess.sh}',
|
||||||
'out-build/vs/base/browser/ui/octiconLabel/octicons/**',
|
'out-build/vs/base/browser/ui/octiconLabel/octicons/**',
|
||||||
'out-build/vs/workbench/browser/media/*-theme.css',
|
'out-build/vs/workbench/browser/media/*-theme.css',
|
||||||
'out-build/vs/workbench/electron-browser/bootstrap/**',
|
'out-build/vs/workbench/electron-browser/bootstrap/**',
|
||||||
@@ -108,9 +93,8 @@ const vscodeResources = [
|
|||||||
'out-build/vs/workbench/parts/welcome/walkThrough/**/*.md',
|
'out-build/vs/workbench/parts/welcome/walkThrough/**/*.md',
|
||||||
'out-build/vs/workbench/services/files/**/*.exe',
|
'out-build/vs/workbench/services/files/**/*.exe',
|
||||||
'out-build/vs/workbench/services/files/**/*.md',
|
'out-build/vs/workbench/services/files/**/*.md',
|
||||||
'out-build/vs/code/electron-browser/sharedProcess/sharedProcess.js',
|
'out-build/vs/code/electron-browser/sharedProcess.js',
|
||||||
'out-build/vs/code/electron-browser/issue/issueReporter.js',
|
// {{SQL CARBON EDIT}}
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
'out-build/sql/workbench/electron-browser/splashscreen/*',
|
'out-build/sql/workbench/electron-browser/splashscreen/*',
|
||||||
'out-build/sql/**/*.{svg,png,cur,html}',
|
'out-build/sql/**/*.{svg,png,cur,html}',
|
||||||
'out-build/sql/base/browser/ui/table/media/*.{gif,png,svg}',
|
'out-build/sql/base/browser/ui/table/media/*.{gif,png,svg}',
|
||||||
@@ -127,7 +111,6 @@ const vscodeResources = [
|
|||||||
'out-build/sql/parts/grid/views/**/*.html',
|
'out-build/sql/parts/grid/views/**/*.html',
|
||||||
'out-build/sql/parts/tasks/**/*.html',
|
'out-build/sql/parts/tasks/**/*.html',
|
||||||
'out-build/sql/parts/taskHistory/viewlet/media/**',
|
'out-build/sql/parts/taskHistory/viewlet/media/**',
|
||||||
'out-build/sql/parts/jobManagement/common/media/*.svg',
|
|
||||||
'out-build/sql/media/objectTypes/*.svg',
|
'out-build/sql/media/objectTypes/*.svg',
|
||||||
'out-build/sql/media/icons/*.svg',
|
'out-build/sql/media/icons/*.svg',
|
||||||
'!**/test/**'
|
'!**/test/**'
|
||||||
@@ -139,7 +122,10 @@ const BUNDLED_FILE_HEADER = [
|
|||||||
' *--------------------------------------------------------*/'
|
' *--------------------------------------------------------*/'
|
||||||
].join('\n');
|
].join('\n');
|
||||||
|
|
||||||
const languages = i18n.defaultLanguages.concat([]); // i18n.defaultLanguages.concat(process.env.VSCODE_QUALITY !== 'stable' ? i18n.extraLanguages : []);
|
var languages = ['chs', 'cht', 'jpn', 'kor', 'deu', 'fra', 'esn', 'rus', 'ita'];
|
||||||
|
if (process.env.VSCODE_QUALITY !== 'stable') {
|
||||||
|
languages = languages.concat(['ptb', 'hun', 'trk']); // Add languages requested by the community to non-stable builds
|
||||||
|
}
|
||||||
|
|
||||||
gulp.task('clean-optimized-vscode', util.rimraf('out-vscode'));
|
gulp.task('clean-optimized-vscode', util.rimraf('out-vscode'));
|
||||||
gulp.task('optimize-vscode', ['clean-optimized-vscode', 'compile-build', 'compile-extensions-build'], common.optimizeTask({
|
gulp.task('optimize-vscode', ['clean-optimized-vscode', 'compile-build', 'compile-extensions-build'], common.optimizeTask({
|
||||||
@@ -149,8 +135,7 @@ gulp.task('optimize-vscode', ['clean-optimized-vscode', 'compile-build', 'compil
|
|||||||
loaderConfig: common.loaderConfig(nodeModules),
|
loaderConfig: common.loaderConfig(nodeModules),
|
||||||
header: BUNDLED_FILE_HEADER,
|
header: BUNDLED_FILE_HEADER,
|
||||||
out: 'out-vscode',
|
out: 'out-vscode',
|
||||||
languages: languages,
|
languages: languages
|
||||||
bundleInfo: undefined
|
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
|
||||||
@@ -169,7 +154,7 @@ gulp.task('minify-vscode', ['clean-minified-vscode', 'optimize-index-js'], commo
|
|||||||
const darwinCreditsTemplate = product.darwinCredits && _.template(fs.readFileSync(path.join(root, product.darwinCredits), 'utf8'));
|
const darwinCreditsTemplate = product.darwinCredits && _.template(fs.readFileSync(path.join(root, product.darwinCredits), 'utf8'));
|
||||||
|
|
||||||
const config = {
|
const config = {
|
||||||
version: getElectronVersion(),
|
version: packageJson.electronVersion,
|
||||||
productAppName: product.nameLong,
|
productAppName: product.nameLong,
|
||||||
companyName: 'Microsoft Corporation',
|
companyName: 'Microsoft Corporation',
|
||||||
copyright: 'Copyright (C) 2018 Microsoft. All rights reserved',
|
copyright: 'Copyright (C) 2018 Microsoft. All rights reserved',
|
||||||
@@ -191,7 +176,7 @@ const config = {
|
|||||||
name: product.nameLong,
|
name: product.nameLong,
|
||||||
urlSchemes: [product.urlProtocol]
|
urlSchemes: [product.urlProtocol]
|
||||||
}],
|
}],
|
||||||
darwinCredits: darwinCreditsTemplate ? Buffer.from(darwinCreditsTemplate({ commit: commit, date: new Date().toISOString() })) : void 0,
|
darwinCredits: darwinCreditsTemplate ? new Buffer(darwinCreditsTemplate({ commit: commit, date: new Date().toISOString() })) : void 0,
|
||||||
linuxExecutableName: product.applicationName,
|
linuxExecutableName: product.applicationName,
|
||||||
winIcon: 'resources/win32/code.ico',
|
winIcon: 'resources/win32/code.ico',
|
||||||
token: process.env['VSCODE_MIXIN_PASSWORD'] || process.env['GITHUB_TOKEN'] || void 0,
|
token: process.env['VSCODE_MIXIN_PASSWORD'] || process.env['GITHUB_TOKEN'] || void 0,
|
||||||
@@ -255,30 +240,10 @@ function computeChecksum(filename) {
|
|||||||
return hash;
|
return hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
function packageBuiltInExtensions() {
|
|
||||||
const sqlBuiltInLocalExtensionDescriptions = glob.sync('extensions/*/package.json')
|
|
||||||
.map(manifestPath => {
|
|
||||||
const extensionPath = path.dirname(path.join(root, manifestPath));
|
|
||||||
const extensionName = path.basename(extensionPath);
|
|
||||||
return { name: extensionName, path: extensionPath };
|
|
||||||
})
|
|
||||||
.filter(({ name }) => excludedExtensions.indexOf(name) === -1)
|
|
||||||
.filter(({ name }) => builtInExtensions.every(b => b.name !== name))
|
|
||||||
.filter(({ name }) => sqlBuiltInExtensions.indexOf(name) >= 0);
|
|
||||||
sqlBuiltInLocalExtensionDescriptions.forEach(element => {
|
|
||||||
const packagePath = path.join(path.dirname(root), element.name + '.vsix');
|
|
||||||
console.info('Creating vsix for ' + element.path + ' result:' + packagePath);
|
|
||||||
vsce.createVSIX({
|
|
||||||
cwd: element.path,
|
|
||||||
packagePath: packagePath
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function packageTask(platform, arch, opts) {
|
function packageTask(platform, arch, opts) {
|
||||||
opts = opts || {};
|
opts = opts || {};
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
const destination = path.join(path.dirname(root), 'sqlops') + (platform ? '-' + platform : '') + (arch ? '-' + arch : '');
|
const destination = path.join(path.dirname(root), 'sqlops') + (platform ? '-' + platform : '') + (arch ? '-' + arch : '');
|
||||||
platform = platform || process.platform;
|
platform = platform || process.platform;
|
||||||
|
|
||||||
@@ -304,10 +269,7 @@ function packageTask(platform, arch, opts) {
|
|||||||
return { name: extensionName, path: extensionPath };
|
return { name: extensionName, path: extensionPath };
|
||||||
})
|
})
|
||||||
.filter(({ name }) => excludedExtensions.indexOf(name) === -1)
|
.filter(({ name }) => excludedExtensions.indexOf(name) === -1)
|
||||||
.filter(({ name }) => builtInExtensions.every(b => b.name !== name))
|
.filter(({ name }) => builtInExtensions.every(b => b.name !== name));
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
.filter(({ name }) => sqlBuiltInExtensions.indexOf(name) === -1);
|
|
||||||
packageBuiltInExtensions();
|
|
||||||
|
|
||||||
const localExtensions = es.merge(...localExtensionDescriptions.map(extension => {
|
const localExtensions = es.merge(...localExtensionDescriptions.map(extension => {
|
||||||
const nlsFilter = filter('**/*.nls.json', { restore: true });
|
const nlsFilter = filter('**/*.nls.json', { restore: true });
|
||||||
@@ -321,20 +283,15 @@ function packageTask(platform, arch, opts) {
|
|||||||
.pipe(nlsFilter.restore);
|
.pipe(nlsFilter.restore);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
const localExtensionDependencies = gulp.src('extensions/node_modules/**', { base: '.' });
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
const extensionDepsSrc = [
|
|
||||||
..._.flatten(extensionsProductionDependencies.map(d => path.relative(root, d.path)).map(d => [`${d}/**`, `!${d}/**/{test,tests}/**`])),
|
|
||||||
];
|
|
||||||
|
|
||||||
const localExtensionDependencies = gulp.src(extensionDepsSrc, { base: '.', dot: true })
|
|
||||||
.pipe(filter(['**', '!**/package-lock.json']))
|
|
||||||
.pipe(util.cleanNodeModule('account-provider-azure', ['node_modules/date-utils/doc/**', 'node_modules/adal_node/node_modules/**'], undefined))
|
|
||||||
.pipe(util.cleanNodeModule('typescript', ['**/**'], undefined));
|
|
||||||
|
|
||||||
|
|
||||||
const sources = es.merge(src, localExtensions, localExtensionDependencies)
|
const sources = es.merge(src, localExtensions, localExtensionDependencies)
|
||||||
.pipe(util.setExecutableBit(['**/*.sh']))
|
.pipe(util.setExecutableBit(['**/*.sh']))
|
||||||
.pipe(filter(['**', '!**/*.js.map']));
|
.pipe(filter(['**',
|
||||||
|
'!**/*.js.map',
|
||||||
|
'!extensions/**/node_modules/**/{test, tests}/**',
|
||||||
|
'!extensions/**/node_modules/**/test.js']));
|
||||||
|
|
||||||
let version = packageJson.version;
|
let version = packageJson.version;
|
||||||
const quality = product.quality;
|
const quality = product.quality;
|
||||||
@@ -358,13 +315,11 @@ function packageTask(platform, arch, opts) {
|
|||||||
|
|
||||||
// TODO the API should be copied to `out` during compile, not here
|
// TODO the API should be copied to `out` during compile, not here
|
||||||
const api = gulp.src('src/vs/vscode.d.ts').pipe(rename('out/vs/vscode.d.ts'));
|
const api = gulp.src('src/vs/vscode.d.ts').pipe(rename('out/vs/vscode.d.ts'));
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
const dataApi = gulp.src('src/vs/data.d.ts').pipe(rename('out/sql/data.d.ts'));
|
const dataApi = gulp.src('src/vs/data.d.ts').pipe(rename('out/sql/data.d.ts'));
|
||||||
|
|
||||||
const depsSrc = [
|
const depsSrc = _.flatten(dependencies
|
||||||
..._.flatten(productionDependencies.map(d => path.relative(root, d.path)).map(d => [`${d}/**`, `!${d}/**/{test,tests}/**`])),
|
.map(function (d) { return ['node_modules/' + d + '/**', '!node_modules/' + d + '/**/{test,tests}/**']; }));
|
||||||
..._.flatten(Object.keys(product.dependencies || {}).map(d => [`node_modules/${d}/**`, `!node_modules/${d}/**/{test,tests}/**`]))
|
|
||||||
];
|
|
||||||
|
|
||||||
const deps = gulp.src(depsSrc, { base: '.', dot: true })
|
const deps = gulp.src(depsSrc, { base: '.', dot: true })
|
||||||
.pipe(filter(['**', '!**/package-lock.json']))
|
.pipe(filter(['**', '!**/package-lock.json']))
|
||||||
@@ -372,35 +327,16 @@ function packageTask(platform, arch, opts) {
|
|||||||
.pipe(util.cleanNodeModule('oniguruma', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node', 'src/*.js']))
|
.pipe(util.cleanNodeModule('oniguruma', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node', 'src/*.js']))
|
||||||
.pipe(util.cleanNodeModule('windows-mutex', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
.pipe(util.cleanNodeModule('windows-mutex', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
||||||
.pipe(util.cleanNodeModule('native-keymap', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node']))
|
.pipe(util.cleanNodeModule('native-keymap', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node']))
|
||||||
.pipe(util.cleanNodeModule('native-is-elevated', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node']))
|
|
||||||
.pipe(util.cleanNodeModule('native-watchdog', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
.pipe(util.cleanNodeModule('native-watchdog', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
||||||
.pipe(util.cleanNodeModule('spdlog', ['binding.gyp', 'build/**', 'deps/**', 'src/**', 'test/**'], ['**/*.node']))
|
|
||||||
.pipe(util.cleanNodeModule('jschardet', ['dist/**']))
|
.pipe(util.cleanNodeModule('jschardet', ['dist/**']))
|
||||||
.pipe(util.cleanNodeModule('windows-foreground-love', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
.pipe(util.cleanNodeModule('windows-foreground-love', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
||||||
.pipe(util.cleanNodeModule('windows-process-tree', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
.pipe(util.cleanNodeModule('windows-process-tree', ['binding.gyp', 'build/**', 'src/**'], ['**/*.node']))
|
||||||
.pipe(util.cleanNodeModule('gc-signals', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node', 'src/index.js']))
|
.pipe(util.cleanNodeModule('gc-signals', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node', 'src/index.js']))
|
||||||
|
.pipe(util.cleanNodeModule('v8-profiler', ['binding.gyp', 'build/**', 'src/**', 'deps/**'], ['**/*.node', 'src/index.js']))
|
||||||
.pipe(util.cleanNodeModule('keytar', ['binding.gyp', 'build/**', 'src/**', 'script/**', 'node_modules/**'], ['**/*.node']))
|
.pipe(util.cleanNodeModule('keytar', ['binding.gyp', 'build/**', 'src/**', 'script/**', 'node_modules/**'], ['**/*.node']))
|
||||||
.pipe(util.cleanNodeModule('node-pty', ['binding.gyp', 'build/**', 'src/**', 'tools/**'], ['build/Release/*.exe', 'build/Release/*.dll', 'build/Release/*.node']))
|
.pipe(util.cleanNodeModule('node-pty', ['binding.gyp', 'build/**', 'src/**', 'tools/**'], ['build/Release/**']))
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
.pipe(util.cleanNodeModule('chart.js', ['node_modules/**'], undefined))
|
|
||||||
.pipe(util.cleanNodeModule('emmet', ['node_modules/**'], undefined))
|
|
||||||
.pipe(util.cleanNodeModule('pty.js', ['build/**'], ['build/Release/**']))
|
|
||||||
.pipe(util.cleanNodeModule('jquery-ui', ['external/**', 'demos/**'], undefined))
|
|
||||||
.pipe(util.cleanNodeModule('core-js', ['**/**'], undefined))
|
|
||||||
.pipe(util.cleanNodeModule('slickgrid', ['node_modules/**', 'examples/**'], undefined))
|
|
||||||
.pipe(util.cleanNodeModule('nsfw', ['binding.gyp', 'build/**', 'src/**', 'openpa/**', 'includes/**'], ['**/*.node', '**/*.a']))
|
.pipe(util.cleanNodeModule('nsfw', ['binding.gyp', 'build/**', 'src/**', 'openpa/**', 'includes/**'], ['**/*.node', '**/*.a']))
|
||||||
.pipe(util.cleanNodeModule('vsda', ['binding.gyp', 'README.md', 'build/**', '*.bat', '*.sh', '*.cpp', '*.h'], ['build/Release/vsda.node']))
|
.pipe(util.cleanNodeModule('vsda', ['binding.gyp', 'README.md', 'build/**', '*.bat', '*.sh', '*.cpp', '*.h'], ['build/Release/vsda.node']));
|
||||||
.pipe(createAsar(path.join(process.cwd(), 'node_modules'), ['**/*.node', '**/vscode-ripgrep/bin/*', '**/node-pty/build/Release/*'], 'app/node_modules.asar'));
|
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
|
||||||
let copiedModules = gulp.src([
|
|
||||||
'node_modules/jquery/**/*.*',
|
|
||||||
'node_modules/reflect-metadata/**/*.*',
|
|
||||||
'node_modules/slickgrid/**/*.*',
|
|
||||||
'node_modules/underscore/**/*.*',
|
|
||||||
'node_modules/zone.js/**/*.*',
|
|
||||||
'node_modules/chart.js/**/*.*'
|
|
||||||
], { base: '.', dot: true });
|
|
||||||
|
|
||||||
let all = es.merge(
|
let all = es.merge(
|
||||||
packageJsonStream,
|
packageJsonStream,
|
||||||
@@ -408,8 +344,7 @@ function packageTask(platform, arch, opts) {
|
|||||||
license,
|
license,
|
||||||
watermark,
|
watermark,
|
||||||
api,
|
api,
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
copiedModules,
|
|
||||||
dataApi,
|
dataApi,
|
||||||
sources,
|
sources,
|
||||||
deps
|
deps
|
||||||
@@ -480,21 +415,25 @@ gulp.task('vscode-linux-x64-min', ['minify-vscode', 'clean-vscode-linux-x64'], p
|
|||||||
gulp.task('vscode-linux-arm-min', ['minify-vscode', 'clean-vscode-linux-arm'], packageTask('linux', 'arm', { minified: true }));
|
gulp.task('vscode-linux-arm-min', ['minify-vscode', 'clean-vscode-linux-arm'], packageTask('linux', 'arm', { minified: true }));
|
||||||
|
|
||||||
// Transifex Localizations
|
// Transifex Localizations
|
||||||
|
const vscodeLanguages = [
|
||||||
const innoSetupConfig = {
|
'zh-hans',
|
||||||
'zh-cn': { codePage: 'CP936', defaultInfo: { name: 'Simplified Chinese', id: '$0804', } },
|
'zh-hant',
|
||||||
'zh-tw': { codePage: 'CP950', defaultInfo: { name: 'Traditional Chinese', id: '$0404' } },
|
'ja',
|
||||||
'ko': { codePage: 'CP949', defaultInfo: { name: 'Korean', id: '$0412' } },
|
'ko',
|
||||||
'ja': { codePage: 'CP932' },
|
'de',
|
||||||
'de': { codePage: 'CP1252' },
|
'fr',
|
||||||
'fr': { codePage: 'CP1252' },
|
'es',
|
||||||
'es': { codePage: 'CP1252' },
|
'ru',
|
||||||
'ru': { codePage: 'CP1251' },
|
'it',
|
||||||
'it': { codePage: 'CP1252' },
|
'pt-br',
|
||||||
'pt-br': { codePage: 'CP1252' },
|
'hu',
|
||||||
'hu': { codePage: 'CP1250' },
|
'tr'
|
||||||
'tr': { codePage: 'CP1254' }
|
];
|
||||||
};
|
const setupDefaultLanguages = [
|
||||||
|
'zh-hans',
|
||||||
|
'zh-hant',
|
||||||
|
'ko'
|
||||||
|
];
|
||||||
|
|
||||||
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;
|
||||||
@@ -502,48 +441,27 @@ const apiToken = process.env.TRANSIFEX_API_TOKEN;
|
|||||||
|
|
||||||
gulp.task('vscode-translations-push', ['optimize-vscode'], function () {
|
gulp.task('vscode-translations-push', ['optimize-vscode'], function () {
|
||||||
const pathToMetadata = './out-vscode/nls.metadata.json';
|
const pathToMetadata = './out-vscode/nls.metadata.json';
|
||||||
const pathToExtensions = './extensions/*';
|
const pathToExtensions = './extensions/**/*.nls.json';
|
||||||
const pathToSetup = 'build/win32/**/{Default.isl,messages.en.isl}';
|
const pathToSetup = 'build/win32/**/{Default.isl,messages.en.isl}';
|
||||||
|
|
||||||
return es.merge(
|
return es.merge(
|
||||||
gulp.src(pathToMetadata).pipe(i18n.createXlfFilesForCoreBundle()),
|
gulp.src(pathToMetadata).pipe(i18n.prepareXlfFiles()),
|
||||||
gulp.src(pathToSetup).pipe(i18n.createXlfFilesForIsl()),
|
gulp.src(pathToSetup).pipe(i18n.prepareXlfFiles()),
|
||||||
gulp.src(pathToExtensions).pipe(i18n.createXlfFilesForExtensions())
|
gulp.src(pathToExtensions).pipe(i18n.prepareXlfFiles('vscode-extensions'))
|
||||||
).pipe(i18n.findObsoleteResources(apiHostname, apiName, apiToken)
|
|
||||||
).pipe(i18n.pushXlfFiles(apiHostname, apiName, apiToken));
|
).pipe(i18n.pushXlfFiles(apiHostname, apiName, apiToken));
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('vscode-translations-push-test', ['optimize-vscode'], function () {
|
|
||||||
const pathToMetadata = './out-vscode/nls.metadata.json';
|
|
||||||
const pathToExtensions = './extensions/*';
|
|
||||||
const pathToSetup = 'build/win32/**/{Default.isl,messages.en.isl}';
|
|
||||||
|
|
||||||
return es.merge(
|
|
||||||
gulp.src(pathToMetadata).pipe(i18n.createXlfFilesForCoreBundle()),
|
|
||||||
gulp.src(pathToSetup).pipe(i18n.createXlfFilesForIsl()),
|
|
||||||
gulp.src(pathToExtensions).pipe(i18n.createXlfFilesForExtensions())
|
|
||||||
).pipe(i18n.findObsoleteResources(apiHostname, apiName, apiToken)
|
|
||||||
).pipe(vfs.dest('../vscode-transifex-input'));
|
|
||||||
});
|
|
||||||
|
|
||||||
gulp.task('vscode-translations-pull', function () {
|
gulp.task('vscode-translations-pull', function () {
|
||||||
[...i18n.defaultLanguages, ...i18n.extraLanguages].forEach(language => {
|
return es.merge(
|
||||||
i18n.pullCoreAndExtensionsXlfFiles(apiHostname, apiName, apiToken, language).pipe(vfs.dest(`../vscode-localization/${language.id}/build`));
|
i18n.pullXlfFiles('vscode-editor', apiHostname, apiName, apiToken, vscodeLanguages),
|
||||||
|
i18n.pullXlfFiles('vscode-workbench', apiHostname, apiName, apiToken, vscodeLanguages),
|
||||||
let includeDefault = !!innoSetupConfig[language.id].defaultInfo;
|
i18n.pullXlfFiles('vscode-extensions', apiHostname, apiName, apiToken, vscodeLanguages),
|
||||||
i18n.pullSetupXlfFiles(apiHostname, apiName, apiToken, language, includeDefault).pipe(vfs.dest(`../vscode-localization/${language.id}/setup`));
|
i18n.pullXlfFiles('vscode-setup', apiHostname, apiName, apiToken, setupDefaultLanguages)
|
||||||
});
|
).pipe(vfs.dest('../vscode-localization'));
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('vscode-translations-import', function () {
|
gulp.task('vscode-translations-import', function () {
|
||||||
[...i18n.defaultLanguages, ...i18n.extraLanguages].forEach(language => {
|
return gulp.src('../vscode-localization/**/*.xlf').pipe(i18n.prepareJsonFiles()).pipe(vfs.dest('./i18n'));
|
||||||
gulp.src(`../vscode-localization/${language.id}/build/*/*.xlf`)
|
|
||||||
.pipe(i18n.prepareI18nFiles())
|
|
||||||
.pipe(vfs.dest(`./i18n/${language.folderName}`));
|
|
||||||
gulp.src(`../vscode-localization/${language.id}/setup/*/*.xlf`)
|
|
||||||
.pipe(i18n.prepareIslFiles(language, innoSetupConfig[language.id]))
|
|
||||||
.pipe(vfs.dest(`./build/win32/i18n`));
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Sourcemaps
|
// Sourcemaps
|
||||||
@@ -569,8 +487,7 @@ gulp.task('upload-vscode-sourcemaps', ['minify-vscode'], () => {
|
|||||||
const allConfigDetailsPath = path.join(os.tmpdir(), 'configuration.json');
|
const allConfigDetailsPath = path.join(os.tmpdir(), 'configuration.json');
|
||||||
gulp.task('upload-vscode-configuration', ['generate-vscode-configuration'], () => {
|
gulp.task('upload-vscode-configuration', ['generate-vscode-configuration'], () => {
|
||||||
const branch = process.env.BUILD_SOURCEBRANCH;
|
const branch = process.env.BUILD_SOURCEBRANCH;
|
||||||
|
if (!branch.endsWith('/master') && !branch.indexOf('/release/') >= 0) {
|
||||||
if (!/\/master$/.test(branch) && branch.indexOf('/release/') < 0) {
|
|
||||||
console.log(`Only runs on master and release branches, not ${branch}`);
|
console.log(`Only runs on master and release branches, not ${branch}`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -665,7 +582,6 @@ function versionStringToNumber(versionStr) {
|
|||||||
return parseInt(match[1], 10) * 1e4 + parseInt(match[2], 10) * 1e2 + parseInt(match[3], 10);
|
return parseInt(match[1], 10) * 1e4 + parseInt(match[2], 10) * 1e2 + parseInt(match[3], 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
// This task is only run for the MacOS build
|
|
||||||
gulp.task('generate-vscode-configuration', () => {
|
gulp.task('generate-vscode-configuration', () => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
const buildDir = process.env['AGENT_BUILDDIRECTORY'];
|
const buildDir = process.env['AGENT_BUILDDIRECTORY'];
|
||||||
@@ -675,8 +591,7 @@ gulp.task('generate-vscode-configuration', () => {
|
|||||||
|
|
||||||
const userDataDir = path.join(os.tmpdir(), 'tmpuserdata');
|
const userDataDir = path.join(os.tmpdir(), 'tmpuserdata');
|
||||||
const extensionsDir = path.join(os.tmpdir(), 'tmpextdir');
|
const extensionsDir = path.join(os.tmpdir(), 'tmpextdir');
|
||||||
const appName = process.env.VSCODE_QUALITY === 'insider' ? 'Visual\\ Studio\\ Code\\ -\\ Insiders.app' : 'Visual\\ Studio\\ Code.app';
|
const appPath = path.join(buildDir, 'VSCode-darwin/Visual\\ Studio\\ Code\\ -\\ Insiders.app/Contents/Resources/app/bin/code');
|
||||||
const appPath = path.join(buildDir, `VSCode-darwin/${appName}/Contents/Resources/app/bin/code`);
|
|
||||||
const codeProc = cp.exec(`${appPath} --export-default-configuration='${allConfigDetailsPath}' --wait --user-data-dir='${userDataDir}' --extensions-dir='${extensionsDir}'`);
|
const codeProc = cp.exec(`${appPath} --export-default-configuration='${allConfigDetailsPath}' --wait --user-data-dir='${userDataDir}' --extensions-dir='${extensionsDir}'`);
|
||||||
|
|
||||||
const timer = setTimeout(() => {
|
const timer = setTimeout(() => {
|
||||||
@@ -705,25 +620,27 @@ gulp.task('generate-vscode-configuration', () => {
|
|||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
// Install service locally before building carbon
|
// Install service locally before building carbon
|
||||||
|
|
||||||
function installService() {
|
function installService(extObj, path) {
|
||||||
let config = require('../extensions/mssql/src/config.json');
|
var installer = new serviceInstaller.ServiceInstaller(extObj, path);
|
||||||
return platformInfo.getCurrent().then(p => {
|
installer.getServiceInstallDirectoryRoot().then(serviceInstallFolder => {
|
||||||
let runtime = p.runtimeId;
|
console.log('Cleaning up the install folder: ' + serviceInstallFolder);
|
||||||
// fix path since it won't be correct
|
del(serviceInstallFolder + '/*').then(() => {
|
||||||
config.installDirectory = path.join(__dirname, '../extensions/mssql/src', config.installDirectory);
|
console.log('Installing the service. Install folder: ' + serviceInstallFolder);
|
||||||
var installer = new serviceDownloader(config);
|
installer.installService();
|
||||||
let serviceInstallFolder = installer.getInstallDirectory(runtime);
|
}, delError => {
|
||||||
console.log('Cleaning up the install folder: ' + serviceInstallFolder);
|
console.log('failed to delete the install folder error: ' + delError);
|
||||||
return del(serviceInstallFolder + '/*').then(() => {
|
});
|
||||||
console.log('Installing the service. Install folder: ' + serviceInstallFolder);
|
}, getFolderPathError => {
|
||||||
return installer.installService(runtime);
|
console.log('failed to call getServiceInstallDirectoryRoot error: ' + getFolderPathError);
|
||||||
}, delError => {
|
|
||||||
console.log('failed to delete the install folder error: ' + delError);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gulp.task('install-sqltoolsservice', () => {
|
gulp.task('install-sqltoolsservice', () => {
|
||||||
return installService();
|
var mssqlExt = require('../extensions/mssql/client/out/models/constants');
|
||||||
|
var extObj = new mssqlExt.Constants();
|
||||||
|
var path = '../extensions/mssql/client/out/config.json';
|
||||||
|
return installService(extObj, path);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -12,12 +12,9 @@ const shell = require('gulp-shell');
|
|||||||
const es = require('event-stream');
|
const es = require('event-stream');
|
||||||
const vfs = require('vinyl-fs');
|
const vfs = require('vinyl-fs');
|
||||||
const util = require('./lib/util');
|
const util = require('./lib/util');
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const packageJson = require('../package.json');
|
const packageJson = require('../package.json');
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const product = require('../product.json');
|
const product = require('../product.json');
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
const rpmDependencies = require('../resources/linux/rpm/dependencies');
|
||||||
const rpmDependencies = require('../resources/linux/rpm/dependencies.json');
|
|
||||||
|
|
||||||
const linuxPackageRevision = Math.floor(new Date().getTime() / 1000);
|
const linuxPackageRevision = Math.floor(new Date().getTime() / 1000);
|
||||||
|
|
||||||
@@ -114,7 +111,8 @@ function buildDebPackage(arch) {
|
|||||||
return shell.task([
|
return shell.task([
|
||||||
'chmod 755 ' + product.applicationName + '-' + debArch + '/DEBIAN/postinst ' + product.applicationName + '-' + debArch + '/DEBIAN/prerm ' + product.applicationName + '-' + debArch + '/DEBIAN/postrm',
|
'chmod 755 ' + product.applicationName + '-' + debArch + '/DEBIAN/postinst ' + product.applicationName + '-' + debArch + '/DEBIAN/prerm ' + product.applicationName + '-' + debArch + '/DEBIAN/postrm',
|
||||||
'mkdir -p deb',
|
'mkdir -p deb',
|
||||||
'fakeroot dpkg-deb -b ' + product.applicationName + '-' + debArch + ' deb'
|
'fakeroot dpkg-deb -b ' + product.applicationName + '-' + debArch + ' deb',
|
||||||
|
'dpkg-scanpackages deb /dev/null > Packages'
|
||||||
], { cwd: '.build/linux/deb/' + debArch });
|
], { cwd: '.build/linux/deb/' + debArch });
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -222,10 +220,10 @@ function prepareSnapPackage(arch) {
|
|||||||
|
|
||||||
function buildSnapPackage(arch) {
|
function buildSnapPackage(arch) {
|
||||||
const snapBuildPath = getSnapBuildPath(arch);
|
const snapBuildPath = getSnapBuildPath(arch);
|
||||||
const snapFilename = `${product.applicationName}-${packageJson.version}-${linuxPackageRevision}-${arch}.snap`;
|
|
||||||
return shell.task([
|
return shell.task([
|
||||||
`chmod +x ${snapBuildPath}/electron-launch`,
|
`chmod +x ${snapBuildPath}/electron-launch`,
|
||||||
`cd ${snapBuildPath} && snapcraft snap --output ../${snapFilename}`
|
`cd ${snapBuildPath} && snapcraft snap`
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -11,11 +11,8 @@ const assert = require('assert');
|
|||||||
const cp = require('child_process');
|
const cp = require('child_process');
|
||||||
const _7z = require('7zip')['7z'];
|
const _7z = require('7zip')['7z'];
|
||||||
const util = require('./lib/util');
|
const util = require('./lib/util');
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const pkg = require('../package.json');
|
const pkg = require('../package.json');
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const product = require('../product.json');
|
const product = require('../product.json');
|
||||||
const vfs = require('vinyl-fs');
|
|
||||||
|
|
||||||
const repoPath = path.dirname(__dirname);
|
const repoPath = path.dirname(__dirname);
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
@@ -94,13 +91,3 @@ gulp.task('vscode-win32-ia32-archive', ['clean-vscode-win32-ia32-archive'], arch
|
|||||||
|
|
||||||
gulp.task('clean-vscode-win32-x64-archive', util.rimraf(zipDir('x64')));
|
gulp.task('clean-vscode-win32-x64-archive', util.rimraf(zipDir('x64')));
|
||||||
gulp.task('vscode-win32-x64-archive', ['clean-vscode-win32-x64-archive'], archiveWin32Setup('x64'));
|
gulp.task('vscode-win32-x64-archive', ['clean-vscode-win32-x64-archive'], archiveWin32Setup('x64'));
|
||||||
|
|
||||||
function copyInnoUpdater(arch) {
|
|
||||||
return () => {
|
|
||||||
return gulp.src('build/win32/{inno_updater.exe,vcruntime140.dll}', { base: 'build/win32' })
|
|
||||||
.pipe(vfs.dest(path.join(buildPath(arch), 'tools')));
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
gulp.task('vscode-win32-ia32-copy-inno-updater', copyInnoUpdater('ia32'));
|
|
||||||
gulp.task('vscode-win32-x64-copy-inno-updater', copyInnoUpdater('x64'));
|
|
||||||
@@ -1,118 +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 });
|
|
||||||
var path = require("path");
|
|
||||||
var es = require("event-stream");
|
|
||||||
var pickle = require("chromium-pickle-js");
|
|
||||||
var Filesystem = require("asar/lib/filesystem");
|
|
||||||
var VinylFile = require("vinyl");
|
|
||||||
var minimatch = require("minimatch");
|
|
||||||
function createAsar(folderPath, unpackGlobs, destFilename) {
|
|
||||||
var shouldUnpackFile = function (file) {
|
|
||||||
for (var i = 0; i < unpackGlobs.length; i++) {
|
|
||||||
if (minimatch(file.relative, unpackGlobs[i])) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
};
|
|
||||||
var filesystem = new Filesystem(folderPath);
|
|
||||||
var out = [];
|
|
||||||
// Keep track of pending inserts
|
|
||||||
var pendingInserts = 0;
|
|
||||||
var onFileInserted = function () { pendingInserts--; };
|
|
||||||
// Do not insert twice the same directory
|
|
||||||
var seenDir = {};
|
|
||||||
var insertDirectoryRecursive = function (dir) {
|
|
||||||
if (seenDir[dir]) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var lastSlash = dir.lastIndexOf('/');
|
|
||||||
if (lastSlash === -1) {
|
|
||||||
lastSlash = dir.lastIndexOf('\\');
|
|
||||||
}
|
|
||||||
if (lastSlash !== -1) {
|
|
||||||
insertDirectoryRecursive(dir.substring(0, lastSlash));
|
|
||||||
}
|
|
||||||
seenDir[dir] = true;
|
|
||||||
filesystem.insertDirectory(dir);
|
|
||||||
};
|
|
||||||
var insertDirectoryForFile = function (file) {
|
|
||||||
var lastSlash = file.lastIndexOf('/');
|
|
||||||
if (lastSlash === -1) {
|
|
||||||
lastSlash = file.lastIndexOf('\\');
|
|
||||||
}
|
|
||||||
if (lastSlash !== -1) {
|
|
||||||
insertDirectoryRecursive(file.substring(0, lastSlash));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
var insertFile = function (relativePath, stat, shouldUnpack) {
|
|
||||||
insertDirectoryForFile(relativePath);
|
|
||||||
pendingInserts++;
|
|
||||||
filesystem.insertFile(relativePath, shouldUnpack, { stat: stat }, {}, onFileInserted);
|
|
||||||
};
|
|
||||||
return es.through(function (file) {
|
|
||||||
if (file.stat.isDirectory()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (!file.stat.isFile()) {
|
|
||||||
throw new Error("unknown item in stream!");
|
|
||||||
}
|
|
||||||
var shouldUnpack = shouldUnpackFile(file);
|
|
||||||
insertFile(file.relative, { size: file.contents.length, mode: file.stat.mode }, shouldUnpack);
|
|
||||||
if (shouldUnpack) {
|
|
||||||
// The file goes outside of xx.asar, in a folder xx.asar.unpacked
|
|
||||||
var relative = path.relative(folderPath, file.path);
|
|
||||||
this.queue(new VinylFile({
|
|
||||||
cwd: folderPath,
|
|
||||||
base: folderPath,
|
|
||||||
path: path.join(destFilename + '.unpacked', relative),
|
|
||||||
stat: file.stat,
|
|
||||||
contents: file.contents
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
// The file goes inside of xx.asar
|
|
||||||
out.push(file.contents);
|
|
||||||
}
|
|
||||||
}, function () {
|
|
||||||
var _this = this;
|
|
||||||
var finish = function () {
|
|
||||||
{
|
|
||||||
var headerPickle = pickle.createEmpty();
|
|
||||||
headerPickle.writeString(JSON.stringify(filesystem.header));
|
|
||||||
var headerBuf = headerPickle.toBuffer();
|
|
||||||
var sizePickle = pickle.createEmpty();
|
|
||||||
sizePickle.writeUInt32(headerBuf.length);
|
|
||||||
var sizeBuf = sizePickle.toBuffer();
|
|
||||||
out.unshift(headerBuf);
|
|
||||||
out.unshift(sizeBuf);
|
|
||||||
}
|
|
||||||
var contents = Buffer.concat(out);
|
|
||||||
out.length = 0;
|
|
||||||
_this.queue(new VinylFile({
|
|
||||||
cwd: folderPath,
|
|
||||||
base: folderPath,
|
|
||||||
path: destFilename,
|
|
||||||
contents: contents
|
|
||||||
}));
|
|
||||||
_this.queue(null);
|
|
||||||
};
|
|
||||||
// Call finish() only when all file inserts have finished...
|
|
||||||
if (pendingInserts === 0) {
|
|
||||||
finish();
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
onFileInserted = function () {
|
|
||||||
pendingInserts--;
|
|
||||||
if (pendingInserts === 0) {
|
|
||||||
finish();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
exports.createAsar = createAsar;
|
|
||||||
@@ -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 path from 'path';
|
|
||||||
import * as es from 'event-stream';
|
|
||||||
import * as pickle from 'chromium-pickle-js';
|
|
||||||
import * as Filesystem from 'asar/lib/filesystem';
|
|
||||||
import * as VinylFile from 'vinyl';
|
|
||||||
import * as minimatch from 'minimatch';
|
|
||||||
|
|
||||||
export function createAsar(folderPath: string, unpackGlobs: string[], destFilename: string): NodeJS.ReadWriteStream {
|
|
||||||
|
|
||||||
const shouldUnpackFile = (file: VinylFile): boolean => {
|
|
||||||
for (let i = 0; i < unpackGlobs.length; i++) {
|
|
||||||
if (minimatch(file.relative, unpackGlobs[i])) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
};
|
|
||||||
|
|
||||||
const filesystem = new Filesystem(folderPath);
|
|
||||||
const out: Buffer[] = [];
|
|
||||||
|
|
||||||
// Keep track of pending inserts
|
|
||||||
let pendingInserts = 0;
|
|
||||||
let onFileInserted = () => { pendingInserts--; };
|
|
||||||
|
|
||||||
// Do not insert twice the same directory
|
|
||||||
const seenDir: { [key: string]: boolean; } = {};
|
|
||||||
const insertDirectoryRecursive = (dir: string) => {
|
|
||||||
if (seenDir[dir]) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let lastSlash = dir.lastIndexOf('/');
|
|
||||||
if (lastSlash === -1) {
|
|
||||||
lastSlash = dir.lastIndexOf('\\');
|
|
||||||
}
|
|
||||||
if (lastSlash !== -1) {
|
|
||||||
insertDirectoryRecursive(dir.substring(0, lastSlash));
|
|
||||||
}
|
|
||||||
seenDir[dir] = true;
|
|
||||||
filesystem.insertDirectory(dir);
|
|
||||||
};
|
|
||||||
|
|
||||||
const insertDirectoryForFile = (file: string) => {
|
|
||||||
let lastSlash = file.lastIndexOf('/');
|
|
||||||
if (lastSlash === -1) {
|
|
||||||
lastSlash = file.lastIndexOf('\\');
|
|
||||||
}
|
|
||||||
if (lastSlash !== -1) {
|
|
||||||
insertDirectoryRecursive(file.substring(0, lastSlash));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const insertFile = (relativePath: string, stat: { size: number; mode: number; }, shouldUnpack: boolean) => {
|
|
||||||
insertDirectoryForFile(relativePath);
|
|
||||||
pendingInserts++;
|
|
||||||
filesystem.insertFile(relativePath, shouldUnpack, { stat: stat }, {}, onFileInserted);
|
|
||||||
};
|
|
||||||
|
|
||||||
return es.through(function (file) {
|
|
||||||
if (file.stat.isDirectory()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (!file.stat.isFile()) {
|
|
||||||
throw new Error(`unknown item in stream!`);
|
|
||||||
}
|
|
||||||
const shouldUnpack = shouldUnpackFile(file);
|
|
||||||
insertFile(file.relative, { size: file.contents.length, mode: file.stat.mode }, shouldUnpack);
|
|
||||||
|
|
||||||
if (shouldUnpack) {
|
|
||||||
// The file goes outside of xx.asar, in a folder xx.asar.unpacked
|
|
||||||
const relative = path.relative(folderPath, file.path);
|
|
||||||
this.queue(new VinylFile({
|
|
||||||
cwd: folderPath,
|
|
||||||
base: folderPath,
|
|
||||||
path: path.join(destFilename + '.unpacked', relative),
|
|
||||||
stat: file.stat,
|
|
||||||
contents: file.contents
|
|
||||||
}));
|
|
||||||
} else {
|
|
||||||
// The file goes inside of xx.asar
|
|
||||||
out.push(file.contents);
|
|
||||||
}
|
|
||||||
}, function () {
|
|
||||||
|
|
||||||
let finish = () => {
|
|
||||||
{
|
|
||||||
const headerPickle = pickle.createEmpty();
|
|
||||||
headerPickle.writeString(JSON.stringify(filesystem.header));
|
|
||||||
const headerBuf = headerPickle.toBuffer();
|
|
||||||
|
|
||||||
const sizePickle = pickle.createEmpty();
|
|
||||||
sizePickle.writeUInt32(headerBuf.length);
|
|
||||||
const sizeBuf = sizePickle.toBuffer();
|
|
||||||
|
|
||||||
out.unshift(headerBuf);
|
|
||||||
out.unshift(sizeBuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
const contents = Buffer.concat(out);
|
|
||||||
out.length = 0;
|
|
||||||
|
|
||||||
this.queue(new VinylFile({
|
|
||||||
cwd: folderPath,
|
|
||||||
base: folderPath,
|
|
||||||
path: destFilename,
|
|
||||||
contents: contents
|
|
||||||
}));
|
|
||||||
this.queue(null);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Call finish() only when all file inserts have finished...
|
|
||||||
if (pendingInserts === 0) {
|
|
||||||
finish();
|
|
||||||
} else {
|
|
||||||
onFileInserted = () => {
|
|
||||||
pendingInserts--;
|
|
||||||
if (pendingInserts === 0) {
|
|
||||||
finish();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
@@ -1,122 +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';
|
|
||||||
|
|
||||||
const fs = require('fs');
|
|
||||||
const path = require('path');
|
|
||||||
const os = require('os');
|
|
||||||
const mkdirp = require('mkdirp');
|
|
||||||
const rimraf = require('rimraf');
|
|
||||||
const es = require('event-stream');
|
|
||||||
const rename = require('gulp-rename');
|
|
||||||
const vfs = require('vinyl-fs');
|
|
||||||
const ext = require('./extensions');
|
|
||||||
const util = require('gulp-util');
|
|
||||||
|
|
||||||
const root = path.dirname(path.dirname(__dirname));
|
|
||||||
// @ts-ignore Microsoft/TypeScript#21262 complains about a require of a JSON file
|
|
||||||
const builtInExtensions = require('../builtInExtensions.json');
|
|
||||||
const controlFilePath = path.join(os.homedir(), '.vscode-oss-dev', 'extensions', 'control.json');
|
|
||||||
|
|
||||||
function getExtensionPath(extension) {
|
|
||||||
return path.join(root, '.build', 'builtInExtensions', extension.name);
|
|
||||||
}
|
|
||||||
|
|
||||||
function isUpToDate(extension) {
|
|
||||||
const packagePath = path.join(getExtensionPath(extension), 'package.json');
|
|
||||||
|
|
||||||
if (!fs.existsSync(packagePath)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const packageContents = fs.readFileSync(packagePath, { encoding: 'utf8' });
|
|
||||||
|
|
||||||
try {
|
|
||||||
const diskVersion = JSON.parse(packageContents).version;
|
|
||||||
return (diskVersion === extension.version);
|
|
||||||
} catch (err) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function syncMarketplaceExtension(extension) {
|
|
||||||
if (isUpToDate(extension)) {
|
|
||||||
util.log(util.colors.blue('[marketplace]'), `${extension.name}@${extension.version}`, util.colors.green('✔︎'));
|
|
||||||
return es.readArray([]);
|
|
||||||
}
|
|
||||||
|
|
||||||
rimraf.sync(getExtensionPath(extension));
|
|
||||||
|
|
||||||
return ext.fromMarketplace(extension.name, extension.version)
|
|
||||||
.pipe(rename(p => p.dirname = `${extension.name}/${p.dirname}`))
|
|
||||||
.pipe(vfs.dest('.build/builtInExtensions'))
|
|
||||||
.on('end', () => util.log(util.colors.blue('[marketplace]'), extension.name, util.colors.green('✔︎')));
|
|
||||||
}
|
|
||||||
|
|
||||||
function syncExtension(extension, controlState) {
|
|
||||||
switch (controlState) {
|
|
||||||
case 'disabled':
|
|
||||||
util.log(util.colors.blue('[disabled]'), util.colors.gray(extension.name));
|
|
||||||
return es.readArray([]);
|
|
||||||
|
|
||||||
case 'marketplace':
|
|
||||||
return syncMarketplaceExtension(extension);
|
|
||||||
|
|
||||||
default:
|
|
||||||
if (!fs.existsSync(controlState)) {
|
|
||||||
util.log(util.colors.red(`Error: Built-in extension '${extension.name}' is configured to run from '${controlState}' but that path does not exist.`));
|
|
||||||
return es.readArray([]);
|
|
||||||
|
|
||||||
} else if (!fs.existsSync(path.join(controlState, 'package.json'))) {
|
|
||||||
util.log(util.colors.red(`Error: Built-in extension '${extension.name}' is configured to run from '${controlState}' but there is no 'package.json' file in that directory.`));
|
|
||||||
return es.readArray([]);
|
|
||||||
}
|
|
||||||
|
|
||||||
util.log(util.colors.blue('[local]'), `${extension.name}: ${util.colors.cyan(controlState)}`, util.colors.green('✔︎'));
|
|
||||||
return es.readArray([]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function readControlFile() {
|
|
||||||
try {
|
|
||||||
return JSON.parse(fs.readFileSync(controlFilePath, 'utf8'));
|
|
||||||
} catch (err) {
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function writeControlFile(control) {
|
|
||||||
mkdirp.sync(path.dirname(controlFilePath));
|
|
||||||
fs.writeFileSync(controlFilePath, JSON.stringify(control, null, 2));
|
|
||||||
}
|
|
||||||
|
|
||||||
function main() {
|
|
||||||
util.log('Syncronizing built-in extensions...');
|
|
||||||
util.log(`You can manage built-in extensions with the ${util.colors.cyan('--builtin')} flag`);
|
|
||||||
|
|
||||||
const control = readControlFile();
|
|
||||||
const streams = [];
|
|
||||||
|
|
||||||
for (const extension of builtInExtensions) {
|
|
||||||
let controlState = control[extension.name] || 'marketplace';
|
|
||||||
control[extension.name] = controlState;
|
|
||||||
|
|
||||||
streams.push(syncExtension(extension, controlState));
|
|
||||||
}
|
|
||||||
|
|
||||||
writeControlFile(control);
|
|
||||||
|
|
||||||
es.merge(streams)
|
|
||||||
.on('error', err => {
|
|
||||||
console.error(err);
|
|
||||||
process.exit(1);
|
|
||||||
})
|
|
||||||
.on('end', () => {
|
|
||||||
process.exit(0);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
main();
|
|
||||||
@@ -217,7 +217,6 @@ function removeDuplicateTSBoilerplate(destFiles) {
|
|||||||
{ start: /^var __metadata/, end: /^};$/ },
|
{ start: /^var __metadata/, end: /^};$/ },
|
||||||
{ start: /^var __param/, end: /^};$/ },
|
{ start: /^var __param/, end: /^};$/ },
|
||||||
{ start: /^var __awaiter/, end: /^};$/ },
|
{ start: /^var __awaiter/, end: /^};$/ },
|
||||||
{ start: /^var __generator/, end: /^};$/ },
|
|
||||||
];
|
];
|
||||||
destFiles.forEach(function (destFile) {
|
destFiles.forEach(function (destFile) {
|
||||||
var SEEN_BOILERPLATE = [];
|
var SEEN_BOILERPLATE = [];
|
||||||
|
|||||||
@@ -44,11 +44,11 @@ interface ILoaderPluginReqFunc {
|
|||||||
|
|
||||||
export interface IEntryPoint {
|
export interface IEntryPoint {
|
||||||
name: string;
|
name: string;
|
||||||
include?: string[];
|
include: string[];
|
||||||
exclude?: string[];
|
exclude: string[];
|
||||||
prepend: string[];
|
prepend: string[];
|
||||||
append?: string[];
|
append: string[];
|
||||||
dest?: string;
|
dest: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface IEntryPointMap {
|
interface IEntryPointMap {
|
||||||
@@ -339,7 +339,6 @@ function removeDuplicateTSBoilerplate(destFiles: IConcatFile[]): IConcatFile[] {
|
|||||||
{ start: /^var __metadata/, end: /^};$/ },
|
{ start: /^var __metadata/, end: /^};$/ },
|
||||||
{ start: /^var __param/, end: /^};$/ },
|
{ start: /^var __param/, end: /^};$/ },
|
||||||
{ start: /^var __awaiter/, end: /^};$/ },
|
{ start: /^var __awaiter/, end: /^};$/ },
|
||||||
{ start: /^var __generator/, end: /^};$/ },
|
|
||||||
];
|
];
|
||||||
|
|
||||||
destFiles.forEach((destFile) => {
|
destFiles.forEach((destFile) => {
|
||||||
|
|||||||
@@ -22,9 +22,6 @@ var rootDir = path.join(__dirname, '../../src');
|
|||||||
var options = require('../../src/tsconfig.json').compilerOptions;
|
var options = require('../../src/tsconfig.json').compilerOptions;
|
||||||
options.verbose = false;
|
options.verbose = false;
|
||||||
options.sourceMap = true;
|
options.sourceMap = true;
|
||||||
if (process.env['VSCODE_NO_SOURCEMAP']) {
|
|
||||||
options.sourceMap = false;
|
|
||||||
}
|
|
||||||
options.rootDir = rootDir;
|
options.rootDir = rootDir;
|
||||||
options.sourceRoot = util.toFileUri(rootDir);
|
options.sourceRoot = util.toFileUri(rootDir);
|
||||||
function createCompile(build, emitError) {
|
function createCompile(build, emitError) {
|
||||||
@@ -61,13 +58,9 @@ function compileTask(out, build) {
|
|||||||
return function () {
|
return function () {
|
||||||
var compile = createCompile(build, true);
|
var compile = createCompile(build, true);
|
||||||
var src = es.merge(gulp.src('src/**', { base: 'src' }), gulp.src('node_modules/typescript/lib/lib.d.ts'));
|
var src = es.merge(gulp.src('src/**', { base: 'src' }), gulp.src('node_modules/typescript/lib/lib.d.ts'));
|
||||||
// Do not write .d.ts files to disk, as they are not needed there.
|
|
||||||
var dtsFilter = util.filter(function (data) { return !/\.d\.ts$/.test(data.path); });
|
|
||||||
return src
|
return src
|
||||||
.pipe(compile())
|
.pipe(compile())
|
||||||
.pipe(dtsFilter)
|
|
||||||
.pipe(gulp.dest(out))
|
.pipe(gulp.dest(out))
|
||||||
.pipe(dtsFilter.restore)
|
|
||||||
.pipe(monacodtsTask(out, false));
|
.pipe(monacodtsTask(out, false));
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -77,19 +70,54 @@ function watchTask(out, build) {
|
|||||||
var compile = createCompile(build);
|
var compile = createCompile(build);
|
||||||
var src = es.merge(gulp.src('src/**', { base: 'src' }), gulp.src('node_modules/typescript/lib/lib.d.ts'));
|
var src = es.merge(gulp.src('src/**', { base: 'src' }), gulp.src('node_modules/typescript/lib/lib.d.ts'));
|
||||||
var watchSrc = watch('src/**', { base: 'src' });
|
var watchSrc = watch('src/**', { base: 'src' });
|
||||||
// Do not write .d.ts files to disk, as they are not needed there.
|
|
||||||
var dtsFilter = util.filter(function (data) { return !/\.d\.ts$/.test(data.path); });
|
|
||||||
return watchSrc
|
return watchSrc
|
||||||
.pipe(util.incremental(compile, src, true))
|
.pipe(util.incremental(compile, src, true))
|
||||||
.pipe(dtsFilter)
|
|
||||||
.pipe(gulp.dest(out))
|
.pipe(gulp.dest(out))
|
||||||
.pipe(dtsFilter.restore)
|
|
||||||
.pipe(monacodtsTask(out, true));
|
.pipe(monacodtsTask(out, true));
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
exports.watchTask = watchTask;
|
exports.watchTask = watchTask;
|
||||||
|
function reloadTypeScriptNodeModule() {
|
||||||
|
var util = require('gulp-util');
|
||||||
|
function log(message) {
|
||||||
|
var rest = [];
|
||||||
|
for (var _i = 1; _i < arguments.length; _i++) {
|
||||||
|
rest[_i - 1] = arguments[_i];
|
||||||
|
}
|
||||||
|
util.log.apply(util, [util.colors.cyan('[memory watch dog]'), message].concat(rest));
|
||||||
|
}
|
||||||
|
function heapUsed() {
|
||||||
|
return (process.memoryUsage().heapUsed / 1024 / 1024).toFixed(2) + ' MB';
|
||||||
|
}
|
||||||
|
return es.through(function (data) {
|
||||||
|
this.emit('data', data);
|
||||||
|
}, function () {
|
||||||
|
log('memory usage after compilation finished: ' + heapUsed());
|
||||||
|
// It appears we are running into some variant of
|
||||||
|
// https://bugs.chromium.org/p/v8/issues/detail?id=2073
|
||||||
|
//
|
||||||
|
// Even though all references are dropped, some
|
||||||
|
// optimized methods in the TS compiler end up holding references
|
||||||
|
// to the entire TypeScript language host (>600MB)
|
||||||
|
//
|
||||||
|
// The idea is to force v8 to drop references to these
|
||||||
|
// optimized methods, by "reloading" the typescript node module
|
||||||
|
log('Reloading typescript node module...');
|
||||||
|
var resolvedName = require.resolve('typescript');
|
||||||
|
var originalModule = require.cache[resolvedName];
|
||||||
|
delete require.cache[resolvedName];
|
||||||
|
var newExports = require('typescript');
|
||||||
|
require.cache[resolvedName] = originalModule;
|
||||||
|
for (var prop in newExports) {
|
||||||
|
if (newExports.hasOwnProperty(prop)) {
|
||||||
|
originalModule.exports[prop] = newExports[prop];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
log('typescript node module reloaded.');
|
||||||
|
this.emit('end');
|
||||||
|
});
|
||||||
|
}
|
||||||
function monacodtsTask(out, isWatch) {
|
function monacodtsTask(out, isWatch) {
|
||||||
var basePath = path.resolve(process.cwd(), out);
|
|
||||||
var neededFiles = {};
|
var neededFiles = {};
|
||||||
monacodts.getFilesToWatch(out).forEach(function (filePath) {
|
monacodts.getFilesToWatch(out).forEach(function (filePath) {
|
||||||
filePath = path.normalize(filePath);
|
filePath = path.normalize(filePath);
|
||||||
@@ -132,7 +160,7 @@ function monacodtsTask(out, isWatch) {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
resultStream = es.through(function (data) {
|
resultStream = es.through(function (data) {
|
||||||
var filePath = path.normalize(path.resolve(basePath, data.relative));
|
var filePath = path.normalize(data.path);
|
||||||
if (neededFiles[filePath]) {
|
if (neededFiles[filePath]) {
|
||||||
setInputFile(filePath, data.contents.toString());
|
setInputFile(filePath, data.contents.toString());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -25,9 +25,6 @@ const rootDir = path.join(__dirname, '../../src');
|
|||||||
const options = require('../../src/tsconfig.json').compilerOptions;
|
const options = require('../../src/tsconfig.json').compilerOptions;
|
||||||
options.verbose = false;
|
options.verbose = false;
|
||||||
options.sourceMap = true;
|
options.sourceMap = true;
|
||||||
if (process.env['VSCODE_NO_SOURCEMAP']) { // To be used by developers in a hurry
|
|
||||||
options.sourceMap = false;
|
|
||||||
}
|
|
||||||
options.rootDir = rootDir;
|
options.rootDir = rootDir;
|
||||||
options.sourceRoot = util.toFileUri(rootDir);
|
options.sourceRoot = util.toFileUri(rootDir);
|
||||||
|
|
||||||
@@ -52,6 +49,7 @@ function createCompile(build: boolean, emitError?: boolean): (token?: util.ICanc
|
|||||||
.pipe(tsFilter)
|
.pipe(tsFilter)
|
||||||
.pipe(util.loadSourcemaps())
|
.pipe(util.loadSourcemaps())
|
||||||
.pipe(ts(token))
|
.pipe(ts(token))
|
||||||
|
// .pipe(build ? reloadTypeScriptNodeModule() : es.through())
|
||||||
.pipe(noDeclarationsFilter)
|
.pipe(noDeclarationsFilter)
|
||||||
.pipe(build ? nls() : es.through())
|
.pipe(build ? nls() : es.through())
|
||||||
.pipe(noDeclarationsFilter.restore)
|
.pipe(noDeclarationsFilter.restore)
|
||||||
@@ -77,14 +75,9 @@ export function compileTask(out: string, build: boolean): () => NodeJS.ReadWrite
|
|||||||
gulp.src('node_modules/typescript/lib/lib.d.ts'),
|
gulp.src('node_modules/typescript/lib/lib.d.ts'),
|
||||||
);
|
);
|
||||||
|
|
||||||
// Do not write .d.ts files to disk, as they are not needed there.
|
|
||||||
const dtsFilter = util.filter(data => !/\.d\.ts$/.test(data.path));
|
|
||||||
|
|
||||||
return src
|
return src
|
||||||
.pipe(compile())
|
.pipe(compile())
|
||||||
.pipe(dtsFilter)
|
|
||||||
.pipe(gulp.dest(out))
|
.pipe(gulp.dest(out))
|
||||||
.pipe(dtsFilter.restore)
|
|
||||||
.pipe(monacodtsTask(out, false));
|
.pipe(monacodtsTask(out, false));
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -100,21 +93,61 @@ export function watchTask(out: string, build: boolean): () => NodeJS.ReadWriteSt
|
|||||||
);
|
);
|
||||||
const watchSrc = watch('src/**', { base: 'src' });
|
const watchSrc = watch('src/**', { base: 'src' });
|
||||||
|
|
||||||
// Do not write .d.ts files to disk, as they are not needed there.
|
|
||||||
const dtsFilter = util.filter(data => !/\.d\.ts$/.test(data.path));
|
|
||||||
|
|
||||||
return watchSrc
|
return watchSrc
|
||||||
.pipe(util.incremental(compile, src, true))
|
.pipe(util.incremental(compile, src, true))
|
||||||
.pipe(dtsFilter)
|
|
||||||
.pipe(gulp.dest(out))
|
.pipe(gulp.dest(out))
|
||||||
.pipe(dtsFilter.restore)
|
|
||||||
.pipe(monacodtsTask(out, true));
|
.pipe(monacodtsTask(out, true));
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
function monacodtsTask(out: string, isWatch: boolean): NodeJS.ReadWriteStream {
|
function reloadTypeScriptNodeModule(): NodeJS.ReadWriteStream {
|
||||||
|
var util = require('gulp-util');
|
||||||
|
function log(message: any, ...rest: any[]): void {
|
||||||
|
util.log(util.colors.cyan('[memory watch dog]'), message, ...rest);
|
||||||
|
}
|
||||||
|
|
||||||
const basePath = path.resolve(process.cwd(), out);
|
function heapUsed(): string {
|
||||||
|
return (process.memoryUsage().heapUsed / 1024 / 1024).toFixed(2) + ' MB';
|
||||||
|
}
|
||||||
|
|
||||||
|
return es.through(function (data) {
|
||||||
|
this.emit('data', data);
|
||||||
|
}, function () {
|
||||||
|
|
||||||
|
log('memory usage after compilation finished: ' + heapUsed());
|
||||||
|
|
||||||
|
// It appears we are running into some variant of
|
||||||
|
// https://bugs.chromium.org/p/v8/issues/detail?id=2073
|
||||||
|
//
|
||||||
|
// Even though all references are dropped, some
|
||||||
|
// optimized methods in the TS compiler end up holding references
|
||||||
|
// to the entire TypeScript language host (>600MB)
|
||||||
|
//
|
||||||
|
// The idea is to force v8 to drop references to these
|
||||||
|
// optimized methods, by "reloading" the typescript node module
|
||||||
|
|
||||||
|
log('Reloading typescript node module...');
|
||||||
|
|
||||||
|
var resolvedName = require.resolve('typescript');
|
||||||
|
|
||||||
|
var originalModule = require.cache[resolvedName];
|
||||||
|
delete require.cache[resolvedName];
|
||||||
|
var newExports = require('typescript');
|
||||||
|
require.cache[resolvedName] = originalModule;
|
||||||
|
|
||||||
|
for (var prop in newExports) {
|
||||||
|
if (newExports.hasOwnProperty(prop)) {
|
||||||
|
originalModule.exports[prop] = newExports[prop];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
log('typescript node module reloaded.');
|
||||||
|
|
||||||
|
this.emit('end');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function monacodtsTask(out: string, isWatch: boolean): NodeJS.ReadWriteStream {
|
||||||
|
|
||||||
const neededFiles: { [file: string]: boolean; } = {};
|
const neededFiles: { [file: string]: boolean; } = {};
|
||||||
monacodts.getFilesToWatch(out).forEach(function (filePath) {
|
monacodts.getFilesToWatch(out).forEach(function (filePath) {
|
||||||
@@ -163,7 +196,7 @@ function monacodtsTask(out: string, isWatch: boolean): NodeJS.ReadWriteStream {
|
|||||||
}
|
}
|
||||||
|
|
||||||
resultStream = es.through(function (data) {
|
resultStream = es.through(function (data) {
|
||||||
const filePath = path.normalize(path.resolve(basePath, data.relative));
|
const filePath = path.normalize(data.path);
|
||||||
if (neededFiles[filePath]) {
|
if (neededFiles[filePath]) {
|
||||||
setInputFile(filePath, data.contents.toString());
|
setInputFile(filePath, data.contents.toString());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,28 +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';
|
|
||||||
|
|
||||||
const fs = require('fs');
|
|
||||||
const path = require('path');
|
|
||||||
const root = path.dirname(path.dirname(__dirname));
|
|
||||||
|
|
||||||
function getElectronVersion() {
|
|
||||||
const yarnrc = fs.readFileSync(path.join(root, '.yarnrc'), 'utf8');
|
|
||||||
const target = /^target "(.*)"$/m.exec(yarnrc)[1];
|
|
||||||
|
|
||||||
return target;
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports.getElectronVersion = getElectronVersion;
|
|
||||||
|
|
||||||
// returns 0 if the right version of electron is in .build/electron
|
|
||||||
if (require.main === module) {
|
|
||||||
const version = getElectronVersion();
|
|
||||||
const versionFile = path.join(root, '.build', 'electron', 'version');
|
|
||||||
const isUpToDate = fs.existsSync(versionFile) && fs.readFileSync(versionFile, 'utf8') === `v${version}`;
|
|
||||||
|
|
||||||
process.exit(isUpToDate ? 0 : 1);
|
|
||||||
}
|
|
||||||
@@ -20,7 +20,7 @@ var vsce = require("vsce");
|
|||||||
var File = require("vinyl");
|
var File = require("vinyl");
|
||||||
function fromLocal(extensionPath) {
|
function fromLocal(extensionPath) {
|
||||||
var result = es.through();
|
var result = es.through();
|
||||||
vsce.listFiles({ cwd: extensionPath, packageManager: vsce.PackageManager.Yarn })
|
vsce.listFiles({ cwd: extensionPath })
|
||||||
.then(function (fileNames) {
|
.then(function (fileNames) {
|
||||||
var files = fileNames
|
var files = fileNames
|
||||||
.map(function (fileName) { return path.join(extensionPath, fileName); })
|
.map(function (fileName) { return path.join(extensionPath, fileName); })
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ import * as File from 'vinyl';
|
|||||||
export function fromLocal(extensionPath: string): Stream {
|
export function fromLocal(extensionPath: string): Stream {
|
||||||
const result = es.through();
|
const result = es.through();
|
||||||
|
|
||||||
vsce.listFiles({ cwd: extensionPath, packageManager: vsce.PackageManager.Yarn })
|
vsce.listFiles({ cwd: extensionPath })
|
||||||
.then(fileNames => {
|
.then(fileNames => {
|
||||||
const files = fileNames
|
const files = fileNames
|
||||||
.map(fileName => path.join(extensionPath, fileName))
|
.map(fileName => path.join(extensionPath, fileName))
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -46,6 +46,10 @@
|
|||||||
"name": "vs/workbench/parts/execution",
|
"name": "vs/workbench/parts/execution",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "vs/workbench/parts/explorers",
|
||||||
|
"project": "vscode-workbench"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "vs/workbench/parts/extensions",
|
"name": "vs/workbench/parts/extensions",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
@@ -67,11 +71,7 @@
|
|||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "vs/workbench/parts/localizations",
|
"name": "vs/workbench/parts/nps",
|
||||||
"project": "vscode-workbench"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "vs/workbench/parts/logs",
|
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -138,10 +138,6 @@
|
|||||||
"name": "vs/workbench/parts/welcome",
|
"name": "vs/workbench/parts/welcome",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"name": "vs/workbench/services/actions",
|
|
||||||
"project": "vscode-workbench"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "vs/workbench/services/configuration",
|
"name": "vs/workbench/services/configuration",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
@@ -150,10 +146,6 @@
|
|||||||
"name": "vs/workbench/services/crashReporter",
|
"name": "vs/workbench/services/crashReporter",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"name": "vs/workbench/services/dialogs",
|
|
||||||
"project": "vscode-workbench"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "vs/workbench/services/editor",
|
"name": "vs/workbench/services/editor",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
@@ -162,10 +154,6 @@
|
|||||||
"name": "vs/workbench/services/extensions",
|
"name": "vs/workbench/services/extensions",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"name": "vs/workbench/services/jsonschemas",
|
|
||||||
"project": "vscode-workbench"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "vs/workbench/services/files",
|
"name": "vs/workbench/services/files",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
@@ -174,6 +162,10 @@
|
|||||||
"name": "vs/workbench/services/keybinding",
|
"name": "vs/workbench/services/keybinding",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "vs/workbench/services/message",
|
||||||
|
"project": "vscode-workbench"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "vs/workbench/services/mode",
|
"name": "vs/workbench/services/mode",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
@@ -201,6 +193,10 @@
|
|||||||
{
|
{
|
||||||
"name": "vs/workbench/services/decorations",
|
"name": "vs/workbench/services/decorations",
|
||||||
"project": "vscode-workbench"
|
"project": "vscode-workbench"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "setup_messages",
|
||||||
|
"project": "vscode-workbench"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
1034
build/lib/i18n.ts
1034
build/lib/i18n.ts
File diff suppressed because it is too large
Load Diff
@@ -79,7 +79,7 @@ function isImportNode(node) {
|
|||||||
function fileFrom(file, contents, path) {
|
function fileFrom(file, contents, path) {
|
||||||
if (path === void 0) { path = file.path; }
|
if (path === void 0) { path = file.path; }
|
||||||
return new File({
|
return new File({
|
||||||
contents: Buffer.from(contents),
|
contents: new Buffer(contents),
|
||||||
base: file.base,
|
base: file.base,
|
||||||
cwd: file.cwd,
|
cwd: file.cwd,
|
||||||
path: path
|
path: path
|
||||||
|
|||||||
@@ -131,7 +131,7 @@ module nls {
|
|||||||
|
|
||||||
export function fileFrom(file: File, contents: string, path: string = file.path) {
|
export function fileFrom(file: File, contents: string, path: string = file.path) {
|
||||||
return new File({
|
return new File({
|
||||||
contents: Buffer.from(contents),
|
contents: new Buffer(contents),
|
||||||
base: file.base,
|
base: file.base,
|
||||||
cwd: file.cwd,
|
cwd: file.cwd,
|
||||||
path: path
|
path: path
|
||||||
|
|||||||
@@ -59,7 +59,7 @@ function loader(bundledFileHeader, bundleLoader) {
|
|||||||
this.emit('data', new VinylFile({
|
this.emit('data', new VinylFile({
|
||||||
path: 'fake',
|
path: 'fake',
|
||||||
base: '',
|
base: '',
|
||||||
contents: Buffer.from(bundledFileHeader)
|
contents: new Buffer(bundledFileHeader)
|
||||||
}));
|
}));
|
||||||
this.emit('data', data);
|
this.emit('data', data);
|
||||||
}
|
}
|
||||||
@@ -98,7 +98,7 @@ function toConcatStream(bundledFileHeader, sources, dest) {
|
|||||||
return new VinylFile({
|
return new VinylFile({
|
||||||
path: source.path ? root + '/' + source.path.replace(/\\/g, '/') : 'fake',
|
path: source.path ? root + '/' + source.path.replace(/\\/g, '/') : 'fake',
|
||||||
base: base,
|
base: base,
|
||||||
contents: Buffer.from(source.contents)
|
contents: new Buffer(source.contents)
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
return es.readArray(treatedSources)
|
return es.readArray(treatedSources)
|
||||||
@@ -141,7 +141,7 @@ function optimizeTask(opts) {
|
|||||||
bundleInfoArray.push(new VinylFile({
|
bundleInfoArray.push(new VinylFile({
|
||||||
path: 'bundleInfo.json',
|
path: 'bundleInfo.json',
|
||||||
base: '.',
|
base: '.',
|
||||||
contents: Buffer.from(JSON.stringify(result.bundleData, null, '\t'))
|
contents: new Buffer(JSON.stringify(result.bundleData, null, '\t'))
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
es.readArray(bundleInfoArray).pipe(bundleInfoStream);
|
es.readArray(bundleInfoArray).pipe(bundleInfoStream);
|
||||||
@@ -174,6 +174,7 @@ function optimizeTask(opts) {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
exports.optimizeTask = optimizeTask;
|
exports.optimizeTask = optimizeTask;
|
||||||
|
;
|
||||||
/**
|
/**
|
||||||
* Wrap around uglify and allow the preserveComments function
|
* Wrap around uglify and allow the preserveComments function
|
||||||
* to have a file "context" to include our copyright only once per file.
|
* to have a file "context" to include our copyright only once per file.
|
||||||
@@ -211,7 +212,8 @@ function uglifyWithCopyrights() {
|
|||||||
return stream.pipe(minify({
|
return stream.pipe(minify({
|
||||||
output: {
|
output: {
|
||||||
comments: preserveComments(f),
|
comments: preserveComments(f),
|
||||||
max_line_len: 1024
|
// linux tfs build agent is crashing, does this help?§
|
||||||
|
max_line_len: 3200000
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
}));
|
}));
|
||||||
@@ -236,3 +238,4 @@ function minifyTask(src, sourceMapBaseUrl) {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
exports.minifyTask = minifyTask;
|
exports.minifyTask = minifyTask;
|
||||||
|
;
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ function log(prefix: string, message: string): void {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
export function loaderConfig(emptyPaths?: string[]) {
|
export function loaderConfig(emptyPaths: string[]) {
|
||||||
const result = {
|
const result = {
|
||||||
paths: {
|
paths: {
|
||||||
'vs': 'out-build/vs',
|
'vs': 'out-build/vs',
|
||||||
@@ -73,7 +73,7 @@ function loader(bundledFileHeader: string, bundleLoader: boolean): NodeJS.ReadWr
|
|||||||
this.emit('data', new VinylFile({
|
this.emit('data', new VinylFile({
|
||||||
path: 'fake',
|
path: 'fake',
|
||||||
base: '',
|
base: '',
|
||||||
contents: Buffer.from(bundledFileHeader)
|
contents: new Buffer(bundledFileHeader)
|
||||||
}));
|
}));
|
||||||
this.emit('data', data);
|
this.emit('data', data);
|
||||||
} else {
|
} else {
|
||||||
@@ -117,7 +117,7 @@ function toConcatStream(bundledFileHeader: string, sources: bundle.IFile[], dest
|
|||||||
return new VinylFile({
|
return new VinylFile({
|
||||||
path: source.path ? root + '/' + source.path.replace(/\\/g, '/') : 'fake',
|
path: source.path ? root + '/' + source.path.replace(/\\/g, '/') : 'fake',
|
||||||
base: base,
|
base: base,
|
||||||
contents: Buffer.from(source.contents)
|
contents: new Buffer(source.contents)
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -165,7 +165,7 @@ export interface IOptimizeTaskOpts {
|
|||||||
/**
|
/**
|
||||||
* (languages to process)
|
* (languages to process)
|
||||||
*/
|
*/
|
||||||
languages: i18n.Language[];
|
languages: string[];
|
||||||
}
|
}
|
||||||
export function optimizeTask(opts: IOptimizeTaskOpts): () => NodeJS.ReadWriteStream {
|
export function optimizeTask(opts: IOptimizeTaskOpts): () => NodeJS.ReadWriteStream {
|
||||||
const entryPoints = opts.entryPoints;
|
const entryPoints = opts.entryPoints;
|
||||||
@@ -201,7 +201,7 @@ export function optimizeTask(opts: IOptimizeTaskOpts): () => NodeJS.ReadWriteStr
|
|||||||
bundleInfoArray.push(new VinylFile({
|
bundleInfoArray.push(new VinylFile({
|
||||||
path: 'bundleInfo.json',
|
path: 'bundleInfo.json',
|
||||||
base: '.',
|
base: '.',
|
||||||
contents: Buffer.from(JSON.stringify(result.bundleData, null, '\t'))
|
contents: new Buffer(JSON.stringify(result.bundleData, null, '\t'))
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
es.readArray(bundleInfoArray).pipe(bundleInfoStream);
|
es.readArray(bundleInfoArray).pipe(bundleInfoStream);
|
||||||
@@ -241,7 +241,7 @@ export function optimizeTask(opts: IOptimizeTaskOpts): () => NodeJS.ReadWriteStr
|
|||||||
}))
|
}))
|
||||||
.pipe(gulp.dest(out));
|
.pipe(gulp.dest(out));
|
||||||
};
|
};
|
||||||
}
|
};
|
||||||
|
|
||||||
declare class FileWithCopyright extends VinylFile {
|
declare class FileWithCopyright extends VinylFile {
|
||||||
public __hasOurCopyright: boolean;
|
public __hasOurCopyright: boolean;
|
||||||
@@ -287,7 +287,8 @@ function uglifyWithCopyrights(): NodeJS.ReadWriteStream {
|
|||||||
return stream.pipe(minify({
|
return stream.pipe(minify({
|
||||||
output: {
|
output: {
|
||||||
comments: preserveComments(<FileWithCopyright>f),
|
comments: preserveComments(<FileWithCopyright>f),
|
||||||
max_line_len: 1024
|
// linux tfs build agent is crashing, does this help?§
|
||||||
|
max_line_len: 3200000
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
}));
|
}));
|
||||||
@@ -295,7 +296,7 @@ function uglifyWithCopyrights(): NodeJS.ReadWriteStream {
|
|||||||
return es.duplex(input, output);
|
return es.duplex(input, output);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function minifyTask(src: string, sourceMapBaseUrl?: string): (cb: any) => void {
|
export function minifyTask(src: string, sourceMapBaseUrl: string): (cb: any) => void {
|
||||||
const sourceMappingURL = sourceMapBaseUrl && (f => `${sourceMapBaseUrl}/${f.relative}.map`);
|
const sourceMappingURL = sourceMapBaseUrl && (f => `${sourceMapBaseUrl}/${f.relative}.map`);
|
||||||
|
|
||||||
return cb => {
|
return cb => {
|
||||||
@@ -326,4 +327,4 @@ export function minifyTask(src: string, sourceMapBaseUrl?: string): (cb: any) =>
|
|||||||
cb(err);
|
cb(err);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
}
|
};
|
||||||
|
|||||||
@@ -88,11 +88,10 @@ var NoUnexternalizedStringsRuleWalker = /** @class */ (function (_super) {
|
|||||||
var info = this.findDescribingParent(node);
|
var info = this.findDescribingParent(node);
|
||||||
// Ignore strings in import and export nodes.
|
// Ignore strings in import and export nodes.
|
||||||
if (info && info.isImport && doubleQuoted) {
|
if (info && info.isImport && doubleQuoted) {
|
||||||
var fix = [
|
this.addFailureAtNode(node, NoUnexternalizedStringsRuleWalker.ImportFailureMessage, new Lint.Fix(NoUnexternalizedStringsRuleWalker.ImportFailureMessage, [
|
||||||
Lint.Replacement.replaceFromTo(node.getStart(), 1, '\''),
|
this.createReplacement(node.getStart(), 1, '\''),
|
||||||
Lint.Replacement.replaceFromTo(node.getStart() + text.length - 1, 1, '\''),
|
this.createReplacement(node.getStart() + text.length - 1, 1, '\''),
|
||||||
];
|
]));
|
||||||
this.addFailureAtNode(node, NoUnexternalizedStringsRuleWalker.ImportFailureMessage, fix);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var callInfo = info ? info.callInfo : null;
|
var callInfo = info ? info.callInfo : null;
|
||||||
@@ -102,9 +101,8 @@ var NoUnexternalizedStringsRuleWalker = /** @class */ (function (_super) {
|
|||||||
}
|
}
|
||||||
if (doubleQuoted && (!callInfo || callInfo.argIndex === -1 || !this.signatures[functionName])) {
|
if (doubleQuoted && (!callInfo || callInfo.argIndex === -1 || !this.signatures[functionName])) {
|
||||||
var s = node.getText();
|
var s = node.getText();
|
||||||
var fix = [
|
var replacement = new Lint.Replacement(node.getStart(), node.getWidth(), "nls.localize('KEY-" + s.substring(1, s.length - 1) + "', " + s + ")");
|
||||||
Lint.Replacement.replaceFromTo(node.getStart(), node.getWidth(), "nls.localize('KEY-" + s.substring(1, s.length - 1) + "', " + s + ")"),
|
var fix = new Lint.Fix('Unexternalitzed string', [replacement]);
|
||||||
];
|
|
||||||
this.addFailure(this.createFailure(node.getStart(), node.getWidth(), "Unexternalized string found: " + node.getText(), fix));
|
this.addFailure(this.createFailure(node.getStart(), node.getWidth(), "Unexternalized string found: " + node.getText(), fix));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -136,24 +134,16 @@ var NoUnexternalizedStringsRuleWalker = /** @class */ (function (_super) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var messageArg = callInfo.callExpression.arguments[this.messageIndex];
|
var messageArg = callInfo.argIndex === this.messageIndex
|
||||||
if (messageArg && messageArg.kind !== ts.SyntaxKind.StringLiteral) {
|
? callInfo.callExpression.arguments[this.messageIndex]
|
||||||
|
: null;
|
||||||
|
if (messageArg && messageArg !== node) {
|
||||||
this.addFailure(this.createFailure(messageArg.getStart(), messageArg.getWidth(), "Message argument to '" + callInfo.callExpression.expression.getText() + "' must be a string literal."));
|
this.addFailure(this.createFailure(messageArg.getStart(), messageArg.getWidth(), "Message argument to '" + callInfo.callExpression.expression.getText() + "' must be a string literal."));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
NoUnexternalizedStringsRuleWalker.prototype.recordKey = function (keyNode, messageNode) {
|
NoUnexternalizedStringsRuleWalker.prototype.recordKey = function (keyNode, messageNode) {
|
||||||
var text = keyNode.getText();
|
var text = keyNode.getText();
|
||||||
// We have an empty key
|
|
||||||
if (text.match(/(['"]) *\1/)) {
|
|
||||||
if (messageNode) {
|
|
||||||
this.addFailureAtNode(keyNode, "Key is empty for message: " + messageNode.getText());
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
this.addFailureAtNode(keyNode, "Key is empty.");
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var occurrences = this.usedKeys[text];
|
var occurrences = this.usedKeys[text];
|
||||||
if (!occurrences) {
|
if (!occurrences) {
|
||||||
occurrences = [];
|
occurrences = [];
|
||||||
@@ -186,7 +176,7 @@ var NoUnexternalizedStringsRuleWalker = /** @class */ (function (_super) {
|
|||||||
node = parent;
|
node = parent;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
NoUnexternalizedStringsRuleWalker.ImportFailureMessage = 'Do not use double quotes for imports.';
|
NoUnexternalizedStringsRuleWalker.ImportFailureMessage = 'Do not use double qoutes for imports.';
|
||||||
NoUnexternalizedStringsRuleWalker.DOUBLE_QUOTE = '"';
|
NoUnexternalizedStringsRuleWalker.DOUBLE_QUOTE = '"';
|
||||||
return NoUnexternalizedStringsRuleWalker;
|
return NoUnexternalizedStringsRuleWalker;
|
||||||
}(Lint.RuleWalker));
|
}(Lint.RuleWalker));
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ interface KeyMessagePair {
|
|||||||
|
|
||||||
class NoUnexternalizedStringsRuleWalker extends Lint.RuleWalker {
|
class NoUnexternalizedStringsRuleWalker extends Lint.RuleWalker {
|
||||||
|
|
||||||
private static ImportFailureMessage = 'Do not use double quotes for imports.';
|
private static ImportFailureMessage = 'Do not use double qoutes for imports.';
|
||||||
|
|
||||||
private static DOUBLE_QUOTE: string = '"';
|
private static DOUBLE_QUOTE: string = '"';
|
||||||
|
|
||||||
@@ -104,14 +104,13 @@ class NoUnexternalizedStringsRuleWalker extends Lint.RuleWalker {
|
|||||||
let info = this.findDescribingParent(node);
|
let info = this.findDescribingParent(node);
|
||||||
// Ignore strings in import and export nodes.
|
// Ignore strings in import and export nodes.
|
||||||
if (info && info.isImport && doubleQuoted) {
|
if (info && info.isImport && doubleQuoted) {
|
||||||
const fix = [
|
|
||||||
Lint.Replacement.replaceFromTo(node.getStart(), 1, '\''),
|
|
||||||
Lint.Replacement.replaceFromTo(node.getStart() + text.length - 1, 1, '\''),
|
|
||||||
];
|
|
||||||
this.addFailureAtNode(
|
this.addFailureAtNode(
|
||||||
node,
|
node,
|
||||||
NoUnexternalizedStringsRuleWalker.ImportFailureMessage,
|
NoUnexternalizedStringsRuleWalker.ImportFailureMessage,
|
||||||
fix
|
new Lint.Fix(NoUnexternalizedStringsRuleWalker.ImportFailureMessage, [
|
||||||
|
this.createReplacement(node.getStart(), 1, '\''),
|
||||||
|
this.createReplacement(node.getStart() + text.length - 1, 1, '\''),
|
||||||
|
])
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -123,9 +122,8 @@ class NoUnexternalizedStringsRuleWalker extends Lint.RuleWalker {
|
|||||||
|
|
||||||
if (doubleQuoted && (!callInfo || callInfo.argIndex === -1 || !this.signatures[functionName])) {
|
if (doubleQuoted && (!callInfo || callInfo.argIndex === -1 || !this.signatures[functionName])) {
|
||||||
const s = node.getText();
|
const s = node.getText();
|
||||||
const fix = [
|
const replacement = new Lint.Replacement(node.getStart(), node.getWidth(), `nls.localize('KEY-${s.substring(1, s.length - 1)}', ${s})`);
|
||||||
Lint.Replacement.replaceFromTo(node.getStart(), node.getWidth(), `nls.localize('KEY-${s.substring(1, s.length - 1)}', ${s})`),
|
const fix = new Lint.Fix('Unexternalitzed string', [replacement]);
|
||||||
];
|
|
||||||
this.addFailure(this.createFailure(node.getStart(), node.getWidth(), `Unexternalized string found: ${node.getText()}`, fix));
|
this.addFailure(this.createFailure(node.getStart(), node.getWidth(), `Unexternalized string found: ${node.getText()}`, fix));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -156,10 +154,10 @@ class NoUnexternalizedStringsRuleWalker extends Lint.RuleWalker {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
let messageArg: ts.Expression = callInfo.argIndex === this.messageIndex
|
||||||
const messageArg = callInfo.callExpression.arguments[this.messageIndex];
|
? callInfo.callExpression.arguments[this.messageIndex]
|
||||||
|
: null;
|
||||||
if (messageArg && messageArg.kind !== ts.SyntaxKind.StringLiteral) {
|
if (messageArg && messageArg !== node) {
|
||||||
this.addFailure(this.createFailure(
|
this.addFailure(this.createFailure(
|
||||||
messageArg.getStart(), messageArg.getWidth(),
|
messageArg.getStart(), messageArg.getWidth(),
|
||||||
`Message argument to '${callInfo.callExpression.expression.getText()}' must be a string literal.`));
|
`Message argument to '${callInfo.callExpression.expression.getText()}' must be a string literal.`));
|
||||||
@@ -169,15 +167,6 @@ class NoUnexternalizedStringsRuleWalker extends Lint.RuleWalker {
|
|||||||
|
|
||||||
private recordKey(keyNode: ts.StringLiteral, messageNode: ts.Node) {
|
private recordKey(keyNode: ts.StringLiteral, messageNode: ts.Node) {
|
||||||
let text = keyNode.getText();
|
let text = keyNode.getText();
|
||||||
// We have an empty key
|
|
||||||
if (text.match(/(['"]) *\1/)) {
|
|
||||||
if (messageNode) {
|
|
||||||
this.addFailureAtNode(keyNode, `Key is empty for message: ${messageNode.getText()}`);
|
|
||||||
} else {
|
|
||||||
this.addFailureAtNode(keyNode, `Key is empty.`);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let occurrences: KeyMessagePair[] = this.usedKeys[text];
|
let occurrences: KeyMessagePair[] = this.usedKeys[text];
|
||||||
if (!occurrences) {
|
if (!occurrences) {
|
||||||
occurrences = [];
|
occurrences = [];
|
||||||
|
|||||||
9
build/lib/typings/event-stream.d.ts
vendored
9
build/lib/typings/event-stream.d.ts
vendored
@@ -1,14 +1,7 @@
|
|||||||
declare module "event-stream" {
|
declare module "event-stream" {
|
||||||
import { Stream } from 'stream';
|
import { Stream } from 'stream';
|
||||||
import { ThroughStream as _ThroughStream} from 'through';
|
import { ThroughStream } from 'through';
|
||||||
import { MapStream } from 'map-stream';
|
import { MapStream } from 'map-stream';
|
||||||
import * as File from 'vinyl';
|
|
||||||
|
|
||||||
export interface ThroughStream extends _ThroughStream {
|
|
||||||
queue(data: File | null);
|
|
||||||
push(data: File | null);
|
|
||||||
paused: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
function merge(streams: Stream[]): ThroughStream;
|
function merge(streams: Stream[]): ThroughStream;
|
||||||
function merge(...streams: Stream[]): ThroughStream;
|
function merge(...streams: Stream[]): ThroughStream;
|
||||||
|
|||||||
@@ -143,7 +143,7 @@ function loadSourcemaps() {
|
|||||||
cb(null, f);
|
cb(null, f);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
f.contents = Buffer.from(contents.replace(/\/\/# sourceMappingURL=(.*)$/g, ''), 'utf8');
|
f.contents = new Buffer(contents.replace(/\/\/# sourceMappingURL=(.*)$/g, ''), 'utf8');
|
||||||
fs.readFile(path.join(path.dirname(f.path), lastMatch[1]), 'utf8', function (err, contents) {
|
fs.readFile(path.join(path.dirname(f.path), lastMatch[1]), 'utf8', function (err, contents) {
|
||||||
if (err) {
|
if (err) {
|
||||||
return cb(err);
|
return cb(err);
|
||||||
@@ -160,7 +160,7 @@ function stripSourceMappingURL() {
|
|||||||
var output = input
|
var output = input
|
||||||
.pipe(es.mapSync(function (f) {
|
.pipe(es.mapSync(function (f) {
|
||||||
var contents = f.contents.toString('utf8');
|
var contents = f.contents.toString('utf8');
|
||||||
f.contents = Buffer.from(contents.replace(/\n\/\/# sourceMappingURL=(.*)$/gm, ''), 'utf8');
|
f.contents = new Buffer(contents.replace(/\n\/\/# sourceMappingURL=(.*)$/gm, ''), 'utf8');
|
||||||
return f;
|
return f;
|
||||||
}));
|
}));
|
||||||
return es.duplex(input, output);
|
return es.duplex(input, output);
|
||||||
@@ -173,6 +173,7 @@ function rimraf(dir) {
|
|||||||
if (!err) {
|
if (!err) {
|
||||||
return cb();
|
return cb();
|
||||||
}
|
}
|
||||||
|
;
|
||||||
if (err.code === 'ENOTEMPTY' && ++retries < 5) {
|
if (err.code === 'ENOTEMPTY' && ++retries < 5) {
|
||||||
return setTimeout(function () { return retry(cb); }, 10);
|
return setTimeout(function () { return retry(cb); }, 10);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ export interface IStreamProvider {
|
|||||||
(cancellationToken?: ICancellationToken): NodeJS.ReadWriteStream;
|
(cancellationToken?: ICancellationToken): NodeJS.ReadWriteStream;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function incremental(streamProvider: IStreamProvider, initial: NodeJS.ReadWriteStream, supportsCancellation?: boolean): NodeJS.ReadWriteStream {
|
export function incremental(streamProvider: IStreamProvider, initial: NodeJS.ReadWriteStream, supportsCancellation: boolean): NodeJS.ReadWriteStream {
|
||||||
const input = es.through();
|
const input = es.through();
|
||||||
const output = es.through();
|
const output = es.through();
|
||||||
let state = 'idle';
|
let state = 'idle';
|
||||||
@@ -129,7 +129,7 @@ export function skipDirectories(): NodeJS.ReadWriteStream {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function cleanNodeModule(name: string, excludes: string[], includes?: string[]): NodeJS.ReadWriteStream {
|
export function cleanNodeModule(name: string, excludes: string[], includes: string[]): NodeJS.ReadWriteStream {
|
||||||
const toGlob = (path: string) => '**/node_modules/' + name + (path ? '/' + path : '');
|
const toGlob = (path: string) => '**/node_modules/' + name + (path ? '/' + path : '');
|
||||||
const negate = (str: string) => '!' + str;
|
const negate = (str: string) => '!' + str;
|
||||||
|
|
||||||
@@ -190,7 +190,7 @@ export function loadSourcemaps(): NodeJS.ReadWriteStream {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
f.contents = Buffer.from(contents.replace(/\/\/# sourceMappingURL=(.*)$/g, ''), 'utf8');
|
f.contents = new Buffer(contents.replace(/\/\/# sourceMappingURL=(.*)$/g, ''), 'utf8');
|
||||||
|
|
||||||
fs.readFile(path.join(path.dirname(f.path), lastMatch[1]), 'utf8', (err, contents) => {
|
fs.readFile(path.join(path.dirname(f.path), lastMatch[1]), 'utf8', (err, contents) => {
|
||||||
if (err) { return cb(err); }
|
if (err) { return cb(err); }
|
||||||
@@ -209,7 +209,7 @@ export function stripSourceMappingURL(): NodeJS.ReadWriteStream {
|
|||||||
const output = input
|
const output = input
|
||||||
.pipe(es.mapSync<VinylFile, VinylFile>(f => {
|
.pipe(es.mapSync<VinylFile, VinylFile>(f => {
|
||||||
const contents = (<Buffer>f.contents).toString('utf8');
|
const contents = (<Buffer>f.contents).toString('utf8');
|
||||||
f.contents = Buffer.from(contents.replace(/\n\/\/# sourceMappingURL=(.*)$/gm, ''), 'utf8');
|
f.contents = new Buffer(contents.replace(/\n\/\/# sourceMappingURL=(.*)$/gm, ''), 'utf8');
|
||||||
return f;
|
return f;
|
||||||
}));
|
}));
|
||||||
|
|
||||||
@@ -223,7 +223,7 @@ export function rimraf(dir: string): (cb: any) => void {
|
|||||||
_rimraf(dir, { maxBusyTries: 1 }, (err: any) => {
|
_rimraf(dir, { maxBusyTries: 1 }, (err: any) => {
|
||||||
if (!err) {
|
if (!err) {
|
||||||
return cb();
|
return cb();
|
||||||
}
|
};
|
||||||
|
|
||||||
if (err.code === 'ENOTEMPTY' && ++retries < 5) {
|
if (err.code === 'ENOTEMPTY' && ++retries < 5) {
|
||||||
return setTimeout(() => retry(cb), 10);
|
return setTimeout(() => retry(cb), 10);
|
||||||
|
|||||||
1
build/lib/watch/.gitignore
vendored
1
build/lib/watch/.gitignore
vendored
@@ -1 +0,0 @@
|
|||||||
.yarnrc
|
|
||||||
@@ -9,7 +9,7 @@ const es = require('event-stream');
|
|||||||
function handleDeletions() {
|
function handleDeletions() {
|
||||||
return es.mapSync(f => {
|
return es.mapSync(f => {
|
||||||
if (/\.ts$/.test(f.relative) && !f.contents) {
|
if (/\.ts$/.test(f.relative) && !f.contents) {
|
||||||
f.contents = Buffer.from('');
|
f.contents = new Buffer('');
|
||||||
f.stat = { mtime: new Date() };
|
f.stat = { mtime: new Date() };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -30,12 +30,12 @@ function watch(root) {
|
|||||||
path: path,
|
path: path,
|
||||||
base: root
|
base: root
|
||||||
});
|
});
|
||||||
//@ts-ignore
|
|
||||||
file.event = type;
|
file.event = type;
|
||||||
result.emit('data', file);
|
result.emit('data', file);
|
||||||
}
|
}
|
||||||
|
|
||||||
nsfw(root, function (events) {
|
nsfw(root, function(events) {
|
||||||
for (var i = 0; i < events.length; i++) {
|
for (var i = 0; i < events.length; i++) {
|
||||||
var e = events[i];
|
var e = events[i];
|
||||||
var changeType = e.action;
|
var changeType = e.action;
|
||||||
@@ -47,16 +47,16 @@ function watch(root) {
|
|||||||
handleEvent(path.join(e.directory, e.file), toChangeType(changeType));
|
handleEvent(path.join(e.directory, e.file), toChangeType(changeType));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}).then(function (watcher) {
|
}).then(function(watcher) {
|
||||||
watcher.start();
|
watcher.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
var cache = Object.create(null);
|
var cache = Object.create(null);
|
||||||
|
|
||||||
module.exports = function (pattern, options) {
|
module.exports = function(pattern, options) {
|
||||||
options = options || {};
|
options = options || {};
|
||||||
|
|
||||||
var cwd = path.normalize(options.cwd || process.cwd());
|
var cwd = path.normalize(options.cwd || process.cwd());
|
||||||
@@ -66,7 +66,7 @@ module.exports = function (pattern, options) {
|
|||||||
watcher = cache[cwd] = watch(cwd);
|
watcher = cache[cwd] = watch(cwd);
|
||||||
}
|
}
|
||||||
|
|
||||||
var rebase = !options.base ? es.through() : es.mapSync(function (f) {
|
var rebase = !options.base ? es.through() : es.mapSync(function(f) {
|
||||||
f.base = options.base;
|
f.base = options.base;
|
||||||
return f;
|
return f;
|
||||||
});
|
});
|
||||||
@@ -74,13 +74,13 @@ module.exports = function (pattern, options) {
|
|||||||
return watcher
|
return watcher
|
||||||
.pipe(filter(['**', '!.git{,/**}'])) // ignore all things git
|
.pipe(filter(['**', '!.git{,/**}'])) // ignore all things git
|
||||||
.pipe(filter(pattern))
|
.pipe(filter(pattern))
|
||||||
.pipe(es.map(function (file, cb) {
|
.pipe(es.map(function(file, cb) {
|
||||||
fs.stat(file.path, function (err, stat) {
|
fs.stat(file.path, function(err, stat) {
|
||||||
if (err && err.code === 'ENOENT') { return cb(null, file); }
|
if (err && err.code === 'ENOENT') { return cb(null, file); }
|
||||||
if (err) { return cb(); }
|
if (err) { return cb(); }
|
||||||
if (!stat.isFile()) { return cb(); }
|
if (!stat.isFile()) { return cb(); }
|
||||||
|
|
||||||
fs.readFile(file.path, function (err, contents) {
|
fs.readFile(file.path, function(err, contents) {
|
||||||
if (err && err.code === 'ENOENT') { return cb(null, file); }
|
if (err && err.code === 'ENOENT') { return cb(null, file); }
|
||||||
if (err) { return cb(); }
|
if (err) { return cb(); }
|
||||||
|
|
||||||
|
|||||||
@@ -24,8 +24,7 @@ function watch(root) {
|
|||||||
var result = es.through();
|
var result = es.through();
|
||||||
var child = cp.spawn(watcherPath, [root]);
|
var child = cp.spawn(watcherPath, [root]);
|
||||||
|
|
||||||
child.stdout.on('data', function (data) {
|
child.stdout.on('data', function(data) {
|
||||||
// @ts-ignore
|
|
||||||
var lines = data.toString('utf8').split('\n');
|
var lines = data.toString('utf8').split('\n');
|
||||||
for (var i = 0; i < lines.length; i++) {
|
for (var i = 0; i < lines.length; i++) {
|
||||||
var line = lines[i].trim();
|
var line = lines[i].trim();
|
||||||
@@ -47,17 +46,17 @@ function watch(root) {
|
|||||||
path: changePathFull,
|
path: changePathFull,
|
||||||
base: root
|
base: root
|
||||||
});
|
});
|
||||||
//@ts-ignore
|
|
||||||
file.event = toChangeType(changeType);
|
file.event = toChangeType(changeType);
|
||||||
result.emit('data', file);
|
result.emit('data', file);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
child.stderr.on('data', function (data) {
|
child.stderr.on('data', function(data) {
|
||||||
result.emit('error', data);
|
result.emit('error', data);
|
||||||
});
|
});
|
||||||
|
|
||||||
child.on('exit', function (code) {
|
child.on('exit', function(code) {
|
||||||
result.emit('error', 'Watcher died with code ' + code);
|
result.emit('error', 'Watcher died with code ' + code);
|
||||||
child = null;
|
child = null;
|
||||||
});
|
});
|
||||||
@@ -71,7 +70,7 @@ function watch(root) {
|
|||||||
|
|
||||||
var cache = Object.create(null);
|
var cache = Object.create(null);
|
||||||
|
|
||||||
module.exports = function (pattern, options) {
|
module.exports = function(pattern, options) {
|
||||||
options = options || {};
|
options = options || {};
|
||||||
|
|
||||||
var cwd = path.normalize(options.cwd || process.cwd());
|
var cwd = path.normalize(options.cwd || process.cwd());
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -32,7 +32,7 @@ END OF winjs NOTICES AND INFORMATION
|
|||||||
|
|
||||||
%% string_scorer version 0.1.20 (https://github.com/joshaven/string_score)
|
%% string_scorer version 0.1.20 (https://github.com/joshaven/string_score)
|
||||||
=========================================
|
=========================================
|
||||||
This software is released under the Source EULA:
|
This software is released under the MIT license:
|
||||||
|
|
||||||
Copyright (c) Joshaven Potter
|
Copyright (c) Joshaven Potter
|
||||||
|
|
||||||
@@ -60,7 +60,7 @@ END OF string_scorer NOTICES AND INFORMATION
|
|||||||
|
|
||||||
%% chjj-marked NOTICES AND INFORMATION BEGIN HERE
|
%% chjj-marked NOTICES AND INFORMATION BEGIN HERE
|
||||||
=========================================
|
=========================================
|
||||||
The Source EULA
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) 2011-2014, Christopher Jeffrey (https://github.com/chjj/)
|
Copyright (c) 2011-2014, Christopher Jeffrey (https://github.com/chjj/)
|
||||||
|
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ declare module monaco.editor {
|
|||||||
#include(vs/editor/standalone/common/standaloneThemeService): BuiltinTheme, IStandaloneThemeData, IColors
|
#include(vs/editor/standalone/common/standaloneThemeService): BuiltinTheme, IStandaloneThemeData, IColors
|
||||||
#include(vs/editor/common/modes/supports/tokenization): ITokenThemeRule
|
#include(vs/editor/common/modes/supports/tokenization): ITokenThemeRule
|
||||||
#include(vs/editor/common/services/webWorker): MonacoWebWorker, IWebWorkerOptions
|
#include(vs/editor/common/services/webWorker): MonacoWebWorker, IWebWorkerOptions
|
||||||
#include(vs/editor/standalone/browser/standaloneCodeEditor): IActionDescriptor, IEditorConstructionOptions, IDiffEditorConstructionOptions, IStandaloneCodeEditor, IStandaloneDiffEditor
|
#include(vs/editor/standalone/browser/standaloneCodeEditor): IEditorConstructionOptions, IDiffEditorConstructionOptions, IStandaloneCodeEditor, IStandaloneDiffEditor
|
||||||
export interface ICommandHandler {
|
export interface ICommandHandler {
|
||||||
(...args:any[]): void;
|
(...args:any[]): void;
|
||||||
}
|
}
|
||||||
@@ -62,24 +62,19 @@ export interface ICommandHandler {
|
|||||||
#include(vs/editor/standalone/browser/colorizer): IColorizerOptions, IColorizerElementOptions
|
#include(vs/editor/standalone/browser/colorizer): IColorizerOptions, IColorizerElementOptions
|
||||||
#include(vs/base/common/scrollable): ScrollbarVisibility
|
#include(vs/base/common/scrollable): ScrollbarVisibility
|
||||||
#include(vs/platform/theme/common/themeService): ThemeColor
|
#include(vs/platform/theme/common/themeService): ThemeColor
|
||||||
#includeAll(vs/editor/common/model;LanguageIdentifier=>languages.LanguageIdentifier): IScrollEvent
|
#includeAll(vs/editor/common/editorCommon;IMode=>languages.IMode;LanguageIdentifier=>languages.LanguageIdentifier;editorOptions.=>): ISelection, IScrollEvent
|
||||||
#includeAll(vs/editor/common/editorCommon;editorOptions.=>): IScrollEvent
|
|
||||||
#includeAll(vs/editor/common/model/textModelEvents):
|
#includeAll(vs/editor/common/model/textModelEvents):
|
||||||
#includeAll(vs/editor/common/controller/cursorEvents):
|
#includeAll(vs/editor/common/controller/cursorEvents):
|
||||||
#includeAll(vs/editor/common/config/editorOptions):
|
#includeAll(vs/editor/common/config/editorOptions):
|
||||||
#includeAll(vs/editor/browser/editorBrowser;editorCommon.=>;editorOptions.=>):
|
#includeAll(vs/editor/browser/editorBrowser;editorCommon.=>;editorOptions.=>):
|
||||||
#include(vs/editor/common/config/fontInfo): FontInfo, BareFontInfo
|
#include(vs/editor/common/config/fontInfo): FontInfo, BareFontInfo
|
||||||
|
|
||||||
//compatibility:
|
|
||||||
export type IReadOnlyModel = ITextModel;
|
|
||||||
export type IModel = ITextModel;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
declare module monaco.languages {
|
declare module monaco.languages {
|
||||||
|
|
||||||
#includeAll(vs/editor/standalone/browser/standaloneLanguages;modes.=>;editorCommon.=>editor.;model.=>editor.;IMarkerData=>editor.IMarkerData):
|
#includeAll(vs/editor/standalone/browser/standaloneLanguages;modes.=>;editorCommon.=>editor.;IMarkerData=>editor.IMarkerData):
|
||||||
#includeAll(vs/editor/common/modes/languageConfiguration):
|
#includeAll(vs/editor/common/modes/languageConfiguration):
|
||||||
#includeAll(vs/editor/common/modes;editorCommon.IRange=>IRange;editorCommon.IPosition=>IPosition;editorCommon.=>editor.;IMarkerData=>editor.IMarkerData;model.=>editor.):
|
#includeAll(vs/editor/common/modes;editorCommon.IRange=>IRange;editorCommon.IPosition=>IPosition;editorCommon.=>editor.):
|
||||||
#include(vs/editor/common/services/modeService): ILanguageExtensionPoint
|
#include(vs/editor/common/services/modeService): ILanguageExtensionPoint
|
||||||
#includeAll(vs/editor/standalone/common/monarch/monarchTypes):
|
#includeAll(vs/editor/standalone/common/monarch/monarchTypes):
|
||||||
|
|
||||||
|
|||||||
@@ -11,5 +11,47 @@
|
|||||||
},
|
},
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/Microsoft/vscode/issues"
|
"url": "https://github.com/Microsoft/vscode/issues"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@types/minimist": "1.2.0",
|
||||||
|
"@types/mocha": "2.2.39",
|
||||||
|
"@types/semver": "5.3.30",
|
||||||
|
"@types/sinon": "1.16.34",
|
||||||
|
"debounce": "^1.0.0",
|
||||||
|
"eslint": "^3.4.0",
|
||||||
|
"event-stream": "^3.1.7",
|
||||||
|
"ghooks": "1.0.3",
|
||||||
|
"glob": "^5.0.13",
|
||||||
|
"gulp": "^3.8.9",
|
||||||
|
"gulp-bom": "^1.0.0",
|
||||||
|
"gulp-concat": "^2.6.0",
|
||||||
|
"gulp-cssnano": "^2.1.0",
|
||||||
|
"gulp-filter": "^3.0.0",
|
||||||
|
"gulp-flatmap": "^1.0.0",
|
||||||
|
"gulp-rename": "^1.2.0",
|
||||||
|
"gulp-sourcemaps": "^1.11.0",
|
||||||
|
"gulp-tsb": "^2.0.3",
|
||||||
|
"gulp-tslint": "^7.0.1",
|
||||||
|
"gulp-uglify": "^2.0.0",
|
||||||
|
"gulp-util": "^3.0.6",
|
||||||
|
"gulp-watch": "^4.3.9",
|
||||||
|
"is": "^3.1.0",
|
||||||
|
"istanbul": "^0.3.17",
|
||||||
|
"jsdom-no-contextify": "^3.1.0",
|
||||||
|
"lazy.js": "^0.4.2",
|
||||||
|
"minimatch": "^2.0.10",
|
||||||
|
"mocha": "^2.2.5",
|
||||||
|
"object-assign": "^4.0.1",
|
||||||
|
"pump": "^1.0.1",
|
||||||
|
"remap-istanbul": "^0.6.4",
|
||||||
|
"rimraf": "^2.2.8",
|
||||||
|
"sinon": "^1.17.2",
|
||||||
|
"source-map": "^0.4.4",
|
||||||
|
"tslint": "^4.3.1",
|
||||||
|
"typescript": "2.5.2",
|
||||||
|
"typescript-formatter": "4.0.1",
|
||||||
|
"underscore": "^1.8.2",
|
||||||
|
"vinyl": "^0.4.5",
|
||||||
|
"vscode-nls-dev": "^2.0.1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -5,15 +5,14 @@
|
|||||||
|
|
||||||
const cp = require('child_process');
|
const cp = require('child_process');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const fs = require('fs');
|
const npm = process.platform === 'win32' ? 'npm.cmd' : 'npm';
|
||||||
const yarn = process.platform === 'win32' ? 'yarn.cmd' : 'yarn';
|
|
||||||
|
|
||||||
function yarnInstall(location, opts) {
|
function npmInstall(location, opts) {
|
||||||
opts = opts || {};
|
opts = opts || {};
|
||||||
opts.cwd = location;
|
opts.cwd = location;
|
||||||
opts.stdio = 'inherit';
|
opts.stdio = 'inherit';
|
||||||
|
|
||||||
const result = cp.spawnSync(yarn, ['install'], opts);
|
const result = cp.spawnSync(npm, ['install'], opts);
|
||||||
|
|
||||||
if (result.error || result.status !== 0) {
|
if (result.error || result.status !== 0) {
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
@@ -21,45 +20,44 @@ function yarnInstall(location, opts) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
// {{SQL CARBON EDIT}}
|
||||||
yarnInstall('extensions'); // node modules shared by all extensions
|
const protocol = [
|
||||||
|
'jsonrpc',
|
||||||
|
'types',
|
||||||
|
'client'
|
||||||
|
];
|
||||||
|
|
||||||
|
protocol.forEach(item => npmInstall(`dataprotocol-node/${item}`));
|
||||||
|
|
||||||
|
// {{SQL CARBON EDIT}}
|
||||||
|
npmInstall('extensions-modules');
|
||||||
|
npmInstall('extensions'); // node modules shared by all extensions
|
||||||
|
|
||||||
const extensions = [
|
const extensions = [
|
||||||
'vscode-colorize-tests',
|
'vscode-colorize-tests',
|
||||||
|
'git',
|
||||||
'json',
|
'json',
|
||||||
'mssql',
|
'mssql',
|
||||||
'configuration-editing',
|
'configuration-editing',
|
||||||
'extension-editing',
|
'extension-editing',
|
||||||
'markdown',
|
'markdown',
|
||||||
'markdown-basics',
|
|
||||||
'git',
|
|
||||||
'merge-conflict',
|
'merge-conflict',
|
||||||
'insights-default',
|
'insights-default',
|
||||||
'account-provider-azure',
|
'account-provider-azure'
|
||||||
'agent'
|
|
||||||
];
|
];
|
||||||
|
|
||||||
extensions.forEach(extension => yarnInstall(`extensions/${extension}`));
|
extensions.forEach(extension => npmInstall(`extensions/${extension}`));
|
||||||
|
|
||||||
function yarnInstallBuildDependencies() {
|
function npmInstallBuildDependencies() {
|
||||||
// make sure we install the deps of build/lib/watch for the system installed
|
// make sure we install gulp watch for the system installed
|
||||||
// node, since that is the driver of gulp
|
// node, since that is the driver of gulp
|
||||||
//@ts-ignore
|
|
||||||
const env = Object.assign({}, process.env);
|
const env = Object.assign({}, process.env);
|
||||||
const watchPath = path.join(path.dirname(__dirname), 'lib', 'watch');
|
|
||||||
const yarnrcPath = path.join(watchPath, '.yarnrc');
|
|
||||||
|
|
||||||
const disturl = 'https://nodejs.org/download/release';
|
delete env['npm_config_disturl'];
|
||||||
const target = process.versions.node;
|
delete env['npm_config_target'];
|
||||||
const runtime = 'node';
|
delete env['npm_config_runtime'];
|
||||||
|
|
||||||
const yarnrc = `disturl "${disturl}"
|
npmInstall(path.join(path.dirname(__dirname), 'lib', 'watch'), { env });
|
||||||
target "${target}"
|
|
||||||
runtime "${runtime}"`;
|
|
||||||
|
|
||||||
fs.writeFileSync(yarnrcPath, yarnrc, 'utf8');
|
|
||||||
yarnInstall(watchPath, { env });
|
|
||||||
}
|
}
|
||||||
|
|
||||||
yarnInstall(`build`); // node modules required for build
|
npmInstall(`build`); // node modules required for build
|
||||||
yarnInstall('test/smoke'); // node modules required for smoketest
|
npmInstallBuildDependencies(); // node modules for watching, specific to host node version, not electron
|
||||||
yarnInstallBuildDependencies(); // node modules for watching, specific to host node version, not electron
|
|
||||||
@@ -3,21 +3,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.
|
||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
let err = false;
|
if (process.env['npm_config_disturl'] !== 'https://atom.io/download/electron') {
|
||||||
|
console.error("You can't use plain npm to install Code's dependencies.");
|
||||||
|
console.error(
|
||||||
|
/^win/.test(process.platform)
|
||||||
|
? "Please run '.\\scripts\\npm.bat install' instead."
|
||||||
|
: "Please run './scripts/npm.sh install' instead."
|
||||||
|
);
|
||||||
|
|
||||||
const major = parseInt(/^(\d+)\./.exec(process.versions.node)[1]);
|
|
||||||
|
|
||||||
if (major < 8) {
|
|
||||||
console.error('\033[1;31m*** Please use node>=8.\033[0;0m');
|
|
||||||
err = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!/yarn\.js$|yarnpkg$/.test(process.env['npm_execpath'])) {
|
|
||||||
console.error('\033[1;31m*** Please use yarn to install dependencies.\033[0;0m');
|
|
||||||
err = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (err) {
|
|
||||||
console.error('');
|
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
@@ -4,11 +4,9 @@
|
|||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
const cp = require('child_process');
|
const cp = require('child_process');
|
||||||
const fs = require('fs');
|
const npm = process.platform === 'win32' ? 'npm.cmd' : 'npm';
|
||||||
const path = require('path');
|
|
||||||
|
|
||||||
function updateGrammar(location) {
|
function updateGrammar(location) {
|
||||||
const npm = process.platform === 'win32' ? 'npm.cmd' : 'npm';
|
|
||||||
const result = cp.spawnSync(npm, ['run', 'update-grammar'], {
|
const result = cp.spawnSync(npm, ['run', 'update-grammar'], {
|
||||||
cwd: location,
|
cwd: location,
|
||||||
stdio: 'inherit'
|
stdio: 'inherit'
|
||||||
@@ -19,17 +17,50 @@ function updateGrammar(location) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const allExtensionFolders = fs.readdirSync('extensions');
|
const extensions = [
|
||||||
const extensions = allExtensionFolders.filter(e => {
|
// 'bat' Grammar no longer available
|
||||||
try {
|
'clojure',
|
||||||
let packageJSON = JSON.parse(fs.readFileSync(path.join('extensions', e, 'package.json')).toString());
|
'coffeescript',
|
||||||
return packageJSON && packageJSON.scripts && packageJSON.scripts['update-grammar'];
|
'cpp',
|
||||||
} catch (e) {
|
'csharp',
|
||||||
return false;
|
'css',
|
||||||
}
|
'diff',
|
||||||
});
|
'docker',
|
||||||
|
'fsharp',
|
||||||
console.log(`Updating ${extensions.length} grammars...`);
|
'gitsyntax',
|
||||||
|
'go',
|
||||||
|
'groovy',
|
||||||
|
'handlebars',
|
||||||
|
'hlsl',
|
||||||
|
'html',
|
||||||
|
'ini',
|
||||||
|
'java',
|
||||||
|
// 'javascript', updated through JavaScript
|
||||||
|
'json',
|
||||||
|
'less',
|
||||||
|
'lua',
|
||||||
|
'make',
|
||||||
|
'markdown',
|
||||||
|
'objective-c',
|
||||||
|
'perl',
|
||||||
|
'php',
|
||||||
|
// 'powershell', grammar not ready yet, @daviwil will ping when ready
|
||||||
|
'pug',
|
||||||
|
'python',
|
||||||
|
'r',
|
||||||
|
'razor',
|
||||||
|
'ruby',
|
||||||
|
'rust',
|
||||||
|
'scss',
|
||||||
|
'shaderlab',
|
||||||
|
'shellscript',
|
||||||
|
'sql',
|
||||||
|
'swift',
|
||||||
|
'typescript',
|
||||||
|
'vb',
|
||||||
|
'xml',
|
||||||
|
'yaml'
|
||||||
|
];
|
||||||
|
|
||||||
extensions.forEach(extension => updateGrammar(`extensions/${extension}`));
|
extensions.forEach(extension => updateGrammar(`extensions/${extension}`));
|
||||||
|
|
||||||
@@ -39,5 +70,4 @@ if (process.platform === 'win32') {
|
|||||||
cp.spawn('.\scripts\test-integration.bat', [], { env: process.env, stdio: 'inherit' });
|
cp.spawn('.\scripts\test-integration.bat', [], { env: process.env, stdio: 'inherit' });
|
||||||
} else {
|
} else {
|
||||||
cp.spawn('/bin/bash', ['./scripts/test-integration.sh'], { env: process.env, stdio: 'inherit' });
|
cp.spawn('/bin/bash', ['./scripts/test-integration.sh'], { env: process.env, stdio: 'inherit' });
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -14,19 +14,14 @@ var url = require('url');
|
|||||||
|
|
||||||
function getOptions(urlString) {
|
function getOptions(urlString) {
|
||||||
var _url = url.parse(urlString);
|
var _url = url.parse(urlString);
|
||||||
var headers = {
|
|
||||||
'User-Agent': 'VSCode'
|
|
||||||
};
|
|
||||||
var token = process.env['GITHUB_TOKEN'];
|
|
||||||
if (token) {
|
|
||||||
headers['Authorization'] = 'token ' + token
|
|
||||||
}
|
|
||||||
return {
|
return {
|
||||||
protocol: _url.protocol,
|
protocol: _url.protocol,
|
||||||
host: _url.host,
|
host: _url.host,
|
||||||
port: _url.port,
|
port: _url.port,
|
||||||
path: _url.path,
|
path: _url.path,
|
||||||
headers: headers
|
headers: {
|
||||||
|
'User-Agent': 'NodeJS'
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -37,16 +32,12 @@ function download(url, redirectCount) {
|
|||||||
response.on('data', function (data) {
|
response.on('data', function (data) {
|
||||||
content += data.toString();
|
content += data.toString();
|
||||||
}).on('end', function () {
|
}).on('end', function () {
|
||||||
if (response.statusCode === 403 && response.headers['x-ratelimit-remaining'] === '0') {
|
|
||||||
e('GitHub API rate exceeded. Set GITHUB_TOKEN environment variable to increase rate limit.');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let count = redirectCount || 0;
|
let count = redirectCount || 0;
|
||||||
if (count < 5 && response.statusCode >= 300 && response.statusCode <= 303 || response.statusCode === 307) {
|
if (count < 5 && response.statusCode >= 300 && response.statusCode <= 303 || response.statusCode === 307) {
|
||||||
let location = response.headers['location'];
|
let location = response.headers['location'];
|
||||||
if (location) {
|
if (location) {
|
||||||
console.log("Redirected " + url + " to " + location);
|
console.log("Redirected " + url + " to " + location);
|
||||||
download(location, count + 1).then(c, e);
|
download(location, count+1).then(c, e);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -68,13 +59,17 @@ function getCommitSha(repoId, repoPath) {
|
|||||||
commitDate: lastCommit.commit.author.date
|
commitDate: lastCommit.commit.author.date
|
||||||
});
|
});
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
return Promise.reject(new Error("Failed extracting the SHA: " + content));
|
console.error("Failed extracting the SHA: " + content);
|
||||||
|
return Promise.resolve(null);
|
||||||
}
|
}
|
||||||
|
}, function () {
|
||||||
|
console.error('Failed loading ' + commitInfo);
|
||||||
|
return Promise.resolve(null);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.update = function (repoId, repoPath, dest, modifyGrammar, version = 'master') {
|
exports.update = function (repoId, repoPath, dest, modifyGrammar) {
|
||||||
var contentPath = 'https://raw.githubusercontent.com/' + repoId + `/${version}/` + repoPath;
|
var contentPath = 'https://raw.githubusercontent.com/' + repoId + '/master/' + repoPath;
|
||||||
console.log('Reading from ' + contentPath);
|
console.log('Reading from ' + contentPath);
|
||||||
return download(contentPath).then(function (content) {
|
return download(contentPath).then(function (content) {
|
||||||
var ext = path.extname(repoPath);
|
var ext = path.extname(repoPath);
|
||||||
@@ -86,7 +81,8 @@ exports.update = function (repoId, repoPath, dest, modifyGrammar, version = 'mas
|
|||||||
} else if (ext === '.json') {
|
} else if (ext === '.json') {
|
||||||
grammar = JSON.parse(content);
|
grammar = JSON.parse(content);
|
||||||
} else {
|
} else {
|
||||||
return Promise.reject(new Error('Unknown file extension: ' + ext));
|
console.error('Unknown file extension: ' + ext);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
if (modifyGrammar) {
|
if (modifyGrammar) {
|
||||||
modifyGrammar(grammar);
|
modifyGrammar(grammar);
|
||||||
@@ -103,10 +99,8 @@ exports.update = function (repoId, repoPath, dest, modifyGrammar, version = 'mas
|
|||||||
if (info) {
|
if (info) {
|
||||||
result.version = 'https://github.com/' + repoId + '/commit/' + info.commitSha;
|
result.version = 'https://github.com/' + repoId + '/commit/' + info.commitSha;
|
||||||
}
|
}
|
||||||
|
for (let key in grammar) {
|
||||||
let keys = ['name', 'scopeName', 'comment', 'injections', 'patterns', 'repository'];
|
if (!result.hasOwnProperty(key)) {
|
||||||
for (let key of keys) {
|
|
||||||
if (grammar.hasOwnProperty(key)) {
|
|
||||||
result[key] = grammar[key];
|
result[key] = grammar[key];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -119,14 +113,11 @@ exports.update = function (repoId, repoPath, dest, modifyGrammar, version = 'mas
|
|||||||
console.log('Updated ' + path.basename(dest));
|
console.log('Updated ' + path.basename(dest));
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
return Promise.reject(e);
|
console.error(e);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
}, console.error).catch(e => {
|
}, console.error);
|
||||||
console.error(e);
|
|
||||||
process.exit(1);
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
if (path.basename(process.argv[1]) === 'update-grammar.js') {
|
if (path.basename(process.argv[1]) === 'update-grammar.js') {
|
||||||
|
|||||||
@@ -1,69 +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';
|
|
||||||
|
|
||||||
let i18n = require("../lib/i18n");
|
|
||||||
|
|
||||||
let fs = require("fs");
|
|
||||||
let path = require("path");
|
|
||||||
let vfs = require("vinyl-fs");
|
|
||||||
let rimraf = require('rimraf');
|
|
||||||
|
|
||||||
function update(idOrPath) {
|
|
||||||
if (!idOrPath) {
|
|
||||||
throw new Error('Argument must be the location of the localization extension.');
|
|
||||||
}
|
|
||||||
let locExtFolder = idOrPath;
|
|
||||||
if (/^\w{2}(-\w+)?$/.test(idOrPath)) {
|
|
||||||
locExtFolder = '../vscode-language-pack-' + idOrPath;
|
|
||||||
}
|
|
||||||
let locExtStat = fs.statSync(locExtFolder);
|
|
||||||
if (!locExtStat || !locExtStat.isDirectory) {
|
|
||||||
throw new Error('No directory found at ' + idOrPath);
|
|
||||||
}
|
|
||||||
let packageJSON = JSON.parse(fs.readFileSync(path.join(locExtFolder, 'package.json')).toString());
|
|
||||||
let contributes = packageJSON['contributes'];
|
|
||||||
if (!contributes) {
|
|
||||||
throw new Error('The extension must define a "localizations" contribution in the "package.json"');
|
|
||||||
}
|
|
||||||
let localizations = contributes['localizations'];
|
|
||||||
if (!localizations) {
|
|
||||||
throw new Error('The extension must define a "localizations" contribution of type array in the "package.json"');
|
|
||||||
}
|
|
||||||
|
|
||||||
localizations.forEach(function (localization) {
|
|
||||||
if (!localization.languageId || !localization.languageName || !localization.localizedLanguageName) {
|
|
||||||
throw new Error('Each localization contribution must define "languageId", "languageName" and "localizedLanguageName" properties.');
|
|
||||||
}
|
|
||||||
let server = localization.server || 'www.transifex.com';
|
|
||||||
let userName = localization.userName || 'api';
|
|
||||||
let apiToken = process.env.TRANSIFEX_API_TOKEN;
|
|
||||||
let languageId = localization.transifexId || localization.languageId;
|
|
||||||
let translationDataFolder = path.join(locExtFolder, 'translations');
|
|
||||||
|
|
||||||
if (fs.existsSync(translationDataFolder) && fs.existsSync(path.join(translationDataFolder, 'main.i18n.json'))) {
|
|
||||||
console.log('Clearing \'' + translationDataFolder + '\'...');
|
|
||||||
rimraf.sync(translationDataFolder);
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log('Downloading translations for \'' + languageId + '\' to \'' + translationDataFolder + '\'...');
|
|
||||||
const translationPaths = [];
|
|
||||||
i18n.pullI18nPackFiles(server, userName, apiToken, { id: languageId }, translationPaths)
|
|
||||||
.pipe(vfs.dest(translationDataFolder)).on('end', function () {
|
|
||||||
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') {
|
|
||||||
update(process.argv[2]);
|
|
||||||
}
|
|
||||||
@@ -11,19 +11,18 @@
|
|||||||
"@types/xml2js": "0.0.33",
|
"@types/xml2js": "0.0.33",
|
||||||
"azure-storage": "^2.1.0",
|
"azure-storage": "^2.1.0",
|
||||||
"decompress": "^4.2.0",
|
"decompress": "^4.2.0",
|
||||||
"documentdb": "1.13.0",
|
"documentdb": "^1.11.0",
|
||||||
"service-downloader": "github:anthonydresser/service-downloader#0.1.2",
|
"extensions-modules": "file:../extensions-modules",
|
||||||
"fs-extra-promise": "^1.0.1",
|
"fs-extra-promise": "^1.0.1",
|
||||||
"mime": "^1.3.4",
|
"mime": "^1.3.4",
|
||||||
"minimist": "^1.2.0",
|
"minimist": "^1.2.0",
|
||||||
"typescript": "2.6.1",
|
"typescript": "2.5.2",
|
||||||
"vscode": "^1.0.1",
|
"vscode": "^1.0.1",
|
||||||
"xml2js": "^0.4.17"
|
"xml2js": "^0.4.17"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"compile": "tsc -p tsconfig.build.json",
|
"compile": "tsc",
|
||||||
"watch": "tsc -p tsconfig.build.json --watch",
|
"watch": "tsc --watch",
|
||||||
"postinstall": "npm run compile",
|
"postinstall": "npm run compile"
|
||||||
"npmCheckJs": "tsc --noEmit"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,9 +6,6 @@ if [ -n "$AGENT_WORKFOLDER" ]
|
|||||||
then
|
then
|
||||||
export npm_config_cache="$AGENT_WORKFOLDER/npm-cache"
|
export npm_config_cache="$AGENT_WORKFOLDER/npm-cache"
|
||||||
echo "Using npm cache: $npm_config_cache"
|
echo "Using npm cache: $npm_config_cache"
|
||||||
|
|
||||||
export YARN_CACHE_FOLDER="$AGENT_WORKFOLDER/yarn-cache"
|
|
||||||
echo "Using yarn cache: $YARN_CACHE_FOLDER"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
SUMMARY="Task;Duration"$'\n'
|
SUMMARY="Task;Duration"$'\n'
|
||||||
|
|||||||
@@ -4,15 +4,23 @@
|
|||||||
*--------------------------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------------------------*/
|
||||||
|
|
||||||
const cp = require('child_process');
|
const cp = require('child_process');
|
||||||
|
const npm = process.platform === 'win32' ? 'npm.cmd' : 'npm';
|
||||||
|
|
||||||
function yarnInstall(package: string): void {
|
function npmInstall(package: string, args: string[]): void {
|
||||||
cp.execSync(`yarn add --no-lockfile ${package}`);
|
const result = cp.spawnSync(npm, ['install', package, ...args], {
|
||||||
|
stdio: 'inherit'
|
||||||
|
});
|
||||||
|
|
||||||
|
if (result.error || result.status !== 0) {
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const product = require('../../../product.json');
|
const product = require('../../../product.json');
|
||||||
const dependencies = product.dependencies || {} as { [name: string]: string; };
|
const dependencies = product.dependencies || {} as { [name: string]: string; };
|
||||||
|
const [, , ...args] = process.argv;
|
||||||
|
|
||||||
Object.keys(dependencies).forEach(name => {
|
Object.keys(dependencies).forEach(name => {
|
||||||
const url = dependencies[name];
|
const url = dependencies[name];
|
||||||
yarnInstall(url);
|
npmInstall(url, args);
|
||||||
});
|
});
|
||||||
@@ -4,15 +4,12 @@ set -e
|
|||||||
# setup nvm
|
# setup nvm
|
||||||
if [[ "$OSTYPE" == "darwin"* ]]; then
|
if [[ "$OSTYPE" == "darwin"* ]]; then
|
||||||
export NVM_DIR=~/.nvm
|
export NVM_DIR=~/.nvm
|
||||||
source $(brew --prefix nvm)/nvm.sh --no-use
|
source $(brew --prefix nvm)/nvm.sh
|
||||||
else
|
else
|
||||||
source $NVM_DIR/nvm.sh --no-use
|
source $NVM_DIR/nvm.sh
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# install node
|
# install node
|
||||||
NODE_VERSION=8.9.1
|
NODE_VERSION=7.10.0
|
||||||
nvm install $NODE_VERSION
|
nvm install $NODE_VERSION
|
||||||
nvm use $NODE_VERSION
|
nvm use $NODE_VERSION
|
||||||
|
|
||||||
# install yarn
|
|
||||||
npm i -g yarn
|
|
||||||
@@ -14,9 +14,8 @@ import * as mime from 'mime';
|
|||||||
import * as minimist from 'minimist';
|
import * as minimist from 'minimist';
|
||||||
import { DocumentClient, NewDocument } from 'documentdb';
|
import { DocumentClient, NewDocument } from 'documentdb';
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
if (process.argv.length < 6) {
|
||||||
if (process.argv.length < 9) {
|
console.error('Usage: node publish.js <product> <platform> <type> <name> <version> <commit> <is_update> <file>');
|
||||||
console.error('Usage: node publish.js <product_quality> <platform> <file_type> <file_name> <version> <is_update> <file> [commit_id]');
|
|
||||||
process.exit(-1);
|
process.exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -70,7 +69,6 @@ interface Asset {
|
|||||||
hash: string;
|
hash: string;
|
||||||
sha256hash: string;
|
sha256hash: string;
|
||||||
size: number;
|
size: number;
|
||||||
supportsFastUpdate?: boolean;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function createOrUpdate(commit: string, quality: string, platform: string, type: string, release: NewDocument, asset: Asset, isUpdate: boolean): Promise<void> {
|
function createOrUpdate(commit: string, quality: string, platform: string, type: string, release: NewDocument, asset: Asset, isUpdate: boolean): Promise<void> {
|
||||||
@@ -185,10 +183,21 @@ async function publish(commit: string, quality: string, platform: string, type:
|
|||||||
const blobService = azure.createBlobService(storageAccount, process.env['AZURE_STORAGE_ACCESS_KEY_2'])
|
const blobService = azure.createBlobService(storageAccount, process.env['AZURE_STORAGE_ACCESS_KEY_2'])
|
||||||
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
const mooncakeBlobService = azure.createBlobService(storageAccount, process.env['MOONCAKE_STORAGE_ACCESS_KEY'], `${storageAccount}.blob.core.chinacloudapi.cn`)
|
||||||
await assertContainer(blobService, quality);
|
.withFilter(new azure.ExponentialRetryPolicyFilter(20));
|
||||||
|
|
||||||
const blobExists = await doesAssetExist(blobService, quality, blobName);
|
// mooncake is fussy and far away, this is needed!
|
||||||
|
mooncakeBlobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
||||||
|
|
||||||
|
await Promise.all([
|
||||||
|
assertContainer(blobService, quality),
|
||||||
|
assertContainer(mooncakeBlobService, quality)
|
||||||
|
]);
|
||||||
|
|
||||||
|
const [blobExists, moooncakeBlobExists] = await Promise.all([
|
||||||
|
doesAssetExist(blobService, quality, blobName),
|
||||||
|
doesAssetExist(mooncakeBlobService, quality, blobName)
|
||||||
|
]);
|
||||||
|
|
||||||
const promises = [];
|
const promises = [];
|
||||||
|
|
||||||
@@ -196,38 +205,10 @@ async function publish(commit: string, quality: string, platform: string, type:
|
|||||||
promises.push(uploadBlob(blobService, quality, blobName, file));
|
promises.push(uploadBlob(blobService, quality, blobName, file));
|
||||||
}
|
}
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
if (!moooncakeBlobExists) {
|
||||||
if (process.env['MOONCAKE_STORAGE_ACCESS_KEY']) {
|
promises.push(uploadBlob(mooncakeBlobService, quality, blobName, file));
|
||||||
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!
|
|
||||||
mooncakeBlobService.defaultClientRequestTimeoutInMs = 10 * 60 * 1000;
|
|
||||||
|
|
||||||
await Promise.all([
|
|
||||||
assertContainer(blobService, quality),
|
|
||||||
assertContainer(mooncakeBlobService, quality)
|
|
||||||
]);
|
|
||||||
|
|
||||||
const [blobExists, moooncakeBlobExists] = await Promise.all([
|
|
||||||
doesAssetExist(blobService, quality, blobName),
|
|
||||||
doesAssetExist(mooncakeBlobService, quality, blobName)
|
|
||||||
]);
|
|
||||||
|
|
||||||
const promises = [];
|
|
||||||
|
|
||||||
if (!blobExists) {
|
|
||||||
promises.push(uploadBlob(blobService, quality, blobName, file));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!moooncakeBlobExists) {
|
|
||||||
promises.push(uploadBlob(mooncakeBlobService, quality, blobName, file));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
console.log('Skipping Mooncake publishing.');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (promises.length === 0) {
|
if (promises.length === 0) {
|
||||||
console.log(`Blob ${quality}, ${blobName} already exists, not publishing again.`);
|
console.log(`Blob ${quality}, ${blobName} already exists, not publishing again.`);
|
||||||
return;
|
return;
|
||||||
@@ -247,20 +228,12 @@ async function publish(commit: string, quality: string, platform: string, type:
|
|||||||
platform: platform,
|
platform: platform,
|
||||||
type: type,
|
type: type,
|
||||||
url: `${process.env['AZURE_CDN_URL']}/${quality}/${blobName}`,
|
url: `${process.env['AZURE_CDN_URL']}/${quality}/${blobName}`,
|
||||||
// {{SQL CARBON EDIT}}
|
mooncakeUrl: `${process.env['MOONCAKE_CDN_URL']}/${quality}/${blobName}`,
|
||||||
mooncakeUrl: process.env['MOONCAKE_CDN_URL'] ? `${process.env['MOONCAKE_CDN_URL']}/${quality}/${blobName}` : undefined,
|
|
||||||
hash: sha1hash,
|
hash: sha1hash,
|
||||||
sha256hash,
|
sha256hash,
|
||||||
size
|
size
|
||||||
};
|
};
|
||||||
|
|
||||||
// Remove this if we ever need to rollback fast updates for windows
|
|
||||||
if (/win32/.test(platform)) {
|
|
||||||
asset.supportsFastUpdate = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log('Asset:', JSON.stringify(asset, null, ' '));
|
|
||||||
|
|
||||||
const release = {
|
const release = {
|
||||||
id: commit,
|
id: commit,
|
||||||
timestamp: (new Date()).getTime(),
|
timestamp: (new Date()).getTime(),
|
||||||
@@ -288,11 +261,8 @@ function main(): void {
|
|||||||
boolean: ['upload-only']
|
boolean: ['upload-only']
|
||||||
});
|
});
|
||||||
|
|
||||||
// {{SQL CARBON EDIT}}
|
const [quality, platform, type, name, version, _isUpdate, file] = opts._;
|
||||||
let [quality, platform, type, name, version, _isUpdate, file, commit] = opts._;
|
const commit = execSync('git rev-parse HEAD', { encoding: 'utf8' }).trim();
|
||||||
if (!commit) {
|
|
||||||
commit = execSync('git rev-parse HEAD', { encoding: 'utf8' }).trim();
|
|
||||||
}
|
|
||||||
|
|
||||||
publish(commit, quality, platform, type, name, version, _isUpdate, file, opts).catch(err => {
|
publish(commit, quality, platform, type, name, version, _isUpdate, file, opts).catch(err => {
|
||||||
console.error(err);
|
console.error(err);
|
||||||
|
|||||||
@@ -14,14 +14,11 @@ VSO_PAT="$6"
|
|||||||
echo "machine monacotools.visualstudio.com password $VSO_PAT" > ~/.netrc
|
echo "machine monacotools.visualstudio.com password $VSO_PAT" > ~/.netrc
|
||||||
|
|
||||||
step "Install dependencies" \
|
step "Install dependencies" \
|
||||||
yarn
|
npm install
|
||||||
|
|
||||||
step "Hygiene" \
|
step "Hygiene" \
|
||||||
npm run gulp -- hygiene
|
npm run gulp -- hygiene
|
||||||
|
|
||||||
step "Monaco Editor Check" \
|
|
||||||
./node_modules/.bin/tsc -p ./src/tsconfig.monaco.json --noEmit
|
|
||||||
|
|
||||||
step "Mix in repository from vscode-distro" \
|
step "Mix in repository from vscode-distro" \
|
||||||
npm run gulp -- mixin
|
npm run gulp -- mixin
|
||||||
|
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
. ./scripts/env.sh
|
. ./scripts/env.sh
|
||||||
. ./build/tfs/common/common.sh
|
. ./build/tfs/common/common.sh
|
||||||
|
|
||||||
|
(cd $BUILD_SOURCESDIRECTORY/build/tfs/common && \
|
||||||
|
step "Install build dependencies" \
|
||||||
|
npm i)
|
||||||
|
|
||||||
REPO=`pwd`
|
REPO=`pwd`
|
||||||
ZIP=$REPO/../VSCode-darwin-selfsigned.zip
|
ZIP=$REPO/../VSCode-darwin-selfsigned.zip
|
||||||
UNSIGNEDZIP=$REPO/../VSCode-darwin-unsigned.zip
|
UNSIGNEDZIP=$REPO/../VSCode-darwin-unsigned.zip
|
||||||
|
|||||||
3
build/tfs/linux/.gitignore
vendored
3
build/tfs/linux/.gitignore
vendored
@@ -1,2 +1 @@
|
|||||||
pat
|
pat
|
||||||
*.js
|
|
||||||
@@ -5,7 +5,6 @@
|
|||||||
. ./build/tfs/common/common.sh
|
. ./build/tfs/common/common.sh
|
||||||
|
|
||||||
export ARCH="$1"
|
export ARCH="$1"
|
||||||
export npm_config_arch="$ARCH"
|
|
||||||
export VSCODE_MIXIN_PASSWORD="$2"
|
export VSCODE_MIXIN_PASSWORD="$2"
|
||||||
export AZURE_STORAGE_ACCESS_KEY="$3"
|
export AZURE_STORAGE_ACCESS_KEY="$3"
|
||||||
export AZURE_STORAGE_ACCESS_KEY_2="$4"
|
export AZURE_STORAGE_ACCESS_KEY_2="$4"
|
||||||
@@ -17,14 +16,11 @@ VSO_PAT="$8"
|
|||||||
echo "machine monacotools.visualstudio.com password $VSO_PAT" > ~/.netrc
|
echo "machine monacotools.visualstudio.com password $VSO_PAT" > ~/.netrc
|
||||||
|
|
||||||
step "Install dependencies" \
|
step "Install dependencies" \
|
||||||
yarn
|
npm install --arch=$ARCH --unsafe-perm
|
||||||
|
|
||||||
step "Hygiene" \
|
step "Hygiene" \
|
||||||
npm run gulp -- hygiene
|
npm run gulp -- hygiene
|
||||||
|
|
||||||
step "Monaco Editor Check" \
|
|
||||||
./node_modules/.bin/tsc -p ./src/tsconfig.monaco.json --noEmit
|
|
||||||
|
|
||||||
step "Mix in repository from vscode-distro" \
|
step "Mix in repository from vscode-distro" \
|
||||||
npm run gulp -- mixin
|
npm run gulp -- mixin
|
||||||
|
|
||||||
@@ -32,7 +28,7 @@ step "Get Electron" \
|
|||||||
npm run gulp -- "electron-$ARCH"
|
npm run gulp -- "electron-$ARCH"
|
||||||
|
|
||||||
step "Install distro dependencies" \
|
step "Install distro dependencies" \
|
||||||
node build/tfs/common/installDistro.js
|
node build/tfs/common/installDistro.js --arch=$ARCH
|
||||||
|
|
||||||
step "Build minified" \
|
step "Build minified" \
|
||||||
npm run gulp -- "vscode-linux-$ARCH-min"
|
npm run gulp -- "vscode-linux-$ARCH-min"
|
||||||
|
|||||||
@@ -1,42 +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 { DocumentClient } from 'documentdb';
|
|
||||||
|
|
||||||
interface Config {
|
|
||||||
id: string;
|
|
||||||
frozen: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
function createDefaultConfig(quality: string): Config {
|
|
||||||
return {
|
|
||||||
id: quality,
|
|
||||||
frozen: false
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function getConfig(quality: string): Promise<Config> {
|
|
||||||
const client = new DocumentClient(process.env['AZURE_DOCUMENTDB_ENDPOINT'], { masterKey: process.env['AZURE_DOCUMENTDB_MASTERKEY'] });
|
|
||||||
const collection = 'dbs/builds/colls/config';
|
|
||||||
const query = {
|
|
||||||
query: `SELECT TOP 1 * FROM c WHERE c.id = @quality`,
|
|
||||||
parameters: [
|
|
||||||
{ name: '@quality', value: quality }
|
|
||||||
]
|
|
||||||
};
|
|
||||||
|
|
||||||
return new Promise<Config>((c, e) => {
|
|
||||||
client.queryDocuments(collection, query).toArray((err, results) => {
|
|
||||||
if (err && err.code !== 409) { return e(err); }
|
|
||||||
|
|
||||||
c(!results || results.length === 0 ? createDefaultConfig(quality) : results[0] as any as Config);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
getConfig(process.argv[2])
|
|
||||||
.then(c => console.log(c.frozen), e => console.error(e));
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "PACKAGENAME",
|
|
||||||
"version": "PACKAGEVERSION",
|
|
||||||
"repositoryId": "REPOSITORYID",
|
|
||||||
"sourceUrl": "PACKAGEURL"
|
|
||||||
}
|
|
||||||
@@ -12,6 +12,10 @@ step "Build RPM package" \
|
|||||||
# step "Build snap package" \
|
# step "Build snap package" \
|
||||||
# npm run gulp -- "vscode-linux-$ARCH-build-snap"
|
# npm run gulp -- "vscode-linux-$ARCH-build-snap"
|
||||||
|
|
||||||
|
(cd $BUILD_SOURCESDIRECTORY/build/tfs/common && \
|
||||||
|
step "Install build dependencies" \
|
||||||
|
npm install --unsafe-perm)
|
||||||
|
|
||||||
# Variables
|
# Variables
|
||||||
PLATFORM_LINUX="linux-$ARCH"
|
PLATFORM_LINUX="linux-$ARCH"
|
||||||
PLATFORM_DEB="linux-deb-$ARCH"
|
PLATFORM_DEB="linux-deb-$ARCH"
|
||||||
@@ -51,29 +55,36 @@ step "Publish RPM package" \
|
|||||||
# SNAP_FILENAME="$(ls $REPO/.build/linux/snap/$ARCH/ | grep .snap)"
|
# SNAP_FILENAME="$(ls $REPO/.build/linux/snap/$ARCH/ | grep .snap)"
|
||||||
# SNAP_PATH="$REPO/.build/linux/snap/$ARCH/$SNAP_FILENAME"
|
# SNAP_PATH="$REPO/.build/linux/snap/$ARCH/$SNAP_FILENAME"
|
||||||
|
|
||||||
IS_FROZEN="$(node build/tfs/linux/frozen-check.js $VSCODE_QUALITY)"
|
|
||||||
|
|
||||||
if [ -z "$VSCODE_QUALITY" ]; then
|
if [ -z "$VSCODE_QUALITY" ]; then
|
||||||
echo "VSCODE_QUALITY is not set, skipping repo package publish"
|
echo "VSCODE_QUALITY is not set, skipping repo package publish"
|
||||||
elif [ "$IS_FROZEN" = "true" ]; then
|
|
||||||
echo "$VSCODE_QUALITY is frozen, skipping repo package publish"
|
|
||||||
else
|
else
|
||||||
if [ "$BUILD_SOURCEBRANCH" = "master" ] || [ "$BUILD_SOURCEBRANCH" = "refs/heads/master" ]; then
|
if [ "$BUILD_SOURCEBRANCH" = "master" ] || [ "$BUILD_SOURCEBRANCH" = "refs/heads/master" ]; then
|
||||||
if [[ $BUILD_QUEUEDBY = *"Project Collection Service Accounts"* || $BUILD_QUEUEDBY = *"Microsoft.VisualStudio.Services.TFS"* ]]; then
|
if [[ $BUILD_QUEUEDBY = *"Project Collection Service Accounts"* || $BUILD_QUEUEDBY = *"Microsoft.VisualStudio.Services.TFS"* ]]; then
|
||||||
|
# Get necessary information
|
||||||
|
pushd $REPO && COMMIT_HASH=$(git rev-parse HEAD) && popd
|
||||||
|
PACKAGE_NAME="$(ls $REPO/.build/linux/deb/$DEB_ARCH/deb/ | sed -e 's/_.*//g')"
|
||||||
|
DEB_URL="https://az764295.vo.msecnd.net/$VSCODE_QUALITY/$COMMIT_HASH/$DEB_FILENAME"
|
||||||
|
RPM_URL="https://az764295.vo.msecnd.net/$VSCODE_QUALITY/$COMMIT_HASH/$RPM_FILENAME"
|
||||||
|
PACKAGE_VERSION="$(ls $REPO/.build/linux/deb/$DEB_ARCH/deb/ | sed -e 's/code-[a-z]*_//g' -e 's/\_.*$//g')"
|
||||||
# Write config files needed by API, use eval to force environment variable expansion
|
# Write config files needed by API, use eval to force environment variable expansion
|
||||||
DIRNAME=$(dirname $(readlink -f $0))
|
DIRNAME=$(dirname $(readlink -f $0))
|
||||||
pushd $DIRNAME
|
pushd $DIRNAME
|
||||||
# Submit to apt repo
|
# Submit to apt repo
|
||||||
if [ "$DEB_ARCH" = "amd64" ]; then
|
if [ "$DEB_ARCH" = "amd64" ]; then
|
||||||
eval echo '{ \"server\": \"azure-apt-cat.cloudapp.net\", \"protocol\": \"https\", \"port\": \"443\", \"repositoryId\": \"58a4adf642421134a1a48d1a\", \"username\": \"$LINUX_REPO_USERNAME\", \"password\": \"$LINUX_REPO_PASSWORD\" }' > apt-config.json
|
eval echo '{ \"server\": \"azure-apt-cat.cloudapp.net\", \"protocol\": \"https\", \"port\": \"443\", \"repositoryId\": \"58a4adf642421134a1a48d1a\", \"username\": \"$LINUX_REPO_USERNAME\", \"password\": \"$LINUX_REPO_PASSWORD\" }' > apt-config.json
|
||||||
|
eval echo '{ \"name\": \"$PACKAGE_NAME\", \"version\": \"$PACKAGE_VERSION\", \"repositoryId\": \"58a4adf642421134a1a48d1a\", \"sourceUrl\": \"$DEB_URL\" }' > apt-addpkg.json
|
||||||
|
echo "Submitting apt-addpkg.json:"
|
||||||
|
cat apt-addpkg.json
|
||||||
|
|
||||||
step "Publish to repositories" \
|
step "Publish to repositories" \
|
||||||
./repoapi_client.sh -config apt-config.json -addfile $DEB_PATH
|
./repoapi_client.sh -config apt-config.json -addpkg apt-addpkg.json
|
||||||
fi
|
fi
|
||||||
# Submit to yum repo (disabled as it's manual until signing is automated)
|
# Submit to yum repo (disabled as it's manual until signing is automated)
|
||||||
# eval echo '{ \"server\": \"azure-apt-cat.cloudapp.net\", \"protocol\": \"https\", \"port\": \"443\", \"repositoryId\": \"58a4ae3542421134a1a48d1b\", \"username\": \"$LINUX_REPO_USERNAME\", \"password\": \"$LINUX_REPO_PASSWORD\" }' > yum-config.json
|
# eval echo '{ \"server\": \"azure-apt-cat.cloudapp.net\", \"protocol\": \"https\", \"port\": \"443\", \"repositoryId\": \"58a4ae3542421134a1a48d1b\", \"username\": \"$LINUX_REPO_USERNAME\", \"password\": \"$LINUX_REPO_PASSWORD\" }' > yum-config.json
|
||||||
|
# eval echo '{ \"name\": \"$PACKAGE_NAME\", \"version\": \"$PACKAGE_VERSION\", \"repositoryId\": \"58a4ae3542421134a1a48d1b\", \"sourceUrl\": \"$RPM_URL\" }' > yum-addpkg.json
|
||||||
# ./repoapi_client.sh -config yum-config.json -addfile $RPM_PATH
|
# echo "Submitting yum-addpkg.json:"
|
||||||
|
# cat yum-addpkg.json
|
||||||
|
# ./repoapi_client.sh -config yum-config.json -addpkg yum-addpkg.json
|
||||||
popd
|
popd
|
||||||
echo "To check repo publish status run ./repoapi_client.sh -config config.json -check <id>"
|
echo "To check repo publish status run ./repoapi_client.sh -config config.json -check <id>"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -2,9 +2,9 @@
|
|||||||
# This is a VERY basic script for Create/Delete operations on repos and packages
|
# This is a VERY basic script for Create/Delete operations on repos and packages
|
||||||
#
|
#
|
||||||
cmd=$1
|
cmd=$1
|
||||||
docDir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" # chrmarti: Changed to script's directory.
|
urls=urls.txt
|
||||||
packageJsonTemplate=$docDir/new_package.json.template
|
defaultPackageFile=new_package.json
|
||||||
repoJsonTemplate=$docDir/new_repo.json.template
|
defaultRepoFile=new_repo.json
|
||||||
|
|
||||||
function Bail
|
function Bail
|
||||||
{
|
{
|
||||||
@@ -24,21 +24,14 @@ function Usage {
|
|||||||
echo "$0 -config FILENAME -listrepos | -listpkgs | -addrepo FILENAME | -addpkg FILENAME |"
|
echo "$0 -config FILENAME -listrepos | -listpkgs | -addrepo FILENAME | -addpkg FILENAME |"
|
||||||
echo "-addpkgs FILENAME | -check ID | -delrepo REPOID | -delpkg PKGID"
|
echo "-addpkgs FILENAME | -check ID | -delrepo REPOID | -delpkg PKGID"
|
||||||
echo -e "\t-config FILENAME : JSON file containing API server name and creds"
|
echo -e "\t-config FILENAME : JSON file containing API server name and creds"
|
||||||
echo -e "Package Operations:"
|
echo -e "\t-listrepos : List repositories"
|
||||||
echo -e "\t-listpkgs [REGEX] : List packages, optionally filter by REGEX"
|
echo -e "\t-listpkgs [REGEX] : List packages, optionally filter by REGEX"
|
||||||
|
echo -e "\t-addrepo FILENAME : Create a new repo using the specified JSON file"
|
||||||
echo -e "\t-addpkg FILENAME : Add package to repo using the specified JSON file"
|
echo -e "\t-addpkg FILENAME : Add package to repo using the specified JSON file"
|
||||||
echo -e "\t-addpkgs FILENAME : Add packages to repo using urls contained in FILENAME"
|
echo -e "\t-addpkgs FILENAME : Add packages to repo using urls contained in FILENAME"
|
||||||
echo -e "\t-check ID : Check upload operation by ID"
|
echo -e "\t-check ID : Check upload operation by ID"
|
||||||
echo -e "\t-delpkg PKGID : Delete the specified package by ID"
|
|
||||||
echo -e "File Operations:"
|
|
||||||
echo -e "\t-uploadfile FILENAME: Upload FILENAME (does not publish) "
|
|
||||||
echo -e "\t-addfile FILENAME : Upload FILENAME AND publish to the repo"
|
|
||||||
echo -e "\t-listfiles : List uploaded files"
|
|
||||||
echo -e "\t-delfile FILEID : Delete uploaded file by ID"
|
|
||||||
echo -e "Repository Operations:"
|
|
||||||
echo -e "\t-listrepos : List repositories"
|
|
||||||
echo -e "\t-addrepo FILENAME : Create a new repo using the specified JSON file"
|
|
||||||
echo -e "\t-delrepo REPOID : Delete the specified repo by ID"
|
echo -e "\t-delrepo REPOID : Delete the specified repo by ID"
|
||||||
|
echo -e "\t-delpkg PKGID : Delete the specified package by ID"
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -91,136 +84,33 @@ function AddRepo
|
|||||||
{
|
{
|
||||||
repoFile=$1
|
repoFile=$1
|
||||||
if [ -z $repoFile ]; then
|
if [ -z $repoFile ]; then
|
||||||
Bail "Error: Must specify a JSON-formatted file. Reference $repoJsonTemplate"
|
Bail "Error: Must specify a JSON-formatted file. Reference $defaultRepoFile.template"
|
||||||
fi
|
fi
|
||||||
if [ ! -f $repoFile ]; then
|
if [ ! -f $repoFile ]; then
|
||||||
Bail "Error: Cannot create repo - $repoFile does not exist"
|
Bail "Error: Cannot create repo - $repoFile does not exist"
|
||||||
fi
|
fi
|
||||||
packageUrl=$(grep "url" $repoFile | head -n 1 | awk '{print $2}' | tr -d ',')
|
packageUrl=$(grep "url" $repoFile | head -n 1 | awk '{print $2}' | tr -d ',')
|
||||||
echo "Creating new repo on $server [$packageUrl]"
|
echo "Creating new repo on $server [$packageUrl]"
|
||||||
curl -i -k "$baseurl/v1/repositories" --data @$repoFile -H "Content-Type: application/json"
|
curl -i -k "$baseurl/v1/repositories" --data @./$repoFile -H "Content-Type: application/json"
|
||||||
echo ""
|
echo ""
|
||||||
}
|
}
|
||||||
|
|
||||||
# Upload AND publish the file
|
|
||||||
function AddFile
|
|
||||||
{
|
|
||||||
packageFile=$1
|
|
||||||
# Validity checks are performed by UploadFile
|
|
||||||
echo "Uploading package to $server [$packageFile]"
|
|
||||||
response=$(UploadFile $packageFile "true")
|
|
||||||
id=$(echo $response | jq -r ".id")
|
|
||||||
|
|
||||||
# Parse package metadata first to confirm it's a valid deb/rpm
|
|
||||||
# Needs to be performed in this function so we can use it to publish the package
|
|
||||||
jsonFile=$(WritePackageInfoToFile $packageFile)
|
|
||||||
|
|
||||||
sed -i "s/REPOSITORYID/$repositoryId/g" $jsonFile
|
|
||||||
# Replace the url field with fileId
|
|
||||||
sed -i "s/PACKAGEURL/$id/g" $jsonFile
|
|
||||||
sed -i "s/sourceUrl/fileId/g" $jsonFile
|
|
||||||
|
|
||||||
AddPackage $jsonFile
|
|
||||||
rm -f $jsonFile
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
# Upload a file
|
|
||||||
function UploadFile
|
|
||||||
{
|
|
||||||
packageFile=$1
|
|
||||||
quick=$2
|
|
||||||
if [ -z $packageFile ]; then
|
|
||||||
Bail "Error: Must specify the path to a file to upload "
|
|
||||||
fi
|
|
||||||
if [ ! -f $packageFile ]; then
|
|
||||||
Bail "Error: Cannot upload - $packageFile does not exist"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Additional validation and output if quick mode isn't enabled
|
|
||||||
# Basically, if this is part of a publish operation, these steps are handled elsewhere
|
|
||||||
if [ "$quick" != "true" ]; then
|
|
||||||
# Parse package metadata first to confirm it's a valid deb/rpm
|
|
||||||
jsonFile=$(WritePackageInfoToFile $packageFile)
|
|
||||||
rm -f $jsonFile
|
|
||||||
|
|
||||||
echo "Uploading package to $server [$packageFile]"
|
|
||||||
fi
|
|
||||||
curl -s -k -X POST -F file=@$packageFile "$baseurl/v1/files"
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
function ListFiles
|
|
||||||
{
|
|
||||||
curl -s -k "$baseurl/v1/files" | jq
|
|
||||||
}
|
|
||||||
|
|
||||||
function DeleteFile
|
|
||||||
{
|
|
||||||
fileId=$1
|
|
||||||
if [ -z "$fileId" ]; then
|
|
||||||
Bail "Error: Must specify an ID to delete"
|
|
||||||
fi
|
|
||||||
curl -s -X DELETE "$baseurl/v1/files/$fileId"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Upload a single package using the specified JSON file
|
# Upload a single package using the specified JSON file
|
||||||
function AddPackage
|
function AddPackage
|
||||||
{
|
{
|
||||||
packageFile=$1
|
packageFile=$1
|
||||||
if [ -z $packageFile ]; then
|
if [ -z $packageFile ]; then
|
||||||
Bail "Error: Must specify a JSON-formatted file. Reference $packageJsonTemplate"
|
Bail "Error: Must specify a JSON-formatted file. Reference $defaultPackageFile.template"
|
||||||
fi
|
fi
|
||||||
if [ ! -f $packageFile ]; then
|
if [ ! -f $packageFile ]; then
|
||||||
Bail "Error: Cannot add package - $packageFile does not exist"
|
Bail "Error: Cannot add package - $packageFile does not exist"
|
||||||
fi
|
fi
|
||||||
packageUrl=$(grep "sourceUrl" $packageFile | head -n 1 | awk '{print $2}')
|
packageUrl=$(grep "sourceUrl" $packageFile | head -n 1 | awk '{print $2}')
|
||||||
echo "Adding package to $server [$packageUrl]"
|
echo "Adding package to $server [$packageUrl]"
|
||||||
curl -i -k "$baseurl/v1/packages" --data @$packageFile -H "Content-Type: application/json"
|
curl -i -k "$baseurl/v1/packages" --data @./$packageFile -H "Content-Type: application/json"
|
||||||
echo ""
|
echo ""
|
||||||
}
|
}
|
||||||
|
|
||||||
# Gets the package name and version and writes it to a file
|
|
||||||
function WritePackageInfoToFile
|
|
||||||
{
|
|
||||||
packageFile=$1
|
|
||||||
tmpOut=$(mktemp)
|
|
||||||
if [ -z "$packageFile" ]; then
|
|
||||||
Bail "Error: Must specify path to a deb/rpm package"
|
|
||||||
elif [ ! -f "$packageFile" ]; then
|
|
||||||
Bail "Error: Specified file $packageFile does not exist"
|
|
||||||
fi
|
|
||||||
if dpkg -I $packageFile > $tmpOut 2> /dev/null; then
|
|
||||||
>&2 echo "File is deb format"
|
|
||||||
pkgName=$(grep "^\s*Package:" $tmpOut | awk '{print $2}')
|
|
||||||
pkgVer=$(grep "^\s*Version:" $tmpOut | awk '{print $2}')
|
|
||||||
elif rpm -qpi $packageFile > $tmpOut 2> /dev/null; then
|
|
||||||
>&2 echo "File is rpm format"
|
|
||||||
pkgName=$(egrep "^Name" $tmpOut | tr -d ':' | awk '{print $2}')
|
|
||||||
pkgVer=$(egrep "^Version" $tmpOut | tr -d ':' | awk '{print $2}')
|
|
||||||
else
|
|
||||||
rm -f $tmpOut
|
|
||||||
Bail "File is not a valid deb/rpm package $url"
|
|
||||||
fi
|
|
||||||
|
|
||||||
rm -f $tmpOut
|
|
||||||
if [ -z "$pkgName" ]; then
|
|
||||||
Bail "Unable to parse package name for $url"
|
|
||||||
elif [ -z "$pkgVer" ]; then
|
|
||||||
Bail "Unable to parse package version number for $url"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Create Package .json file
|
|
||||||
outJson=$(mktemp)
|
|
||||||
escapedUrl=$(echo "$url" | sed 's/\//\\\//g' | sed 's/\&/\\\&/g')
|
|
||||||
cp $packageJsonTemplate $outJson
|
|
||||||
sed -i "s/PACKAGENAME/$pkgName/g" $outJson
|
|
||||||
sed -i "s/PACKAGEVERSION/$pkgVer/g" $outJson
|
|
||||||
|
|
||||||
# Return path to json file
|
|
||||||
echo $outJson
|
|
||||||
}
|
|
||||||
|
|
||||||
# Upload a single package by dynamically creating a JSON file using a provided URL
|
# Upload a single package by dynamically creating a JSON file using a provided URL
|
||||||
function AddPackageByUrl
|
function AddPackageByUrl
|
||||||
{
|
{
|
||||||
@@ -229,20 +119,41 @@ function AddPackageByUrl
|
|||||||
Bail "Unable to publish package because no URL was specified"
|
Bail "Unable to publish package because no URL was specified"
|
||||||
fi
|
fi
|
||||||
tmpFile=$(mktemp)
|
tmpFile=$(mktemp)
|
||||||
|
tmpOut=$(mktemp)
|
||||||
if ! wget -q "$url" -O $tmpFile; then
|
if ! wget -q "$url" -O $tmpFile; then
|
||||||
rm -f $tmpFile
|
rm -f $tmpFile $tmpFile
|
||||||
Bail "Unable to download URL $url"
|
Bail "Unable to download URL $url"
|
||||||
|
elif dpkg -I $tmpFile > $tmpOut 2> /dev/null; then
|
||||||
|
echo "File is deb format"
|
||||||
|
pkgName=$(grep "^\s*Package:" $tmpOut | awk '{print $2}')
|
||||||
|
pkgVer=$(grep "^\s*Version:" $tmpOut | awk '{print $2}')
|
||||||
|
elif rpm -qpi $tmpFile > $tmpOut 2> /dev/null; then
|
||||||
|
echo "File is rpm format"
|
||||||
|
pkgName=$(egrep "^Name" $tmpOut | tr -d ':' | awk '{print $2}')
|
||||||
|
pkgVer=$(egrep "^Version" $tmpOut | tr -d ':' | awk '{print $2}')
|
||||||
|
else
|
||||||
|
rm -f $tmpFile $tmpOut
|
||||||
|
Bail "File is not a valid deb/rpm package $url"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -f $tmpFile $tmpOut
|
||||||
|
if [ -z "$pkgName" ]; then
|
||||||
|
Bail "Unable to parse package name for $url"
|
||||||
|
elif [ -z "$pkgVer" ]; then
|
||||||
|
Bail "Unable to parse package version number for $url"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
jsonFile=$(WritePackageInfoToFile $tmpFile)
|
|
||||||
# Create Package .json file
|
# Create Package .json file
|
||||||
escapedUrl=$(echo "$url" | sed 's/\//\\\//g' | sed 's/\&/\\\&/g')
|
escapedUrl=$(echo "$url" | sed 's/\//\\\//g' | sed 's/\&/\\\&/g')
|
||||||
sed -i "s/PACKAGEURL/$escapedUrl/g" $jsonFile
|
cp $defaultPackageFile.template $defaultPackageFile
|
||||||
sed -i "s/REPOSITORYID/$repositoryId/g" $jsonFile
|
sed -i "s/PACKAGENAME/$pkgName/g" $defaultPackageFile
|
||||||
|
sed -i "s/PACKAGEVERSION/$pkgVer/g" $defaultPackageFile
|
||||||
|
sed -i "s/PACKAGEURL/$escapedUrl/g" $defaultPackageFile
|
||||||
|
sed -i "s/REPOSITORYID/$repositoryId/g" $defaultPackageFile
|
||||||
# Perform Upload
|
# Perform Upload
|
||||||
AddPackage $jsonFile
|
AddPackage $defaultPackageFile
|
||||||
# Cleanup
|
# Cleanup
|
||||||
rm -f $jsonFile
|
rm -f $defaultPackageFile
|
||||||
}
|
}
|
||||||
|
|
||||||
# Upload multiple packages by reading urls line-by-line from the specified file
|
# Upload multiple packages by reading urls line-by-line from the specified file
|
||||||
@@ -269,7 +180,7 @@ function CheckUpload {
|
|||||||
if [ -z "$id" ]; then
|
if [ -z "$id" ]; then
|
||||||
Bail "Must specify an ID"
|
Bail "Must specify an ID"
|
||||||
fi
|
fi
|
||||||
curl -s -k $baseurl/v1/packages/queue/$id | jq
|
curl -k $baseurl/v1/packages/queue/$id
|
||||||
echo ""
|
echo ""
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -321,20 +232,6 @@ while (( "$#" )); do
|
|||||||
operation=AddPackages
|
operation=AddPackages
|
||||||
shift
|
shift
|
||||||
operand="$1"
|
operand="$1"
|
||||||
elif [[ "$1" == "-addfile" ]]; then
|
|
||||||
operation=AddFile
|
|
||||||
shift
|
|
||||||
operand="$1"
|
|
||||||
elif [[ "$1" == "-uploadfile" ]]; then
|
|
||||||
operation=UploadFile
|
|
||||||
shift
|
|
||||||
operand="$1"
|
|
||||||
elif [[ "$1" == "-listfiles" ]]; then
|
|
||||||
operation=ListFiles
|
|
||||||
elif [[ "$1" == "-delfile" ]]; then
|
|
||||||
operation=DeleteFile
|
|
||||||
shift
|
|
||||||
operand="$1"
|
|
||||||
elif [[ "$1" == "-check" ]]; then
|
elif [[ "$1" == "-check" ]]; then
|
||||||
operation=CheckUpload
|
operation=CheckUpload
|
||||||
shift
|
shift
|
||||||
|
|||||||
@@ -14,20 +14,15 @@ Param(
|
|||||||
|
|
||||||
# Set the right architecture
|
# Set the right architecture
|
||||||
$env:npm_config_arch="$arch"
|
$env:npm_config_arch="$arch"
|
||||||
$env:CHILD_CONCURRENCY="1"
|
|
||||||
|
|
||||||
step "Install dependencies" {
|
step "Install dependencies" {
|
||||||
exec { & yarn }
|
exec { & npm install }
|
||||||
}
|
}
|
||||||
|
|
||||||
step "Hygiene" {
|
step "Hygiene" {
|
||||||
exec { & npm run gulp -- hygiene }
|
exec { & npm run gulp -- hygiene }
|
||||||
}
|
}
|
||||||
|
|
||||||
step "Monaco Editor Check" {
|
|
||||||
exec { & .\node_modules\.bin\tsc -p .\src\tsconfig.monaco.json --noEmit }
|
|
||||||
}
|
|
||||||
|
|
||||||
$env:VSCODE_MIXIN_PASSWORD = $mixinPassword
|
$env:VSCODE_MIXIN_PASSWORD = $mixinPassword
|
||||||
step "Mix in repository from vscode-distro" {
|
step "Mix in repository from vscode-distro" {
|
||||||
exec { & npm run gulp -- mixin }
|
exec { & npm run gulp -- mixin }
|
||||||
@@ -45,10 +40,6 @@ step "Build minified" {
|
|||||||
exec { & npm run gulp -- "vscode-win32-$global:arch-min" }
|
exec { & npm run gulp -- "vscode-win32-$global:arch-min" }
|
||||||
}
|
}
|
||||||
|
|
||||||
step "Copy Inno updater" {
|
|
||||||
exec { & npm run gulp -- "vscode-win32-$global:arch-copy-inno-updater" }
|
|
||||||
}
|
|
||||||
|
|
||||||
# step "Create loader snapshot" {
|
# step "Create loader snapshot" {
|
||||||
# exec { & node build\lib\snapshotLoader.js --arch=$global:arch }
|
# exec { & node build\lib\snapshotLoader.js --arch=$global:arch }
|
||||||
# }
|
# }
|
||||||
|
|||||||
@@ -17,10 +17,9 @@ Param(
|
|||||||
|
|
||||||
# Set the right architecture
|
# Set the right architecture
|
||||||
$env:npm_config_arch="$arch"
|
$env:npm_config_arch="$arch"
|
||||||
$env:CHILD_CONCURRENCY="1"
|
|
||||||
|
|
||||||
step "Install dependencies" {
|
step "Install dependencies" {
|
||||||
exec { & yarn }
|
exec { & npm install }
|
||||||
}
|
}
|
||||||
|
|
||||||
step "Hygiene" {
|
step "Hygiene" {
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ $env:HOME=$env:USERPROFILE
|
|||||||
if (Test-Path env:AGENT_WORKFOLDER) {
|
if (Test-Path env:AGENT_WORKFOLDER) {
|
||||||
$env:HOME="${env:AGENT_WORKFOLDER}\home"
|
$env:HOME="${env:AGENT_WORKFOLDER}\home"
|
||||||
$env:npm_config_cache="${env:HOME}\npm-cache"
|
$env:npm_config_cache="${env:HOME}\npm-cache"
|
||||||
$env:YARN_CACHE_FOLDER="${env:HOME}\yarn-cache"
|
|
||||||
$env:npm_config_devdir="${env:HOME}\npm-devdir"
|
$env:npm_config_devdir="${env:HOME}\npm-devdir"
|
||||||
New-Item -Path "$env:HOME" -Type directory -Force | out-null
|
New-Item -Path "$env:HOME" -Type directory -Force | out-null
|
||||||
New-Item -Path "$env:npm_config_cache" -Type directory -Force | out-null
|
New-Item -Path "$env:npm_config_cache" -Type directory -Force | out-null
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
# install node
|
# install node
|
||||||
$env:Path = $env:NVM_HOME + ";" + $env:NVM_SYMLINK + ";" + $env:Path
|
$env:Path = $env:NVM_HOME + ";" + $env:NVM_SYMLINK + ";" + $env:Path
|
||||||
$NodeVersion = "8.9.1"
|
$NodeVersion = "7.10.0"
|
||||||
# nvm install $NodeVersion
|
nvm install $NodeVersion
|
||||||
# nvm use $NodeVersion
|
nvm use $NodeVersion
|
||||||
# npm install -g yarn
|
|
||||||
$env:Path = $env:NVM_HOME + "\v" + $NodeVersion + ";" + $env:Path
|
$env:Path = $env:NVM_HOME + "\v" + $NodeVersion + ";" + $env:Path
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
{
|
|
||||||
"extends": "./tsconfig.json",
|
|
||||||
"compilerOptions": {
|
|
||||||
"allowJs": false,
|
|
||||||
"checkJs": false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -7,12 +7,7 @@
|
|||||||
"preserveConstEnums": true,
|
"preserveConstEnums": true,
|
||||||
"sourceMap": false,
|
"sourceMap": false,
|
||||||
"experimentalDecorators": true,
|
"experimentalDecorators": true,
|
||||||
"newLine": "LF",
|
"newLine": "LF"
|
||||||
// enable JavaScript type checking for the language service
|
|
||||||
// use the tsconfig.build.json for compiling wich disable JavaScript
|
|
||||||
// type checking so that JavaScript file are not transpiled
|
|
||||||
"allowJs": true,
|
|
||||||
"checkJs": true
|
|
||||||
},
|
},
|
||||||
"exclude": [
|
"exclude": [
|
||||||
"node_modules/**"
|
"node_modules/**"
|
||||||
|
|||||||
@@ -2,13 +2,12 @@
|
|||||||
"rules": {
|
"rules": {
|
||||||
"no-unused-expression": true,
|
"no-unused-expression": true,
|
||||||
"no-duplicate-variable": true,
|
"no-duplicate-variable": true,
|
||||||
|
"no-unused-variable": true,
|
||||||
"curly": true,
|
"curly": true,
|
||||||
"class-name": true,
|
"class-name": true,
|
||||||
"semicolon": [
|
"semicolon": [
|
||||||
true,
|
|
||||||
"always"
|
"always"
|
||||||
],
|
],
|
||||||
"triple-equals": true
|
"triple-equals": true
|
||||||
},
|
}
|
||||||
"defaultSeverity": "warning"
|
|
||||||
}
|
}
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -19,7 +19,7 @@ OutputDir={#OutputDir}
|
|||||||
OutputBaseFilename=SqlOpsStudioSetup
|
OutputBaseFilename=SqlOpsStudioSetup
|
||||||
Compression=lzma
|
Compression=lzma
|
||||||
SolidCompression=yes
|
SolidCompression=yes
|
||||||
AppMutex={code:GetAppMutex}
|
AppMutex={#AppMutex}
|
||||||
SetupMutex={#AppMutex}setup
|
SetupMutex={#AppMutex}setup
|
||||||
WizardImageFile={#RepoDir}\resources\win32\inno-big.bmp
|
WizardImageFile={#RepoDir}\resources\win32\inno-big.bmp
|
||||||
WizardSmallImageFile={#RepoDir}\resources\win32\inno-small.bmp
|
WizardSmallImageFile={#RepoDir}\resources\win32\inno-small.bmp
|
||||||
@@ -48,16 +48,11 @@ Name: "simplifiedChinese"; MessagesFile: "{#RepoDir}\build\win32\i18n\Default.zh
|
|||||||
Name: "traditionalChinese"; MessagesFile: "{#RepoDir}\build\win32\i18n\Default.zh-tw.isl,{#RepoDir}\build\win32\i18n\messages.zh-tw.isl" {#LocalizedLanguageFile("cht")}
|
Name: "traditionalChinese"; MessagesFile: "{#RepoDir}\build\win32\i18n\Default.zh-tw.isl,{#RepoDir}\build\win32\i18n\messages.zh-tw.isl" {#LocalizedLanguageFile("cht")}
|
||||||
|
|
||||||
[InstallDelete]
|
[InstallDelete]
|
||||||
Type: filesandordirs; Name: "{app}\resources\app\out"; Check: IsNotUpdate
|
Type: filesandordirs; Name: {app}\resources\app\out
|
||||||
Type: filesandordirs; Name: "{app}\resources\app\plugins"; Check: IsNotUpdate
|
Type: filesandordirs; Name: {app}\resources\app\plugins
|
||||||
Type: filesandordirs; Name: "{app}\resources\app\extensions"; Check: IsNotUpdate
|
Type: filesandordirs; Name: {app}\resources\app\extensions
|
||||||
Type: filesandordirs; Name: "{app}\resources\app\node_modules"; Check: IsNotUpdate
|
Type: filesandordirs; Name: {app}\resources\app\node_modules
|
||||||
Type: filesandordirs; Name: "{app}\resources\app\node_modules.asar.unpacked"; Check: IsNotUpdate
|
Type: files; Name: {app}\resources\app\Credits_45.0.2454.85.html
|
||||||
Type: files; Name: "{app}\resources\app\node_modules.asar"; Check: IsNotUpdate
|
|
||||||
Type: files; Name: "{app}\resources\app\Credits_45.0.2454.85.html"; Check: IsNotUpdate
|
|
||||||
|
|
||||||
[UninstallDelete]
|
|
||||||
Type: filesandordirs; Name: "{app}\_"
|
|
||||||
|
|
||||||
[Tasks]
|
[Tasks]
|
||||||
Name: "quicklaunchicon"; Description: "{cm:CreateQuickLaunchIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked; OnlyBelowVersion: 0,6.1
|
Name: "quicklaunchicon"; Description: "{cm:CreateQuickLaunchIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked; OnlyBelowVersion: 0,6.1
|
||||||
@@ -73,13 +68,14 @@ Name: "{commondesktop}\{#NameLong}"; Filename: "{app}\{#ExeBasename}.exe"; AppUs
|
|||||||
Name: "{userappdata}\Microsoft\Internet Explorer\Quick Launch\{#NameLong}"; Filename: "{app}\{#ExeBasename}.exe"; Tasks: quicklaunchicon; AppUserModelID: "{#AppUserId}"
|
Name: "{userappdata}\Microsoft\Internet Explorer\Quick Launch\{#NameLong}"; Filename: "{app}\{#ExeBasename}.exe"; Tasks: quicklaunchicon; AppUserModelID: "{#AppUserId}"
|
||||||
|
|
||||||
[Run]
|
[Run]
|
||||||
Filename: "{app}\{#ExeBasename}.exe"; Description: "{cm:LaunchProgram,{#NameLong}}"; Tasks: runcode; Flags: nowait postinstall; Check: ShouldRunAfterUpdate
|
Filename: "{app}\{#ExeBasename}.exe"; Description: "{cm:LaunchProgram,{#NameLong}}"; Tasks: runcode; Flags: nowait postinstall; Check: WizardSilent
|
||||||
Filename: "{app}\{#ExeBasename}.exe"; Description: "{cm:LaunchProgram,{#NameLong}}"; Flags: nowait postinstall; Check: WizardNotSilent
|
Filename: "{app}\{#ExeBasename}.exe"; Description: "{cm:LaunchProgram,{#NameLong}}"; Flags: nowait postinstall; Check: WizardNotSilent
|
||||||
|
|
||||||
[Registry]
|
[Registry]
|
||||||
Root: HKCR; Subkey: "{#RegValueName}SourceFile"; ValueType: string; ValueName: ""; ValueData: "{cm:SourceFile,{#NameLong}}"; Flags: uninsdeletekey
|
Root: HKCR; Subkey: "{#RegValueName}SourceFile"; ValueType: string; ValueName: ""; ValueData: "{cm:SourceFile,{#NameLong}}"; Flags: uninsdeletekey
|
||||||
Root: HKCR; Subkey: "{#RegValueName}SourceFile\DefaultIcon"; ValueType: string; ValueName: ""; ValueData: "{app}\resources\app\resources\win32\code_file.ico"
|
Root: HKCR; Subkey: "{#RegValueName}SourceFile\DefaultIcon"; ValueType: string; ValueName: ""; ValueData: "{app}\resources\app\resources\win32\code_file.ico"
|
||||||
Root: HKCR; Subkey: "{#RegValueName}SourceFile\shell\open\command"; ValueType: string; ValueName: ""; ValueData: """{app}\{#ExeBasename}.exe"" ""%1"""
|
Root: HKCR; Subkey: "{#RegValueName}SourceFile\shell\open\command"; ValueType: string; ValueName: ""; ValueData: """{app}\{#ExeBasename}.exe"" ""%1"""
|
||||||
|
|
||||||
Root: HKCU; Subkey: "Environment"; ValueType: expandsz; ValueName: "Path"; ValueData: "{olddata};{app}\bin"; Tasks: addtopath; Check: NeedsAddPath(ExpandConstant('{app}\bin'))
|
Root: HKCU; Subkey: "Environment"; ValueType: expandsz; ValueName: "Path"; ValueData: "{olddata};{app}\bin"; Tasks: addtopath; Check: NeedsAddPath(ExpandConstant('{app}\bin'))
|
||||||
|
|
||||||
[Code]
|
[Code]
|
||||||
@@ -116,75 +112,6 @@ begin
|
|||||||
Result := not WizardSilent();
|
Result := not WizardSilent();
|
||||||
end;
|
end;
|
||||||
|
|
||||||
// Updates
|
|
||||||
function IsBackgroundUpdate(): Boolean;
|
|
||||||
begin
|
|
||||||
Result := ExpandConstant('{param:update|false}') <> 'false';
|
|
||||||
end;
|
|
||||||
|
|
||||||
function IsNotUpdate(): Boolean;
|
|
||||||
begin
|
|
||||||
Result := not IsBackgroundUpdate();
|
|
||||||
end;
|
|
||||||
|
|
||||||
// SqlOps will create a flag file before the update starts (/update=C:\foo\bar)
|
|
||||||
// - if the file exists at this point, the user quit SqlOps before the update finished, so don't start SqlOps after update
|
|
||||||
// - otherwise, the user has accepted to apply the update and SqlOps should start
|
|
||||||
function LockFileExists(): Boolean;
|
|
||||||
begin
|
|
||||||
Result := FileExists(ExpandConstant('{param:update}'))
|
|
||||||
end;
|
|
||||||
|
|
||||||
function ShouldRunAfterUpdate(): Boolean;
|
|
||||||
begin
|
|
||||||
if IsBackgroundUpdate() then
|
|
||||||
Result := not LockFileExists()
|
|
||||||
else
|
|
||||||
Result := True;
|
|
||||||
end;
|
|
||||||
|
|
||||||
function GetAppMutex(Value: string): string;
|
|
||||||
begin
|
|
||||||
if IsBackgroundUpdate() then
|
|
||||||
Result := ''
|
|
||||||
else
|
|
||||||
Result := '{#AppMutex}';
|
|
||||||
end;
|
|
||||||
|
|
||||||
function GetDestDir(Value: string): string;
|
|
||||||
begin
|
|
||||||
if IsBackgroundUpdate() then
|
|
||||||
Result := ExpandConstant('{app}\_')
|
|
||||||
else
|
|
||||||
Result := ExpandConstant('{app}');
|
|
||||||
end;
|
|
||||||
|
|
||||||
function BoolToStr(Value: Boolean): String;
|
|
||||||
begin
|
|
||||||
if Value then
|
|
||||||
Result := 'true'
|
|
||||||
else
|
|
||||||
Result := 'false';
|
|
||||||
end;
|
|
||||||
|
|
||||||
procedure CurStepChanged(CurStep: TSetupStep);
|
|
||||||
var
|
|
||||||
UpdateResultCode: Integer;
|
|
||||||
begin
|
|
||||||
if IsBackgroundUpdate() and (CurStep = ssPostInstall) then
|
|
||||||
begin
|
|
||||||
CreateMutex('{#AppMutex}-ready');
|
|
||||||
|
|
||||||
while (CheckForMutexes('{#AppMutex}')) do
|
|
||||||
begin
|
|
||||||
Log('Application is still running, waiting');
|
|
||||||
Sleep(1000);
|
|
||||||
end;
|
|
||||||
|
|
||||||
Exec(ExpandConstant('{app}\tools\inno_updater.exe'), ExpandConstant('"{app}\{#ExeBasename}.exe" ' + BoolToStr(LockFileExists())), '', SW_SHOW, ewWaitUntilTerminated, UpdateResultCode);
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
// http://stackoverflow.com/a/23838239/261019
|
// http://stackoverflow.com/a/23838239/261019
|
||||||
procedure Explode(var Dest: TArrayOfString; Text: String; Separator: String);
|
procedure Explode(var Dest: TArrayOfString; Text: String; Separator: String);
|
||||||
var
|
var
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
AddContextMenuFiles=エクスプローラーのファイル コンテキスト メニューに [%1 で開く] アクションを追加する
|
AddContextMenuFiles=エクスプローラーのファイル コンテキスト メニューに [%1 で開く] アクションを追加する
|
||||||
AddContextMenuFolders=エクスプローラーのディレクトリ コンテキスト メニューに [%1 で開く] アクションを追加する
|
AddContextMenuFolders=エクスプローラーのディレクトリ コンテキスト メニューに [%1 で開く] アクションを追加する
|
||||||
AssociateWithFiles=サポートされているファイルの種類のエディターとして、%1 を登録する
|
AssociateWithFiles=サポートされているファイルの種類のエディターとして、%1 を登録する
|
||||||
AddToPath=PATH への追加(再起動後に使用可能)
|
AddToPath=PATH への追加 (再起動後に使用可能になる)
|
||||||
RunAfter=インストール後に %1 を実行する
|
RunAfter=インストール後に %1 を実行する
|
||||||
Other=その他:
|
Other=その他:
|
||||||
SourceFile=%1 ソース ファイル
|
SourceFile=%1 ソース ファイル
|
||||||
Binary file not shown.
Binary file not shown.
2172
build/yarn.lock
2172
build/yarn.lock
File diff suppressed because it is too large
Load Diff
29
dataprotocol-node/.gitignore
vendored
Normal file
29
dataprotocol-node/.gitignore
vendored
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
# Logs
|
||||||
|
logs
|
||||||
|
*.log
|
||||||
|
|
||||||
|
# Runtime data
|
||||||
|
pids
|
||||||
|
*.pid
|
||||||
|
*.seed
|
||||||
|
|
||||||
|
# Directory for instrumented libs generated by jscoverage/JSCover
|
||||||
|
lib-cov
|
||||||
|
|
||||||
|
# Coverage directory used by tools like istanbul
|
||||||
|
coverage
|
||||||
|
|
||||||
|
# node-waf configuration
|
||||||
|
.lock-wscript
|
||||||
|
|
||||||
|
# Compiled binary addons (http://nodejs.org/api/addons.html)
|
||||||
|
build/Release
|
||||||
|
lib/
|
||||||
|
out/
|
||||||
|
|
||||||
|
# Dependency directory
|
||||||
|
# https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git-
|
||||||
|
node_modules
|
||||||
|
|
||||||
|
# Debug log from npm
|
||||||
|
npm-debug.log
|
||||||
18
dataprotocol-node/License.txt
Normal file
18
dataprotocol-node/License.txt
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
|
||||||
|
Copyright (c) Microsoft Corporation
|
||||||
|
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Source EULA
|
||||||
|
|
||||||
|
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.
|
||||||
4
dataprotocol-node/README.md
Normal file
4
dataprotocol-node/README.md
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
# Microsoft Data Management Protocol - Node
|
||||||
|
|
||||||
|
## License
|
||||||
|
[MIT](https://github.com/Microsoft/carbon/blob/dev/license.txt)
|
||||||
24
dataprotocol-node/client/.eslintrc
Normal file
24
dataprotocol-node/client/.eslintrc
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
{
|
||||||
|
"rules": {
|
||||||
|
"indent": [
|
||||||
|
2,
|
||||||
|
"tab"
|
||||||
|
],
|
||||||
|
"quotes": [
|
||||||
|
2,
|
||||||
|
"single"
|
||||||
|
],
|
||||||
|
"linebreak-style": [
|
||||||
|
2,
|
||||||
|
"windows"
|
||||||
|
],
|
||||||
|
"semi": [
|
||||||
|
2,
|
||||||
|
"always"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"env": {
|
||||||
|
"node": true
|
||||||
|
},
|
||||||
|
"extends": "eslint:recommended"
|
||||||
|
}
|
||||||
9
dataprotocol-node/client/.npmignore
Normal file
9
dataprotocol-node/client/.npmignore
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
.vscode/
|
||||||
|
lib/test/
|
||||||
|
lib/*.map
|
||||||
|
src/
|
||||||
|
test/
|
||||||
|
.eslintrc
|
||||||
|
.gitignore
|
||||||
|
gulpfile.js
|
||||||
|
tsd.json
|
||||||
32
dataprotocol-node/client/.vscode/launch.json
vendored
Normal file
32
dataprotocol-node/client/.vscode/launch.json
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
{
|
||||||
|
"version": "0.1.0",
|
||||||
|
// List of configurations. Add new configurations or edit existing ones.
|
||||||
|
// ONLY "node" and "mono" are supported, change "type" to switch.
|
||||||
|
"configurations": [
|
||||||
|
{
|
||||||
|
"request": "launch",
|
||||||
|
// Name of configuration; appears in the launch configuration drop down menu.
|
||||||
|
"name": "Mocha",
|
||||||
|
// Type of configuration. Possible values: "node", "mono".
|
||||||
|
"type": "node",
|
||||||
|
// Workspace relative or absolute path to the program.
|
||||||
|
"program": "node_modules/mocha/bin/_mocha",
|
||||||
|
// Automatically stop program after launch.
|
||||||
|
"stopOnEntry": false,
|
||||||
|
// Command line arguments passed to the program.
|
||||||
|
"args": ["--timeout", "999999"],
|
||||||
|
// Workspace relative or absolute path to the working directory of the program being debugged. Default is the current workspace.
|
||||||
|
"cwd": ".",
|
||||||
|
// Workspace relative or absolute path to the runtime executable to be used. Default is the runtime executable on the PATH.
|
||||||
|
"runtimeExecutable": null,
|
||||||
|
// Optional arguments passed to the runtime executable.
|
||||||
|
"runtimeArgs": [],
|
||||||
|
// Environment variables passed to the program.
|
||||||
|
"env": { },
|
||||||
|
// Use JavaScript source maps (if they exist).
|
||||||
|
"sourceMaps": true,
|
||||||
|
// If JavaScript source maps are enabled, the generated code is expected in this directory.
|
||||||
|
"outDir": "lib"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
11
dataprotocol-node/client/.vscode/settings.json
vendored
Normal file
11
dataprotocol-node/client/.vscode/settings.json
vendored
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
// Place your settings in this file to overwrite default and user settings.
|
||||||
|
{
|
||||||
|
"javascript.validate.enable": false,
|
||||||
|
"files.trimTrailingWhitespace": true,
|
||||||
|
"eslint.enable": false,
|
||||||
|
"editor.insertSpaces": false,
|
||||||
|
"editor.tabSize": 4,
|
||||||
|
"tslint.enable": false,
|
||||||
|
"typescript.tsdk": "./node_modules/typescript/lib",
|
||||||
|
"typescript.tsserver.trace": "off"
|
||||||
|
}
|
||||||
9
dataprotocol-node/client/.vscode/tasks.json
vendored
Normal file
9
dataprotocol-node/client/.vscode/tasks.json
vendored
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"version": "0.1.0",
|
||||||
|
"command": "npm",
|
||||||
|
"isShellCommand": true,
|
||||||
|
"args": ["run", "watch"],
|
||||||
|
"showOutput": "silent",
|
||||||
|
"isWatching": true,
|
||||||
|
"problemMatcher": "$tsc-watch"
|
||||||
|
}
|
||||||
4
dataprotocol-node/client/README.md
Normal file
4
dataprotocol-node/client/README.md
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
# Microsoft Data Management Protocol - Node
|
||||||
|
|
||||||
|
## License
|
||||||
|
[MIT](https://github.com/Microsoft/carbon/blob/dev/license.txt)
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user