mirror of
https://github.com/microsoft/monaco-editor.git
synced 2025-12-22 20:52:56 +01:00
Bundle AMD using requirejs
This commit is contained in:
parent
770b47221c
commit
db021c78d6
10 changed files with 116 additions and 8574 deletions
8551
package-lock.json
generated
8551
package-lock.json
generated
File diff suppressed because it is too large
Load diff
14
package.json
14
package.json
|
|
@ -3,9 +3,9 @@
|
||||||
"version": "2.0.0",
|
"version": "2.0.0",
|
||||||
"description": "CSS, LESS and SCSS plugin for the Monaco Editor",
|
"description": "CSS, LESS and SCSS plugin for the Monaco Editor",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"compile": "mrmdir ./out && tsc -p ./src",
|
"compile": "mrmdir ./out && tsc -p ./src/tsconfig.json && tsc -p ./src/tsconfig.esm.json",
|
||||||
"watch": "tsc -p ./src --watch",
|
"watch": "tsc -p ./src --watch",
|
||||||
"prepublish": "mrmdir ./release && npm run compile && node ./scripts/release.js && webpack --config webpack.dev.config.js && webpack --config webpack.min.config.js && mcopy ./src/monaco.d.ts ./release/monaco.d.ts",
|
"prepublish": "mrmdir ./release && npm run compile && node ./scripts/release.js && node ./scripts/bundle && mcopy ./src/monaco.d.ts ./release/monaco.d.ts",
|
||||||
"install-service-next": "npm install vscode-css-languageservice@next -f -D && npm install vscode-languageserver-types@next -f -D",
|
"install-service-next": "npm install vscode-css-languageservice@next -f -D && npm install vscode-languageserver-types@next -f -D",
|
||||||
"install-service-local": "npm install ../vscode-css-languageservice -f -D && npm install ../vscode-languageserver-node/types -f -D"
|
"install-service-local": "npm install ../vscode-css-languageservice -f -D && npm install ../vscode-languageserver-node/types -f -D"
|
||||||
},
|
},
|
||||||
|
|
@ -19,13 +19,13 @@
|
||||||
"url": "https://github.com/Microsoft/monaco-css/issues"
|
"url": "https://github.com/Microsoft/monaco-css/issues"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"monaco-editor-core": "0.11.1",
|
"monaco-editor-core": "0.11.3",
|
||||||
"monaco-languages": "0.9.0",
|
"monaco-languages": "1.0.0",
|
||||||
"monaco-plugin-helpers": "^1.0.2",
|
"monaco-plugin-helpers": "^1.0.2",
|
||||||
|
"requirejs": "^2.3.5",
|
||||||
"typescript": "2.7.2",
|
"typescript": "2.7.2",
|
||||||
|
"uglify-js": "^3.3.14",
|
||||||
"vscode-css-languageservice": "3.0.8",
|
"vscode-css-languageservice": "3.0.8",
|
||||||
"vscode-languageserver-types": "3.6.1",
|
"vscode-languageserver-types": "3.6.1"
|
||||||
"webpack": "^4.1.1",
|
|
||||||
"webpack-cli": "^2.0.10"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
69
scripts/bundle.js
Normal file
69
scripts/bundle.js
Normal file
|
|
@ -0,0 +1,69 @@
|
||||||
|
const requirejs = require('requirejs');
|
||||||
|
const path = require('path');
|
||||||
|
const fs = require('fs');
|
||||||
|
const UglifyJS = require("uglify-js");
|
||||||
|
const helpers = require('monaco-plugin-helpers');
|
||||||
|
|
||||||
|
const REPO_ROOT = path.resolve(__dirname, '..');
|
||||||
|
|
||||||
|
const sha1 = helpers.getGitVersion(REPO_ROOT);
|
||||||
|
const semver = require('../package.json').version;
|
||||||
|
const headerVersion = semver + '(' + sha1 + ')';
|
||||||
|
|
||||||
|
const BUNDLED_FILE_HEADER = [
|
||||||
|
'/*!-----------------------------------------------------------------------------',
|
||||||
|
' * Copyright (c) Microsoft Corporation. All rights reserved.',
|
||||||
|
' * monaco-css version: ' + headerVersion,
|
||||||
|
' * Released under the MIT license',
|
||||||
|
' * https://github.com/Microsoft/monaco-css/blob/master/LICENSE.md',
|
||||||
|
' *-----------------------------------------------------------------------------*/',
|
||||||
|
''
|
||||||
|
].join('\n');
|
||||||
|
|
||||||
|
bundleOne('monaco.contribution');
|
||||||
|
bundleOne('cssMode');
|
||||||
|
bundleOne('cssWorker');
|
||||||
|
|
||||||
|
function bundleOne(moduleId, exclude) {
|
||||||
|
requirejs.optimize({
|
||||||
|
baseUrl: 'out/amd/',
|
||||||
|
name: 'vs/language/css/' + moduleId,
|
||||||
|
out: 'release/dev/' + moduleId + '.js',
|
||||||
|
exclude: exclude,
|
||||||
|
paths: {
|
||||||
|
'vs/language/css': REPO_ROOT + '/out/amd'
|
||||||
|
},
|
||||||
|
optimize: 'none',
|
||||||
|
packages: [{
|
||||||
|
name: 'vscode-css-languageservice',
|
||||||
|
location: path.join(REPO_ROOT, 'node_modules/vscode-css-languageservice/lib/umd'),
|
||||||
|
main: 'cssLanguageService'
|
||||||
|
}, {
|
||||||
|
name: 'vscode-languageserver-types',
|
||||||
|
location: path.join(REPO_ROOT, 'node_modules/vscode-languageserver-types/lib/umd'),
|
||||||
|
main: 'main'
|
||||||
|
}, {
|
||||||
|
name: 'vscode-uri',
|
||||||
|
location: path.join(REPO_ROOT, 'node_modules/vscode-uri/lib/umd'),
|
||||||
|
main: 'index'
|
||||||
|
}, {
|
||||||
|
name: 'vscode-nls',
|
||||||
|
location: path.join(REPO_ROOT, '/out/amd/fillers'),
|
||||||
|
main: 'vscode-nls'
|
||||||
|
}]
|
||||||
|
}, function (buildResponse) {
|
||||||
|
const devFilePath = path.join(REPO_ROOT, 'release/dev/' + moduleId + '.js');
|
||||||
|
const minFilePath = path.join(REPO_ROOT, 'release/min/' + moduleId + '.js');
|
||||||
|
const fileContents = fs.readFileSync(devFilePath).toString();
|
||||||
|
console.log();
|
||||||
|
console.log(`Minifying ${devFilePath}...`);
|
||||||
|
const result = UglifyJS.minify(fileContents, {
|
||||||
|
output: {
|
||||||
|
comments: 'some'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
console.log(`Done.`);
|
||||||
|
try { fs.mkdirSync(path.join(REPO_ROOT, 'release/min')) } catch (err) { }
|
||||||
|
fs.writeFileSync(minFilePath, BUNDLED_FILE_HEADER + result.code);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
@ -10,7 +10,7 @@ const REPO_ROOT = path.join(__dirname, '../');
|
||||||
|
|
||||||
helpers.packageESM({
|
helpers.packageESM({
|
||||||
repoRoot: REPO_ROOT,
|
repoRoot: REPO_ROOT,
|
||||||
esmSource: 'out',
|
esmSource: 'out/esm',
|
||||||
esmDestination: 'release/esm',
|
esmDestination: 'release/esm',
|
||||||
entryPoints: [
|
entryPoints: [
|
||||||
'monaco.contribution.js',
|
'monaco.contribution.js',
|
||||||
|
|
@ -18,7 +18,7 @@ helpers.packageESM({
|
||||||
'css.worker.js',
|
'css.worker.js',
|
||||||
],
|
],
|
||||||
resolveAlias: {
|
resolveAlias: {
|
||||||
'vscode-nls': path.join(REPO_ROOT, "out/fillers/vscode-nls.js")
|
'vscode-nls': path.join(REPO_ROOT, "out/esm/fillers/vscode-nls.js")
|
||||||
},
|
},
|
||||||
resolveSkip: [
|
resolveSkip: [
|
||||||
'monaco-editor-core'
|
'monaco-editor-core'
|
||||||
|
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
const path = require('path');
|
|
||||||
const webpack = require('webpack');
|
|
||||||
|
|
||||||
const REPO_ROOT = path.resolve(__dirname, '..');
|
|
||||||
|
|
||||||
exports.createWebpackConfig = function (isDev) {
|
|
||||||
let targetFolder = isDev ? './release/dev' : './release/min';
|
|
||||||
let mode = isDev ? 'development' : 'production';
|
|
||||||
|
|
||||||
return {
|
|
||||||
entry: {
|
|
||||||
"monaco.contribution": './release/esm/monaco.contribution',
|
|
||||||
"cssMode": './release/esm/cssMode',
|
|
||||||
"cssWorker": './release/esm/cssWorker'
|
|
||||||
},
|
|
||||||
output: {
|
|
||||||
filename: '[name].js',
|
|
||||||
path: path.resolve(REPO_ROOT, targetFolder),
|
|
||||||
libraryTarget: "amd"
|
|
||||||
},
|
|
||||||
mode: mode,
|
|
||||||
plugins: [
|
|
||||||
new webpack.optimize.LimitChunkCountPlugin({
|
|
||||||
maxChunks: 1,
|
|
||||||
})
|
|
||||||
],
|
|
||||||
};
|
|
||||||
};
|
|
||||||
14
src/tsconfig.esm.json
Normal file
14
src/tsconfig.esm.json
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"module": "esnext",
|
||||||
|
"moduleResolution": "node",
|
||||||
|
"outDir": "../out/esm",
|
||||||
|
"target": "es5",
|
||||||
|
"lib": [
|
||||||
|
"dom",
|
||||||
|
"es5",
|
||||||
|
"es2015.collection",
|
||||||
|
"es2015.promise"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,8 +1,8 @@
|
||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"module": "esnext",
|
"module": "amd",
|
||||||
"moduleResolution": "node",
|
"moduleResolution": "node",
|
||||||
"outDir": "../out",
|
"outDir": "../out/amd",
|
||||||
"target": "es5",
|
"target": "es5",
|
||||||
"lib": [
|
"lib": [
|
||||||
"dom",
|
"dom",
|
||||||
|
|
|
||||||
|
|
@ -14,7 +14,7 @@
|
||||||
// Loading basic-languages to get the css language definition
|
// Loading basic-languages to get the css language definition
|
||||||
var require = {
|
var require = {
|
||||||
paths: {
|
paths: {
|
||||||
'vs/basic-languages': '../node_modules/monaco-languages/release',
|
'vs/basic-languages': '../node_modules/monaco-languages/release/dev',
|
||||||
'vs/language/css': '../release/dev',
|
'vs/language/css': '../release/dev',
|
||||||
'vs': '../node_modules/monaco-editor-core/dev/vs'
|
'vs': '../node_modules/monaco-editor-core/dev/vs'
|
||||||
}
|
}
|
||||||
|
|
@ -26,7 +26,7 @@
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
require([
|
require([
|
||||||
'vs/basic-languages/src/monaco.contribution',
|
'vs/basic-languages/monaco.contribution',
|
||||||
'vs/language/css/monaco.contribution'
|
'vs/language/css/monaco.contribution'
|
||||||
], function() {
|
], function() {
|
||||||
var editor = monaco.editor.create(document.getElementById('container'), {
|
var editor = monaco.editor.create(document.getElementById('container'), {
|
||||||
|
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
module.exports = require('./scripts/webpack').createWebpackConfig(true);
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
module.exports = require('./scripts/webpack').createWebpackConfig(false);
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue