ソースを参照

Bundle AMD using requirejs

Alex Dima 7 年 前
コミット
364575ee25
10 ファイル変更120 行追加6971 行削除
  1. 22 6930
      package-lock.json
  2. 5 5
      package.json
  3. 73 0
      scripts/bundle.js
  4. 2 2
      scripts/release.js
  5. 0 28
      scripts/webpack.js
  6. 14 0
      src/tsconfig.esm.json
  7. 2 2
      src/tsconfig.json
  8. 2 2
      test/index.html
  9. 0 1
      webpack.dev.config.js
  10. 0 1
      webpack.min.config.js

ファイルの差分が大きいため隠しています
+ 22 - 6930
package-lock.json


+ 5 - 5
package.json

@@ -3,9 +3,9 @@
   "version": "2.0.0",
   "description": "JSON plugin for the Monaco Editor",
   "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",
-    "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-json-languageservice@next -f -D && npm install vscode-languageserver-types@next -f -D",
     "install-service-local": "npm install ../vscode-json-languageservice -f -D && npm install ../vscode-languageserver-node/types -f -D"
   },
@@ -23,10 +23,10 @@
     "monaco-editor-core": "0.11.3",
     "monaco-languages": "1.0.0",
     "monaco-plugin-helpers": "^1.0.2",
+    "requirejs": "^2.3.5",
     "typescript": "2.7.2",
+    "uglify-js": "^3.3.14",
     "vscode-json-languageservice": "3.0.12",
-    "vscode-languageserver-types": "3.6.1",
-    "webpack": "^4.1.1",
-    "webpack-cli": "^2.0.11"
+    "vscode-languageserver-types": "3.6.1"
   }
 }

+ 73 - 0
scripts/bundle.js

@@ -0,0 +1,73 @@
+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-json version: ' + headerVersion,
+	' * Released under the MIT license',
+	' * https://github.com/Microsoft/monaco-json/blob/master/LICENSE.md',
+	' *-----------------------------------------------------------------------------*/',
+	''
+].join('\n');
+
+bundleOne('monaco.contribution');
+bundleOne('jsonMode');
+bundleOne('jsonWorker');
+
+function bundleOne(moduleId, exclude) {
+	requirejs.optimize({
+		baseUrl: 'out/amd/',
+		name: 'vs/language/json/' + moduleId,
+		out: 'release/dev/' + moduleId + '.js',
+		exclude: exclude,
+		paths: {
+			'vs/language/json': REPO_ROOT + '/out/amd'
+		},
+		optimize: 'none',
+		packages: [{
+			name: 'vscode-json-languageservice',
+			location: path.join(REPO_ROOT, 'node_modules/vscode-json-languageservice/lib/umd'),
+			main: 'jsonLanguageService'
+		}, {
+			name: 'vscode-languageserver-types',
+			location: path.join(REPO_ROOT, 'node_modules/vscode-languageserver-types/lib/umd'),
+			main: 'main'
+		}, {
+			name: 'jsonc-parser',
+			location: path.join(REPO_ROOT, 'node_modules/jsonc-parser/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);
+	})
+}

+ 2 - 2
scripts/release.js

@@ -10,7 +10,7 @@ const REPO_ROOT = path.join(__dirname, '../');
 
 helpers.packageESM({
 	repoRoot: REPO_ROOT,
-	esmSource: 'out',
+	esmSource: 'out/esm',
 	esmDestination: 'release/esm',
 	entryPoints: [
 		'monaco.contribution.js',
@@ -18,7 +18,7 @@ helpers.packageESM({
 		'json.worker.js'
 	],
 	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: [
 		'monaco-editor-core'

+ 0 - 28
scripts/webpack.js

@@ -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',
-			"jsonMode": './release/esm/jsonMode',
-			"jsonWorker": './release/esm/jsonWorker'
-		},
-		output: {
-			filename: '[name].js',
-			path: path.resolve(REPO_ROOT, targetFolder),
-			libraryTarget: "amd"
-		},
-		mode: mode,
-		plugins: [
-			new webpack.optimize.LimitChunkCountPlugin({
-				maxChunks: 1,
-			})
-		],
-	};
-};

+ 14 - 0
src/tsconfig.esm.json

@@ -0,0 +1,14 @@
+{
+  "compilerOptions": {
+    "module": "esnext",
+    "moduleResolution": "node",
+    "outDir": "../out/esm",
+    "target": "es5",
+    "lib": [
+      "dom",
+      "es5",
+      "es2015.collection",
+      "es2015.promise"
+    ]
+  }
+}

+ 2 - 2
src/tsconfig.json

@@ -1,8 +1,8 @@
 {
   "compilerOptions": {
-    "module": "esnext",
+    "module": "amd",
     "moduleResolution": "node",
-    "outDir": "../out",
+    "outDir": "../out/amd",
     "target": "es5",
     "lib": [
       "dom",

+ 2 - 2
test/index.html

@@ -14,7 +14,7 @@
 	// Loading basic-languages to get the json language definition
 	var require = {
 		paths: {
-			'vs/basic-languages': '../node_modules/monaco-languages/release',
+			'vs/basic-languages': '../node_modules/monaco-languages/release/dev',
 			'vs/language/json': '../release/dev',
 			'vs': '../node_modules/monaco-editor-core/dev/vs'
 		}
@@ -26,7 +26,7 @@
 
 <script>
 	require([
-		'vs/basic-languages/src/monaco.contribution',
+		'vs/basic-languages/monaco.contribution',
 		'vs/language/json/monaco.contribution'
 	], function() {
 		var editor = monaco.editor.create(document.getElementById('container'), {

+ 0 - 1
webpack.dev.config.js

@@ -1 +0,0 @@
-module.exports = require('./scripts/webpack').createWebpackConfig(true);

+ 0 - 1
webpack.min.config.js

@@ -1 +0,0 @@
-module.exports = require('./scripts/webpack').createWebpackConfig(false);

この差分においてかなりの量のファイルが変更されているため、一部のファイルを表示していません