Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RuntimeTypeInspector.js: Add RTI build target + Examples integration #5817

Draft
wants to merge 74 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
74 commits
Select commit Hold shift + click to select a range
5e8b2a6
Adding RTI transpiler to every target, I will fine-tune a bit later
kungfooman Nov 9, 2023
e8aa110
Merge branch 'main' into rti
kungfooman Nov 9, 2023
91dec96
name output build/playcanvas-rti and update packages
kungfooman Nov 9, 2023
d4bb80d
Merge branch 'main' into rti
kungfooman Nov 10, 2023
1ff92a2
Resolve RTI runtime and update to latest RTI rollup plugin
kungfooman Nov 10, 2023
82feb3a
Integrate RTI into Examples browser via `npm run develop:rti`
kungfooman Nov 10, 2023
53ab80c
only add node-resolve plugin for RTI
kungfooman Nov 10, 2023
af6366e
Don't type check framework/parsers/draco-worker.js (because a Worker …
kungfooman Nov 11, 2023
20a249a
npm i @runtime-type-inspector/[email protected] (added `types.d.ts`…
kungfooman Nov 11, 2023
3cae39b
Merge branch 'main' into rti
kungfooman Nov 11, 2023
c89fde4
Add type reporting mode: never
kungfooman Nov 13, 2023
c1bab6b
Merge branch 'main' into rti
kungfooman Nov 28, 2023
b4cb08d
npm run develop:rti - Support live reload
kungfooman Nov 28, 2023
8fcb5e1
extras: JSDoc
kungfooman Dec 2, 2023
1557987
update RTI version, use index.rti.js for custom types/validations
kungfooman Dec 2, 2023
6472337
JSDoc fixes from Splat PR for extras type testing
kungfooman Dec 3, 2023
46daac2
fix lint
kungfooman Dec 3, 2023
5e668a0
Merge branch 'main' into rti
kungfooman Dec 6, 2023
c26a7c5
rollup.config.mjs: add rti target
kungfooman Dec 6, 2023
d18508c
Keep utils/rollup-build-target.mjs without RTI, using rollup-build-ta…
kungfooman Dec 6, 2023
eb75549
Fix lint
kungfooman Dec 6, 2023
5bd053b
little jsdoc fix
kungfooman Dec 17, 2023
e4a1433
npm install --save-dev @runtime-type-inspector/[email protected]
kungfooman Dec 30, 2023
2636752
Fix rollup/acorn error
kungfooman Dec 31, 2023
66c6492
Merge branch 'main' into rti
kungfooman Jan 1, 2024
e2f01a0
package-lock.json: npm install (changed jsdoc-typeof-plugin)
kungfooman Jan 1, 2024
73d1fca
npm update @runtime-type-inspector/transpiler (in root and examples/)
kungfooman Jan 1, 2024
bf397b2
npm update @runtime-type-inspector/plugin-rollup
kungfooman Jan 19, 2024
f3b1567
npm update @runtime-type-inspector/plugin-rollup
kungfooman Jan 20, 2024
1e9eb4f
Merge branch 'main' into rti
kungfooman Jan 25, 2024
cbb2d95
Update to @runtime-type-inspector/[email protected]
kungfooman Jan 25, 2024
9e35146
Merge branch 'main' into rti
kungfooman Jan 25, 2024
6e37268
Ignore node_modules for RTI to fix issue with DisplayAnything
kungfooman Jan 25, 2024
788331d
Merge branch 'main' into rti
kungfooman Feb 22, 2024
5837e5a
Bump RTI rollup plugin and integrate into examples again for `npm run…
kungfooman Feb 23, 2024
faa9c92
`cd examples && npm install` to fix `examples/package-lock.json`
kungfooman Feb 23, 2024
4f68608
Update RTI rollup plugin to 3.2.5
kungfooman May 13, 2024
add8005
Merge branch 'main' into rti
kungfooman May 14, 2024
78a6fd7
Reintegrate npm run build:rti
kungfooman May 14, 2024
e751a99
Reintegrate RTI after bunch of merge conflicts
kungfooman May 15, 2024
a305044
Merge branch 'main' into rti
kungfooman May 15, 2024
d8116b8
Fix package.json and package-lock.json from merge conflict
kungfooman May 15, 2024
4787e03
npm i --save-dev @runtime-type-inspector/[email protected]
kungfooman May 16, 2024
6272f07
Merge branch 'main' into rti
kungfooman May 18, 2024
cba932b
src/framework/anim/binder/anim-binder.js mini comment fix, you can te…
kungfooman May 18, 2024
ae4abb8
Fix custom types
kungfooman May 18, 2024
1dafa68
Merge branch 'main' into rti
kungfooman May 24, 2024
8dccff2
Bump RTI version
kungfooman Jun 13, 2024
b84f139
Merge branch 'main' into rti
kungfooman Jun 13, 2024
871dbab
Bump RTI to 3.3.1
kungfooman Jun 14, 2024
c5034cd
Validate `ArrayBufferView`'s via `ArrayBuffer.isView` as custom type
kungfooman Jun 14, 2024
3229985
Bump RTI to 3.3.2
kungfooman Jun 14, 2024
37cb138
src/index.rti.js: IArguments and ArrayBufferView are checked in RTI i…
kungfooman Jun 14, 2024
2a650a3
src/index.rti.js: Check for Quaternion floating point precision error…
kungfooman Jun 16, 2024
0830707
src/index.rti.js: Add specific warning message to Quat denormalizatio…
kungfooman Jun 17, 2024
b97bcde
Bump RTI to 3.3.3
kungfooman Jun 17, 2024
c0b4013
Fix loaders/gsplat-many example (workers don't do RTI)
kungfooman Jun 17, 2024
f90ab9f
Bump RTI to 3.3.7
kungfooman Jun 21, 2024
f64f74e
Merge branch 'main' into rti
kungfooman Jun 21, 2024
9fed558
Ignore denormalization check for `Quat#mulScalar` aswell
kungfooman Jun 21, 2024
831a781
Merge branch 'main' into rti
kungfooman Sep 4, 2024
3ad1089
Merge branch 'main' into rti
kungfooman Sep 9, 2024
503e473
Fix lint for new single quote rule
kungfooman Sep 11, 2024
ab85082
Merge branch 'main' into rti
kungfooman Sep 11, 2024
81aac9c
Sync both engine/ and examples/ package-lock.json
kungfooman Sep 11, 2024
48c3c30
Merge branch 'main' into rti
kungfooman Sep 29, 2024
4caa970
Small JSDoc fixes
kungfooman Sep 29, 2024
6d5743c
Few more JSDoc fixes
kungfooman Sep 29, 2024
41f53e4
Merge branch 'main' into rti
kungfooman Nov 15, 2024
05c2440
Merge branch 'main' into rti
kungfooman Nov 15, 2024
568e5ff
Fix lint
kungfooman Nov 15, 2024
2f88759
Merge branch 'main' into rti
kungfooman Nov 15, 2024
7e218c9
Update package-lock.json
kungfooman Nov 15, 2024
0774a34
Update to RTI v4 (ability to send errors over context boundaries, e.g…
kungfooman Nov 16, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions examples/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions examples/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
"build:thumbnails": "node ./scripts/build-thumbnails.mjs",
"clean": "node ./scripts/clean.mjs",
"develop": "cross-env NODE_ENV=development concurrently --kill-others \"npm run watch\" \"npm run serve\"",
"develop:rti": "RTI=on npm run develop",
"lint": "eslint .",
"serve": "serve dist -l 5555 --no-request-logging --config ../serve.json",
"watch": "npm run -s build:pre && cross-env NODE_ENV=development rollup -c -w"
Expand Down
7 changes: 6 additions & 1 deletion examples/rollup.config.js → examples/rollup.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,15 @@ import { buildExamples } from './utils/plugins/rollup-build-examples.mjs';
import { copyStatic } from './utils/plugins/rollup-copy-static.mjs';
import { isModuleWithExternalDependencies } from './utils/utils.mjs';
import { treeshakeIgnore } from '../utils/plugins/rollup-treeshake-ignore.mjs';
import { buildTargetRTI } from '../utils/rollup-build-target-rti.mjs';
import { buildTarget } from '../utils/rollup-build-target.mjs';

// util functions

const NODE_ENV = process.env.NODE_ENV ?? '';
const ENGINE_PATH = !process.env.ENGINE_PATH && NODE_ENV === 'development' ?
'../src/index.js' : process.env.ENGINE_PATH ?? '';
const { RTI = '' } = process.env;

const getEnginePathFiles = () => {
if (!ENGINE_PATH) {
Expand Down Expand Up @@ -54,6 +56,9 @@ const getEngineTargets = () => {
checkAppEngine();

const targets = [];
if (RTI === 'on') {
targets.push(buildTargetRTI('es', '../src/index.rti.js', 'dist/iframe/ENGINE_PATH'));
}
if (ENGINE_PATH) {
return targets;
}
Expand Down Expand Up @@ -146,7 +151,7 @@ export default [
skipWrite: true
},
treeshake: false,
plugins: [buildExamples(NODE_ENV, ENGINE_PATH), copyStatic(NODE_ENV, STATIC_FILES)]
plugins: [buildExamples(NODE_ENV, ENGINE_PATH, RTI), copyStatic(NODE_ENV, STATIC_FILES)]
},
{
// A debug build is ~2.3MB and a release build ~0.6MB
Expand Down
5 changes: 4 additions & 1 deletion examples/scripts/build-examples.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,10 @@ const generateExampleFile = (categoryKebab, exampleNameKebab, setEngineType, fil

// engine
const engineType = process.env.ENGINE_PATH ? 'development' : process.env.NODE_ENV === 'development' ? 'debug' : setEngineType;
const engine = engineFor(engineType);
let engine = engineFor(engineType);
if (process.env.RTI === 'on') {
engine = './ENGINE_PATH/playcanvas.rti.mjs';
}
html = html.replace(/'@ENGINE'/g, JSON.stringify(engine));

if (/'@[A-Z0-9_]+'/.test(html)) {
Expand Down
7 changes: 4 additions & 3 deletions examples/utils/plugins/rollup-build-examples.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,10 @@ const REGULAR_OUT = '\x1b[22m';
*
* @param {string} nodeEnv - The node environment.
* @param {string} enginePath - The path to the engine.
* @param {string} rti - Whether to activate RuntimeTypeInspector.
* @returns {import('rollup').Plugin} The plugin.
*/
export function buildExamples(nodeEnv, enginePath) {
export function buildExamples(nodeEnv, enginePath, rti) {
return {
name: 'build-examples',
buildStart() {
Expand All @@ -24,8 +25,8 @@ export function buildExamples(nodeEnv, enginePath) {
}
},
buildEnd() {
build({ NODE_ENV: nodeEnv, ENGINE_PATH: enginePath });
console.log(`${GREEN_OUT}built examples using NODE_ENV=${BOLD_OUT}${nodeEnv}${REGULAR_OUT} ENGINE_PATH=${BOLD_OUT}${enginePath}${REGULAR_OUT}`);
build({ NODE_ENV: nodeEnv, ENGINE_PATH: enginePath, RTI: rti });
console.log(`${GREEN_OUT}built examples using NODE_ENV=${BOLD_OUT}${nodeEnv}${REGULAR_OUT} ENGINE_PATH=${BOLD_OUT}${enginePath}${REGULAR_OUT} RTI=${BOLD_OUT}${rti}${REGULAR_OUT}`);
}
};
}
57 changes: 57 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@
"@rollup/plugin-strip": "^3.0.4",
"@rollup/plugin-terser": "^0.4.4",
"@rollup/pluginutils": "^5.1.0",
"@runtime-type-inspector/plugin-rollup": "^4.0.3",
"c8": "^10.1.2",
"chai": "^5.1.0",
"eslint": "^9.10.0",
Expand Down Expand Up @@ -115,6 +116,7 @@
"build:treenet": "npm run build target:umd treenet",
"build:treesun": "npm run build target:umd treesun",
"build:sourcemaps": "npm run build -- -m",
"build:rti": "rollup -c --environment target:rti",
"watch": "npm run build -- -w",
"watch:release": "npm run build target:release -- -w",
"watch:debug": "npm run build target:debug -- -w",
Expand Down
6 changes: 6 additions & 0 deletions rollup.config.mjs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import * as fs from 'node:fs';
import { version, revision } from './utils/rollup-version-revision.mjs';
import { buildTarget } from './utils/rollup-build-target.mjs';
import { buildTargetRTI } from './utils/rollup-build-target-rti.mjs';

// unofficial package plugins
import dts from 'rollup-plugin-dts';
Expand Down Expand Up @@ -103,6 +104,11 @@ BUILD_TYPES.forEach((buildType) => {
});
});

if (envTarget === 'rti') {
targets.length = 0;
targets.push(buildTargetRTI('umd'), buildTargetRTI('es'));
}

if (envTarget === null || envTarget === 'types') {
targets.push(...TYPES_TARGET);
}
Expand Down
2 changes: 1 addition & 1 deletion src/core/debug.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ class Debug {
/**
* Assertion error message. If the assertion is false, the error message is written to the log.
*
* @param {boolean|object} assertion - The assertion to check.
* @param {boolean|object|string} assertion - The assertion to check.
* @param {...*} args - The values to be written to the log.
*/
static assert(assertion, ...args) {
Expand Down
2 changes: 1 addition & 1 deletion src/framework/anim/binder/anim-binder.js
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ class AnimBinder {
* or string path.
* @returns {string} The locator encoded as a string.
* @example
* // returns 'spotLight/light/color.r'
* // returns 'spotLight/light/color/r'
* encode(['spotLight'], 'light', ['color', 'r']);
*/
static encode(entityPath, component, propertyPath) {
Expand Down
6 changes: 3 additions & 3 deletions src/framework/asset/asset-reference.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,15 +59,15 @@ class AssetReference {
* Sets the asset id which this references. One of either id or url must be set to
* initialize an asset reference.
*
* @type {number}
* @type {number|null}
*/
set id(value) {
if (this.url) throw Error('Can\'t set id and url');

this._unbind();

this._id = value;
this.asset = this._registry.get(this._id);
this.asset = this._id === null ? null : this._registry.get(this._id);

this._bind();
}
Expand All @@ -93,7 +93,7 @@ class AssetReference {
this._unbind();

this._url = value;
this.asset = this._registry.getByUrl(this._url);
this.asset = this._url === null ? null : this._registry.getByUrl(this._url);

this._bind();
}
Expand Down
102 changes: 102 additions & 0 deletions src/index.rti.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
export * from './index.js';
import { Vec2 } from './core/math/vec2.js';
import { Vec3 } from './core/math/vec3.js';
import { Vec4 } from './core/math/vec4.js';
import { Quat } from './core/math/quat.js';
import { Mat3 } from './core/math/mat3.js';
import { Mat4 } from './core/math/mat4.js';
import { customTypes, customValidations, validateNumber, TypePanel } from '@runtime-type-inspector/runtime';
import 'display-anything/src/style.js';
Object.assign(customTypes, {
AnimSetter(value) {
// Fix for type in ./framework/anim/evaluator/anim-target.js
// The AnimSetter type is not sufficient, just patching in the correct type here
if (value instanceof Function) {
return true;
}
return value?.set instanceof Function && value?.set instanceof Function;
},
AnimBinder(value) {
// Still using: @implements {AnimBinder}
// RTI doesn't take notice of that so far and we started removing `@implements` aswell:
// Testable via graphics/contact-hardening-shadows example.
return value?.constructor?.name?.endsWith('Binder');
},
ComponentData(value) {
// Used in src/framework/components/collision/trigger.js
// Why do we neither use @implements nor `extends` for such type?
// Testable via animation/locomotion example.
return value?.constructor?.name?.endsWith('ComponentData');
},
Renderer(value) {
// E.g. instance of `ForwardRenderer`
return value?.constructor?.name?.endsWith('Renderer');
}
});
// For quickly checking props of Vec2/Vec3/Vec4/Quat/Mat3/Mat4 without GC
const propsXY = ['x', 'y'];
const propsXYZ = ['x', 'y', 'z'];
const propsXYZW = ['x', 'y', 'z', 'w'];
const props9 = [0, 1, 2, 3, 4, 5, 6, 7, 8];
const props16 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15];
/**
* `@ignoreRTI`
* @param {any} value - The value.
* @param {*} expect - Expected type structure.
* @todo Split array/class.
* @param {string} loc - String like `BoundingBox#compute`
* @param {string} name - Name of the argument.
* @param {boolean} critical - Only false for unions.
* @param {console["warn"]} warn - Function to warn with.
* @param {number} depth - The depth to detect recursion.
* @returns {boolean} Only false if we can find some NaN issues or denormalisation issues.
*/
function validate(value, expect, loc, name, critical, warn, depth) {
/**
* @param {string|number} prop - Something like 'x', 'y', 'z', 'w', 0, 1, 2, 3, 4 etc.
* @returns {boolean} Wether prop is a valid number.
*/
const checkProp = (prop) => {
return validateNumber(value, prop);
};
if (value instanceof Vec2) {
return propsXY.every(checkProp);
}
if (value instanceof Vec3) {
return propsXYZ.every(checkProp);
}
if (value instanceof Vec4) {
return propsXYZW.every(checkProp);
}
if (value instanceof Quat) {
const length = value.length();
// Don't want developers of denormalized Quat's when they normalize it.
if (loc !== 'Quat#normalize' && loc !== 'Quat#mulScalar') {
// A quaternion should have unit length, but can become denormalized due to
// floating point precision errors (aka error creep). For instance through:
// - Successive quaternion operations
// - Conversion from matrices, which accumulated FP precision loss.
// Simple solution is to renormalize the quaternion.
if (Math.abs(1 - length) > 0.001) {
warn('Quat is denormalized, please renormalize it before use.');
return false;
}
}
return propsXYZW.every(checkProp);
}
if (value instanceof Mat3) {
return props9.every(prop => validateNumber(value.data, prop));
}
if (value instanceof Mat4) {
return props16.every(prop => validateNumber(value.data, prop));
}
return true;
}
customValidations.push(validate);
export const typePanel = new TypePanel();
globalThis.parent.addEventListener('message', (e) => {
if (e.data.type !== 'rti') {
return;
}
typePanel.handleEvent(e);
});
2 changes: 1 addition & 1 deletion src/platform/graphics/index-buffer.js
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,7 @@ class IndexBuffer {
/**
* Set preallocated data on the index buffer.
*
* @param {ArrayBuffer} data - The index data to set.
* @param {ArrayBuffer|Uint16Array} data - The index data to set.
* @returns {boolean} True if the data was set successfully, false otherwise.
* @ignore
*/
Expand Down
2 changes: 1 addition & 1 deletion src/platform/graphics/texture.js
Original file line number Diff line number Diff line change
Expand Up @@ -876,7 +876,7 @@ class Texture {
* Set the pixel data of the texture from a canvas, image, video DOM element. If the texture is
* a cubemap, the supplied source must be an array of 6 canvases, images or videos.
*
* @param {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement|HTMLCanvasElement[]|HTMLImageElement[]|HTMLVideoElement[]} source - A
* @param {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement|HTMLCanvasElement[]|HTMLImageElement[]|HTMLVideoElement[]|ImageBitmap} source - A
* canvas, image or video element, or an array of 6 canvas, image or video elements.
* @param {number} [mipLevel] - A non-negative integer specifying the image level of detail.
* Defaults to 0, which represents the base image source. A level value of N, that is greater
Expand Down
2 changes: 1 addition & 1 deletion src/platform/graphics/vertex-buffer.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ class VertexBuffer {
* @param {object} [options] - Object for passing optional arguments.
* @param {number} [options.usage] - The usage type of the vertex buffer (see BUFFER_*).
* Defaults to BUFFER_STATIC.
* @param {ArrayBuffer} [options.data] - Initial data.
* @param {ArrayBuffer|Float32Array} [options.data] - Initial data.
* @param {boolean} [options.storage] - Defines if the vertex buffer can be used as a storage
* buffer by a compute shader. Defaults to false. Only supported on WebGPU.
*/
Expand Down
2 changes: 0 additions & 2 deletions src/platform/graphics/vertex-iterator.js
Original file line number Diff line number Diff line change
Expand Up @@ -122,8 +122,6 @@ class VertexIteratorAccessor {
* that are not relevant to this attribute.
* @param {number} vertexElement.stride - The number of total bytes that are between the start
* of one vertex, and the start of the next.
* @param {ScopeId} vertexElement.scopeId - The shader input variable corresponding to the
* attribute.
* @param {number} vertexElement.size - The size of the attribute in bytes.
* @param {VertexFormat} vertexFormat - A vertex format that defines the layout of vertex data
* inside the buffer.
Expand Down
4 changes: 2 additions & 2 deletions src/platform/input/keyboard-event.js
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ class KeyboardEvent {
/**
* Create a new KeyboardEvent.
*
* @param {Keyboard} keyboard - The keyboard object which is firing the event.
* @param {globalThis.KeyboardEvent} event - The original browser event that was fired.
* @param {Keyboard} [keyboard] - The keyboard object which is firing the event.
* @param {globalThis.KeyboardEvent} [event] - The original browser event that was fired.
* @example
* const onKeyDown = function (e) {
* if (e.key === pc.KEY_SPACE) {
Expand Down
Loading