From e4db3560255965089d10236a2549538f963912b5 Mon Sep 17 00:00:00 2001 From: UnTamedStArBlOb Date: Wed, 2 Apr 2025 23:48:55 -0400 Subject: [PATCH] typescript def file generator from jsdoc annotations --- .../src/avatars-renderer/Avatar.h | 2 +- libraries/avatars/src/AvatarData.cpp | 14 +- .../controllers/impl/MappingBuilderProxy.h | 4 +- .../src/controllers/impl/RouteBuilderProxy.h | 4 +- .../GraphicsScriptingInterface.h | 2 +- .../src/graphics-scripting/ScriptableMesh.cpp | 2 +- .../graphics-scripting/ScriptableMeshPart.h | 8 +- libraries/midi/src/Midi.h | 4 +- libraries/networking/src/AssetClient.cpp | 5 +- libraries/physics/src/ObjectDynamic.cpp | 6 +- libraries/render-utils/src/GeometryCache.h | 13 + .../src/AssetScriptingInterface.cpp | 27 + .../src/ConsoleScriptingInterface.h | 14 +- libraries/script-engine/src/ScriptManager.cpp | 2 +- libraries/script-engine/src/ScriptManager.h | 2 +- .../src/ScriptManagerScriptingInterface.h | 8 +- libraries/shared/src/DebugDraw.h | 4 +- libraries/ui/src/QmlFragmentClass.h | 2 +- tools/jsdoc/CMakeLists.txt | 2 + tools/jsdoc/overte-tsd-jsdoc/Dictionary.js | 3 + .../jsdoc/overte-tsd-jsdoc/Dictionary.js.map | 1 + tools/jsdoc/overte-tsd-jsdoc/Emitter.js | 681 ++++++++++++++++++ tools/jsdoc/overte-tsd-jsdoc/Emitter.js.map | 1 + tools/jsdoc/overte-tsd-jsdoc/LICENSE | 21 + tools/jsdoc/overte-tsd-jsdoc/PropTree.js | 50 ++ tools/jsdoc/overte-tsd-jsdoc/PropTree.js.map | 1 + tools/jsdoc/overte-tsd-jsdoc/assert_never.js | 7 + .../overte-tsd-jsdoc/assert_never.js.map | 1 + .../jsdoc/overte-tsd-jsdoc/create_helpers.js | 390 ++++++++++ .../overte-tsd-jsdoc/create_helpers.js.map | 1 + tools/jsdoc/overte-tsd-jsdoc/doclet_utils.js | 164 +++++ .../overte-tsd-jsdoc/doclet_utils.js.map | 1 + tools/jsdoc/overte-tsd-jsdoc/logger.js | 59 ++ tools/jsdoc/overte-tsd-jsdoc/logger.js.map | 1 + tools/jsdoc/overte-tsd-jsdoc/package.json | 41 ++ tools/jsdoc/overte-tsd-jsdoc/plugin.js | 25 + tools/jsdoc/overte-tsd-jsdoc/plugin.js.map | 1 + tools/jsdoc/overte-tsd-jsdoc/publish.js | 82 +++ tools/jsdoc/overte-tsd-jsdoc/publish.js.map | 1 + .../overte-tsd-jsdoc/type_resolve_helpers.js | 523 ++++++++++++++ .../type_resolve_helpers.js.map | 1 + 41 files changed, 2145 insertions(+), 36 deletions(-) create mode 100644 tools/jsdoc/overte-tsd-jsdoc/Dictionary.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/Dictionary.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/Emitter.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/Emitter.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/LICENSE create mode 100644 tools/jsdoc/overte-tsd-jsdoc/PropTree.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/PropTree.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/assert_never.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/assert_never.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/create_helpers.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/create_helpers.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/doclet_utils.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/doclet_utils.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/logger.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/logger.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/package.json create mode 100644 tools/jsdoc/overte-tsd-jsdoc/plugin.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/plugin.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/publish.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/publish.js.map create mode 100644 tools/jsdoc/overte-tsd-jsdoc/type_resolve_helpers.js create mode 100644 tools/jsdoc/overte-tsd-jsdoc/type_resolve_helpers.js.map diff --git a/libraries/avatars-renderer/src/avatars-renderer/Avatar.h b/libraries/avatars-renderer/src/avatars-renderer/Avatar.h index c3b6f9b92d..619bab842a 100644 --- a/libraries/avatars-renderer/src/avatars-renderer/Avatar.h +++ b/libraries/avatars-renderer/src/avatars-renderer/Avatar.h @@ -565,7 +565,7 @@ signals: * restrictions on permissible scale values imposed by the domain. * @function MyAvatar.targetScaleChanged * @param {number} targetScale - The avatar's target scale. - * @returns Signal + * @returns {*} Signal */ void targetScaleChanged(float targetScale); diff --git a/libraries/avatars/src/AvatarData.cpp b/libraries/avatars/src/AvatarData.cpp index fc28ad9e02..ef792dd328 100644 --- a/libraries/avatars/src/AvatarData.cpp +++ b/libraries/avatars/src/AvatarData.cpp @@ -2857,14 +2857,24 @@ glm::mat4 AvatarData::getControllerRightHandMatrix() const { * @property {boolean} intersects - true if an avatar is intersected, false if it isn't. * @property {string} avatarID - The ID of the avatar that is intersected. * @property {number} distance - The distance from the ray origin to the intersection. - * @property {string} face - The name of the box face that is intersected; "UNKNOWN_FACE" if mesh was picked - * against. + * @property {string} face - The name of the box face that is intersected; "UNKNOWN_FACE" if mesh was picked against. * @property {Vec3} intersection - The ray intersection point in world coordinates. * @property {Vec3} surfaceNormal - The surface normal at the intersection point. * @property {number} jointIndex - The index of the joint intersected. * @property {SubmeshIntersection} extraInfo - Extra information on the mesh intersected if mesh was picked against, * {} if it wasn't. */ + + /*@jsdoc + * Information about a parabola-to-avatar intersection. + * @typedef {Object} ParabolaToAvatarIntersectionParameters + * @property {PickParabola} pick - The pick used for the intersection calculation. + * @property {Uuid[]} avatarsToInclude - List of avatars to include in the intersection check. + * @property {Uuid[]} avatarsToDiscard - List of avatars to exclude from the intersection check. + * + * @typedef {RayToAvatarIntersectionResult} ParabolaToAvatarIntersectionResult + */ + ScriptValue RayToAvatarIntersectionResultToScriptValue(ScriptEngine* engine, const RayToAvatarIntersectionResult& value) { ScriptValue obj = engine->newObject(); obj.setProperty("intersects", value.intersects); diff --git a/libraries/controllers/src/controllers/impl/MappingBuilderProxy.h b/libraries/controllers/src/controllers/impl/MappingBuilderProxy.h index 99004f9f41..567dbd0657 100644 --- a/libraries/controllers/src/controllers/impl/MappingBuilderProxy.h +++ b/libraries/controllers/src/controllers/impl/MappingBuilderProxy.h @@ -116,9 +116,9 @@ class UserInputMapper; * A filter in a {@link Controller.MappingJSONRoute}. * @typedef {object} Controller.MappingJSONFilter * @property {string} type - The name of the filter, being the name of the one of the {@link RouteObject}'s filter methods. - * @property {string} [?] - If the filter method has a first parameter, the property name is the name of that parameter and the + * @property {string} [_1] - If the filter method has a first parameter, the property name is the name of that parameter and the * property value is the value to use. - * @property {string} [?] - If the filter method has a second parameter, the property name is the name of that parameter and + * @property {string} [_2] - If the filter method has a second parameter, the property name is the name of that parameter and * the property value is the value to use. * @example A hysteresis filter. * { diff --git a/libraries/controllers/src/controllers/impl/RouteBuilderProxy.h b/libraries/controllers/src/controllers/impl/RouteBuilderProxy.h index da3e3ec26b..8879d3611b 100644 --- a/libraries/controllers/src/controllers/impl/RouteBuilderProxy.h +++ b/libraries/controllers/src/controllers/impl/RouteBuilderProxy.h @@ -71,7 +71,7 @@ class RouteBuilderProxy : public QObject { * routes using the same input are processed. *

This is a QML-specific version of {@link MappingObject#when|when}: use this version in QML files.

* @function RouteObject#whenQml - * @param {condition|condition[]} expression -

A condition may be a:

+ * @param { boolean | boolean[] | number | number[] } expression -

A condition may be a:

*