@html-validate/release-scripts 3.1.0 → 3.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -15,4 +15,5 @@ Various scripts used by release toolchain.
15
15
  }
16
16
  ```
17
17
 
18
- If the library or CLI tool bundles all dependencies use `release-prepack --bundle package.json`.
18
+ If the library or CLI tool bundles all dependencies use `release-prepack package.json --bundle`.
19
+ Dependencies can also be filtered by marking dependencies as external: `--bundle --external:foo --external:bar`.
@@ -0,0 +1,23 @@
1
+ /**
2
+ * @param {Record<string, string>} dependencies
3
+ * @param {boolean} bundle
4
+ * @param {string[]} externals
5
+ * @returns {Record<string, string> | undefined}
6
+ */
7
+ function filterDependencies(dependencies, bundle, externals) {
8
+ if (!bundle) {
9
+ return dependencies;
10
+ }
11
+ if (externals.length === 0) {
12
+ return undefined;
13
+ }
14
+ const filtered = Object.entries(dependencies).filter(([key]) => {
15
+ return externals.includes(key);
16
+ });
17
+ if (filtered.length === 0) {
18
+ return undefined;
19
+ }
20
+ return Object.fromEntries(filtered);
21
+ }
22
+
23
+ module.exports = { filterDependencies };
@@ -0,0 +1,11 @@
1
+ /* eslint-disable no-console, no-process-exit */
2
+
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+
6
+ const filename = process.argv[2];
7
+ const filepath = path.resolve(filename);
8
+ const origfile = `${filepath}.orig`;
9
+
10
+ console.log(`Restoring "${filepath}"`);
11
+ fs.renameSync(origfile, filepath);
package/lib/prepack.js ADDED
@@ -0,0 +1,45 @@
1
+ /* eslint-disable no-console, no-process-exit */
2
+
3
+ const path = require("path");
4
+ const fs = require("fs");
5
+ const { filterDependencies } = require("./filter-dependencies");
6
+ const { stripFields } = require("./strip-fields");
7
+
8
+ const filename = process.argv[2];
9
+ const filepath = path.resolve(filename);
10
+ const tmpfile = `${filepath}.tmp`;
11
+ const origfile = `${filepath}.orig`;
12
+
13
+ const bundle = process.argv.includes("--bundle");
14
+ const externals = process.argv
15
+ .filter((it) => it.startsWith("--external:"))
16
+ .map((it) => it.slice("--external:".length));
17
+
18
+ if (!fs.existsSync(filepath)) {
19
+ process.stderr.write(`release-prepack: No such file or directory: "${filepath}"\n`);
20
+ process.exit(1);
21
+ }
22
+
23
+ const pkg = JSON.parse(fs.readFileSync(filepath, "utf-8"));
24
+ pkg.dependencies = filterDependencies(pkg.dependencies, bundle, externals);
25
+
26
+ stripFields(pkg);
27
+
28
+ const content = JSON.stringify(pkg, null, 2);
29
+ console.log(content);
30
+
31
+ /* backup original file in case of error */
32
+ fs.copyFileSync(filepath, origfile);
33
+
34
+ try {
35
+ /* write to a temporary file first */
36
+ fs.writeFileSync(tmpfile, `${content}\n`, "utf-8");
37
+
38
+ /* swap tempfile for original */
39
+ fs.renameSync(tmpfile, filepath);
40
+ } catch (err) {
41
+ console.error(err);
42
+ process.stderr.write(`\nRestoring "${filename}" after failure\n`);
43
+ fs.copyFileSync(origfile, filepath);
44
+ process.exit(1);
45
+ }
@@ -0,0 +1,29 @@
1
+ const strip = [
2
+ "ava",
3
+ "c8",
4
+ "commitlint",
5
+ "devDependencies",
6
+ "greenkeeper",
7
+ "husky",
8
+ "jest",
9
+ "lint-staged",
10
+ "nyc",
11
+ "pre-commit",
12
+ "prettier",
13
+ "release",
14
+ "renovate",
15
+ "scripts",
16
+ "simple-git-hooks",
17
+ "stylelint",
18
+ "tsd",
19
+ "xo",
20
+ ];
21
+
22
+ function stripFields(pkg) {
23
+ for (const key of strip) {
24
+ /* eslint-disable-next-line security/detect-object-injection */
25
+ delete pkg[key];
26
+ }
27
+ }
28
+
29
+ module.exports = { stripFields };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@html-validate/release-scripts",
3
- "version": "3.1.0",
3
+ "version": "3.3.0",
4
4
  "description": "Various script used by release toolchain",
5
5
  "keywords": [
6
6
  "release"
@@ -21,7 +21,9 @@
21
21
  "release-prepack": "scripts/prepack"
22
22
  },
23
23
  "files": [
24
- "scripts"
24
+ "lib",
25
+ "scripts",
26
+ "!**/*.spec.js"
25
27
  ],
26
28
  "devDependencies": {
27
29
  "execa": "5.1.1",
@@ -34,5 +36,5 @@
34
36
  "publishConfig": {
35
37
  "access": "public"
36
38
  },
37
- "gitHead": "54615e3803c20dc5a6579a24f9653bcaa2537932"
39
+ "gitHead": "e0f7962305559737b4ceab5e95e65b6642dbbcb0"
38
40
  }
package/scripts/postpack CHANGED
@@ -1,9 +1,4 @@
1
- #!/bin/bash
1
+ #!/usr/bin/env node
2
+ "use strict";
2
3
 
3
- set -e
4
-
5
- FILENAME="$1"
6
- ORIGINAL="${FILENAME}.orig"
7
-
8
- echo "Restoring ${FILENAME}"
9
- mv "${ORIGINAL}" "${FILENAME}"
4
+ require("../lib/postpack");
package/scripts/prepack CHANGED
@@ -1,36 +1,4 @@
1
- #!/bin/bash
1
+ #!/usr/bin/env node
2
+ "use strict";
2
3
 
3
- FILENAME="$1"
4
- ORIGINAL="${FILENAME}.orig"
5
- TMPFILE="${FILENAME}.tmp"
6
- shift 1
7
-
8
- restore() {
9
- echo "Restoring ${FILENAME} after failure" > /dev/stderr
10
- if [[ -e "${ORIGINAL}" ]]; then
11
- mv "${ORIGINAL}" "${FILENAME}"
12
- fi
13
- }
14
-
15
- set -e
16
- set -o pipefail
17
- trap restore ERR
18
-
19
- cp "${FILENAME}" "${ORIGINAL}"
20
- cat <<EOF | node - -- "$@" | tee "${TMPFILE}"
21
- const path = require("path");
22
- const pkg = require(path.resolve("${FILENAME}"));
23
- if (process.argv.includes("--bundle")) {
24
- delete pkg.dependencies;
25
- }
26
- delete pkg.devDependencies;
27
- delete pkg.scripts;
28
- delete pkg.commitlint;
29
- delete pkg["lint-staged"];
30
- delete pkg.prettier;
31
- delete pkg.jest;
32
- delete pkg.release;
33
- delete pkg.renovate;
34
- console.log(JSON.stringify(pkg, null, 2));
35
- EOF
36
- mv "${TMPFILE}" "${FILENAME}"
4
+ require("../lib/prepack");