@itwin/core-backend 5.0.0-dev.90 → 5.0.0-dev.93
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/lib/esm/BackendHubAccess.d.ts +215 -0
- package/lib/esm/BackendHubAccess.d.ts.map +1 -0
- package/lib/esm/BackendHubAccess.js +41 -0
- package/lib/esm/BackendHubAccess.js.map +1 -0
- package/lib/esm/BackendLoggerCategory.d.ts +88 -0
- package/lib/esm/BackendLoggerCategory.d.ts.map +1 -0
- package/lib/esm/BackendLoggerCategory.js +93 -0
- package/lib/esm/BackendLoggerCategory.js.map +1 -0
- package/lib/esm/BisCoreSchema.d.ts +22 -0
- package/lib/esm/BisCoreSchema.d.ts.map +1 -0
- package/lib/esm/BisCoreSchema.js +61 -0
- package/lib/esm/BisCoreSchema.js.map +1 -0
- package/lib/esm/BlobContainerService.d.ts +159 -0
- package/lib/esm/BlobContainerService.d.ts.map +1 -0
- package/lib/esm/BlobContainerService.js +15 -0
- package/lib/esm/BlobContainerService.js.map +1 -0
- package/lib/esm/BriefcaseManager.d.ts +213 -0
- package/lib/esm/BriefcaseManager.d.ts.map +1 -0
- package/lib/esm/BriefcaseManager.js +520 -0
- package/lib/esm/BriefcaseManager.js.map +1 -0
- package/lib/esm/Category.d.ts +136 -0
- package/lib/esm/Category.d.ts.map +1 -0
- package/lib/esm/Category.js +224 -0
- package/lib/esm/Category.js.map +1 -0
- package/lib/esm/ChangeSummaryManager.d.ts +161 -0
- package/lib/esm/ChangeSummaryManager.d.ts.map +1 -0
- package/lib/esm/ChangeSummaryManager.js +414 -0
- package/lib/esm/ChangeSummaryManager.js.map +1 -0
- package/lib/esm/ChangedElementsDb.d.ts +101 -0
- package/lib/esm/ChangedElementsDb.d.ts.map +1 -0
- package/lib/esm/ChangedElementsDb.js +165 -0
- package/lib/esm/ChangedElementsDb.js.map +1 -0
- package/lib/esm/ChangesetECAdaptor.d.ts +203 -0
- package/lib/esm/ChangesetECAdaptor.d.ts.map +1 -0
- package/lib/esm/ChangesetECAdaptor.js +814 -0
- package/lib/esm/ChangesetECAdaptor.js.map +1 -0
- package/lib/esm/ChannelControl.d.ts +68 -0
- package/lib/esm/ChannelControl.d.ts.map +1 -0
- package/lib/esm/ChannelControl.js +15 -0
- package/lib/esm/ChannelControl.js.map +1 -0
- package/lib/esm/CheckpointManager.d.ts +123 -0
- package/lib/esm/CheckpointManager.d.ts.map +1 -0
- package/lib/esm/CheckpointManager.js +375 -0
- package/lib/esm/CheckpointManager.js.map +1 -0
- package/lib/esm/ClassRegistry.d.ts +134 -0
- package/lib/esm/ClassRegistry.d.ts.map +1 -0
- package/lib/esm/ClassRegistry.js +324 -0
- package/lib/esm/ClassRegistry.js.map +1 -0
- package/lib/esm/CloudSqlite.d.ts +682 -0
- package/lib/esm/CloudSqlite.d.ts.map +1 -0
- package/lib/esm/CloudSqlite.js +511 -0
- package/lib/esm/CloudSqlite.js.map +1 -0
- package/lib/esm/CodeService.d.ts +402 -0
- package/lib/esm/CodeService.d.ts.map +1 -0
- package/lib/esm/CodeService.js +65 -0
- package/lib/esm/CodeService.js.map +1 -0
- package/lib/esm/CodeSpecs.d.ts +59 -0
- package/lib/esm/CodeSpecs.d.ts.map +1 -0
- package/lib/esm/CodeSpecs.js +152 -0
- package/lib/esm/CodeSpecs.js.map +1 -0
- package/lib/esm/ConcurrentQuery.d.ts +14 -0
- package/lib/esm/ConcurrentQuery.d.ts.map +1 -0
- package/lib/esm/ConcurrentQuery.js +33 -0
- package/lib/esm/ConcurrentQuery.js.map +1 -0
- package/lib/esm/CustomViewState3dCreator.d.ts +22 -0
- package/lib/esm/CustomViewState3dCreator.d.ts.map +1 -0
- package/lib/esm/CustomViewState3dCreator.js +78 -0
- package/lib/esm/CustomViewState3dCreator.js.map +1 -0
- package/lib/esm/DevTools.d.ts +73 -0
- package/lib/esm/DevTools.d.ts.map +1 -0
- package/lib/esm/DevTools.js +153 -0
- package/lib/esm/DevTools.js.map +1 -0
- package/lib/esm/DisplayStyle.d.ts +99 -0
- package/lib/esm/DisplayStyle.d.ts.map +1 -0
- package/lib/esm/DisplayStyle.js +264 -0
- package/lib/esm/DisplayStyle.js.map +1 -0
- package/lib/esm/ECDb.d.ts +170 -0
- package/lib/esm/ECDb.d.ts.map +1 -0
- package/lib/esm/ECDb.js +329 -0
- package/lib/esm/ECDb.js.map +1 -0
- package/lib/esm/ECSchemaXmlContext.d.ts +46 -0
- package/lib/esm/ECSchemaXmlContext.d.ts.map +1 -0
- package/lib/esm/ECSchemaXmlContext.js +66 -0
- package/lib/esm/ECSchemaXmlContext.js.map +1 -0
- package/lib/esm/ECSqlStatement.d.ts +492 -0
- package/lib/esm/ECSqlStatement.d.ts.map +1 -0
- package/lib/esm/ECSqlStatement.js +810 -0
- package/lib/esm/ECSqlStatement.js.map +1 -0
- package/lib/esm/Element.d.ts +987 -0
- package/lib/esm/Element.d.ts.map +1 -0
- package/lib/esm/Element.js +1337 -0
- package/lib/esm/Element.js.map +1 -0
- package/lib/esm/ElementAspect.d.ts +164 -0
- package/lib/esm/ElementAspect.d.ts.map +1 -0
- package/lib/esm/ElementAspect.js +204 -0
- package/lib/esm/ElementAspect.js.map +1 -0
- package/lib/esm/ElementGraphics.d.ts +7 -0
- package/lib/esm/ElementGraphics.d.ts.map +1 -0
- package/lib/esm/ElementGraphics.js +36 -0
- package/lib/esm/ElementGraphics.js.map +1 -0
- package/lib/esm/ElementTreeWalker.d.ts +182 -0
- package/lib/esm/ElementTreeWalker.d.ts.map +1 -0
- package/lib/esm/ElementTreeWalker.js +421 -0
- package/lib/esm/ElementTreeWalker.js.map +1 -0
- package/lib/esm/Entity.d.ts +142 -0
- package/lib/esm/Entity.d.ts.map +1 -0
- package/lib/esm/Entity.js +186 -0
- package/lib/esm/Entity.js.map +1 -0
- package/lib/esm/EntityReferences.d.ts +50 -0
- package/lib/esm/EntityReferences.d.ts.map +1 -0
- package/lib/esm/EntityReferences.js +92 -0
- package/lib/esm/EntityReferences.js.map +1 -0
- package/lib/esm/ExportGraphics.d.ts +318 -0
- package/lib/esm/ExportGraphics.d.ts.map +1 -0
- package/lib/esm/ExportGraphics.js +209 -0
- package/lib/esm/ExportGraphics.js.map +1 -0
- package/lib/esm/ExternalSource.d.ts +89 -0
- package/lib/esm/ExternalSource.d.ts.map +1 -0
- package/lib/esm/ExternalSource.js +139 -0
- package/lib/esm/ExternalSource.js.map +1 -0
- package/lib/esm/FontFile.d.ts +68 -0
- package/lib/esm/FontFile.d.ts.map +1 -0
- package/lib/esm/FontFile.js +33 -0
- package/lib/esm/FontFile.js.map +1 -0
- package/lib/esm/GeoCoordConfig.d.ts +30 -0
- package/lib/esm/GeoCoordConfig.d.ts.map +1 -0
- package/lib/esm/GeoCoordConfig.js +78 -0
- package/lib/esm/GeoCoordConfig.js.map +1 -0
- package/lib/esm/GeographicCRSServices.d.ts +40 -0
- package/lib/esm/GeographicCRSServices.d.ts.map +1 -0
- package/lib/esm/GeographicCRSServices.js +17 -0
- package/lib/esm/GeographicCRSServices.js.map +1 -0
- package/lib/esm/GeometrySummary.d.ts +5 -0
- package/lib/esm/GeometrySummary.d.ts.map +1 -0
- package/lib/esm/GeometrySummary.js +381 -0
- package/lib/esm/GeometrySummary.js.map +1 -0
- package/lib/esm/HubMock.d.ts +95 -0
- package/lib/esm/HubMock.d.ts.map +1 -0
- package/lib/esm/HubMock.js +220 -0
- package/lib/esm/HubMock.js.map +1 -0
- package/lib/esm/IModelDb.d.ts +1398 -0
- package/lib/esm/IModelDb.d.ts.map +1 -0
- package/lib/esm/IModelDb.js +3230 -0
- package/lib/esm/IModelDb.js.map +1 -0
- package/lib/esm/IModelDbFonts.d.ts +54 -0
- package/lib/esm/IModelDbFonts.d.ts.map +1 -0
- package/lib/esm/IModelDbFonts.js +9 -0
- package/lib/esm/IModelDbFonts.js.map +1 -0
- package/lib/esm/IModelElementCloneContext.d.ts +92 -0
- package/lib/esm/IModelElementCloneContext.d.ts.map +1 -0
- package/lib/esm/IModelElementCloneContext.js +168 -0
- package/lib/esm/IModelElementCloneContext.js.map +1 -0
- package/lib/esm/IModelHost.d.ts +387 -0
- package/lib/esm/IModelHost.d.ts.map +1 -0
- package/lib/esm/IModelHost.js +502 -0
- package/lib/esm/IModelHost.js.map +1 -0
- package/lib/esm/IModelJsFs.d.ts +62 -0
- package/lib/esm/IModelJsFs.d.ts.map +1 -0
- package/lib/esm/IModelJsFs.js +151 -0
- package/lib/esm/IModelJsFs.js.map +1 -0
- package/lib/esm/ImageSourceConversion.d.ts +49 -0
- package/lib/esm/ImageSourceConversion.d.ts.map +1 -0
- package/lib/esm/ImageSourceConversion.js +33 -0
- package/lib/esm/ImageSourceConversion.js.map +1 -0
- package/lib/esm/IpcHost.d.ts +111 -0
- package/lib/esm/IpcHost.d.ts.map +1 -0
- package/lib/esm/IpcHost.js +311 -0
- package/lib/esm/IpcHost.js.map +1 -0
- package/lib/esm/LineStyle.d.ts +312 -0
- package/lib/esm/LineStyle.d.ts.map +1 -0
- package/lib/esm/LineStyle.js +293 -0
- package/lib/esm/LineStyle.js.map +1 -0
- package/lib/esm/LocalHub.d.ts +163 -0
- package/lib/esm/LocalHub.d.ts.map +1 -0
- package/lib/esm/LocalHub.js +583 -0
- package/lib/esm/LocalHub.js.map +1 -0
- package/lib/esm/LocalhostIpcHost.d.ts +22 -0
- package/lib/esm/LocalhostIpcHost.d.ts.map +1 -0
- package/lib/esm/LocalhostIpcHost.js +74 -0
- package/lib/esm/LocalhostIpcHost.js.map +1 -0
- package/lib/esm/LockControl.d.ts +73 -0
- package/lib/esm/LockControl.d.ts.map +1 -0
- package/lib/esm/LockControl.js +9 -0
- package/lib/esm/LockControl.js.map +1 -0
- package/lib/esm/Material.d.ts +131 -0
- package/lib/esm/Material.d.ts.map +1 -0
- package/lib/esm/Material.js +235 -0
- package/lib/esm/Material.js.map +1 -0
- package/lib/esm/Model.d.ts +375 -0
- package/lib/esm/Model.d.ts.map +1 -0
- package/lib/esm/Model.js +484 -0
- package/lib/esm/Model.js.map +1 -0
- package/lib/esm/NativeAppStorage.d.ts +52 -0
- package/lib/esm/NativeAppStorage.d.ts.map +1 -0
- package/lib/esm/NativeAppStorage.js +205 -0
- package/lib/esm/NativeAppStorage.js.map +1 -0
- package/lib/esm/NativeHost.d.ts +53 -0
- package/lib/esm/NativeHost.d.ts.map +1 -0
- package/lib/esm/NativeHost.js +158 -0
- package/lib/esm/NativeHost.js.map +1 -0
- package/lib/esm/NavigationRelationship.d.ts +185 -0
- package/lib/esm/NavigationRelationship.d.ts.map +1 -0
- package/lib/esm/NavigationRelationship.js +238 -0
- package/lib/esm/NavigationRelationship.js.map +1 -0
- package/lib/esm/PromiseMemoizer.d.ts +48 -0
- package/lib/esm/PromiseMemoizer.d.ts.map +1 -0
- package/lib/esm/PromiseMemoizer.js +101 -0
- package/lib/esm/PromiseMemoizer.js.map +1 -0
- package/lib/esm/PropertyStore.d.ts +134 -0
- package/lib/esm/PropertyStore.d.ts.map +1 -0
- package/lib/esm/PropertyStore.js +177 -0
- package/lib/esm/PropertyStore.js.map +1 -0
- package/lib/esm/Relationship.d.ts +399 -0
- package/lib/esm/Relationship.d.ts.map +1 -0
- package/lib/esm/Relationship.js +474 -0
- package/lib/esm/Relationship.js.map +1 -0
- package/lib/esm/RpcBackend.d.ts +6 -0
- package/lib/esm/RpcBackend.d.ts.map +1 -0
- package/lib/esm/RpcBackend.js +28 -0
- package/lib/esm/RpcBackend.js.map +1 -0
- package/lib/esm/SQLiteDb.d.ts +324 -0
- package/lib/esm/SQLiteDb.d.ts.map +1 -0
- package/lib/esm/SQLiteDb.js +379 -0
- package/lib/esm/SQLiteDb.js.map +1 -0
- package/lib/esm/Schema.d.ts +79 -0
- package/lib/esm/Schema.d.ts.map +1 -0
- package/lib/esm/Schema.js +113 -0
- package/lib/esm/Schema.js.map +1 -0
- package/lib/esm/SchemaSync.d.ts +47 -0
- package/lib/esm/SchemaSync.d.ts.map +1 -0
- package/lib/esm/SchemaSync.js +148 -0
- package/lib/esm/SchemaSync.js.map +1 -0
- package/lib/esm/SchemaUtils.d.ts +19 -0
- package/lib/esm/SchemaUtils.d.ts.map +1 -0
- package/lib/esm/SchemaUtils.js +37 -0
- package/lib/esm/SchemaUtils.js.map +1 -0
- package/lib/esm/SheetIndex.d.ts +148 -0
- package/lib/esm/SheetIndex.d.ts.map +1 -0
- package/lib/esm/SheetIndex.js +228 -0
- package/lib/esm/SheetIndex.js.map +1 -0
- package/lib/esm/SqliteChangesetReader.d.ts +278 -0
- package/lib/esm/SqliteChangesetReader.d.ts.map +1 -0
- package/lib/esm/SqliteChangesetReader.js +337 -0
- package/lib/esm/SqliteChangesetReader.js.map +1 -0
- package/lib/esm/SqliteStatement.d.ts +375 -0
- package/lib/esm/SqliteStatement.d.ts.map +1 -0
- package/lib/esm/SqliteStatement.js +615 -0
- package/lib/esm/SqliteStatement.js.map +1 -0
- package/lib/esm/TextAnnotationElement.d.ts +54 -0
- package/lib/esm/TextAnnotationElement.d.ts.map +1 -0
- package/lib/esm/TextAnnotationElement.js +89 -0
- package/lib/esm/TextAnnotationElement.js.map +1 -0
- package/lib/esm/TextAnnotationGeometry.d.ts +32 -0
- package/lib/esm/TextAnnotationGeometry.d.ts.map +1 -0
- package/lib/esm/TextAnnotationGeometry.js +181 -0
- package/lib/esm/TextAnnotationGeometry.js.map +1 -0
- package/lib/esm/TextAnnotationLayout.d.ts +177 -0
- package/lib/esm/TextAnnotationLayout.d.ts.map +1 -0
- package/lib/esm/TextAnnotationLayout.js +513 -0
- package/lib/esm/TextAnnotationLayout.js.map +1 -0
- package/lib/esm/Texture.d.ts +58 -0
- package/lib/esm/Texture.d.ts.map +1 -0
- package/lib/esm/Texture.js +81 -0
- package/lib/esm/Texture.js.map +1 -0
- package/lib/esm/TileStorage.d.ts +59 -0
- package/lib/esm/TileStorage.d.ts.map +1 -0
- package/lib/esm/TileStorage.js +158 -0
- package/lib/esm/TileStorage.js.map +1 -0
- package/lib/esm/TxnManager.d.ts +296 -0
- package/lib/esm/TxnManager.d.ts.map +1 -0
- package/lib/esm/TxnManager.js +619 -0
- package/lib/esm/TxnManager.js.map +1 -0
- package/lib/esm/ViewDefinition.d.ts +392 -0
- package/lib/esm/ViewDefinition.d.ts.map +1 -0
- package/lib/esm/ViewDefinition.js +638 -0
- package/lib/esm/ViewDefinition.js.map +1 -0
- package/lib/esm/ViewStateHydrator.d.ts +14 -0
- package/lib/esm/ViewStateHydrator.d.ts.map +1 -0
- package/lib/esm/ViewStateHydrator.js +89 -0
- package/lib/esm/ViewStateHydrator.js.map +1 -0
- package/lib/esm/ViewStore.d.ts +502 -0
- package/lib/esm/ViewStore.d.ts.map +1 -0
- package/lib/esm/ViewStore.js +1259 -0
- package/lib/esm/ViewStore.js.map +1 -0
- package/lib/esm/core-backend.d.ts +183 -0
- package/lib/esm/core-backend.d.ts.map +1 -0
- package/lib/esm/core-backend.js +187 -0
- package/lib/esm/core-backend.js.map +1 -0
- package/lib/esm/domains/FunctionalElements.d.ts +86 -0
- package/lib/esm/domains/FunctionalElements.d.ts.map +1 -0
- package/lib/esm/domains/FunctionalElements.js +117 -0
- package/lib/esm/domains/FunctionalElements.js.map +1 -0
- package/lib/esm/domains/FunctionalSchema.d.ts +14 -0
- package/lib/esm/domains/FunctionalSchema.d.ts.map +1 -0
- package/lib/esm/domains/FunctionalSchema.js +37 -0
- package/lib/esm/domains/FunctionalSchema.js.map +1 -0
- package/lib/esm/domains/GenericElements.d.ts +160 -0
- package/lib/esm/domains/GenericElements.d.ts.map +1 -0
- package/lib/esm/domains/GenericElements.js +225 -0
- package/lib/esm/domains/GenericElements.js.map +1 -0
- package/lib/esm/domains/GenericSchema.d.ts +11 -0
- package/lib/esm/domains/GenericSchema.d.ts.map +1 -0
- package/lib/esm/domains/GenericSchema.js +25 -0
- package/lib/esm/domains/GenericSchema.js.map +1 -0
- package/lib/esm/internal/ChangesetConflictArgs.d.ts +62 -0
- package/lib/esm/internal/ChangesetConflictArgs.d.ts.map +1 -0
- package/lib/esm/internal/ChangesetConflictArgs.js +104 -0
- package/lib/esm/internal/ChangesetConflictArgs.js.map +1 -0
- package/lib/esm/internal/ChannelAdmin.d.ts +34 -0
- package/lib/esm/internal/ChannelAdmin.d.ts.map +1 -0
- package/lib/esm/internal/ChannelAdmin.js +122 -0
- package/lib/esm/internal/ChannelAdmin.js.map +1 -0
- package/lib/esm/internal/FontFileImpl.d.ts +34 -0
- package/lib/esm/internal/FontFileImpl.d.ts.map +1 -0
- package/lib/esm/internal/FontFileImpl.js +135 -0
- package/lib/esm/internal/FontFileImpl.js.map +1 -0
- package/lib/esm/internal/IModelDbFontsImpl.d.ts +7 -0
- package/lib/esm/internal/IModelDbFontsImpl.d.ts.map +1 -0
- package/lib/esm/internal/IModelDbFontsImpl.js +183 -0
- package/lib/esm/internal/IModelDbFontsImpl.js.map +1 -0
- package/lib/esm/internal/NativePlatform.d.ts +15 -0
- package/lib/esm/internal/NativePlatform.d.ts.map +1 -0
- package/lib/esm/internal/NativePlatform.js +43 -0
- package/lib/esm/internal/NativePlatform.js.map +1 -0
- package/lib/esm/internal/NoLocks.d.ts +6 -0
- package/lib/esm/internal/NoLocks.d.ts.map +1 -0
- package/lib/esm/internal/NoLocks.js +24 -0
- package/lib/esm/internal/NoLocks.js.map +1 -0
- package/lib/esm/internal/ServerBasedLocks.d.ts +52 -0
- package/lib/esm/internal/ServerBasedLocks.d.ts.map +1 -0
- package/lib/esm/internal/ServerBasedLocks.js +175 -0
- package/lib/esm/internal/ServerBasedLocks.js.map +1 -0
- package/lib/esm/internal/Symbols.d.ts +18 -0
- package/lib/esm/internal/Symbols.d.ts.map +1 -0
- package/lib/esm/internal/Symbols.js +25 -0
- package/lib/esm/internal/Symbols.js.map +1 -0
- package/lib/esm/internal/cross-package.d.ts +4 -0
- package/lib/esm/internal/cross-package.d.ts.map +1 -0
- package/lib/esm/internal/cross-package.js +8 -0
- package/lib/esm/internal/cross-package.js.map +1 -0
- package/lib/esm/internal/workspace/SettingsImpl.d.ts +43 -0
- package/lib/esm/internal/workspace/SettingsImpl.d.ts.map +1 -0
- package/lib/esm/internal/workspace/SettingsImpl.js +154 -0
- package/lib/esm/internal/workspace/SettingsImpl.js.map +1 -0
- package/lib/esm/internal/workspace/SettingsSchemasImpl.d.ts +6 -0
- package/lib/esm/internal/workspace/SettingsSchemasImpl.d.ts.map +1 -0
- package/lib/esm/internal/workspace/SettingsSchemasImpl.js +268 -0
- package/lib/esm/internal/workspace/SettingsSchemasImpl.js.map +1 -0
- package/lib/esm/internal/workspace/WorkspaceImpl.d.ts +41 -0
- package/lib/esm/internal/workspace/WorkspaceImpl.d.ts.map +1 -0
- package/lib/esm/internal/workspace/WorkspaceImpl.js +691 -0
- package/lib/esm/internal/workspace/WorkspaceImpl.js.map +1 -0
- package/lib/esm/internal/workspace/WorkspaceSqliteDb.d.ts +10 -0
- package/lib/esm/internal/workspace/WorkspaceSqliteDb.d.ts.map +1 -0
- package/lib/esm/internal/workspace/WorkspaceSqliteDb.js +35 -0
- package/lib/esm/internal/workspace/WorkspaceSqliteDb.js.map +1 -0
- package/lib/esm/rpc/multipart.d.ts +12 -0
- package/lib/esm/rpc/multipart.d.ts.map +1 -0
- package/lib/esm/rpc/multipart.js +67 -0
- package/lib/esm/rpc/multipart.js.map +1 -0
- package/lib/esm/rpc/tracing.d.ts +29 -0
- package/lib/esm/rpc/tracing.d.ts.map +1 -0
- package/lib/esm/rpc/tracing.js +71 -0
- package/lib/esm/rpc/tracing.js.map +1 -0
- package/lib/esm/rpc/web/logging.d.ts +10 -0
- package/lib/esm/rpc/web/logging.d.ts.map +1 -0
- package/lib/esm/rpc/web/logging.js +41 -0
- package/lib/esm/rpc/web/logging.js.map +1 -0
- package/lib/esm/rpc/web/request.d.ts +7 -0
- package/lib/esm/rpc/web/request.d.ts.map +1 -0
- package/lib/esm/rpc/web/request.js +71 -0
- package/lib/esm/rpc/web/request.js.map +1 -0
- package/lib/esm/rpc/web/response.d.ts +7 -0
- package/lib/esm/rpc/web/response.d.ts.map +1 -0
- package/lib/esm/rpc/web/response.js +136 -0
- package/lib/esm/rpc/web/response.js.map +1 -0
- package/lib/esm/rpc-impl/DevToolsRpcImpl.d.ts +16 -0
- package/lib/esm/rpc-impl/DevToolsRpcImpl.d.ts.map +1 -0
- package/lib/esm/rpc-impl/DevToolsRpcImpl.js +29 -0
- package/lib/esm/rpc-impl/DevToolsRpcImpl.js.map +1 -0
- package/lib/esm/rpc-impl/IModelReadRpcImpl.d.ts +51 -0
- package/lib/esm/rpc-impl/IModelReadRpcImpl.d.ts.map +1 -0
- package/lib/esm/rpc-impl/IModelReadRpcImpl.js +313 -0
- package/lib/esm/rpc-impl/IModelReadRpcImpl.js.map +1 -0
- package/lib/esm/rpc-impl/IModelTileRpcImpl.d.ts +21 -0
- package/lib/esm/rpc-impl/IModelTileRpcImpl.d.ts.map +1 -0
- package/lib/esm/rpc-impl/IModelTileRpcImpl.js +193 -0
- package/lib/esm/rpc-impl/IModelTileRpcImpl.js.map +1 -0
- package/lib/esm/rpc-impl/RpcBriefcaseUtility.d.ts +45 -0
- package/lib/esm/rpc-impl/RpcBriefcaseUtility.d.ts.map +1 -0
- package/lib/esm/rpc-impl/RpcBriefcaseUtility.js +166 -0
- package/lib/esm/rpc-impl/RpcBriefcaseUtility.js.map +1 -0
- package/lib/esm/rpc-impl/SnapshotIModelRpcImpl.d.ts +18 -0
- package/lib/esm/rpc-impl/SnapshotIModelRpcImpl.d.ts.map +1 -0
- package/lib/esm/rpc-impl/SnapshotIModelRpcImpl.js +41 -0
- package/lib/esm/rpc-impl/SnapshotIModelRpcImpl.js.map +1 -0
- package/lib/esm/test/AdvancedEqual.d.ts +38 -0
- package/lib/esm/test/AdvancedEqual.d.ts.map +1 -0
- package/lib/esm/test/AdvancedEqual.js +67 -0
- package/lib/esm/test/AdvancedEqual.js.map +1 -0
- package/lib/esm/test/AttachDb.test.d.ts +2 -0
- package/lib/esm/test/AttachDb.test.d.ts.map +1 -0
- package/lib/esm/test/AttachDb.test.js +157 -0
- package/lib/esm/test/AttachDb.test.js.map +1 -0
- package/lib/esm/test/GeometryTestUtil.d.ts +7 -0
- package/lib/esm/test/GeometryTestUtil.d.ts.map +1 -0
- package/lib/esm/test/GeometryTestUtil.js +25 -0
- package/lib/esm/test/GeometryTestUtil.js.map +1 -0
- package/lib/esm/test/IModelHost.test.d.ts +2 -0
- package/lib/esm/test/IModelHost.test.d.ts.map +1 -0
- package/lib/esm/test/IModelHost.test.js +187 -0
- package/lib/esm/test/IModelHost.test.js.map +1 -0
- package/lib/esm/test/IModelTestUtils.d.ts +173 -0
- package/lib/esm/test/IModelTestUtils.d.ts.map +1 -0
- package/lib/esm/test/IModelTestUtils.js +1113 -0
- package/lib/esm/test/IModelTestUtils.js.map +1 -0
- package/lib/esm/test/ImageSourceConversion.test.d.ts +2 -0
- package/lib/esm/test/ImageSourceConversion.test.d.ts.map +1 -0
- package/lib/esm/test/ImageSourceConversion.test.js +171 -0
- package/lib/esm/test/ImageSourceConversion.test.js.map +1 -0
- package/lib/esm/test/IpcHost.test.d.ts +2 -0
- package/lib/esm/test/IpcHost.test.d.ts.map +1 -0
- package/lib/esm/test/IpcHost.test.js +55 -0
- package/lib/esm/test/IpcHost.test.js.map +1 -0
- package/lib/esm/test/KnownTestLocations.d.ts +7 -0
- package/lib/esm/test/KnownTestLocations.d.ts.map +1 -0
- package/lib/esm/test/KnownTestLocations.js +27 -0
- package/lib/esm/test/KnownTestLocations.js.map +1 -0
- package/lib/esm/test/PrintElementTree.d.ts +7 -0
- package/lib/esm/test/PrintElementTree.d.ts.map +1 -0
- package/lib/esm/test/PrintElementTree.js +35 -0
- package/lib/esm/test/PrintElementTree.js.map +1 -0
- package/lib/esm/test/PropertyDb.test.d.ts +2 -0
- package/lib/esm/test/PropertyDb.test.d.ts.map +1 -0
- package/lib/esm/test/PropertyDb.test.js +71 -0
- package/lib/esm/test/PropertyDb.test.js.map +1 -0
- package/lib/esm/test/RevisionUtility.d.ts +33 -0
- package/lib/esm/test/RevisionUtility.d.ts.map +1 -0
- package/lib/esm/test/RevisionUtility.js +52 -0
- package/lib/esm/test/RevisionUtility.js.map +1 -0
- package/lib/esm/test/SchemaUtils.test.d.ts +2 -0
- package/lib/esm/test/SchemaUtils.test.d.ts.map +1 -0
- package/lib/esm/test/SchemaUtils.test.js +97 -0
- package/lib/esm/test/SchemaUtils.test.js.map +1 -0
- package/lib/esm/test/SequentialLogMatcher.d.ts +35 -0
- package/lib/esm/test/SequentialLogMatcher.d.ts.map +1 -0
- package/lib/esm/test/SequentialLogMatcher.js +130 -0
- package/lib/esm/test/SequentialLogMatcher.js.map +1 -0
- package/lib/esm/test/TestChangeSetUtility.d.ts +23 -0
- package/lib/esm/test/TestChangeSetUtility.d.ts.map +1 -0
- package/lib/esm/test/TestChangeSetUtility.js +65 -0
- package/lib/esm/test/TestChangeSetUtility.js.map +1 -0
- package/lib/esm/test/TestUtils.d.ts +38 -0
- package/lib/esm/test/TestUtils.d.ts.map +1 -0
- package/lib/esm/test/TestUtils.js +99 -0
- package/lib/esm/test/TestUtils.js.map +1 -0
- package/lib/esm/test/annotations/TextAnnotation.test.d.ts +2 -0
- package/lib/esm/test/annotations/TextAnnotation.test.d.ts.map +1 -0
- package/lib/esm/test/annotations/TextAnnotation.test.js +1135 -0
- package/lib/esm/test/annotations/TextAnnotation.test.js.map +1 -0
- package/lib/esm/test/categories/Category.test.d.ts +2 -0
- package/lib/esm/test/categories/Category.test.d.ts.map +1 -0
- package/lib/esm/test/categories/Category.test.js +51 -0
- package/lib/esm/test/categories/Category.test.js.map +1 -0
- package/lib/esm/test/codespec/CodeSpec.test.d.ts +2 -0
- package/lib/esm/test/codespec/CodeSpec.test.d.ts.map +1 -0
- package/lib/esm/test/codespec/CodeSpec.test.js +51 -0
- package/lib/esm/test/codespec/CodeSpec.test.js.map +1 -0
- package/lib/esm/test/ecdb/CTE.test.d.ts +2 -0
- package/lib/esm/test/ecdb/CTE.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/CTE.test.js +177 -0
- package/lib/esm/test/ecdb/CTE.test.js.map +1 -0
- package/lib/esm/test/ecdb/ConcurrentQueryLoad.test.d.ts +2 -0
- package/lib/esm/test/ecdb/ConcurrentQueryLoad.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ConcurrentQueryLoad.test.js +167 -0
- package/lib/esm/test/ecdb/ConcurrentQueryLoad.test.js.map +1 -0
- package/lib/esm/test/ecdb/ECDb.test.d.ts +2 -0
- package/lib/esm/test/ecdb/ECDb.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ECDb.test.js +642 -0
- package/lib/esm/test/ecdb/ECDb.test.js.map +1 -0
- package/lib/esm/test/ecdb/ECDbTestHelper.d.ts +5 -0
- package/lib/esm/test/ecdb/ECDbTestHelper.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ECDbTestHelper.js +28 -0
- package/lib/esm/test/ecdb/ECDbTestHelper.js.map +1 -0
- package/lib/esm/test/ecdb/ECSchemaXmlContext.test.d.ts +2 -0
- package/lib/esm/test/ecdb/ECSchemaXmlContext.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ECSchemaXmlContext.test.js +63 -0
- package/lib/esm/test/ecdb/ECSchemaXmlContext.test.js.map +1 -0
- package/lib/esm/test/ecdb/ECSqlAst.test.d.ts +5 -0
- package/lib/esm/test/ecdb/ECSqlAst.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ECSqlAst.test.js +971 -0
- package/lib/esm/test/ecdb/ECSqlAst.test.js.map +1 -0
- package/lib/esm/test/ecdb/ECSqlQuery.test.d.ts +2 -0
- package/lib/esm/test/ecdb/ECSqlQuery.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ECSqlQuery.test.js +770 -0
- package/lib/esm/test/ecdb/ECSqlQuery.test.js.map +1 -0
- package/lib/esm/test/ecdb/ECSqlReader.test.d.ts +2 -0
- package/lib/esm/test/ecdb/ECSqlReader.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ECSqlReader.test.js +669 -0
- package/lib/esm/test/ecdb/ECSqlReader.test.js.map +1 -0
- package/lib/esm/test/ecdb/ECSqlStatement.test.d.ts +2 -0
- package/lib/esm/test/ecdb/ECSqlStatement.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/ECSqlStatement.test.js +3239 -0
- package/lib/esm/test/ecdb/ECSqlStatement.test.js.map +1 -0
- package/lib/esm/test/ecdb/SqliteStatement.test.d.ts +2 -0
- package/lib/esm/test/ecdb/SqliteStatement.test.d.ts.map +1 -0
- package/lib/esm/test/ecdb/SqliteStatement.test.js +508 -0
- package/lib/esm/test/ecdb/SqliteStatement.test.js.map +1 -0
- package/lib/esm/test/ecsql/dataset/ECSqlDatasets.d.ts +4 -0
- package/lib/esm/test/ecsql/dataset/ECSqlDatasets.d.ts.map +1 -0
- package/lib/esm/test/ecsql/dataset/ECSqlDatasets.js +127 -0
- package/lib/esm/test/ecsql/dataset/ECSqlDatasets.js.map +1 -0
- package/lib/esm/test/ecsql/src/ECSqlTestGenerator.d.ts +2 -0
- package/lib/esm/test/ecsql/src/ECSqlTestGenerator.d.ts.map +1 -0
- package/lib/esm/test/ecsql/src/ECSqlTestGenerator.js +196 -0
- package/lib/esm/test/ecsql/src/ECSqlTestGenerator.js.map +1 -0
- package/lib/esm/test/ecsql/src/ECSqlTestParser.d.ts +66 -0
- package/lib/esm/test/ecsql/src/ECSqlTestParser.d.ts.map +1 -0
- package/lib/esm/test/ecsql/src/ECSqlTestParser.js +420 -0
- package/lib/esm/test/ecsql/src/ECSqlTestParser.js.map +1 -0
- package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.d.ts +2 -0
- package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.d.ts.map +1 -0
- package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.js +365 -0
- package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.js.map +1 -0
- package/lib/esm/test/element/DeleteDefinitionElements.test.d.ts +2 -0
- package/lib/esm/test/element/DeleteDefinitionElements.test.d.ts.map +1 -0
- package/lib/esm/test/element/DeleteDefinitionElements.test.js +208 -0
- package/lib/esm/test/element/DeleteDefinitionElements.test.js.map +1 -0
- package/lib/esm/test/element/ElementAspect.test.d.ts +2 -0
- package/lib/esm/test/element/ElementAspect.test.d.ts.map +1 -0
- package/lib/esm/test/element/ElementAspect.test.js +363 -0
- package/lib/esm/test/element/ElementAspect.test.js.map +1 -0
- package/lib/esm/test/element/ElementDependencyGraph.test.d.ts +2 -0
- package/lib/esm/test/element/ElementDependencyGraph.test.d.ts.map +1 -0
- package/lib/esm/test/element/ElementDependencyGraph.test.js +383 -0
- package/lib/esm/test/element/ElementDependencyGraph.test.js.map +1 -0
- package/lib/esm/test/element/ElementRoundTrip.test.d.ts +2 -0
- package/lib/esm/test/element/ElementRoundTrip.test.d.ts.map +1 -0
- package/lib/esm/test/element/ElementRoundTrip.test.js +916 -0
- package/lib/esm/test/element/ElementRoundTrip.test.js.map +1 -0
- package/lib/esm/test/element/ExcludedElements.test.d.ts +2 -0
- package/lib/esm/test/element/ExcludedElements.test.d.ts.map +1 -0
- package/lib/esm/test/element/ExcludedElements.test.js +57 -0
- package/lib/esm/test/element/ExcludedElements.test.js.map +1 -0
- package/lib/esm/test/element/ExternalSource.test.d.ts +2 -0
- package/lib/esm/test/element/ExternalSource.test.d.ts.map +1 -0
- package/lib/esm/test/element/ExternalSource.test.js +107 -0
- package/lib/esm/test/element/ExternalSource.test.js.map +1 -0
- package/lib/esm/test/element/NullStructArray.test.d.ts +2 -0
- package/lib/esm/test/element/NullStructArray.test.d.ts.map +1 -0
- package/lib/esm/test/element/NullStructArray.test.js +77 -0
- package/lib/esm/test/element/NullStructArray.test.js.map +1 -0
- package/lib/esm/test/element/UrlLink.test.d.ts +2 -0
- package/lib/esm/test/element/UrlLink.test.d.ts.map +1 -0
- package/lib/esm/test/element/UrlLink.test.js +36 -0
- package/lib/esm/test/element/UrlLink.test.js.map +1 -0
- package/lib/esm/test/font/FontFile.test.d.ts +2 -0
- package/lib/esm/test/font/FontFile.test.d.ts.map +1 -0
- package/lib/esm/test/font/FontFile.test.js +139 -0
- package/lib/esm/test/font/FontFile.test.js.map +1 -0
- package/lib/esm/test/font/IModelDbFonts.test.d.ts +2 -0
- package/lib/esm/test/font/IModelDbFonts.test.d.ts.map +1 -0
- package/lib/esm/test/font/IModelDbFonts.test.js +264 -0
- package/lib/esm/test/font/IModelDbFonts.test.js.map +1 -0
- package/lib/esm/test/hubaccess/BriefcaseManager.test.d.ts +2 -0
- package/lib/esm/test/hubaccess/BriefcaseManager.test.d.ts.map +1 -0
- package/lib/esm/test/hubaccess/BriefcaseManager.test.js +165 -0
- package/lib/esm/test/hubaccess/BriefcaseManager.test.js.map +1 -0
- package/lib/esm/test/hubaccess/CheckpointManager.test.d.ts +2 -0
- package/lib/esm/test/hubaccess/CheckpointManager.test.d.ts.map +1 -0
- package/lib/esm/test/hubaccess/CheckpointManager.test.js +137 -0
- package/lib/esm/test/hubaccess/CheckpointManager.test.js.map +1 -0
- package/lib/esm/test/imageData.d.ts +9 -0
- package/lib/esm/test/imageData.d.ts.map +1 -0
- package/lib/esm/test/imageData.js +16 -0
- package/lib/esm/test/imageData.js.map +1 -0
- package/lib/esm/test/imodel/ElementTreeWalker.test.d.ts +2 -0
- package/lib/esm/test/imodel/ElementTreeWalker.test.d.ts.map +1 -0
- package/lib/esm/test/imodel/ElementTreeWalker.test.js +382 -0
- package/lib/esm/test/imodel/ElementTreeWalker.test.js.map +1 -0
- package/lib/esm/test/imodel/GetTextureImage.test.d.ts +2 -0
- package/lib/esm/test/imodel/GetTextureImage.test.d.ts.map +1 -0
- package/lib/esm/test/imodel/GetTextureImage.test.js +29 -0
- package/lib/esm/test/imodel/GetTextureImage.test.js.map +1 -0
- package/lib/esm/test/imodel/IModel.test.d.ts +2 -0
- package/lib/esm/test/imodel/IModel.test.d.ts.map +1 -0
- package/lib/esm/test/imodel/IModel.test.js +2601 -0
- package/lib/esm/test/imodel/IModel.test.js.map +1 -0
- package/lib/esm/test/imodel/ProjectExtents.test.d.ts +2 -0
- package/lib/esm/test/imodel/ProjectExtents.test.d.ts.map +1 -0
- package/lib/esm/test/imodel/ProjectExtents.test.js +66 -0
- package/lib/esm/test/imodel/ProjectExtents.test.js.map +1 -0
- package/lib/esm/test/imodel/SchemaXmlImport.test.d.ts +2 -0
- package/lib/esm/test/imodel/SchemaXmlImport.test.d.ts.map +1 -0
- package/lib/esm/test/imodel/SchemaXmlImport.test.js +74 -0
- package/lib/esm/test/imodel/SchemaXmlImport.test.js.map +1 -0
- package/lib/esm/test/index.d.ts +7 -0
- package/lib/esm/test/index.d.ts.map +1 -0
- package/lib/esm/test/index.js +11 -0
- package/lib/esm/test/index.js.map +1 -0
- package/lib/esm/test/misc/DevTools.test.d.ts +2 -0
- package/lib/esm/test/misc/DevTools.test.d.ts.map +1 -0
- package/lib/esm/test/misc/DevTools.test.js +72 -0
- package/lib/esm/test/misc/DevTools.test.js.map +1 -0
- package/lib/esm/test/misc/EntitySubClasses.test.d.ts +2 -0
- package/lib/esm/test/misc/EntitySubClasses.test.d.ts.map +1 -0
- package/lib/esm/test/misc/EntitySubClasses.test.js +106 -0
- package/lib/esm/test/misc/EntitySubClasses.test.js.map +1 -0
- package/lib/esm/test/misc/GeoServices.test.d.ts +2 -0
- package/lib/esm/test/misc/GeoServices.test.d.ts.map +1 -0
- package/lib/esm/test/misc/GeoServices.test.js +850 -0
- package/lib/esm/test/misc/GeoServices.test.js.map +1 -0
- package/lib/esm/test/misc/PromiseMemoizer.test.d.ts +2 -0
- package/lib/esm/test/misc/PromiseMemoizer.test.d.ts.map +1 -0
- package/lib/esm/test/misc/PromiseMemoizer.test.js +111 -0
- package/lib/esm/test/misc/PromiseMemoizer.test.js.map +1 -0
- package/lib/esm/test/native/DgnDbWorker.test.d.ts +2 -0
- package/lib/esm/test/native/DgnDbWorker.test.d.ts.map +1 -0
- package/lib/esm/test/native/DgnDbWorker.test.js +159 -0
- package/lib/esm/test/native/DgnDbWorker.test.js.map +1 -0
- package/lib/esm/test/rpc/response.test.d.ts +2 -0
- package/lib/esm/test/rpc/response.test.d.ts.map +1 -0
- package/lib/esm/test/rpc/response.test.js +112 -0
- package/lib/esm/test/rpc/response.test.js.map +1 -0
- package/lib/esm/test/schema/ClassRegistry.test.d.ts +2 -0
- package/lib/esm/test/schema/ClassRegistry.test.d.ts.map +1 -0
- package/lib/esm/test/schema/ClassRegistry.test.js +679 -0
- package/lib/esm/test/schema/ClassRegistry.test.js.map +1 -0
- package/lib/esm/test/schema/FunctionalDomain.test.d.ts +2 -0
- package/lib/esm/test/schema/FunctionalDomain.test.d.ts.map +1 -0
- package/lib/esm/test/schema/FunctionalDomain.test.js +490 -0
- package/lib/esm/test/schema/FunctionalDomain.test.js.map +1 -0
- package/lib/esm/test/schema/GenericDomain.test.d.ts +2 -0
- package/lib/esm/test/schema/GenericDomain.test.d.ts.map +1 -0
- package/lib/esm/test/schema/GenericDomain.test.js +132 -0
- package/lib/esm/test/schema/GenericDomain.test.js.map +1 -0
- package/lib/esm/test/schema/IModelSchemaContext.test.d.ts +2 -0
- package/lib/esm/test/schema/IModelSchemaContext.test.d.ts.map +1 -0
- package/lib/esm/test/schema/IModelSchemaContext.test.js +95 -0
- package/lib/esm/test/schema/IModelSchemaContext.test.js.map +1 -0
- package/lib/esm/test/sheetindex/SheetIndex.test.d.ts +4 -0
- package/lib/esm/test/sheetindex/SheetIndex.test.d.ts.map +1 -0
- package/lib/esm/test/sheetindex/SheetIndex.test.js +312 -0
- package/lib/esm/test/sheetindex/SheetIndex.test.js.map +1 -0
- package/lib/esm/test/standalone/ChangeMerge.test.d.ts +2 -0
- package/lib/esm/test/standalone/ChangeMerge.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ChangeMerge.test.js +413 -0
- package/lib/esm/test/standalone/ChangeMerge.test.js.map +1 -0
- package/lib/esm/test/standalone/ChangesetReader.test.d.ts +2 -0
- package/lib/esm/test/standalone/ChangesetReader.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ChangesetReader.test.js +890 -0
- package/lib/esm/test/standalone/ChangesetReader.test.js.map +1 -0
- package/lib/esm/test/standalone/CustomViewState3dCreator.test.d.ts +2 -0
- package/lib/esm/test/standalone/CustomViewState3dCreator.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/CustomViewState3dCreator.test.js +49 -0
- package/lib/esm/test/standalone/CustomViewState3dCreator.test.js.map +1 -0
- package/lib/esm/test/standalone/DisplayStyle.test.d.ts +2 -0
- package/lib/esm/test/standalone/DisplayStyle.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/DisplayStyle.test.js +136 -0
- package/lib/esm/test/standalone/DisplayStyle.test.js.map +1 -0
- package/lib/esm/test/standalone/ElementGraphics.test.d.ts +2 -0
- package/lib/esm/test/standalone/ElementGraphics.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ElementGraphics.test.js +127 -0
- package/lib/esm/test/standalone/ElementGraphics.test.js.map +1 -0
- package/lib/esm/test/standalone/ElementMesh.test.d.ts +2 -0
- package/lib/esm/test/standalone/ElementMesh.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ElementMesh.test.js +142 -0
- package/lib/esm/test/standalone/ElementMesh.test.js.map +1 -0
- package/lib/esm/test/standalone/ExportGraphics.test.d.ts +2 -0
- package/lib/esm/test/standalone/ExportGraphics.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ExportGraphics.test.js +1040 -0
- package/lib/esm/test/standalone/ExportGraphics.test.js.map +1 -0
- package/lib/esm/test/standalone/GeometryChangeEvents.test.d.ts +2 -0
- package/lib/esm/test/standalone/GeometryChangeEvents.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/GeometryChangeEvents.test.js +139 -0
- package/lib/esm/test/standalone/GeometryChangeEvents.test.js.map +1 -0
- package/lib/esm/test/standalone/GeometryStream.test.d.ts +2 -0
- package/lib/esm/test/standalone/GeometryStream.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/GeometryStream.test.js +2869 -0
- package/lib/esm/test/standalone/GeometryStream.test.js.map +1 -0
- package/lib/esm/test/standalone/HubMock.test.d.ts +2 -0
- package/lib/esm/test/standalone/HubMock.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/HubMock.test.js +343 -0
- package/lib/esm/test/standalone/HubMock.test.js.map +1 -0
- package/lib/esm/test/standalone/IModelWrite.test.d.ts +7 -0
- package/lib/esm/test/standalone/IModelWrite.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/IModelWrite.test.js +859 -0
- package/lib/esm/test/standalone/IModelWrite.test.js.map +1 -0
- package/lib/esm/test/standalone/InlineGeometryPartReferences.test.d.ts +2 -0
- package/lib/esm/test/standalone/InlineGeometryPartReferences.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/InlineGeometryPartReferences.test.js +417 -0
- package/lib/esm/test/standalone/InlineGeometryPartReferences.test.js.map +1 -0
- package/lib/esm/test/standalone/MergeConflict.test.d.ts +7 -0
- package/lib/esm/test/standalone/MergeConflict.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/MergeConflict.test.js +345 -0
- package/lib/esm/test/standalone/MergeConflict.test.js.map +1 -0
- package/lib/esm/test/standalone/NativeAppStorage.test.d.ts +2 -0
- package/lib/esm/test/standalone/NativeAppStorage.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/NativeAppStorage.test.js +121 -0
- package/lib/esm/test/standalone/NativeAppStorage.test.js.map +1 -0
- package/lib/esm/test/standalone/RenderMaterialElement.test.d.ts +2 -0
- package/lib/esm/test/standalone/RenderMaterialElement.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/RenderMaterialElement.test.js +398 -0
- package/lib/esm/test/standalone/RenderMaterialElement.test.js.map +1 -0
- package/lib/esm/test/standalone/RenderTimeline.test.d.ts +2 -0
- package/lib/esm/test/standalone/RenderTimeline.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/RenderTimeline.test.js +71 -0
- package/lib/esm/test/standalone/RenderTimeline.test.js.map +1 -0
- package/lib/esm/test/standalone/SQLiteDb.test.d.ts +2 -0
- package/lib/esm/test/standalone/SQLiteDb.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/SQLiteDb.test.js +63 -0
- package/lib/esm/test/standalone/SQLiteDb.test.js.map +1 -0
- package/lib/esm/test/standalone/SchemaUtils.test.d.ts +2 -0
- package/lib/esm/test/standalone/SchemaUtils.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/SchemaUtils.test.js +25 -0
- package/lib/esm/test/standalone/SchemaUtils.test.js.map +1 -0
- package/lib/esm/test/standalone/SectionDrawing.test.d.ts +2 -0
- package/lib/esm/test/standalone/SectionDrawing.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/SectionDrawing.test.js +83 -0
- package/lib/esm/test/standalone/SectionDrawing.test.js.map +1 -0
- package/lib/esm/test/standalone/ServerBasedLocks.test.d.ts +2 -0
- package/lib/esm/test/standalone/ServerBasedLocks.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ServerBasedLocks.test.js +279 -0
- package/lib/esm/test/standalone/ServerBasedLocks.test.js.map +1 -0
- package/lib/esm/test/standalone/Setting.test.d.ts +2 -0
- package/lib/esm/test/standalone/Setting.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/Setting.test.js +76 -0
- package/lib/esm/test/standalone/Setting.test.js.map +1 -0
- package/lib/esm/test/standalone/Settings.test.d.ts +2 -0
- package/lib/esm/test/standalone/Settings.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/Settings.test.js +349 -0
- package/lib/esm/test/standalone/Settings.test.js.map +1 -0
- package/lib/esm/test/standalone/SettingsSchemas.test.d.ts +2 -0
- package/lib/esm/test/standalone/SettingsSchemas.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/SettingsSchemas.test.js +31 -0
- package/lib/esm/test/standalone/SettingsSchemas.test.js.map +1 -0
- package/lib/esm/test/standalone/SnapshotDb.test.d.ts +2 -0
- package/lib/esm/test/standalone/SnapshotDb.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/SnapshotDb.test.js +153 -0
- package/lib/esm/test/standalone/SnapshotDb.test.js.map +1 -0
- package/lib/esm/test/standalone/Texture.test.d.ts +2 -0
- package/lib/esm/test/standalone/Texture.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/Texture.test.js +90 -0
- package/lib/esm/test/standalone/Texture.test.js.map +1 -0
- package/lib/esm/test/standalone/TileCache.test.d.ts +9 -0
- package/lib/esm/test/standalone/TileCache.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/TileCache.test.js +127 -0
- package/lib/esm/test/standalone/TileCache.test.js.map +1 -0
- package/lib/esm/test/standalone/TileTree.test.d.ts +2 -0
- package/lib/esm/test/standalone/TileTree.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/TileTree.test.js +241 -0
- package/lib/esm/test/standalone/TileTree.test.js.map +1 -0
- package/lib/esm/test/standalone/TxnManager.test.d.ts +2 -0
- package/lib/esm/test/standalone/TxnManager.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/TxnManager.test.js +878 -0
- package/lib/esm/test/standalone/TxnManager.test.js.map +1 -0
- package/lib/esm/test/standalone/ViewDefinition.test.d.ts +2 -0
- package/lib/esm/test/standalone/ViewDefinition.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ViewDefinition.test.js +279 -0
- package/lib/esm/test/standalone/ViewDefinition.test.js.map +1 -0
- package/lib/esm/test/standalone/ViewStoreDb.test.d.ts +2 -0
- package/lib/esm/test/standalone/ViewStoreDb.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/ViewStoreDb.test.js +288 -0
- package/lib/esm/test/standalone/ViewStoreDb.test.js.map +1 -0
- package/lib/esm/test/standalone/Workspace.test.d.ts +2 -0
- package/lib/esm/test/standalone/Workspace.test.d.ts.map +1 -0
- package/lib/esm/test/standalone/Workspace.test.js +161 -0
- package/lib/esm/test/standalone/Workspace.test.js.map +1 -0
- package/lib/esm/workspace/Settings.d.ts +216 -0
- package/lib/esm/workspace/Settings.d.ts.map +1 -0
- package/lib/esm/workspace/Settings.js +83 -0
- package/lib/esm/workspace/Settings.js.map +1 -0
- package/lib/esm/workspace/SettingsSchemas.d.ts +135 -0
- package/lib/esm/workspace/SettingsSchemas.d.ts.map +1 -0
- package/lib/esm/workspace/SettingsSchemas.js +9 -0
- package/lib/esm/workspace/SettingsSchemas.js.map +1 -0
- package/lib/esm/workspace/Workspace.d.ts +507 -0
- package/lib/esm/workspace/Workspace.d.ts.map +1 -0
- package/lib/esm/workspace/Workspace.js +97 -0
- package/lib/esm/workspace/Workspace.js.map +1 -0
- package/lib/esm/workspace/WorkspaceEditor.d.ts +245 -0
- package/lib/esm/workspace/WorkspaceEditor.d.ts.map +1 -0
- package/lib/esm/workspace/WorkspaceEditor.js +31 -0
- package/lib/esm/workspace/WorkspaceEditor.js.map +1 -0
- package/package.json +19 -15
|
@@ -0,0 +1,810 @@
|
|
|
1
|
+
/*---------------------------------------------------------------------------------------------
|
|
2
|
+
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
3
|
+
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
4
|
+
*--------------------------------------------------------------------------------------------*/
|
|
5
|
+
/** @packageDocumentation
|
|
6
|
+
* @module ECSQL
|
|
7
|
+
*/
|
|
8
|
+
import { assert, DbResult } from "@itwin/core-bentley";
|
|
9
|
+
import { Range3d, XYZ } from "@itwin/core-geometry";
|
|
10
|
+
import { ECJsNames, ECSqlValueType, IModelError, PropertyMetaDataMap, QueryRowFormat } from "@itwin/core-common";
|
|
11
|
+
import { IModelNative } from "./internal/NativePlatform";
|
|
12
|
+
/** The result of an **ECSQL INSERT** statement as returned from [ECSqlStatement.stepForInsert]($backend).
|
|
13
|
+
*
|
|
14
|
+
* If the step was successful, the ECSqlInsertResult contains
|
|
15
|
+
* [DbResult.BE_SQLITE_DONE]($core-bentley)
|
|
16
|
+
* and the ECInstanceId of the newly created instance.
|
|
17
|
+
* In case of failure it contains the [DbResult]($core-bentley) error code.
|
|
18
|
+
*
|
|
19
|
+
* > Insert statements can be used with ECDb only, not with IModelDb.
|
|
20
|
+
* @public
|
|
21
|
+
*/
|
|
22
|
+
export class ECSqlInsertResult {
|
|
23
|
+
status;
|
|
24
|
+
id;
|
|
25
|
+
constructor(status, id) {
|
|
26
|
+
this.status = status;
|
|
27
|
+
this.id = id;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
/** Executes ECSQL statements.
|
|
31
|
+
*
|
|
32
|
+
* A statement must be prepared before it can be executed, and it must be released when no longer needed.
|
|
33
|
+
* See [IModelDb.withPreparedStatement]($backend) or
|
|
34
|
+
* [ECDb.withPreparedStatement]($backend) for a convenient and
|
|
35
|
+
* reliable way to prepare, execute, and then release a statement.
|
|
36
|
+
*
|
|
37
|
+
* A statement may contain parameters that must be filled in before use by the **bind** methods.
|
|
38
|
+
*
|
|
39
|
+
* Once prepared (and parameters are bound, if any), the statement is executed by calling [ECSqlStatement.step]($backend).
|
|
40
|
+
* In case of an **ECSQL SELECT** statement, the current row can be retrieved with [ECSqlStatement.getRow]($backend) as
|
|
41
|
+
* a whole, or with [ECSqlStatement.getValue]($backend) when individual values are needed.
|
|
42
|
+
* Alternatively, query results of an **ECSQL SELECT** statement can be stepped through by using
|
|
43
|
+
* standard iteration syntax, such as `for of`.
|
|
44
|
+
*
|
|
45
|
+
* > Preparing a statement can be time-consuming. The best way to reduce the effect of this overhead is to cache and reuse prepared
|
|
46
|
+
* > statements. A cached prepared statement may be used in different places in an app, as long as the statement is general enough.
|
|
47
|
+
* > The key to making this strategy work is to phrase a statement in a general way and use placeholders to represent parameters that will vary on each use.
|
|
48
|
+
*
|
|
49
|
+
* See also
|
|
50
|
+
* - [Executing ECSQL]($docs/learning/backend/ExecutingECSQL) provides more background on ECSQL and an introduction on how to execute ECSQL with the iTwin.js API.
|
|
51
|
+
* - [Code Examples]($docs/learning/backend/ECSQLCodeExamples) illustrate the use of the iTwin.js API for executing and working with ECSQL
|
|
52
|
+
* @public
|
|
53
|
+
*/
|
|
54
|
+
export class ECSqlStatement {
|
|
55
|
+
_stmt;
|
|
56
|
+
_sql;
|
|
57
|
+
_props = new PropertyMetaDataMap([]);
|
|
58
|
+
get sql() { return this._sql; } // eslint-disable-line @typescript-eslint/no-non-null-assertion
|
|
59
|
+
/** Check if this statement has been prepared successfully or not */
|
|
60
|
+
get isPrepared() { return !!this._stmt; }
|
|
61
|
+
/** Prepare this statement prior to first use.
|
|
62
|
+
* @param db The DgnDb or ECDb to prepare the statement against
|
|
63
|
+
* @param ecsql The ECSQL statement string to prepare
|
|
64
|
+
* @param logErrors Determine if errors are logged or not
|
|
65
|
+
* @throws [IModelError]($common) if the ECSQL statement cannot be prepared. Normally, prepare fails due to ECSQL syntax errors or references to tables or properties that do not exist.
|
|
66
|
+
* The error.message property will provide details.
|
|
67
|
+
* @internal
|
|
68
|
+
*/
|
|
69
|
+
prepare(db, ecsql, logErrors = true) {
|
|
70
|
+
const stat = this.tryPrepare(db, ecsql, logErrors);
|
|
71
|
+
if (stat.status !== DbResult.BE_SQLITE_OK) {
|
|
72
|
+
throw new IModelError(stat.status, stat.message);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
/** Prepare this statement prior to first use.
|
|
76
|
+
* @param db The DgnDb or ECDb to prepare the statement against
|
|
77
|
+
* @param ecsql The ECSQL statement string to prepare
|
|
78
|
+
* @param logErrors Determine if errors are logged or not, its set to false by default for tryPrepare()
|
|
79
|
+
* @returns An object with a `status` member equal to [DbResult.BE_SQLITE_OK]($bentley) on success. Upon error, the `message` member will provide details.
|
|
80
|
+
* @internal
|
|
81
|
+
*/
|
|
82
|
+
tryPrepare(db, ecsql, logErrors = false) {
|
|
83
|
+
if (this.isPrepared)
|
|
84
|
+
throw new Error("ECSqlStatement is already prepared");
|
|
85
|
+
this._sql = ecsql;
|
|
86
|
+
this._stmt = new IModelNative.platform.ECSqlStatement();
|
|
87
|
+
return this._stmt.prepare(db, ecsql, logErrors);
|
|
88
|
+
}
|
|
89
|
+
/** Reset this statement so that the next call to step will return the first row, if any. */
|
|
90
|
+
reset() {
|
|
91
|
+
assert(undefined !== this._stmt);
|
|
92
|
+
this._stmt.reset();
|
|
93
|
+
this._props = new PropertyMetaDataMap([]);
|
|
94
|
+
}
|
|
95
|
+
/** Get the Native SQL statement
|
|
96
|
+
* @internal
|
|
97
|
+
*/
|
|
98
|
+
getNativeSql() {
|
|
99
|
+
assert(undefined !== this._stmt);
|
|
100
|
+
return this._stmt.getNativeSql();
|
|
101
|
+
}
|
|
102
|
+
/** Call this function when finished with this statement. This releases the native resources held by the statement.
|
|
103
|
+
*
|
|
104
|
+
* > Do not call this method directly on a statement that is being managed by a statement cache.
|
|
105
|
+
*/
|
|
106
|
+
[Symbol.dispose]() {
|
|
107
|
+
if (this._stmt) {
|
|
108
|
+
this._stmt.dispose(); // free native statement
|
|
109
|
+
this._stmt = undefined;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
/** @deprecated in 5.0 Use [Symbol.dispose] instead. */
|
|
113
|
+
dispose() {
|
|
114
|
+
this[Symbol.dispose]();
|
|
115
|
+
}
|
|
116
|
+
/** Binds the specified value to the specified ECSQL parameter.
|
|
117
|
+
* The section "[iTwin.js Types used in ECSQL Parameter Bindings]($docs/learning/ECSQLParameterTypes)" describes the
|
|
118
|
+
* iTwin.js types to be used for the different ECSQL parameter types.
|
|
119
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
120
|
+
*/
|
|
121
|
+
bindValue(parameter, val) { this.getBinder(parameter).bind(val); }
|
|
122
|
+
/** Binds null to the specified ECSQL parameter.
|
|
123
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
124
|
+
*/
|
|
125
|
+
bindNull(parameter) { this.getBinder(parameter).bindNull(); }
|
|
126
|
+
/** Binds a BLOB value to the specified ECSQL parameter.
|
|
127
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
128
|
+
* @param BLOB value as either a Uint8Array, ArrayBuffer or a Base64 string
|
|
129
|
+
*/
|
|
130
|
+
bindBlob(parameter, blob) { this.getBinder(parameter).bindBlob(blob); }
|
|
131
|
+
/** Binds a boolean value to the specified ECSQL parameter.
|
|
132
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
133
|
+
* @param val Boolean value
|
|
134
|
+
*/
|
|
135
|
+
bindBoolean(parameter, val) { this.getBinder(parameter).bindBoolean(val); }
|
|
136
|
+
/** Binds a DateTime value to the specified ECSQL parameter.
|
|
137
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
138
|
+
* @param isoDateTimeString DateTime value as ISO8601 string
|
|
139
|
+
*/
|
|
140
|
+
bindDateTime(parameter, isoDateTimeString) { this.getBinder(parameter).bindDateTime(isoDateTimeString); }
|
|
141
|
+
/** Binds a double value to the specified ECSQL parameter.
|
|
142
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
143
|
+
* @param val Double value
|
|
144
|
+
*/
|
|
145
|
+
bindDouble(parameter, val) { this.getBinder(parameter).bindDouble(val); }
|
|
146
|
+
/** Binds an GUID value to the specified ECSQL parameter.
|
|
147
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
148
|
+
* @param val GUID value
|
|
149
|
+
*/
|
|
150
|
+
bindGuid(parameter, val) { this.getBinder(parameter).bindGuid(val); }
|
|
151
|
+
/** Binds an Id value to the specified ECSQL parameter.
|
|
152
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
153
|
+
* @param val Id value
|
|
154
|
+
*/
|
|
155
|
+
bindId(parameter, val) { this.getBinder(parameter).bindId(val); }
|
|
156
|
+
/** Binds an integer value to the specified ECSQL parameter.
|
|
157
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
158
|
+
* @param val Integer value as number, decimal string or hexadecimal string.
|
|
159
|
+
*/
|
|
160
|
+
bindInteger(parameter, val) { this.getBinder(parameter).bindInteger(val); }
|
|
161
|
+
/** Binds an Point2d value to the specified ECSQL parameter.
|
|
162
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
163
|
+
* @param val Point2d value
|
|
164
|
+
*/
|
|
165
|
+
bindPoint2d(parameter, val) { this.getBinder(parameter).bindPoint2d(val); }
|
|
166
|
+
/** Binds an Point3d value to the specified ECSQL parameter.
|
|
167
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
168
|
+
* @param val Point3d value
|
|
169
|
+
*/
|
|
170
|
+
bindPoint3d(parameter, val) { this.getBinder(parameter).bindPoint3d(val); }
|
|
171
|
+
/** Binds a Range3d as a blob to the specified ECSQL parameter
|
|
172
|
+
* @param parameter Index(1-based) or name of the parameter
|
|
173
|
+
* @param val Range3d value
|
|
174
|
+
*/
|
|
175
|
+
bindRange3d(parameter, val) { this.getBinder(parameter).bindRange3d(val); }
|
|
176
|
+
/** Binds an string to the specified ECSQL parameter.
|
|
177
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
178
|
+
* @param val String value
|
|
179
|
+
*/
|
|
180
|
+
bindString(parameter, val) { this.getBinder(parameter).bindString(val); }
|
|
181
|
+
/** Binds a navigation property value to the specified ECSQL parameter.
|
|
182
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
183
|
+
* @param val Navigation property value
|
|
184
|
+
*/
|
|
185
|
+
bindNavigation(parameter, val) { this.getBinder(parameter).bindNavigation(val); }
|
|
186
|
+
/** Binds a struct property value to the specified ECSQL parameter.
|
|
187
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
188
|
+
* @param val Struct value. The struct value is an object composed of pairs of a struct member property name and its value
|
|
189
|
+
* (of one of the supported types)
|
|
190
|
+
*/
|
|
191
|
+
bindStruct(parameter, val) { this.getBinder(parameter).bindStruct(val); }
|
|
192
|
+
/** Binds an array value to the specified ECSQL parameter.
|
|
193
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
194
|
+
* @param val Array value. The array value is an array of values of the supported types
|
|
195
|
+
*/
|
|
196
|
+
bindArray(parameter, val) { this.getBinder(parameter).bindArray(val); }
|
|
197
|
+
bindIdSet(parameter, val) { this.getBinder(parameter).bindIdSet(val); }
|
|
198
|
+
/**
|
|
199
|
+
* Gets a binder to bind a value for an ECSQL parameter
|
|
200
|
+
* > This is the most low-level API to bind a value to a specific parameter. Alternatively you can use the ECSqlStatement.bindXX methods
|
|
201
|
+
* > or [ECSqlStatement.bindValues]($backend).
|
|
202
|
+
* @param parameter Index (1-based) or name of the parameter
|
|
203
|
+
*/
|
|
204
|
+
getBinder(parameter) {
|
|
205
|
+
assert(undefined !== this._stmt);
|
|
206
|
+
return new ECSqlBinder(this._stmt.getBinder(parameter));
|
|
207
|
+
}
|
|
208
|
+
/** Bind values to all parameters in the statement.
|
|
209
|
+
* @param values The values to bind to the parameters.
|
|
210
|
+
* Pass an *array* of values if the parameters are *positional*.
|
|
211
|
+
* Pass an *object of the values keyed on the parameter name* for *named parameters*.
|
|
212
|
+
* The values in either the array or object must match the respective types of the parameter.
|
|
213
|
+
*
|
|
214
|
+
* The section "[iTwin.js Types used in ECSQL Parameter Bindings]($docs/learning/ECSQLParameterTypes)" describes the
|
|
215
|
+
* iTwin.js types to be used for the different ECSQL parameter types.
|
|
216
|
+
*
|
|
217
|
+
* See also these [Code Samples]($docs/learning/backend/ECSQLCodeExamples#binding-to-all-parameters-at-once)
|
|
218
|
+
*/
|
|
219
|
+
bindValues(values) {
|
|
220
|
+
if (Array.isArray(values)) {
|
|
221
|
+
for (let i = 0; i < values.length; i++) {
|
|
222
|
+
const paramIndex = i + 1;
|
|
223
|
+
const paramValue = values[i];
|
|
224
|
+
if (paramValue === undefined || paramValue === null)
|
|
225
|
+
continue;
|
|
226
|
+
this.bindValue(paramIndex, paramValue);
|
|
227
|
+
}
|
|
228
|
+
return;
|
|
229
|
+
}
|
|
230
|
+
for (const entry of Object.entries(values)) {
|
|
231
|
+
const paramName = entry[0];
|
|
232
|
+
const paramValue = entry[1];
|
|
233
|
+
if (paramValue === undefined || paramValue === null)
|
|
234
|
+
continue;
|
|
235
|
+
this.bindValue(paramName, paramValue);
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
/** Clear any bindings that were previously set on this statement.
|
|
239
|
+
* @throws [IModelError]($common) in case of errors
|
|
240
|
+
*/
|
|
241
|
+
clearBindings() {
|
|
242
|
+
if (this._stmt) {
|
|
243
|
+
const stat = this._stmt.clearBindings();
|
|
244
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
245
|
+
throw new IModelError(stat, "Error clearing bindings");
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
/** Step this statement to the next row.
|
|
249
|
+
*
|
|
250
|
+
* For **ECSQL SELECT** statements the method returns
|
|
251
|
+
* - [DbResult.BE_SQLITE_ROW]($core-bentley) if the statement now points successfully to the next row.
|
|
252
|
+
* - [DbResult.BE_SQLITE_DONE]($core-bentley) if the statement has no more rows.
|
|
253
|
+
* - Error status in case of errors.
|
|
254
|
+
*
|
|
255
|
+
* For **ECSQL INSERT, UPDATE, DELETE** statements the method returns
|
|
256
|
+
* - [DbResult.BE_SQLITE_DONE]($core-bentley) if the statement has been executed successfully.
|
|
257
|
+
* - Error status in case of errors.
|
|
258
|
+
*
|
|
259
|
+
* > Insert statements can be used with ECDb only, not with IModelDb.
|
|
260
|
+
*
|
|
261
|
+
* See also: [Code Samples]($docs/learning/backend/ECSQLCodeExamples)
|
|
262
|
+
*/
|
|
263
|
+
step() { return this._stmt.step(); } // eslint-disable-line @typescript-eslint/no-non-null-assertion
|
|
264
|
+
/** @internal added this back in for testing purposes */
|
|
265
|
+
async stepAsync() {
|
|
266
|
+
return new Promise((resolve, _reject) => {
|
|
267
|
+
this._stmt.stepAsync(resolve); // eslint-disable-line @typescript-eslint/no-non-null-assertion
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
/** Step this INSERT statement and returns status and the ECInstanceId of the newly
|
|
271
|
+
* created instance.
|
|
272
|
+
*
|
|
273
|
+
* > Insert statements can be used with ECDb only, not with IModelDb.
|
|
274
|
+
*
|
|
275
|
+
* @returns Returns the generated ECInstanceId in case of success and the status of the step
|
|
276
|
+
* call. In case of error, the respective error code is returned.
|
|
277
|
+
*/
|
|
278
|
+
stepForInsert() {
|
|
279
|
+
assert(undefined !== this._stmt);
|
|
280
|
+
const r = this._stmt.stepForInsert();
|
|
281
|
+
if (r.status === DbResult.BE_SQLITE_DONE)
|
|
282
|
+
return new ECSqlInsertResult(r.status, r.id);
|
|
283
|
+
return new ECSqlInsertResult(r.status);
|
|
284
|
+
}
|
|
285
|
+
/** Get the query result's column count (only for ECSQL SELECT statements). */
|
|
286
|
+
getColumnCount() { return this._stmt.getColumnCount(); } // eslint-disable-line @typescript-eslint/no-non-null-assertion
|
|
287
|
+
/** Get the current row.
|
|
288
|
+
* The returned row is formatted as JavaScript object where every SELECT clause item becomes a property in the JavaScript object.
|
|
289
|
+
*
|
|
290
|
+
* See also:
|
|
291
|
+
* - [ECSQL row format]($docs/learning/ECSQLRowFormat) for details about the format of the returned row.
|
|
292
|
+
* - [Code Samples]($docs/learning/backend/ECSQLCodeExamples#working-with-the-query-result)
|
|
293
|
+
*/
|
|
294
|
+
getRow(args) {
|
|
295
|
+
if (!this._stmt)
|
|
296
|
+
throw new Error("ECSqlStatement is not prepared");
|
|
297
|
+
args = args ?? {};
|
|
298
|
+
if (args.rowFormat === undefined) {
|
|
299
|
+
args.rowFormat = QueryRowFormat.UseJsPropertyNames;
|
|
300
|
+
}
|
|
301
|
+
const resp = this._stmt.toRow({
|
|
302
|
+
classIdsToClassNames: args.classIdsToClassNames,
|
|
303
|
+
useJsName: args.rowFormat === QueryRowFormat.UseJsPropertyNames,
|
|
304
|
+
abbreviateBlobs: false,
|
|
305
|
+
// In 4.x, people are currently dependent on the behavior of aliased classIds `select classId as aliasedClassId` not being
|
|
306
|
+
// converted into classNames which is a bug that we must now support.This option preserves this special behavior until
|
|
307
|
+
// it can be removed in a future version.
|
|
308
|
+
doNotConvertClassIdsToClassNamesWhenAliased: true,
|
|
309
|
+
});
|
|
310
|
+
return this.formatCurrentRow(resp, args.rowFormat);
|
|
311
|
+
}
|
|
312
|
+
formatCurrentRow(currentResp, rowFormat = QueryRowFormat.UseJsPropertyNames) {
|
|
313
|
+
if (!this._stmt)
|
|
314
|
+
throw new Error("ECSqlStatement is not prepared");
|
|
315
|
+
if (rowFormat === QueryRowFormat.UseECSqlPropertyIndexes)
|
|
316
|
+
return currentResp.data;
|
|
317
|
+
if (this._props.length === 0) {
|
|
318
|
+
const resp = this._stmt.getMetadata();
|
|
319
|
+
this._props = new PropertyMetaDataMap(resp.meta);
|
|
320
|
+
}
|
|
321
|
+
const formattedRow = {};
|
|
322
|
+
for (const prop of this._props) {
|
|
323
|
+
const propName = rowFormat === QueryRowFormat.UseJsPropertyNames ? prop.jsonName : prop.name;
|
|
324
|
+
const val = currentResp.data[prop.index];
|
|
325
|
+
if (typeof val !== "undefined" && val !== null) {
|
|
326
|
+
Object.defineProperty(formattedRow, propName, {
|
|
327
|
+
value: val,
|
|
328
|
+
enumerable: true,
|
|
329
|
+
writable: true,
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
return formattedRow;
|
|
334
|
+
}
|
|
335
|
+
/** Calls step when called as an iterator.
|
|
336
|
+
*
|
|
337
|
+
* Each iteration returns an [ECSQL row format]($docs/learning/ECSQLRowFormat) as returned
|
|
338
|
+
* from [ECSqlStatement.getRow]($backend).
|
|
339
|
+
*/
|
|
340
|
+
next() {
|
|
341
|
+
if (DbResult.BE_SQLITE_ROW === this.step()) {
|
|
342
|
+
return {
|
|
343
|
+
done: false,
|
|
344
|
+
value: this.getRow(),
|
|
345
|
+
};
|
|
346
|
+
}
|
|
347
|
+
else {
|
|
348
|
+
return {
|
|
349
|
+
done: true,
|
|
350
|
+
value: undefined,
|
|
351
|
+
};
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
/** The iterator that will step through the results of this statement. */
|
|
355
|
+
[Symbol.iterator]() { return this; }
|
|
356
|
+
/** Get the value for the column at the given index in the query result.
|
|
357
|
+
* @param columnIx Index of ECSQL column in query result (0-based)
|
|
358
|
+
*
|
|
359
|
+
* See also: [Code Samples]($docs/learning/backend/ECSQLCodeExamples#working-with-the-query-result)
|
|
360
|
+
*/
|
|
361
|
+
getValue(columnIx) {
|
|
362
|
+
assert(undefined !== this._stmt);
|
|
363
|
+
return new ECSqlValue(this._stmt.getValue(columnIx));
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
/** Binds a value to an ECSQL parameter.
|
|
367
|
+
*
|
|
368
|
+
* See also:
|
|
369
|
+
*
|
|
370
|
+
* - [ECSqlStatement]($backend)
|
|
371
|
+
* - [ECSqlStatement.getBinder]($backend)
|
|
372
|
+
* - [Executing ECSQL]($docs/learning/backend/ExecutingECSQL)
|
|
373
|
+
* @public
|
|
374
|
+
*/
|
|
375
|
+
export class ECSqlBinder {
|
|
376
|
+
_binder;
|
|
377
|
+
/** @internal */
|
|
378
|
+
constructor(binder) { this._binder = binder; }
|
|
379
|
+
/** Binds the specified value to the ECSQL parameter.
|
|
380
|
+
* The section "[iTwin.js Types used in ECSQL Parameter Bindings]($docs/learning/ECSQLParameterTypes)" describes the
|
|
381
|
+
* iTwin.js types to be used for the different ECSQL parameter types.
|
|
382
|
+
* @param val Value to bind
|
|
383
|
+
*/
|
|
384
|
+
bind(val) {
|
|
385
|
+
ECSqlBindingHelper.bindValue(this, val);
|
|
386
|
+
}
|
|
387
|
+
/** Binds null to the ECSQL parameter. */
|
|
388
|
+
bindNull() {
|
|
389
|
+
const stat = this._binder.bindNull();
|
|
390
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
391
|
+
throw new IModelError(stat, "Error binding null");
|
|
392
|
+
}
|
|
393
|
+
/** Binds a BLOB value to the ECSQL parameter.
|
|
394
|
+
* @param BLOB value as either a UInt8Array, ArrayBuffer or a Base64 string
|
|
395
|
+
*/
|
|
396
|
+
bindBlob(blob) {
|
|
397
|
+
const stat = this._binder.bindBlob(blob);
|
|
398
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
399
|
+
throw new IModelError(stat, "Error binding blob");
|
|
400
|
+
}
|
|
401
|
+
/** Binds a boolean value to the ECSQL parameter.
|
|
402
|
+
* @param val Boolean value
|
|
403
|
+
*/
|
|
404
|
+
bindBoolean(val) {
|
|
405
|
+
const stat = this._binder.bindBoolean(val);
|
|
406
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
407
|
+
throw new IModelError(stat, "Error binding boolean");
|
|
408
|
+
}
|
|
409
|
+
/** Binds a DateTime value to the ECSQL parameter.
|
|
410
|
+
* @param isoDateTimeString DateTime value as ISO8601 string
|
|
411
|
+
*/
|
|
412
|
+
bindDateTime(isoDateTimeString) {
|
|
413
|
+
const stat = this._binder.bindDateTime(isoDateTimeString);
|
|
414
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
415
|
+
throw new IModelError(stat, "Error binding DateTime");
|
|
416
|
+
}
|
|
417
|
+
/** Binds a double value to the ECSQL parameter.
|
|
418
|
+
* @param val Double value
|
|
419
|
+
*/
|
|
420
|
+
bindDouble(val) {
|
|
421
|
+
const stat = this._binder.bindDouble(val);
|
|
422
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
423
|
+
throw new IModelError(stat, "Error binding double");
|
|
424
|
+
}
|
|
425
|
+
/** Binds an GUID value to the ECSQL parameter.
|
|
426
|
+
* @param val GUID value. If passed as string, it must be formatted as described in [GuidString]($core-bentley).
|
|
427
|
+
*/
|
|
428
|
+
bindGuid(val) {
|
|
429
|
+
const stat = this._binder.bindGuid(val);
|
|
430
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
431
|
+
throw new IModelError(stat, "Error binding GUID");
|
|
432
|
+
}
|
|
433
|
+
/** Binds an Id value to the ECSQL parameter.
|
|
434
|
+
* @param val Id value. If passed as string it must be the hexadecimal representation of the Id.
|
|
435
|
+
*/
|
|
436
|
+
bindId(val) {
|
|
437
|
+
const stat = this._binder.bindId(val);
|
|
438
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
439
|
+
throw new IModelError(stat, "Error binding Id");
|
|
440
|
+
}
|
|
441
|
+
/** Binds an integer value to the ECSQL parameter.
|
|
442
|
+
* @param val Integer value as number, decimal string or hexadecimal string.
|
|
443
|
+
*/
|
|
444
|
+
bindInteger(val) {
|
|
445
|
+
const stat = this._binder.bindInteger(val);
|
|
446
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
447
|
+
throw new IModelError(stat, "Error binding integer");
|
|
448
|
+
}
|
|
449
|
+
/** Binds an Point2d value to the ECSQL parameter.
|
|
450
|
+
* @param val Point2d value
|
|
451
|
+
*/
|
|
452
|
+
bindPoint2d(val) {
|
|
453
|
+
const stat = this._binder.bindPoint2d(val.x, val.y);
|
|
454
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
455
|
+
throw new IModelError(stat, "Error binding Point2d");
|
|
456
|
+
}
|
|
457
|
+
/** Binds an Point3d value to the ECSQL parameter.
|
|
458
|
+
* @param val Point3d value
|
|
459
|
+
*/
|
|
460
|
+
bindPoint3d(val) {
|
|
461
|
+
const stat = this._binder.bindPoint3d(val.x, val.y, val.z);
|
|
462
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
463
|
+
throw new IModelError(stat, "Error binding Point3d");
|
|
464
|
+
}
|
|
465
|
+
/** Binds a Range3d as a blob to the ECSQL parameter.
|
|
466
|
+
* @param val Range3d value
|
|
467
|
+
*/
|
|
468
|
+
bindRange3d(val) {
|
|
469
|
+
const stat = this._binder.bindBlob(Range3d.toFloat64Array(val).buffer);
|
|
470
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
471
|
+
throw new IModelError(stat, "Error binding Range3d");
|
|
472
|
+
}
|
|
473
|
+
/** Binds an string to the ECSQL parameter.
|
|
474
|
+
* @param val String value
|
|
475
|
+
*/
|
|
476
|
+
bindString(val) {
|
|
477
|
+
const stat = this._binder.bindString(val);
|
|
478
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
479
|
+
throw new IModelError(stat, "Error binding string");
|
|
480
|
+
}
|
|
481
|
+
/** Binds a navigation property value to the ECSQL parameter.
|
|
482
|
+
* @param val Navigation property value
|
|
483
|
+
*/
|
|
484
|
+
bindNavigation(val) {
|
|
485
|
+
const stat = this._binder.bindNavigation(val.id, val.relClassName, val.relClassTableSpace);
|
|
486
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
487
|
+
throw new IModelError(stat, "Error binding navigation property");
|
|
488
|
+
}
|
|
489
|
+
/** Binds a struct property value to the ECSQL parameter.
|
|
490
|
+
* @param val Struct value. The struct value is an object composed of pairs of a struct member property name and its value
|
|
491
|
+
* (of one of the supported types)
|
|
492
|
+
*/
|
|
493
|
+
bindStruct(val) { ECSqlBindingHelper.bindStruct(this, val); }
|
|
494
|
+
/** Gets the binder for the specified member of a struct parameter
|
|
495
|
+
*
|
|
496
|
+
* > This is the most low-level way to bind struct parameters with most flexibility. A simpler alternative is
|
|
497
|
+
* > to just call [ECSqlBinder.bindStruct]($backend).
|
|
498
|
+
*/
|
|
499
|
+
bindMember(memberName) { return new ECSqlBinder(this._binder.bindMember(memberName)); }
|
|
500
|
+
/** Binds a set of Id strings to the ECSQL parameter.
|
|
501
|
+
* @param val array of Id values. If passed as string they must be the hexadecimal representation of the Ids.
|
|
502
|
+
*/
|
|
503
|
+
bindIdSet(vector) {
|
|
504
|
+
const stat = this._binder.bindIdSet(vector);
|
|
505
|
+
if (stat !== DbResult.BE_SQLITE_OK)
|
|
506
|
+
throw new IModelError(stat, "Error binding id set");
|
|
507
|
+
}
|
|
508
|
+
/** Binds an array value to the ECSQL parameter.
|
|
509
|
+
* @param val Array value. The array value is an array of values of the supported types
|
|
510
|
+
*/
|
|
511
|
+
bindArray(val) { ECSqlBindingHelper.bindArray(this, val); }
|
|
512
|
+
/** Adds a new array element to the array parameter and returns the binder for the new array element
|
|
513
|
+
*
|
|
514
|
+
* > This is the most low-level way to bind array parameters with most flexibility. A simpler alternative is
|
|
515
|
+
* > to just call [ECSqlBinder.bindArray]($backend).
|
|
516
|
+
*/
|
|
517
|
+
addArrayElement() { return new ECSqlBinder(this._binder.addArrayElement()); }
|
|
518
|
+
}
|
|
519
|
+
/** Value of a column in a row of an ECSQL query result.
|
|
520
|
+
*
|
|
521
|
+
* See also:
|
|
522
|
+
* - [ECSqlStatement]($backend)
|
|
523
|
+
* - [ECSqlStatement.getValue]($backend)
|
|
524
|
+
* - [Code Samples]($docs/learning/backend/ECSQLCodeExamples#working-with-the-query-result)
|
|
525
|
+
* @public
|
|
526
|
+
*/
|
|
527
|
+
export class ECSqlValue {
|
|
528
|
+
_val;
|
|
529
|
+
/** @internal */
|
|
530
|
+
constructor(val) { this._val = val; }
|
|
531
|
+
/** Get information about the query result's column this value refers to. */
|
|
532
|
+
get columnInfo() { return this._val.getColumnInfo(); }
|
|
533
|
+
/** Get the value of this ECSQL value */
|
|
534
|
+
get value() { return ECSqlValueHelper.getValue(this); }
|
|
535
|
+
/** Indicates whether the value is NULL or not. */
|
|
536
|
+
get isNull() { return this._val.isNull(); }
|
|
537
|
+
/** Get the value as BLOB */
|
|
538
|
+
getBlob() { return this._val.getBlob(); }
|
|
539
|
+
/** Get the value as a boolean value */
|
|
540
|
+
getBoolean() { return this._val.getBoolean(); }
|
|
541
|
+
/** Get the value as a DateTime value (formatted as ISO8601 string) */
|
|
542
|
+
getDateTime() { return this._val.getDateTime(); }
|
|
543
|
+
/** Get the value as a double value */
|
|
544
|
+
getDouble() { return this._val.getDouble(); }
|
|
545
|
+
/** Get the value as a IGeometry value (as ECJSON IGeometry) */
|
|
546
|
+
getGeometry() { return JSON.parse(this._val.getGeometry()); }
|
|
547
|
+
/** Get the value as a GUID (formatted as GUID string).
|
|
548
|
+
* See [GuidString]($core-bentley)
|
|
549
|
+
*/
|
|
550
|
+
getGuid() { return this._val.getGuid(); }
|
|
551
|
+
/** Get the value as a Id (formatted as hexadecimal string). */
|
|
552
|
+
getId() { return this._val.getId(); }
|
|
553
|
+
/** Get the ClassId value formatted as fully qualified class name. */
|
|
554
|
+
getClassNameForClassId() { return this._val.getClassNameForClassId(); }
|
|
555
|
+
/** Get the value as a integer value */
|
|
556
|
+
getInteger() { return this._val.getInt64(); }
|
|
557
|
+
/** Get the value as a string value */
|
|
558
|
+
getString() { return this._val.getString(); }
|
|
559
|
+
/** Get the value as [XAndY]($core-geometry) */
|
|
560
|
+
getXAndY() { return this._val.getPoint2d(); }
|
|
561
|
+
/** Get the value as [XYAndZ]($core-geometry) */
|
|
562
|
+
getXYAndZ() { return this._val.getPoint3d(); }
|
|
563
|
+
/** Get the value as ECEnumeration value
|
|
564
|
+
* Note: This method is optional. Using [[ECSqlValue.getInteger]] for integral enums and
|
|
565
|
+
* [[ECSqlValue.getString]] for string enums respectively are the usual way to get
|
|
566
|
+
* enum values. This method can be used if the context of the underlying ECEnumeration
|
|
567
|
+
* is required.
|
|
568
|
+
* The value is broken down into the ECEnumerators that make it up, if the value
|
|
569
|
+
* is a combination of ECEnumerators. If the value is not a strict match of an ECEnumerator
|
|
570
|
+
* or a combination of them, undefined is returned.
|
|
571
|
+
* > Note: You can call [[ECSqlValue.columnInfo.isEnum]] to find out whether
|
|
572
|
+
* > this method can be called or not.
|
|
573
|
+
* @return ECEnumeration value(s) or undefined if the ECSqlValue does not represent an ECEnumeration.
|
|
574
|
+
* or is not a strict match of an ECEnumerator or a combination of them.
|
|
575
|
+
*/
|
|
576
|
+
getEnum() { return this._val.getEnum(); }
|
|
577
|
+
/** Get the value as [NavigationValue]($common) */
|
|
578
|
+
getNavigation() { return this._val.getNavigation(); }
|
|
579
|
+
/** Get an iterator for iterating the struct members of this struct value. */
|
|
580
|
+
getStructIterator() { return new ECSqlValueIterator(this._val.getStructIterator()); }
|
|
581
|
+
/** Get this struct value's content as object literal */
|
|
582
|
+
getStruct() { return ECSqlValueHelper.getStruct(this); }
|
|
583
|
+
/** Get an iterator for iterating the array elements of this array value. */
|
|
584
|
+
getArrayIterator() { return new ECSqlValueIterator(this._val.getArrayIterator()); }
|
|
585
|
+
/** Get this array value as JavaScript array */
|
|
586
|
+
getArray() { return ECSqlValueHelper.getArray(this); }
|
|
587
|
+
}
|
|
588
|
+
/** Iterator over members of a struct [ECSqlValue]($backend) or the elements of an array [ECSqlValue]($backend).
|
|
589
|
+
* See [ECSqlValue.getStructIterator]($backend) or [ECSqlValue.getArrayIterator]($backend).
|
|
590
|
+
* @public
|
|
591
|
+
*/
|
|
592
|
+
export class ECSqlValueIterator {
|
|
593
|
+
_it;
|
|
594
|
+
/** @internal */
|
|
595
|
+
constructor(it) { this._it = it; }
|
|
596
|
+
next() {
|
|
597
|
+
if (this._it.moveNext())
|
|
598
|
+
return { done: false, value: new ECSqlValue(this._it.getCurrent()) };
|
|
599
|
+
return { done: true, value: undefined };
|
|
600
|
+
}
|
|
601
|
+
[Symbol.iterator]() { return this; }
|
|
602
|
+
}
|
|
603
|
+
class ECSqlBindingHelper {
|
|
604
|
+
/** Binds the specified value to the specified binder
|
|
605
|
+
* @param binder Parameter Binder to bind to
|
|
606
|
+
* @param val Value to be bound. (See [iTwin.js Types used in ECSQL Parameter Bindings]($docs/learning/ECSQLParameterTypes))
|
|
607
|
+
* @throws IModelError in case of errors
|
|
608
|
+
*/
|
|
609
|
+
static bindValue(binder, val) {
|
|
610
|
+
// returns false if val is no primitive and returns true if it is primitive and a binding call was done
|
|
611
|
+
if (ECSqlBindingHelper.tryBindPrimitiveTypes(binder, val))
|
|
612
|
+
return;
|
|
613
|
+
if (Array.isArray(val)) {
|
|
614
|
+
ECSqlBindingHelper.bindArray(binder, val);
|
|
615
|
+
return;
|
|
616
|
+
}
|
|
617
|
+
if (typeof (val) === "object") {
|
|
618
|
+
ECSqlBindingHelper.bindStruct(binder, val);
|
|
619
|
+
return;
|
|
620
|
+
}
|
|
621
|
+
throw new Error(`Bound value is of an unsupported type: ${val}`);
|
|
622
|
+
}
|
|
623
|
+
/** Binds the specified primitive value to the specified binder
|
|
624
|
+
* @param binder Parameter Binder to bind to
|
|
625
|
+
* @param val Primitive value to be bound. Must be of one of these types described here:
|
|
626
|
+
* [ECSQL Binding types]($docs/learning/ECSQLParameterTypes)
|
|
627
|
+
* @throws IModelError in case of errors
|
|
628
|
+
*/
|
|
629
|
+
static bindPrimitive(binder, val) {
|
|
630
|
+
if (!ECSqlBindingHelper.tryBindPrimitiveTypes(binder, val))
|
|
631
|
+
throw new IModelError(DbResult.BE_SQLITE_ERROR, `Binding value is of an unsupported primitive type: ${val}`);
|
|
632
|
+
}
|
|
633
|
+
/** Binds the specified object to the specified struct binder
|
|
634
|
+
* @param binder Struct parameter binder to bind to
|
|
635
|
+
* @param val Value to be bound. Must be an Object with members of the supported types
|
|
636
|
+
* @throws IModelError in case of errors
|
|
637
|
+
*/
|
|
638
|
+
static bindStruct(binder, val) {
|
|
639
|
+
if (val === null || val === undefined) {
|
|
640
|
+
binder.bindNull();
|
|
641
|
+
return;
|
|
642
|
+
}
|
|
643
|
+
for (const member of Object.entries(val)) {
|
|
644
|
+
const memberName = member[0];
|
|
645
|
+
const memberVal = member[1];
|
|
646
|
+
ECSqlBindingHelper.bindValue(binder.bindMember(memberName), memberVal);
|
|
647
|
+
}
|
|
648
|
+
}
|
|
649
|
+
/** Binds the specified array to the specified array binder
|
|
650
|
+
* @param binder Array parameter binder to bind to
|
|
651
|
+
* @param val Value to be bound. Must be an Array with elements of the supported types
|
|
652
|
+
* @throws IModelError in case of errors
|
|
653
|
+
*/
|
|
654
|
+
static bindArray(binder, val) {
|
|
655
|
+
if (val === null || val === undefined) {
|
|
656
|
+
binder.bindNull();
|
|
657
|
+
return;
|
|
658
|
+
}
|
|
659
|
+
for (const element of val) {
|
|
660
|
+
ECSqlBindingHelper.bindValue(binder.addArrayElement(), element);
|
|
661
|
+
}
|
|
662
|
+
}
|
|
663
|
+
/** tries to interpret the passed value as known leaf types (primitives and navigation values).
|
|
664
|
+
* @returns Returns undefined if the value wasn't a primitive. DbResult if it was a primitive and was bound to the binder
|
|
665
|
+
*/
|
|
666
|
+
static tryBindPrimitiveTypes(binder, val) {
|
|
667
|
+
if (val === undefined || val === null) {
|
|
668
|
+
binder.bindNull();
|
|
669
|
+
return true;
|
|
670
|
+
}
|
|
671
|
+
if (typeof (val) === "number") {
|
|
672
|
+
if (Number.isInteger(val))
|
|
673
|
+
binder.bindInteger(val);
|
|
674
|
+
else
|
|
675
|
+
binder.bindDouble(val);
|
|
676
|
+
return true;
|
|
677
|
+
}
|
|
678
|
+
if (typeof (val) === "boolean") {
|
|
679
|
+
binder.bindBoolean(val);
|
|
680
|
+
return true;
|
|
681
|
+
}
|
|
682
|
+
if (typeof (val) === "string") {
|
|
683
|
+
binder.bindString(val);
|
|
684
|
+
return true;
|
|
685
|
+
}
|
|
686
|
+
if (ECSqlTypeHelper.isBlob(val)) {
|
|
687
|
+
binder.bindBlob(val);
|
|
688
|
+
return true;
|
|
689
|
+
}
|
|
690
|
+
if (ECSqlTypeHelper.isXYAndZ(val)) {
|
|
691
|
+
binder.bindPoint3d(val);
|
|
692
|
+
return true;
|
|
693
|
+
}
|
|
694
|
+
if (ECSqlTypeHelper.isXAndY(val)) {
|
|
695
|
+
binder.bindPoint2d(val);
|
|
696
|
+
return true;
|
|
697
|
+
}
|
|
698
|
+
if (ECSqlTypeHelper.isLowAndHighXYZ(val)) {
|
|
699
|
+
binder.bindRange3d(val);
|
|
700
|
+
return true;
|
|
701
|
+
}
|
|
702
|
+
if (ECSqlTypeHelper.isNavigationBindingValue(val)) {
|
|
703
|
+
binder.bindNavigation(val);
|
|
704
|
+
return true;
|
|
705
|
+
}
|
|
706
|
+
return false;
|
|
707
|
+
}
|
|
708
|
+
}
|
|
709
|
+
class ECSqlValueHelper {
|
|
710
|
+
static getValue(ecsqlValue) {
|
|
711
|
+
if (ecsqlValue.isNull)
|
|
712
|
+
return undefined;
|
|
713
|
+
const dataType = ecsqlValue.columnInfo.getType();
|
|
714
|
+
switch (dataType) {
|
|
715
|
+
case ECSqlValueType.Struct:
|
|
716
|
+
return ECSqlValueHelper.getStruct(ecsqlValue);
|
|
717
|
+
case ECSqlValueType.Navigation:
|
|
718
|
+
return ecsqlValue.getNavigation();
|
|
719
|
+
case ECSqlValueType.PrimitiveArray:
|
|
720
|
+
case ECSqlValueType.StructArray:
|
|
721
|
+
return ECSqlValueHelper.getArray(ecsqlValue);
|
|
722
|
+
default:
|
|
723
|
+
return ECSqlValueHelper.getPrimitiveValue(ecsqlValue);
|
|
724
|
+
}
|
|
725
|
+
}
|
|
726
|
+
static getStruct(ecsqlValue) {
|
|
727
|
+
if (ecsqlValue.isNull)
|
|
728
|
+
return undefined;
|
|
729
|
+
const structVal = {};
|
|
730
|
+
const it = ecsqlValue.getStructIterator();
|
|
731
|
+
try {
|
|
732
|
+
for (const memberECSqlVal of it) {
|
|
733
|
+
if (memberECSqlVal.isNull)
|
|
734
|
+
continue;
|
|
735
|
+
const memberName = ECJsNames.toJsName(memberECSqlVal.columnInfo.getPropertyName());
|
|
736
|
+
const memberVal = ECSqlValueHelper.getValue(memberECSqlVal);
|
|
737
|
+
Object.defineProperty(structVal, memberName, { enumerable: true, configurable: true, writable: true, value: memberVal });
|
|
738
|
+
}
|
|
739
|
+
}
|
|
740
|
+
finally {
|
|
741
|
+
}
|
|
742
|
+
return structVal;
|
|
743
|
+
}
|
|
744
|
+
static getArray(ecsqlValue) {
|
|
745
|
+
const arrayVal = [];
|
|
746
|
+
const it = ecsqlValue.getArrayIterator();
|
|
747
|
+
try {
|
|
748
|
+
for (const elementECSqlVal of it) {
|
|
749
|
+
const memberVal = ECSqlValueHelper.getValue(elementECSqlVal);
|
|
750
|
+
arrayVal.push(memberVal);
|
|
751
|
+
}
|
|
752
|
+
}
|
|
753
|
+
finally {
|
|
754
|
+
}
|
|
755
|
+
return arrayVal;
|
|
756
|
+
}
|
|
757
|
+
static getPrimitiveValue(ecsqlValue) {
|
|
758
|
+
if (ecsqlValue.isNull)
|
|
759
|
+
return undefined;
|
|
760
|
+
const colInfo = ecsqlValue.columnInfo;
|
|
761
|
+
switch (colInfo.getType()) {
|
|
762
|
+
case ECSqlValueType.Blob:
|
|
763
|
+
return ecsqlValue.getBlob();
|
|
764
|
+
case ECSqlValueType.Boolean:
|
|
765
|
+
return ecsqlValue.getBoolean();
|
|
766
|
+
case ECSqlValueType.DateTime:
|
|
767
|
+
return ecsqlValue.getDateTime();
|
|
768
|
+
case ECSqlValueType.Double:
|
|
769
|
+
return ecsqlValue.getDouble();
|
|
770
|
+
case ECSqlValueType.Geometry:
|
|
771
|
+
return ecsqlValue.getGeometry();
|
|
772
|
+
case ECSqlValueType.Guid:
|
|
773
|
+
return ecsqlValue.getGuid();
|
|
774
|
+
case ECSqlValueType.Id: {
|
|
775
|
+
if (colInfo.isSystemProperty() && colInfo.getPropertyName().endsWith("ECClassId"))
|
|
776
|
+
return ecsqlValue.getClassNameForClassId();
|
|
777
|
+
return ecsqlValue.getId();
|
|
778
|
+
}
|
|
779
|
+
case ECSqlValueType.Int:
|
|
780
|
+
case ECSqlValueType.Int64:
|
|
781
|
+
return ecsqlValue.getInteger();
|
|
782
|
+
case ECSqlValueType.Point2d:
|
|
783
|
+
return ecsqlValue.getXAndY();
|
|
784
|
+
case ECSqlValueType.Point3d:
|
|
785
|
+
return ecsqlValue.getXYAndZ();
|
|
786
|
+
case ECSqlValueType.String:
|
|
787
|
+
return ecsqlValue.getString();
|
|
788
|
+
default:
|
|
789
|
+
throw new IModelError(DbResult.BE_SQLITE_ERROR, `Unsupported type ${ecsqlValue.columnInfo.getType()} of the ECSQL Value`);
|
|
790
|
+
}
|
|
791
|
+
}
|
|
792
|
+
static queryClassName(ecdb, classId, tableSpace) {
|
|
793
|
+
if (!tableSpace)
|
|
794
|
+
tableSpace = "main";
|
|
795
|
+
return ecdb.withPreparedStatement(`SELECT s.Name, c.Name FROM [${tableSpace}].meta.ECSchemaDef s, JOIN [${tableSpace}].meta.ECClassDef c ON s.ECInstanceId=c.SchemaId WHERE c.ECInstanceId=?`, (stmt) => {
|
|
796
|
+
stmt.bindId(1, classId);
|
|
797
|
+
if (stmt.step() !== DbResult.BE_SQLITE_ROW)
|
|
798
|
+
throw new IModelError(DbResult.BE_SQLITE_ERROR, `No class found with ECClassId ${classId} in table space ${tableSpace}.`);
|
|
799
|
+
return `${stmt.getValue(0).getString()}.${stmt.getValue(1).getString()}`;
|
|
800
|
+
});
|
|
801
|
+
}
|
|
802
|
+
}
|
|
803
|
+
class ECSqlTypeHelper {
|
|
804
|
+
static isBlob(val) { return val instanceof Uint8Array; }
|
|
805
|
+
static isXAndY(val) { return XYZ.isXAndY(val); }
|
|
806
|
+
static isXYAndZ(val) { return XYZ.isXYAndZ(val); }
|
|
807
|
+
static isLowAndHighXYZ(arg) { return arg.low !== undefined && ECSqlTypeHelper.isXYAndZ(arg.low) && arg.high !== undefined && ECSqlTypeHelper.isXYAndZ(arg.high); }
|
|
808
|
+
static isNavigationBindingValue(val) { return val.id !== undefined && typeof (val.id) === "string"; }
|
|
809
|
+
}
|
|
810
|
+
//# sourceMappingURL=ECSqlStatement.js.map
|