q5 2.11.1 → 2.11.2

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.
Files changed (3) hide show
  1. package/deno.json +1 -1
  2. package/package.json +3 -2
  3. package/q5-server.js +41 -37
package/deno.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@q5/q5",
3
- "version": "2.11.0",
3
+ "version": "2.11.2",
4
4
  "license": "LGPL-3.0",
5
5
  "description": "A sequel to p5.js that's optimized for interactive art",
6
6
  "author": "quinton-ashley",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "q5",
3
- "version": "2.11.1",
3
+ "version": "2.11.2",
4
4
  "description": "A sequel to p5.js that's optimized for interactive art",
5
5
  "author": "quinton-ashley",
6
6
  "contributors": [
@@ -15,7 +15,7 @@
15
15
  "min": "terser q5.js --compress ecma=2024 --mangle > q5.min.js",
16
16
  "dist": "bun bundle && bun min",
17
17
  "dist-p5play": "bun dist && cp q5.js ../../web/p5play-web/v3/q5.js && cp q5.min.js ../../web/p5play-web/v3/q5.min.js",
18
- "tests": "deno test --unstable-node-globals -A",
18
+ "tests": "jest test",
19
19
  "v": "npm version patch --force",
20
20
  "V": "npm version minor --force",
21
21
  "version": "git add -A",
@@ -38,6 +38,7 @@
38
38
  "q5js"
39
39
  ],
40
40
  "devDependencies": {
41
+ "jest-cli": "^29.7.0",
41
42
  "jsdom": "^25.0.1",
42
43
  "skia-canvas": "^1.0.2"
43
44
  }
package/q5-server.js CHANGED
@@ -3,54 +3,58 @@
3
3
  * @description Run q5 with node.js using node-canvas and jsdom
4
4
  */
5
5
 
6
+ let depsLoaded = false;
7
+
6
8
  try {
7
9
  global.SkiaCanvas ??= require('skia-canvas');
8
10
  global.JSDOM ??= require('jsdom').JSDOM;
11
+ depsLoaded = true;
9
12
  } catch (e) {
10
13
  require('./q5.js');
11
14
  module.exports = Q5;
12
- return;
13
15
  }
14
16
 
15
- global.window = new JSDOM('', { url: 'http://localhost' }).window;
17
+ if (depsLoaded) {
18
+ global.window = new JSDOM('', { url: 'http://localhost' }).window;
16
19
 
17
- {
18
- let props = Object.getOwnPropertyNames(window).concat(Object.getOwnPropertyNames(Object.getPrototypeOf(window)));
19
- for (let prop of props) {
20
- if (!global[prop]) {
21
- Object.defineProperty(global, prop, Object.getOwnPropertyDescriptor(window, prop));
20
+ {
21
+ let props = Object.getOwnPropertyNames(window).concat(Object.getOwnPropertyNames(Object.getPrototypeOf(window)));
22
+ for (let prop of props) {
23
+ if (!global[prop]) {
24
+ Object.defineProperty(global, prop, Object.getOwnPropertyDescriptor(window, prop));
25
+ }
22
26
  }
27
+ global.Event = window.Event;
23
28
  }
24
- global.Event = window.Event;
25
- }
26
29
 
27
- global.Image = window.Image = SkiaCanvas.Image;
28
- global.Window ??= SkiaCanvas.Window;
29
-
30
- require('./q5.js');
31
-
32
- Q5._createServerCanvas = function () {
33
- let skiaCanvas = new SkiaCanvas.Canvas(...arguments);
34
- let domCanvas = document.createElement('canvas');
35
-
36
- skiaCanvas.save = skiaCanvas.saveAsSync;
37
-
38
- return new Proxy(skiaCanvas, {
39
- get: function (target, prop) {
40
- let t = prop in target ? target : domCanvas;
41
- let p = t[prop];
42
- if (typeof p === 'function') return p.bind(t);
43
- return p;
44
- },
45
- set: function (target, prop, value) {
46
- if (prop in target) {
47
- target[prop] = value;
48
- } else {
49
- domCanvas[prop] = value;
30
+ global.Image = window.Image = SkiaCanvas.Image;
31
+ global.Window ??= SkiaCanvas.Window;
32
+
33
+ require('./q5.js');
34
+
35
+ Q5._createServerCanvas = function () {
36
+ let skiaCanvas = new SkiaCanvas.Canvas(...arguments);
37
+ let domCanvas = document.createElement('canvas');
38
+
39
+ skiaCanvas.save = skiaCanvas.saveAsSync;
40
+
41
+ return new Proxy(skiaCanvas, {
42
+ get: function (target, prop) {
43
+ let t = prop in target ? target : domCanvas;
44
+ let p = t[prop];
45
+ if (typeof p === 'function') return p.bind(t);
46
+ return p;
47
+ },
48
+ set: function (target, prop, value) {
49
+ if (prop in target) {
50
+ target[prop] = value;
51
+ } else {
52
+ domCanvas[prop] = value;
53
+ }
54
+ return true;
50
55
  }
51
- return true;
52
- }
53
- });
54
- };
56
+ });
57
+ };
55
58
 
56
- module.exports = Q5;
59
+ module.exports = Q5;
60
+ }