如何处理 javascript 捆绑包中的版权声明?
How to handle Copyright notice in javascript bundle?
我正在编写几个小演示来向同事解释装饰器(打字稿),这时我注意到我的捆绑包有一个 Microsoft 版权声明,这使得我的整个文件对所有人免费(并且由 MS 制作)。
应该如何有效地处理这个问题(如果我创建的东西不是免费的)?
我使用 Typescript 3.1 进行编译和打包汇总。
代码:
import { isNotUndefined, isNotNullOrUndefined } from "goodcore/Test";
function deprecated<S>(instead?: string, message?: string) {
// Logic removed for brevity...
}
class Car {
@deprecated()
public turnIgnitionKey() {
this.start();
}
public pressStartButton() {
this.start();
}
private start() {
console.log("Running!");
}
}
let car = new Car();
car.turnIgnitionKey();
car.pressStartButton();
和bundle beginning(最后一个函数是我的,之前的是MS):
'use strict';
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
function __decorate(decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
}
function __metadata(metadataKey, metadataValue) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
}
function isNullOrUndefined(arg) {
return arg === undefined || arg === null;
}
@JGoodgive,
您可以在您创建的每个 JavaScript 文件上方添加您自己的自定义许可证,这样当它们捆绑在一起时,您的许可证文件应该显示在您的 JS 代码上方。
/*! *****************************************************************************
Copyright (c) <Author>. All rights reserved.
<Custom license text here>
***************************************************************************** */
// Your JS code below your custom license
Rollup 将所有需要的东西打包到输出文件中。你看到的是来自 tslib
模块的 Typescript 助手。
您可以用 tslib
库导入替换该代码(并摆脱 MS 许可证)。
添加到您的 rollup.config.js
以下设置:external: ["tslib"]
。不幸的是,您需要将 tslib
模块添加到项目的依赖项(或 peerDependencies)中。
查看以下对话了解更多详情:
https://github.com/ezolenko/rollup-plugin-typescript2/issues/58(关于外部设置)
https://github.com/ReactiveX/rxjs/issues/2436#issuecomment-371585945(关于依赖与 peerDependency 的问题)
这里是关于助手的:
https://mariusschulz.com/blog/external-helpers-library-in-typescript
我在汇总配置中添加了 rollup-plugin-terser 并将注释设置为 false,以便删除所有注释。
...
import { terser } from 'rollup-plugin-terser';
...
plugins: [
...
terser({ format: { comments: false } }),
...
]
我正在编写几个小演示来向同事解释装饰器(打字稿),这时我注意到我的捆绑包有一个 Microsoft 版权声明,这使得我的整个文件对所有人免费(并且由 MS 制作)。
应该如何有效地处理这个问题(如果我创建的东西不是免费的)?
我使用 Typescript 3.1 进行编译和打包汇总。
代码:
import { isNotUndefined, isNotNullOrUndefined } from "goodcore/Test";
function deprecated<S>(instead?: string, message?: string) {
// Logic removed for brevity...
}
class Car {
@deprecated()
public turnIgnitionKey() {
this.start();
}
public pressStartButton() {
this.start();
}
private start() {
console.log("Running!");
}
}
let car = new Car();
car.turnIgnitionKey();
car.pressStartButton();
和bundle beginning(最后一个函数是我的,之前的是MS):
'use strict';
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
function __decorate(decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
}
function __metadata(metadataKey, metadataValue) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
}
function isNullOrUndefined(arg) {
return arg === undefined || arg === null;
}
@JGoodgive,
您可以在您创建的每个 JavaScript 文件上方添加您自己的自定义许可证,这样当它们捆绑在一起时,您的许可证文件应该显示在您的 JS 代码上方。
/*! *****************************************************************************
Copyright (c) <Author>. All rights reserved.
<Custom license text here>
***************************************************************************** */
// Your JS code below your custom license
Rollup 将所有需要的东西打包到输出文件中。你看到的是来自 tslib
模块的 Typescript 助手。
您可以用 tslib
库导入替换该代码(并摆脱 MS 许可证)。
添加到您的 rollup.config.js
以下设置:external: ["tslib"]
。不幸的是,您需要将 tslib
模块添加到项目的依赖项(或 peerDependencies)中。
查看以下对话了解更多详情: https://github.com/ezolenko/rollup-plugin-typescript2/issues/58(关于外部设置)
https://github.com/ReactiveX/rxjs/issues/2436#issuecomment-371585945(关于依赖与 peerDependency 的问题)
这里是关于助手的: https://mariusschulz.com/blog/external-helpers-library-in-typescript
我在汇总配置中添加了 rollup-plugin-terser 并将注释设置为 false,以便删除所有注释。
...
import { terser } from 'rollup-plugin-terser';
...
plugins: [
...
terser({ format: { comments: false } }),
...
]