Compare commits
149 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 84b234f26b | |||
| b71728086c | |||
| 79570b4070 | |||
| e974b360c1 | |||
| ca52be3c48 | |||
| 38a5254b30 | |||
| 37e04368ed | |||
| 7ffdc289d0 | |||
| 09b7ae77d5 | |||
| 73df695458 | |||
| 03dd5e5f5d | |||
| d2dde18fdb | |||
| 8c12621772 | |||
| c0d42b8316 | |||
| a38e44f2ea | |||
| 5d0e8d3ae4 | |||
| de0c645f5b | |||
| 218a67d92d | |||
| d6b76cfd56 | |||
| 45ccebc710 | |||
| b7c1f75d6a | |||
| c51b67318d | |||
| a330baf5da | |||
| ea103f3849 | |||
| 664fdaf39a | |||
| a6f15e9a53 | |||
| 0e0dc7da2d | |||
| cdd4df09ca | |||
| e612ed1192 | |||
| ed75c2110c | |||
| 96759f7e9e | |||
| 902ddcc8f1 | |||
| b62201cf95 | |||
| 4e60d95ce9 | |||
| 03ad5a80af | |||
| fbbf559e83 | |||
| da457a3438 | |||
| 767e379ff3 | |||
| 08c15c87a2 | |||
| 1827323712 | |||
| 653824c498 | |||
| 0dc823785d | |||
| bacdbc4d61 | |||
| 0343ac95ca | |||
| 53589d7ea0 | |||
| 98c6ac7c9e | |||
| 6d0cc1f7e6 | |||
| 077a74b2a3 | |||
| ef989ad8c7 | |||
| 8d8934657c | |||
| f019c88b27 | |||
| d7a95fd37c | |||
| 246b9099c4 | |||
| 74d4871fbd | |||
| 2f83e01f66 | |||
| 9e126e3dbf | |||
| c646129244 | |||
| 29e786574c | |||
| f634f158f9 | |||
| 48988fbe53 | |||
| 2c0d53c186 | |||
| 51370ababc | |||
| 8132eec03e | |||
| 86373c01c9 | |||
| 718c673845 | |||
| af8eb2c817 | |||
| 0d2d8028a2 | |||
| bed2cf9d42 | |||
| 5e4bcf48d6 | |||
| 59549e1065 | |||
| 16bbfae097 | |||
| 82bd96de61 | |||
| 51ed951d7d | |||
| cc6c884f47 | |||
| 4afed92ba9 | |||
| 326cb80f89 | |||
| ca2df4c020 | |||
| 787b2aa6e8 | |||
| 7d29bad9b5 | |||
| ba193c9dda | |||
| 764b548900 | |||
| 71dac48830 | |||
| 5684364119 | |||
| 45c4311d95 | |||
| 794658ed9c | |||
| ae521de698 | |||
| 0ff87576da | |||
| 141c503e81 | |||
| 319bc2826c | |||
| dee45512a1 | |||
| ce18804c95 | |||
| 2cfb66a872 | |||
| ed59150363 | |||
| 5715148cdd | |||
| 2f534e3fd0 | |||
| dd0cb8feb8 | |||
| 63c3c9befa | |||
| 281a2654c9 | |||
| 8fdbaaa52d | |||
| 67b12ae353 | |||
| 690e527b81 | |||
| 8f2e31c16e | |||
| e9b768daec | |||
| e5bf001590 | |||
| 7c0ac2e8f6 | |||
| 0969026f39 | |||
| 3d2aab8862 | |||
| bdea330c2e | |||
| b066b4ba3c | |||
| 3f772150ff | |||
| e00fd99d3c | |||
| 72e8ea78d9 | |||
| ede131ca0b | |||
| c4fcce4df8 | |||
| dcbd795b1f | |||
| 8a37d3fbd6 | |||
| 7256e11c3a | |||
| 9b8ab47eab | |||
| f72d5202f9 | |||
| dcac8390cf | |||
| 8893653583 | |||
| 0d5dd7156e | |||
| a5b681a6ed | |||
| 0c09205935 | |||
| 405d183124 | |||
| 7a1335681a | |||
| 889019a3e8 | |||
| 0dee313366 | |||
| a169d8b1d2 | |||
| 6d51b2d868 | |||
| 2c6909e98e | |||
| eeb4dab690 | |||
| e27808b73d | |||
| 5f1c942584 | |||
| 7dfe8fb964 | |||
| 73b04a7588 | |||
| 63bb28db0f | |||
| 3368e7a6dc | |||
| 01bb88b4a1 | |||
| 35f4e58a58 | |||
| 6d14607634 | |||
| 5363819e8d | |||
| 3be1676b1a | |||
| f5b5ff6487 | |||
| 878988df95 | |||
| f44f0413d0 | |||
| b80b5aef94 | |||
| 702f99eced | |||
| 42cf641a01 |
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"version": 1,
|
||||||
|
"isRoot": true,
|
||||||
|
"tools": {
|
||||||
|
"gitversion.tool": {
|
||||||
|
"version": "6.0.2",
|
||||||
|
"commands": ["dotnet-gitversion"],
|
||||||
|
"rollForward": false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,91 @@
|
|||||||
|
# This workflow uses actions that are not certified by GitHub.
|
||||||
|
# They are provided by a third-party and are governed by
|
||||||
|
# separate terms of service, privacy policy, and support
|
||||||
|
# documentation.
|
||||||
|
|
||||||
|
name: MSBuild
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: ["main", "develop", "release/*", "alan/*"] # Continuous delivery on every long-lived branch
|
||||||
|
tags: ["v3.*"] # Manual delivery on every 3.x tag
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: windows-latest
|
||||||
|
outputs:
|
||||||
|
version: ${{ steps.set-version.outputs.version }}
|
||||||
|
file_version: ${{ steps.set-info-version.outputs.file_version }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
path: speckle-cpp-connectors
|
||||||
|
fetch-depth: 0
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: r-wessel/ActiveLib
|
||||||
|
path: ActiveLib
|
||||||
|
ref: develop
|
||||||
|
|
||||||
|
- name: Download zip file
|
||||||
|
run: |
|
||||||
|
New-Item -ItemType Directory -Path "Archicad 27" -Force
|
||||||
|
Invoke-WebRequest -Uri "https://github.com/GRAPHISOFT/archicad-api-devkit/releases/download/27.3001/API.Development.Kit.WIN.27.3001.zip" -OutFile "file.zip"
|
||||||
|
|
||||||
|
- name: Extract zip file to Archicad 27 folder
|
||||||
|
run: |
|
||||||
|
Add-Type -AssemblyName System.IO.Compression.FileSystem
|
||||||
|
[System.IO.Compression.ZipFile]::ExtractToDirectory("file.zip", "Archicad 27")
|
||||||
|
|
||||||
|
- name: Add MSBuild to PATH
|
||||||
|
uses: microsoft/setup-msbuild@v2
|
||||||
|
|
||||||
|
- name: ⚒️ Run GitVersion
|
||||||
|
working-directory: speckle-cpp-connectors
|
||||||
|
run: ./build.ps1 build-server-version
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
working-directory: speckle-cpp-connectors
|
||||||
|
run: ./build.ps1
|
||||||
|
|
||||||
|
- uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: output-${{ env.GitVersion_FullSemVer }}
|
||||||
|
path: speckle-cpp-connectors/output/*.zip
|
||||||
|
retention-days: 1
|
||||||
|
|
||||||
|
- id: set-version
|
||||||
|
name: Set version to output
|
||||||
|
run: echo "version=${{ env.GitVersion_FullSemVer }}" >> "$Env:GITHUB_OUTPUT"
|
||||||
|
|
||||||
|
- id: set-info-version
|
||||||
|
name: Set file version to output
|
||||||
|
run: echo "file_version=${{ env.GitVersion_AssemblySemVer}}" >> "$Env:GITHUB_OUTPUT" # version will be retrieved from tag?
|
||||||
|
deploy-installers:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: build
|
||||||
|
env:
|
||||||
|
IS_TAG_BUILD: ${{ github.ref_type == 'tag' }}
|
||||||
|
IS_RELEASE_BRANCH: true
|
||||||
|
steps:
|
||||||
|
- name: 🔫 Trigger Build Installers
|
||||||
|
uses: ALEEF02/workflow-dispatch@v3.0.0
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
workflow: build-cpp-installers
|
||||||
|
repo: specklesystems/connector-installers
|
||||||
|
token: ${{ secrets.CONNECTORS_GH_TOKEN }}
|
||||||
|
inputs: '{ "run_id": "${{ github.run_id }}", "version": "${{ needs.build.outputs.version }}", "file_version": "${{needs.build.outputs.file_version}}", "public_release": ${{ env.IS_TAG_BUILD }}, "store_artifacts": ${{ env.IS_RELEASE_BRANCH }} }'
|
||||||
|
ref: main
|
||||||
|
wait-for-completion: true
|
||||||
|
wait-for-completion-interval: 10s
|
||||||
|
wait-for-completion-timeout: 10m
|
||||||
|
display-workflow-run-url: true
|
||||||
|
display-workflow-run-url-interval: 10s
|
||||||
|
|
||||||
|
- uses: geekyeggo/delete-artifact@v5
|
||||||
|
with:
|
||||||
|
name: output-*
|
||||||
+5
-1
@@ -3,6 +3,7 @@ build/
|
|||||||
Documents/
|
Documents/
|
||||||
ResourceObjects/
|
ResourceObjects/
|
||||||
Install/
|
Install/
|
||||||
|
enc_temp_folder/
|
||||||
.vs/
|
.vs/
|
||||||
.vscode/
|
.vscode/
|
||||||
xcuserdata/
|
xcuserdata/
|
||||||
@@ -25,4 +26,7 @@ XCBuildData/
|
|||||||
*.log
|
*.log
|
||||||
.idea
|
.idea
|
||||||
*.mui
|
*.mui
|
||||||
*.aps
|
*.aps
|
||||||
|
**/obj
|
||||||
|
**/bin
|
||||||
|
output/
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
workflow: GitFlow/v1
|
||||||
|
next-version: 3.0.0
|
||||||
|
branches:
|
||||||
|
release:
|
||||||
|
prevent-increment:
|
||||||
|
when-current-commit-tagged: true
|
||||||
@@ -13,6 +13,8 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ActiveLib17", "..\..\Active
|
|||||||
EndProject
|
EndProject
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SpeckleLib17", "..\SpeckleLib\SpeckleLib17.vcxproj", "{942743B7-B3CB-4F91-BE46-28937F5E3FD1}"
|
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SpeckleLib17", "..\SpeckleLib\SpeckleLib17.vcxproj", "{942743B7-B3CB-4F91-BE46-28937F5E3FD1}"
|
||||||
EndProject
|
EndProject
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Build", "..\ci-build\Build.csproj", "{702DE13A-1CCF-485D-A50D-846F645F07D3}"
|
||||||
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
Debug16|x64 = Debug16|x64
|
Debug16|x64 = Debug16|x64
|
||||||
@@ -143,6 +145,40 @@ Global
|
|||||||
{942743B7-B3CB-4F91-BE46-28937F5E3FD1}.ReleaseVS2022|x64.Build.0 = ReleaseAC27|x64
|
{942743B7-B3CB-4F91-BE46-28937F5E3FD1}.ReleaseVS2022|x64.Build.0 = ReleaseAC27|x64
|
||||||
{942743B7-B3CB-4F91-BE46-28937F5E3FD1}.ReleaseVS2022|x86.ActiveCfg = ReleaseAC27|Win32
|
{942743B7-B3CB-4F91-BE46-28937F5E3FD1}.ReleaseVS2022|x86.ActiveCfg = ReleaseAC27|Win32
|
||||||
{942743B7-B3CB-4F91-BE46-28937F5E3FD1}.ReleaseVS2022|x86.Build.0 = ReleaseAC27|Win32
|
{942743B7-B3CB-4F91-BE46-28937F5E3FD1}.ReleaseVS2022|x86.Build.0 = ReleaseAC27|Win32
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug16|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug16|x64.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug16|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug16|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug17|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug17|x64.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug17|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Debug17|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.DebugAC27|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.DebugAC27|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.DebugAC27|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.DebugVS2022|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.DebugVS2022|x64.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.DebugVS2022|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.DebugVS2022|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release16|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release16|x64.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release16|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release16|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release17|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release17|x64.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release17|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.Release17|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseAC27|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseAC27|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2019|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2019|x64.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2019|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2019|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2022|x64.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2022|x64.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2022|x86.ActiveCfg = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseVS2022|x86.Build.0 = Debug|Any CPU
|
||||||
|
{702DE13A-1CCF-485D-A50D-846F645F07D3}.ReleaseAC27|x64.ActiveCfg = Release|Any CPU
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
|
|||||||
@@ -94,6 +94,7 @@
|
|||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="Connector\Connector.cpp" />
|
<ClCompile Include="Connector\Connector.cpp" />
|
||||||
<ClCompile Include="Connector\Database\ModelCardDatabase.cpp" />
|
<ClCompile Include="Connector\Database\ModelCardDatabase.cpp" />
|
||||||
|
<ClCompile Include="Connector\Environment\ConnectorProject.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Account\AccountBridge.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Account\AccountBridge.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Account\GetAccounts.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Account\GetAccounts.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\AddModel.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\AddModel.cpp" />
|
||||||
@@ -104,6 +105,9 @@
|
|||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\GetDocumentState.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\GetDocumentState.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationName.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationName.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationVersion.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationVersion.cpp" />
|
||||||
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\HighlightModel.cpp" />
|
||||||
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\HighlightObjects.cpp" />
|
||||||
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\OpenUrl.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\RemoveModel.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\RemoveModel.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\UpdateModel.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\UpdateModel.cpp" />
|
||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Config\Arg\ConnectorConfig.cpp" />
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Config\Arg\ConnectorConfig.cpp" />
|
||||||
@@ -148,6 +152,7 @@
|
|||||||
<ClInclude Include="Connector\ConnectorResource.h" />
|
<ClInclude Include="Connector\ConnectorResource.h" />
|
||||||
<ClInclude Include="Connector\Database\Identity\RecordID.h" />
|
<ClInclude Include="Connector\Database\Identity\RecordID.h" />
|
||||||
<ClInclude Include="Connector\Database\ModelCardDatabase.h" />
|
<ClInclude Include="Connector\Database\ModelCardDatabase.h" />
|
||||||
|
<ClInclude Include="Connector\Environment\ConnectorProject.h" />
|
||||||
<ClInclude Include="Connector\Event\ConnectorEventID.h" />
|
<ClInclude Include="Connector\Event\ConnectorEventID.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Account\AccountBridge.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Account\AccountBridge.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Account\GetAccounts.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Account\GetAccounts.h" />
|
||||||
@@ -159,6 +164,9 @@
|
|||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\GetDocumentState.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\GetDocumentState.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationName.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationName.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationVersion.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\GetSourceApplicationVersion.h" />
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\HighlightModel.h" />
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\HighlightObjects.h" />
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\OpenUrl.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\RemoveModel.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\RemoveModel.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\UpdateModel.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\UpdateModel.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Config\Arg\ConnectorConfig.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Config\Arg\ConnectorConfig.h" />
|
||||||
@@ -170,6 +178,7 @@
|
|||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Selection\GetSelection.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Selection\GetSelection.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Selection\SelectionBridge.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Selection\SelectionBridge.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\ConversionResult.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\ConversionResult.h" />
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendConversionResult.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendError.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendError.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendObject.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendObject.h" />
|
||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendViaBrowserArgs.h" />
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendViaBrowserArgs.h" />
|
||||||
|
|||||||
@@ -71,6 +71,9 @@
|
|||||||
<Filter Include="Connector\Interface\Browser\Bridge\Selection\Arg">
|
<Filter Include="Connector\Interface\Browser\Bridge\Selection\Arg">
|
||||||
<UniqueIdentifier>{8bb3df60-affe-4b66-8d78-f1b98e6ba8df}</UniqueIdentifier>
|
<UniqueIdentifier>{8bb3df60-affe-4b66-8d78-f1b98e6ba8df}</UniqueIdentifier>
|
||||||
</Filter>
|
</Filter>
|
||||||
|
<Filter Include="Connector\Environment">
|
||||||
|
<UniqueIdentifier>{1d9a10c3-cac6-4b15-afb9-f117b99b3a24}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="RFIX.win\Connector.rc2">
|
<None Include="RFIX.win\Connector.rc2">
|
||||||
@@ -243,6 +246,18 @@
|
|||||||
<ClCompile Include="Connector\Interface\Browser\Bridge\Selection\Arg\SelectionInfo.cpp">
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Selection\Arg\SelectionInfo.cpp">
|
||||||
<Filter>Connector\Interface\Browser\Bridge\Selection\Arg</Filter>
|
<Filter>Connector\Interface\Browser\Bridge\Selection\Arg</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\HighlightModel.cpp">
|
||||||
|
<Filter>Connector\Interface\Browser\Bridge\Base</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\OpenUrl.cpp">
|
||||||
|
<Filter>Connector\Interface\Browser\Bridge\Base</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="Connector\Environment\ConnectorProject.cpp">
|
||||||
|
<Filter>Connector\Environment</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="Connector\Interface\Browser\Bridge\Base\HighlightObjects.cpp">
|
||||||
|
<Filter>Connector\Interface\Browser\Bridge\Base</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClInclude Include="Connector\ConnectorResource.h">
|
<ClInclude Include="Connector\ConnectorResource.h">
|
||||||
@@ -411,5 +426,20 @@
|
|||||||
<ClInclude Include="Connector\Interface\Browser\Bridge\Selection\Arg\SelectionInfo.h">
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Selection\Arg\SelectionInfo.h">
|
||||||
<Filter>Connector\Interface\Browser\Bridge\Selection\Arg</Filter>
|
<Filter>Connector\Interface\Browser\Bridge\Selection\Arg</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\HighlightModel.h">
|
||||||
|
<Filter>Connector\Interface\Browser\Bridge\Base</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\OpenUrl.h">
|
||||||
|
<Filter>Connector\Interface\Browser\Bridge\Base</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="Connector\Environment\ConnectorProject.h">
|
||||||
|
<Filter>Connector\Environment</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Send\Arg\SendConversionResult.h">
|
||||||
|
<Filter>Connector\Interface\Browser\Bridge\Send\Arg</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="Connector\Interface\Browser\Bridge\Base\HighlightObjects.h">
|
||||||
|
<Filter>Connector\Interface\Browser\Bridge\Base</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
||||||
@@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
210CC8832C80E6A300610F58 /* TriggerEvent.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 210CC8812C80E6A300610F58 /* TriggerEvent.cpp */; };
|
210CC8832C80E6A300610F58 /* TriggerEvent.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 210CC8812C80E6A300610F58 /* TriggerEvent.cpp */; };
|
||||||
|
21384BCD2CD2EE7400D4602B /* OpenUrl.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21384BC92CD2EE7400D4602B /* OpenUrl.cpp */; };
|
||||||
213CC39C2B1101F500088049 /* Cocoa.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 2151077C2AEDB9070022CD24 /* Cocoa.framework */; };
|
213CC39C2B1101F500088049 /* Cocoa.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 2151077C2AEDB9070022CD24 /* Cocoa.framework */; };
|
||||||
214B7A372C764BCD00D586C1 /* UpdateConfig.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21F69FBD2C7630B3008B6A06 /* UpdateConfig.cpp */; };
|
214B7A372C764BCD00D586C1 /* UpdateConfig.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21F69FBD2C7630B3008B6A06 /* UpdateConfig.cpp */; };
|
||||||
215F082A2C947F4400CD343B /* CardMover.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 215F08262C947F4400CD343B /* CardMover.cpp */; };
|
215F082A2C947F4400CD343B /* CardMover.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 215F08262C947F4400CD343B /* CardMover.cpp */; };
|
||||||
@@ -30,8 +31,14 @@
|
|||||||
215F08372C95808B00CD343B /* ReceiverModelCard.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 215F08362C95808B00CD343B /* ReceiverModelCard.cpp */; };
|
215F08372C95808B00CD343B /* ReceiverModelCard.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 215F08362C95808B00CD343B /* ReceiverModelCard.cpp */; };
|
||||||
215F08462C9633A800CD343B /* EverythingSendFilter.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 215F08452C9633A800CD343B /* EverythingSendFilter.cpp */; };
|
215F08462C9633A800CD343B /* EverythingSendFilter.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 215F08452C9633A800CD343B /* EverythingSendFilter.cpp */; };
|
||||||
2192460D2CA3469D00CF5703 /* ProjectCollection.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2192460B2CA3469D00CF5703 /* ProjectCollection.cpp */; };
|
2192460D2CA3469D00CF5703 /* ProjectCollection.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2192460B2CA3469D00CF5703 /* ProjectCollection.cpp */; };
|
||||||
|
2199BB552CDA4B1700A4BEEC /* ConnectorProject.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2199BB522CDA4B1700A4BEEC /* ConnectorProject.cpp */; };
|
||||||
|
2199BB7E2CDD3FA800A4BEEC /* HighlightObjects.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2199BB7C2CDD3FA800A4BEEC /* HighlightObjects.cpp */; };
|
||||||
219F30422C769283009834E9 /* ConfigTests.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 219F30402C769282009834E9 /* ConfigTests.cpp */; };
|
219F30422C769283009834E9 /* ConfigTests.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 219F30402C769282009834E9 /* ConfigTests.cpp */; };
|
||||||
21A0FB982CB723240023F24E /* FinishProxy.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21A0FB942CB723240023F24E /* FinishProxy.cpp */; };
|
21A0FB982CB723240023F24E /* FinishProxy.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21A0FB942CB723240023F24E /* FinishProxy.cpp */; };
|
||||||
|
21A79EC92CCDA45C001754E4 /* HighlightModel.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21A79EC52CCDA45C001754E4 /* HighlightModel.cpp */; };
|
||||||
|
21A890BC2CC15C540087E732 /* SelectionInfo.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21A890B22CC15C540087E732 /* SelectionInfo.cpp */; };
|
||||||
|
21A890BD2CC15C540087E732 /* GetSelection.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21A890B52CC15C540087E732 /* GetSelection.cpp */; };
|
||||||
|
21A890BE2CC15C540087E732 /* SelectionBridge.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21A890B72CC15C540087E732 /* SelectionBridge.cpp */; };
|
||||||
21AEF9EB2CAB56E5000B8681 /* SendError.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21AEF9E32CAB56E5000B8681 /* SendError.cpp */; };
|
21AEF9EB2CAB56E5000B8681 /* SendError.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21AEF9E32CAB56E5000B8681 /* SendError.cpp */; };
|
||||||
21AEF9EC2CAB56E5000B8681 /* SendViaBrowserArgs.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21AEF9E52CAB56E5000B8681 /* SendViaBrowserArgs.cpp */; };
|
21AEF9EC2CAB56E5000B8681 /* SendViaBrowserArgs.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21AEF9E52CAB56E5000B8681 /* SendViaBrowserArgs.cpp */; };
|
||||||
21AEF9EF2CAB5720000B8681 /* SendObject.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21AEF9EE2CAB5720000B8681 /* SendObject.cpp */; };
|
21AEF9EF2CAB5720000B8681 /* SendObject.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 21AEF9EE2CAB5720000B8681 /* SendObject.cpp */; };
|
||||||
@@ -292,6 +299,8 @@
|
|||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
210CC8812C80E6A300610F58 /* TriggerEvent.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TriggerEvent.cpp; sourceTree = "<group>"; };
|
210CC8812C80E6A300610F58 /* TriggerEvent.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TriggerEvent.cpp; sourceTree = "<group>"; };
|
||||||
210CC8822C80E6A300610F58 /* TriggerEvent.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TriggerEvent.h; sourceTree = "<group>"; };
|
210CC8822C80E6A300610F58 /* TriggerEvent.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TriggerEvent.h; sourceTree = "<group>"; };
|
||||||
|
21384BC92CD2EE7400D4602B /* OpenUrl.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = OpenUrl.cpp; sourceTree = "<group>"; };
|
||||||
|
21384BCC2CD2EE7400D4602B /* OpenUrl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = OpenUrl.h; sourceTree = "<group>"; };
|
||||||
213CC3A52B1101F500088049 /* Speckle Connector.bundle */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "Speckle Connector.bundle"; sourceTree = BUILT_PRODUCTS_DIR; };
|
213CC3A52B1101F500088049 /* Speckle Connector.bundle */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "Speckle Connector.bundle"; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
2151077C2AEDB9070022CD24 /* Cocoa.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Cocoa.framework; path = System/Library/Frameworks/Cocoa.framework; sourceTree = SDKROOT; };
|
2151077C2AEDB9070022CD24 /* Cocoa.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Cocoa.framework; path = System/Library/Frameworks/Cocoa.framework; sourceTree = SDKROOT; };
|
||||||
215F08262C947F4400CD343B /* CardMover.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CardMover.cpp; sourceTree = "<group>"; };
|
215F08262C947F4400CD343B /* CardMover.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CardMover.cpp; sourceTree = "<group>"; };
|
||||||
@@ -309,11 +318,26 @@
|
|||||||
2192460B2CA3469D00CF5703 /* ProjectCollection.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ProjectCollection.cpp; sourceTree = "<group>"; };
|
2192460B2CA3469D00CF5703 /* ProjectCollection.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ProjectCollection.cpp; sourceTree = "<group>"; };
|
||||||
2192460C2CA3469D00CF5703 /* ProjectCollection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ProjectCollection.h; sourceTree = "<group>"; };
|
2192460C2CA3469D00CF5703 /* ProjectCollection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ProjectCollection.h; sourceTree = "<group>"; };
|
||||||
219388682C4E5DE2002A0180 /* CMakeLists.txt */ = {isa = PBXFileReference; lastKnownFileType = text; path = CMakeLists.txt; sourceTree = "<group>"; };
|
219388682C4E5DE2002A0180 /* CMakeLists.txt */ = {isa = PBXFileReference; lastKnownFileType = text; path = CMakeLists.txt; sourceTree = "<group>"; };
|
||||||
|
2199BB512CDA481A00A4BEEC /* ConnectorFix.grc */ = {isa = PBXFileReference; lastKnownFileType = text; name = ConnectorFix.grc; path = RFIX/ConnectorFix.grc; sourceTree = "<group>"; };
|
||||||
|
2199BB522CDA4B1700A4BEEC /* ConnectorProject.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ConnectorProject.cpp; sourceTree = "<group>"; };
|
||||||
|
2199BB532CDA4B1700A4BEEC /* ConnectorProject.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ConnectorProject.h; sourceTree = "<group>"; };
|
||||||
|
2199BB5C2CDA93CE00A4BEEC /* ConnectorImagesFix.grc */ = {isa = PBXFileReference; lastKnownFileType = text; name = ConnectorImagesFix.grc; path = RFIX/ConnectorImagesFix.grc; sourceTree = "<group>"; };
|
||||||
|
2199BB792CDCEA3900A4BEEC /* SendConversionResult.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SendConversionResult.h; sourceTree = "<group>"; };
|
||||||
|
2199BB7C2CDD3FA800A4BEEC /* HighlightObjects.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = HighlightObjects.cpp; sourceTree = "<group>"; };
|
||||||
|
2199BB7D2CDD3FA800A4BEEC /* HighlightObjects.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = HighlightObjects.h; sourceTree = "<group>"; };
|
||||||
219F30352C768F0A009834E9 /* Connector-AC27-Test.bundle */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "Connector-AC27-Test.bundle"; sourceTree = BUILT_PRODUCTS_DIR; };
|
219F30352C768F0A009834E9 /* Connector-AC27-Test.bundle */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "Connector-AC27-Test.bundle"; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
219F30402C769282009834E9 /* ConfigTests.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = ConfigTests.cpp; sourceTree = "<group>"; };
|
219F30402C769282009834E9 /* ConfigTests.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = ConfigTests.cpp; sourceTree = "<group>"; };
|
||||||
219F30432C7693B6009834E9 /* Connector-AC27-Debug.xctestplan */ = {isa = PBXFileReference; lastKnownFileType = text; path = "Connector-AC27-Debug.xctestplan"; sourceTree = SOURCE_ROOT; };
|
219F30432C7693B6009834E9 /* Connector-AC27-Debug.xctestplan */ = {isa = PBXFileReference; lastKnownFileType = text; path = "Connector-AC27-Debug.xctestplan"; sourceTree = SOURCE_ROOT; };
|
||||||
21A0FB942CB723240023F24E /* FinishProxy.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = FinishProxy.cpp; sourceTree = "<group>"; };
|
21A0FB942CB723240023F24E /* FinishProxy.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = FinishProxy.cpp; sourceTree = "<group>"; };
|
||||||
21A0FB972CB723240023F24E /* FinishProxy.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = FinishProxy.h; sourceTree = "<group>"; };
|
21A0FB972CB723240023F24E /* FinishProxy.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = FinishProxy.h; sourceTree = "<group>"; };
|
||||||
|
21A79EC52CCDA45C001754E4 /* HighlightModel.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = HighlightModel.cpp; sourceTree = "<group>"; };
|
||||||
|
21A79EC82CCDA45C001754E4 /* HighlightModel.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = HighlightModel.h; sourceTree = "<group>"; };
|
||||||
|
21A890B22CC15C540087E732 /* SelectionInfo.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = SelectionInfo.cpp; sourceTree = "<group>"; };
|
||||||
|
21A890B32CC15C540087E732 /* SelectionInfo.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SelectionInfo.h; sourceTree = "<group>"; };
|
||||||
|
21A890B52CC15C540087E732 /* GetSelection.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = GetSelection.cpp; sourceTree = "<group>"; };
|
||||||
|
21A890B62CC15C540087E732 /* GetSelection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = GetSelection.h; sourceTree = "<group>"; };
|
||||||
|
21A890B72CC15C540087E732 /* SelectionBridge.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = SelectionBridge.cpp; sourceTree = "<group>"; };
|
||||||
|
21A890B82CC15C540087E732 /* SelectionBridge.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SelectionBridge.h; sourceTree = "<group>"; };
|
||||||
21AEF9E32CAB56E5000B8681 /* SendError.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = SendError.cpp; sourceTree = "<group>"; };
|
21AEF9E32CAB56E5000B8681 /* SendError.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = SendError.cpp; sourceTree = "<group>"; };
|
||||||
21AEF9E42CAB56E5000B8681 /* SendError.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SendError.h; sourceTree = "<group>"; };
|
21AEF9E42CAB56E5000B8681 /* SendError.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SendError.h; sourceTree = "<group>"; };
|
||||||
21AEF9E52CAB56E5000B8681 /* SendViaBrowserArgs.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = SendViaBrowserArgs.cpp; sourceTree = "<group>"; };
|
21AEF9E52CAB56E5000B8681 /* SendViaBrowserArgs.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = SendViaBrowserArgs.cpp; sourceTree = "<group>"; };
|
||||||
@@ -533,7 +557,6 @@
|
|||||||
21D1E9AC2BF14AF200957EAA /* TeamworkProductVersion.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = TeamworkProductVersion.framework; path = "../Archicad 27/Support/Frameworks/TeamworkProductVersion.framework"; sourceTree = "<group>"; };
|
21D1E9AC2BF14AF200957EAA /* TeamworkProductVersion.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = TeamworkProductVersion.framework; path = "../Archicad 27/Support/Frameworks/TeamworkProductVersion.framework"; sourceTree = "<group>"; };
|
||||||
21D1EA452BF14B0700957EAA /* VWMM.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = VWMM.framework; path = "../Vectorworks 2024/SDKLib/LibMac/Release/VWMM.framework"; sourceTree = "<group>"; };
|
21D1EA452BF14B0700957EAA /* VWMM.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = VWMM.framework; path = "../Vectorworks 2024/SDKLib/LibMac/Release/VWMM.framework"; sourceTree = "<group>"; };
|
||||||
21D1EA4A2BF14BBC00957EAA /* Connector.grc */ = {isa = PBXFileReference; lastKnownFileType = text; name = Connector.grc; path = RINT/Connector.grc; sourceTree = "<group>"; };
|
21D1EA4A2BF14BBC00957EAA /* Connector.grc */ = {isa = PBXFileReference; lastKnownFileType = text; name = Connector.grc; path = RINT/Connector.grc; sourceTree = "<group>"; };
|
||||||
21D1EA4B2BF14BC700957EAA /* ConnectorFix.grc */ = {isa = PBXFileReference; lastKnownFileType = text; name = ConnectorFix.grc; path = RFIX/ConnectorFix.grc; sourceTree = "<group>"; };
|
|
||||||
21D1EA4C2BF14BF000957EAA /* Module-Info27.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; name = "Module-Info27.plist"; path = "RINT.Archicad/EN-GB/Module-Info27.plist"; sourceTree = "<group>"; };
|
21D1EA4C2BF14BF000957EAA /* Module-Info27.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; name = "Module-Info27.plist"; path = "RINT.Archicad/EN-GB/Module-Info27.plist"; sourceTree = "<group>"; };
|
||||||
21F69EC62C64C035008B6A06 /* SpeckleLib.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = SpeckleLib.xcodeproj; path = ../SpeckleLib/SpeckleLib.xcodeproj; sourceTree = "<group>"; };
|
21F69EC62C64C035008B6A06 /* SpeckleLib.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = SpeckleLib.xcodeproj; path = ../SpeckleLib/SpeckleLib.xcodeproj; sourceTree = "<group>"; };
|
||||||
21F69EDB2C64ED10008B6A06 /* ConnectorMenu.grc */ = {isa = PBXFileReference; lastKnownFileType = text; name = ConnectorMenu.grc; path = RINT/ConnectorMenu.grc; sourceTree = "<group>"; };
|
21F69EDB2C64ED10008B6A06 /* ConnectorMenu.grc */ = {isa = PBXFileReference; lastKnownFileType = text; name = ConnectorMenu.grc; path = RINT/ConnectorMenu.grc; sourceTree = "<group>"; };
|
||||||
@@ -953,6 +976,24 @@
|
|||||||
path = Identity;
|
path = Identity;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
2199BB4E2CDA47F900A4BEEC /* Fixed */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
2199BB512CDA481A00A4BEEC /* ConnectorFix.grc */,
|
||||||
|
2199BB5C2CDA93CE00A4BEEC /* ConnectorImagesFix.grc */,
|
||||||
|
);
|
||||||
|
name = Fixed;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
2199BB542CDA4B1700A4BEEC /* Environment */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
2199BB522CDA4B1700A4BEEC /* ConnectorProject.cpp */,
|
||||||
|
2199BB532CDA4B1700A4BEEC /* ConnectorProject.h */,
|
||||||
|
);
|
||||||
|
path = Environment;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
219F30412C769282009834E9 /* ConnectorTests */ = {
|
219F30412C769282009834E9 /* ConnectorTests */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
@@ -963,11 +1004,33 @@
|
|||||||
path = ConnectorTests;
|
path = ConnectorTests;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
21A890B42CC15C540087E732 /* Arg */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
21A890B22CC15C540087E732 /* SelectionInfo.cpp */,
|
||||||
|
21A890B32CC15C540087E732 /* SelectionInfo.h */,
|
||||||
|
);
|
||||||
|
path = Arg;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
21A890B92CC15C540087E732 /* Selection */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
21A890B42CC15C540087E732 /* Arg */,
|
||||||
|
21A890B52CC15C540087E732 /* GetSelection.cpp */,
|
||||||
|
21A890B62CC15C540087E732 /* GetSelection.h */,
|
||||||
|
21A890B72CC15C540087E732 /* SelectionBridge.cpp */,
|
||||||
|
21A890B82CC15C540087E732 /* SelectionBridge.h */,
|
||||||
|
);
|
||||||
|
path = Selection;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
21AEF9E72CAB56E5000B8681 /* Arg */ = {
|
21AEF9E72CAB56E5000B8681 /* Arg */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
21AEF9F92CAC3897000B8681 /* ConversionResult.cpp */,
|
21AEF9F92CAC3897000B8681 /* ConversionResult.cpp */,
|
||||||
21AEF9F82CAC3897000B8681 /* ConversionResult.h */,
|
21AEF9F82CAC3897000B8681 /* ConversionResult.h */,
|
||||||
|
2199BB792CDCEA3900A4BEEC /* SendConversionResult.h */,
|
||||||
21AEF9E32CAB56E5000B8681 /* SendError.cpp */,
|
21AEF9E32CAB56E5000B8681 /* SendError.cpp */,
|
||||||
21AEF9E42CAB56E5000B8681 /* SendError.h */,
|
21AEF9E42CAB56E5000B8681 /* SendError.h */,
|
||||||
21AEF9EE2CAB5720000B8681 /* SendObject.cpp */,
|
21AEF9EE2CAB5720000B8681 /* SendObject.cpp */,
|
||||||
@@ -996,6 +1059,12 @@
|
|||||||
21B67CA82C77329800FD64FC /* GetSourceApplicationName.h */,
|
21B67CA82C77329800FD64FC /* GetSourceApplicationName.h */,
|
||||||
21B67CA92C77329800FD64FC /* GetSourceApplicationVersion.cpp */,
|
21B67CA92C77329800FD64FC /* GetSourceApplicationVersion.cpp */,
|
||||||
21B67CAA2C77329800FD64FC /* GetSourceApplicationVersion.h */,
|
21B67CAA2C77329800FD64FC /* GetSourceApplicationVersion.h */,
|
||||||
|
21A79EC52CCDA45C001754E4 /* HighlightModel.cpp */,
|
||||||
|
21A79EC82CCDA45C001754E4 /* HighlightModel.h */,
|
||||||
|
2199BB7C2CDD3FA800A4BEEC /* HighlightObjects.cpp */,
|
||||||
|
2199BB7D2CDD3FA800A4BEEC /* HighlightObjects.h */,
|
||||||
|
21384BC92CD2EE7400D4602B /* OpenUrl.cpp */,
|
||||||
|
21384BCC2CD2EE7400D4602B /* OpenUrl.h */,
|
||||||
21D0BDD52C935DAE0077E104 /* RemoveModel.cpp */,
|
21D0BDD52C935DAE0077E104 /* RemoveModel.cpp */,
|
||||||
21D0BDD62C935DAE0077E104 /* RemoveModel.h */,
|
21D0BDD62C935DAE0077E104 /* RemoveModel.h */,
|
||||||
21D0BDD22C935D1A0077E104 /* UpdateModel.cpp */,
|
21D0BDD22C935D1A0077E104 /* UpdateModel.cpp */,
|
||||||
@@ -1123,7 +1192,6 @@
|
|||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
21D1EA4A2BF14BBC00957EAA /* Connector.grc */,
|
21D1EA4A2BF14BBC00957EAA /* Connector.grc */,
|
||||||
21D1EA4B2BF14BC700957EAA /* ConnectorFix.grc */,
|
|
||||||
21F69EDB2C64ED10008B6A06 /* ConnectorMenu.grc */,
|
21F69EDB2C64ED10008B6A06 /* ConnectorMenu.grc */,
|
||||||
21D1EA4C2BF14BF000957EAA /* Module-Info27.plist */,
|
21D1EA4C2BF14BF000957EAA /* Module-Info27.plist */,
|
||||||
21F69EFE2C66AD55008B6A06 /* SpecklePalette.grc */,
|
21F69EFE2C66AD55008B6A06 /* SpecklePalette.grc */,
|
||||||
@@ -1176,6 +1244,7 @@
|
|||||||
21B67CCD2C77694500FD64FC /* Connector.h */,
|
21B67CCD2C77694500FD64FC /* Connector.h */,
|
||||||
21F69F102C677BC0008B6A06 /* ConnectorResource.h */,
|
21F69F102C677BC0008B6A06 /* ConnectorResource.h */,
|
||||||
21B67CCB2C77670400FD64FC /* Database */,
|
21B67CCB2C77670400FD64FC /* Database */,
|
||||||
|
2199BB542CDA4B1700A4BEEC /* Environment */,
|
||||||
21F69F092C677BC0008B6A06 /* Event */,
|
21F69F092C677BC0008B6A06 /* Event */,
|
||||||
21F69F0E2C677BC0008B6A06 /* Interface */,
|
21F69F0E2C677BC0008B6A06 /* Interface */,
|
||||||
21D0BDD82C9387E60077E104 /* Record */,
|
21D0BDD82C9387E60077E104 /* Record */,
|
||||||
@@ -1202,6 +1271,7 @@
|
|||||||
21B67CAB2C77329800FD64FC /* Base */,
|
21B67CAB2C77329800FD64FC /* Base */,
|
||||||
21F69FB82C762EF0008B6A06 /* Config */,
|
21F69FB82C762EF0008B6A06 /* Config */,
|
||||||
21D0BD5D2C89BFEA0077E104 /* Send */,
|
21D0BD5D2C89BFEA0077E104 /* Send */,
|
||||||
|
21A890B92CC15C540087E732 /* Selection */,
|
||||||
21B67CD82C78C83800FD64FC /* Test */,
|
21B67CD82C78C83800FD64FC /* Test */,
|
||||||
);
|
);
|
||||||
path = Bridge;
|
path = Bridge;
|
||||||
@@ -1255,6 +1325,7 @@
|
|||||||
81494D9D09DA5892006864FB /* Resource */ = {
|
81494D9D09DA5892006864FB /* Resource */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
2199BB4E2CDA47F900A4BEEC /* Fixed */,
|
||||||
7EA5F91E157FA18400693CEA /* EN-GB */,
|
7EA5F91E157FA18400693CEA /* EN-GB */,
|
||||||
);
|
);
|
||||||
name = Resource;
|
name = Resource;
|
||||||
@@ -1456,6 +1527,7 @@
|
|||||||
215F08462C9633A800CD343B /* EverythingSendFilter.cpp in Sources */,
|
215F08462C9633A800CD343B /* EverythingSendFilter.cpp in Sources */,
|
||||||
21F69FBB2C762EF0008B6A06 /* ConfigBridge.cpp in Sources */,
|
21F69FBB2C762EF0008B6A06 /* ConfigBridge.cpp in Sources */,
|
||||||
21F69F8A2C70D2C4008B6A06 /* AccountBridge.cpp in Sources */,
|
21F69F8A2C70D2C4008B6A06 /* AccountBridge.cpp in Sources */,
|
||||||
|
21A890BE2CC15C540087E732 /* SelectionBridge.cpp in Sources */,
|
||||||
21D0BD8E2C8EE4490077E104 /* Send.cpp in Sources */,
|
21D0BD8E2C8EE4490077E104 /* Send.cpp in Sources */,
|
||||||
21D0BDCF2C92DAC60077E104 /* AddModel.cpp in Sources */,
|
21D0BDCF2C92DAC60077E104 /* AddModel.cpp in Sources */,
|
||||||
21B67CF72C78D4DE00FD64FC /* GetComplexType.cpp in Sources */,
|
21B67CF72C78D4DE00FD64FC /* GetComplexType.cpp in Sources */,
|
||||||
@@ -1463,6 +1535,7 @@
|
|||||||
21B67CAE2C77329800FD64FC /* GetSourceApplicationVersion.cpp in Sources */,
|
21B67CAE2C77329800FD64FC /* GetSourceApplicationVersion.cpp in Sources */,
|
||||||
21A0FB982CB723240023F24E /* FinishProxy.cpp in Sources */,
|
21A0FB982CB723240023F24E /* FinishProxy.cpp in Sources */,
|
||||||
21B67CC32C77649F00FD64FC /* GetDocumentState.cpp in Sources */,
|
21B67CC32C77649F00FD64FC /* GetDocumentState.cpp in Sources */,
|
||||||
|
2199BB7E2CDD3FA800A4BEEC /* HighlightObjects.cpp in Sources */,
|
||||||
21D0BD602C89BFEA0077E104 /* SendBridge.cpp in Sources */,
|
21D0BD602C89BFEA0077E104 /* SendBridge.cpp in Sources */,
|
||||||
21D0BD972C8F13F30077E104 /* GetSendFilters.cpp in Sources */,
|
21D0BD972C8F13F30077E104 /* GetSendFilters.cpp in Sources */,
|
||||||
21B67CAC2C77329800FD64FC /* BaseBridge.cpp in Sources */,
|
21B67CAC2C77329800FD64FC /* BaseBridge.cpp in Sources */,
|
||||||
@@ -1476,8 +1549,10 @@
|
|||||||
214B7A372C764BCD00D586C1 /* UpdateConfig.cpp in Sources */,
|
214B7A372C764BCD00D586C1 /* UpdateConfig.cpp in Sources */,
|
||||||
21AEF9EC2CAB56E5000B8681 /* SendViaBrowserArgs.cpp in Sources */,
|
21AEF9EC2CAB56E5000B8681 /* SendViaBrowserArgs.cpp in Sources */,
|
||||||
21FF70492CA1A7F400AAD99A /* RecordCollection.cpp in Sources */,
|
21FF70492CA1A7F400AAD99A /* RecordCollection.cpp in Sources */,
|
||||||
|
21A79EC92CCDA45C001754E4 /* HighlightModel.cpp in Sources */,
|
||||||
21B67CC02C775A0D00FD64FC /* GetDocumentInfo.cpp in Sources */,
|
21B67CC02C775A0D00FD64FC /* GetDocumentInfo.cpp in Sources */,
|
||||||
21D0BDD42C935D1A0077E104 /* UpdateModel.cpp in Sources */,
|
21D0BDD42C935D1A0077E104 /* UpdateModel.cpp in Sources */,
|
||||||
|
21A890BD2CC15C540087E732 /* GetSelection.cpp in Sources */,
|
||||||
21B67CE72C78D23B00FD64FC /* ConnectorConfig.cpp in Sources */,
|
21B67CE72C78D23B00FD64FC /* ConnectorConfig.cpp in Sources */,
|
||||||
21B67CAD2C77329800FD64FC /* GetSourceApplicationName.cpp in Sources */,
|
21B67CAD2C77329800FD64FC /* GetSourceApplicationName.cpp in Sources */,
|
||||||
21D0BDE02C9393980077E104 /* SendFilter.cpp in Sources */,
|
21D0BDE02C9393980077E104 /* SendFilter.cpp in Sources */,
|
||||||
@@ -1485,7 +1560,10 @@
|
|||||||
215F082A2C947F4400CD343B /* CardMover.cpp in Sources */,
|
215F082A2C947F4400CD343B /* CardMover.cpp in Sources */,
|
||||||
215F08372C95808B00CD343B /* ReceiverModelCard.cpp in Sources */,
|
215F08372C95808B00CD343B /* ReceiverModelCard.cpp in Sources */,
|
||||||
21D0BDD72C935DAE0077E104 /* RemoveModel.cpp in Sources */,
|
21D0BDD72C935DAE0077E104 /* RemoveModel.cpp in Sources */,
|
||||||
|
21A890BC2CC15C540087E732 /* SelectionInfo.cpp in Sources */,
|
||||||
|
2199BB552CDA4B1700A4BEEC /* ConnectorProject.cpp in Sources */,
|
||||||
21AEF9EF2CAB5720000B8681 /* SendObject.cpp in Sources */,
|
21AEF9EF2CAB5720000B8681 /* SendObject.cpp in Sources */,
|
||||||
|
21384BCD2CD2EE7400D4602B /* OpenUrl.cpp in Sources */,
|
||||||
21B67CDC2C78C88000FD64FC /* SayHi.cpp in Sources */,
|
21B67CDC2C78C88000FD64FC /* SayHi.cpp in Sources */,
|
||||||
215F082E2C94C5C000CD343B /* FilterMover.cpp in Sources */,
|
215F082E2C94C5C000CD343B /* FilterMover.cpp in Sources */,
|
||||||
21F69F122C677BC0008B6A06 /* ConnectorMenu.cpp in Sources */,
|
21F69F122C677BC0008B6A06 /* ConnectorMenu.cpp in Sources */,
|
||||||
@@ -2031,7 +2109,7 @@
|
|||||||
);
|
);
|
||||||
LOCALISATION_SUFFIX = "EN-GB";
|
LOCALISATION_SUFFIX = "EN-GB";
|
||||||
MACH_O_TYPE = mh_bundle;
|
MACH_O_TYPE = mh_bundle;
|
||||||
MACOSX_DEPLOYMENT_TARGET = 11.0;
|
MACOSX_DEPLOYMENT_TARGET = 13.3;
|
||||||
NNA_WARNING_CPLUSPLUSFLAGS = "-Wno-deprecated";
|
NNA_WARNING_CPLUSPLUSFLAGS = "-Wno-deprecated";
|
||||||
OBJROOT = "";
|
OBJROOT = "";
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
ONLY_ACTIVE_ARCH = YES;
|
||||||
@@ -2138,7 +2216,7 @@
|
|||||||
);
|
);
|
||||||
LOCALISATION_SUFFIX = "EN-GB";
|
LOCALISATION_SUFFIX = "EN-GB";
|
||||||
MACH_O_TYPE = mh_bundle;
|
MACH_O_TYPE = mh_bundle;
|
||||||
MACOSX_DEPLOYMENT_TARGET = 11.0;
|
MACOSX_DEPLOYMENT_TARGET = 13.3;
|
||||||
NNA_WARNING_CPLUSPLUSFLAGS = "-Wno-deprecated";
|
NNA_WARNING_CPLUSPLUSFLAGS = "-Wno-deprecated";
|
||||||
OBJROOT = "";
|
OBJROOT = "";
|
||||||
PLUGIN_FOLDER = "";
|
PLUGIN_FOLDER = "";
|
||||||
|
|||||||
Executable → Regular
+9
-8
@@ -1,7 +1,7 @@
|
|||||||
#include "Active/File/Directory.h"
|
#include "Active/File/Directory.h"
|
||||||
#include "ConnectorResource.h"
|
#include "ConnectorResource.h"
|
||||||
#include "Connector/Connector.h"
|
#include "Connector/Connector.h"
|
||||||
#include "Connector/Database/ModelCardDatabase.h"
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
#include "Connector/Interface/ConnectorMenu.h"
|
#include "Connector/Interface/ConnectorMenu.h"
|
||||||
#include "Connector/Interface/ConnectorPalette.h"
|
#include "Connector/Interface/ConnectorPalette.h"
|
||||||
#include "Speckle/Database/AccountDatabase.h"
|
#include "Speckle/Database/AccountDatabase.h"
|
||||||
@@ -11,7 +11,7 @@
|
|||||||
using namespace active::file;
|
using namespace active::file;
|
||||||
using namespace active::environment;
|
using namespace active::environment;
|
||||||
using namespace connector;
|
using namespace connector;
|
||||||
using namespace connector::database;
|
using namespace connector::environment;
|
||||||
using namespace speckle::database;
|
using namespace speckle::database;
|
||||||
using namespace speckle::environment;
|
using namespace speckle::environment;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
@@ -29,8 +29,6 @@ namespace {
|
|||||||
ConnectorInstance(const String& name) : ConnectorAddon{name} {
|
ConnectorInstance(const String& name) : ConnectorAddon{name} {
|
||||||
add<ConnectorMenu>();
|
add<ConnectorMenu>();
|
||||||
add<ConnectorPalette>();
|
add<ConnectorPalette>();
|
||||||
//The connector 'owns' the model card database, so the publisher list should only hold a weak reference
|
|
||||||
addWeak(m_modelCards.getSubscription());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// MARK: Functions (const)
|
// MARK: Functions (const)
|
||||||
@@ -40,15 +38,18 @@ namespace {
|
|||||||
@return The account database
|
@return The account database
|
||||||
*/
|
*/
|
||||||
const AccountDatabase* getAccountDatabase() const override;
|
const AccountDatabase* getAccountDatabase() const override;
|
||||||
|
|
||||||
|
protected:
|
||||||
/*!
|
/*!
|
||||||
Get the model card database
|
Make a new new project. Allows Addon subclasses to define a Project subclass with additional functions/databases
|
||||||
@return The model card database
|
@return A new project instance
|
||||||
*/
|
*/
|
||||||
const ModelCardDatabase* getModelCardDatabase() const override { return &m_modelCards; }
|
virtual std::shared_ptr<Project> makeProject() const override {
|
||||||
|
return std::dynamic_pointer_cast<Project>(std::make_shared<ConnectorProject>());
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
mutable std::unique_ptr<AccountDatabase> m_account;
|
mutable std::unique_ptr<AccountDatabase> m_account;
|
||||||
ModelCardDatabase m_modelCards;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
///The active addon instance
|
///The active addon instance
|
||||||
|
|||||||
@@ -3,10 +3,6 @@
|
|||||||
|
|
||||||
namespace speckle::database {
|
namespace speckle::database {
|
||||||
class AccountDatabase;
|
class AccountDatabase;
|
||||||
class BIMElementDatabase;
|
|
||||||
}
|
|
||||||
namespace connector::database {
|
|
||||||
class ModelCardDatabase;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace connector {
|
namespace connector {
|
||||||
@@ -22,11 +18,6 @@ namespace connector {
|
|||||||
@return The account database
|
@return The account database
|
||||||
*/
|
*/
|
||||||
const virtual speckle::database::AccountDatabase* getAccountDatabase() const = 0;
|
const virtual speckle::database::AccountDatabase* getAccountDatabase() const = 0;
|
||||||
/*!
|
|
||||||
Get the model card database
|
|
||||||
@return The model card database
|
|
||||||
*/
|
|
||||||
const virtual database::ModelCardDatabase* getModelCardDatabase() const = 0;
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/*!
|
/*!
|
||||||
|
|||||||
@@ -58,6 +58,7 @@ enum ErrorString {
|
|||||||
modelCardNotFoundID,
|
modelCardNotFoundID,
|
||||||
noProjectOpenID,
|
noProjectOpenID,
|
||||||
accountNotFoundID,
|
accountNotFoundID,
|
||||||
|
elementTypeNotConvertedID,
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif //CONNECTOR_RESOURCE
|
#endif //CONNECTOR_RESOURCE
|
||||||
|
|||||||
@@ -1,16 +1,8 @@
|
|||||||
#ifndef CONNECTOR_DATABASE_ID
|
#ifndef CONNECTOR_DATABASE_ID
|
||||||
#define CONNECTOR_DATABASE_ID
|
#define CONNECTOR_DATABASE_ID
|
||||||
|
|
||||||
#include "Speckle/Utility/Guid.h"
|
|
||||||
|
|
||||||
namespace connector::database {
|
namespace connector::database {
|
||||||
|
|
||||||
//BIM element record identifier
|
|
||||||
using ElementID = speckle::utility::Guid;
|
|
||||||
|
|
||||||
//A list of element IDs
|
|
||||||
using ElementIDList = std::vector<ElementID>;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif //CONNECTOR_DATABASE_ID
|
#endif //CONNECTOR_DATABASE_ID
|
||||||
|
|||||||
@@ -0,0 +1,33 @@
|
|||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
|
|
||||||
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
|
|
||||||
|
using namespace active::event;
|
||||||
|
using namespace connector::database;
|
||||||
|
using namespace connector::environment;
|
||||||
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Default constructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
ConnectorProject::ConnectorProject() {
|
||||||
|
m_modelCards = std::make_shared<ModelCardDatabase>();
|
||||||
|
connector()->addWeak(m_modelCards->getSubscription());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Destructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
ConnectorProject::~ConnectorProject() {}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get the model card database
|
||||||
|
|
||||||
|
return; The model card database
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
const ModelCardDatabase* ConnectorProject::getModelCardDatabase() const {
|
||||||
|
return m_modelCards.get();
|
||||||
|
} //ConnectorProject::getModelCardDatabase
|
||||||
@@ -0,0 +1,53 @@
|
|||||||
|
#ifndef CONNECTOR_ENVIRONMENT_CONNECTOR_PROJECT
|
||||||
|
#define CONNECTOR_ENVIRONMENT_CONNECTOR_PROJECT
|
||||||
|
|
||||||
|
#include "Speckle/Environment/Project.h"
|
||||||
|
|
||||||
|
namespace connector::database {
|
||||||
|
class ModelCardDatabase;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace connector::environment {
|
||||||
|
|
||||||
|
/*!
|
||||||
|
A BIM project contained Speckle connector data, e.g. a model card database
|
||||||
|
*/
|
||||||
|
class ConnectorProject : public speckle::environment::Project {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// MARK: - Types
|
||||||
|
|
||||||
|
///Shared pointer
|
||||||
|
using Shared = std::shared_ptr<ConnectorProject>;
|
||||||
|
///Weak pointer
|
||||||
|
using Weak = std::weak_ptr<ConnectorProject>;
|
||||||
|
|
||||||
|
// MARK: - Constructors
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Default constructor
|
||||||
|
*/
|
||||||
|
ConnectorProject();
|
||||||
|
|
||||||
|
ConnectorProject(const ConnectorProject&) = delete;
|
||||||
|
/*!
|
||||||
|
Destructor
|
||||||
|
*/
|
||||||
|
~ConnectorProject();
|
||||||
|
|
||||||
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Get the model card database
|
||||||
|
@return The model card database
|
||||||
|
*/
|
||||||
|
const connector::database::ModelCardDatabase* getModelCardDatabase() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
///The model card database
|
||||||
|
std::shared_ptr<connector::database::ModelCardDatabase> m_modelCards;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_ENVIRONMENT_CONNECTOR_PROJECT
|
||||||
@@ -14,7 +14,7 @@ using namespace speckle::utility;
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
using WrappedValue = active::serialise::CargoHold<ContainerWrap<Vector<Account>>, Vector<Account>>;
|
using WrappedValue = CargoHold<ContainerWrap<Vector<Account>>, Vector<Account>>;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to retrieve the names of the methods supported by the bridge
|
JS Function class to retrieve the user's account(s)
|
||||||
*/
|
*/
|
||||||
class GetAccounts : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
class GetAccounts : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
||||||
public:
|
public:
|
||||||
|
|||||||
@@ -1,21 +1,16 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Base/AddModel.h"
|
#include "Connector/Interface/Browser/Bridge/Base/AddModel.h"
|
||||||
|
|
||||||
#include "Connector/Connector.h"
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
#include "Connector/Database/ModelCardDatabase.h"
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/Arg/DocumentInfo.h"
|
|
||||||
|
|
||||||
using namespace active::container;
|
using namespace active::container;
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
|
using namespace connector::environment;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
using WrappedValue = active::serialise::CargoHold<PackageWrap, DocumentInfo>;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Default constructor
|
Default constructor
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
@@ -30,6 +25,10 @@ AddModel::AddModel() : BridgeMethod{"AddModel", [&](const ModelCardEventWrapper&
|
|||||||
card: The card to add
|
card: The card to add
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
void AddModel::run(const ModelCard& card) const {
|
void AddModel::run(const ModelCard& card) const {
|
||||||
if (auto modelCardDBase = connector()->getModelCardDatabase(); modelCardDBase != nullptr)
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return;
|
||||||
|
if (auto modelCardDBase = connectorProject->getModelCardDatabase(); modelCardDBase != nullptr)
|
||||||
modelCardDBase->write(card);
|
modelCardDBase->write(card);
|
||||||
} //AddModel::run
|
} //AddModel::run
|
||||||
|
|||||||
@@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
///Argument parameter for a string
|
///Argument parameter for a model card
|
||||||
using CardHold = active::serialise::CargoHold<connector::record::CardMover, connector::record::ModelCard>;
|
using CardHold = active::serialise::CargoHold<connector::record::CardMover, connector::record::ModelCard>;
|
||||||
///Argument type for this method
|
///Argument type for this method
|
||||||
using ModelCardEventWrapper = speckle::interfac::browser::bridge::JSArgType<CardHold>;
|
using ModelCardEventWrapper = speckle::interfac::browser::bridge::JSArgType<CardHold>;
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Base/BaseBridge.h"
|
#include "Connector/Interface/Browser/Bridge/Base/BaseBridge.h"
|
||||||
|
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/AddModel.h"
|
#include "Connector/Interface/Browser/Bridge/Base/AddModel.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/GetConnectorVersion.h"
|
#include "Connector/Interface/Browser/Bridge/Base/GetConnectorVersion.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/GetDocumentInfo.h"
|
#include "Connector/Interface/Browser/Bridge/Base/GetDocumentInfo.h"
|
||||||
@@ -8,6 +7,20 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Base/GetSourceApplicationVersion.h"
|
#include "Connector/Interface/Browser/Bridge/Base/GetSourceApplicationVersion.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/RemoveModel.h"
|
#include "Connector/Interface/Browser/Bridge/Base/RemoveModel.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/UpdateModel.h"
|
#include "Connector/Interface/Browser/Bridge/Base/UpdateModel.h"
|
||||||
|
#include "Connector/Interface/Browser/Bridge/Base/HighlightModel.h"
|
||||||
|
#include "Connector/Interface/Browser/Bridge/Base/HighlightObjects.h"
|
||||||
|
#include "Connector/Interface/Browser/Bridge/Base/OpenUrl.h"
|
||||||
|
#include "Speckle/Event/Type/ProjectEvent.h"
|
||||||
|
|
||||||
|
#include "Speckle/Environment/Project.h"
|
||||||
|
#include "Speckle/Record/Element/Element.h"
|
||||||
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/ConnectorResource.h"
|
||||||
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
|
#include "Speckle/Database/BIMElementDatabase.h"
|
||||||
|
#include "Connector/Record/Model/SenderModelCard.h"
|
||||||
|
#include "Connector/Record/Model/Filter/SendFilter.h"
|
||||||
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
|
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
|
|
||||||
@@ -22,6 +35,28 @@ BaseBridge::BaseBridge() : BrowserBridge{"baseBinding"} {
|
|||||||
addMethod<GetDocumentState>();
|
addMethod<GetDocumentState>();
|
||||||
addMethod<GetSourceApplicationName>();
|
addMethod<GetSourceApplicationName>();
|
||||||
addMethod<GetSourceApplicationVersion>();
|
addMethod<GetSourceApplicationVersion>();
|
||||||
|
addMethod<HighlightModel>();
|
||||||
|
addMethod<HighlightObjects>();
|
||||||
|
addMethod<OpenUrl>();
|
||||||
addMethod<RemoveModel>();
|
addMethod<RemoveModel>();
|
||||||
addMethod<UpdateModel>();
|
addMethod<UpdateModel>();
|
||||||
} //BaseBridge::BaseBridge
|
} //BaseBridge::BaseBridge
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Handle a project event
|
||||||
|
|
||||||
|
event: The project event
|
||||||
|
|
||||||
|
return: True if the event should be closed
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
bool BaseBridge::handle(const speckle::event::ProjectEvent& event) {
|
||||||
|
using enum speckle::event::ProjectEvent::Type;
|
||||||
|
switch (event.getType()) {
|
||||||
|
case open:
|
||||||
|
sendEvent("documentChanged");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
} //BaseBridge::handle
|
||||||
|
|||||||
@@ -2,13 +2,14 @@
|
|||||||
#define CONNECTOR_INTERFACE_BRIDGE_BASE_BRIDGE
|
#define CONNECTOR_INTERFACE_BRIDGE_BASE_BRIDGE
|
||||||
|
|
||||||
#include "Speckle/Interface/Browser/Bridge/BrowserBridge.h"
|
#include "Speckle/Interface/Browser/Bridge/BrowserBridge.h"
|
||||||
|
#include "Speckle/Event/Subscriber/ProjectSubscriber.h"
|
||||||
|
|
||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
A browser bridge to provide configuration settings
|
A browser bridge to manage document settings
|
||||||
*/
|
*/
|
||||||
class BaseBridge : public speckle::interfac::browser::bridge::BrowserBridge {
|
class BaseBridge : public speckle::interfac::browser::bridge::BrowserBridge, public speckle::event::ProjectSubscriber {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// MARK: - Types
|
// MARK: - Types
|
||||||
@@ -22,6 +23,14 @@ namespace connector::interfac::browser::bridge {
|
|||||||
Default constructor
|
Default constructor
|
||||||
*/
|
*/
|
||||||
BaseBridge();
|
BaseBridge();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
/*!
|
||||||
|
Handle the project events
|
||||||
|
@param event The project event
|
||||||
|
@return True if the event should be closed
|
||||||
|
*/
|
||||||
|
bool handle(const speckle::event::ProjectEvent& event) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -25,13 +25,13 @@ GetConnectorVersion::GetConnectorVersion() : BridgeMethod{"GetConnectorVersion",
|
|||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Get the host application version
|
Get the connector software version
|
||||||
|
|
||||||
return: The application version
|
return: The connector software version
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
std::unique_ptr<Cargo> GetConnectorVersion::run() const {
|
std::unique_ptr<Cargo> GetConnectorVersion::run() const {
|
||||||
//Implement other platforms as required
|
//Implement other platforms as required
|
||||||
String result{active::utility::String{connector::versionMajor} + "." + active::utility::String{connector::versionMinor} + "." +
|
String result{String{connector::versionMajor} + "." + String{connector::versionMinor} + "." +
|
||||||
active::utility::String{connector::versionPatch}};
|
String{connector::versionPatch}};
|
||||||
return std::make_unique<WrappedValue>(result);
|
return std::make_unique<WrappedValue>(result);
|
||||||
} //GetConnectorVersion::run
|
} //GetConnectorVersion::run
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ namespace connector::interfac::browser::bridge {
|
|||||||
class ConnectorConfig;
|
class ConnectorConfig;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to retrieve the names of the methods supported by the bridge
|
JS Function class to get the connector software version
|
||||||
*/
|
*/
|
||||||
class GetConnectorVersion : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
class GetConnectorVersion : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
||||||
public:
|
public:
|
||||||
@@ -23,8 +23,8 @@ namespace connector::interfac::browser::bridge {
|
|||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Get the host application version
|
Get the connector software version
|
||||||
@return The application version
|
@return The connector software version
|
||||||
*/
|
*/
|
||||||
std::unique_ptr<active::serialise::Cargo> run() const;
|
std::unique_ptr<active::serialise::Cargo> run() const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
#include "Active/Serialise/CargoHold.h"
|
#include "Active/Serialise/CargoHold.h"
|
||||||
#include "Connector/Connector.h"
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
#include "Connector/Database/ModelCardDatabase.h"
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/Arg/DocumentInfo.h"
|
#include "Connector/Interface/Browser/Bridge/Base/Arg/DocumentInfo.h"
|
||||||
#include "Speckle/Environment/Project.h"
|
#include "Speckle/Environment/Project.h"
|
||||||
@@ -9,6 +10,7 @@
|
|||||||
|
|
||||||
using namespace active::container;
|
using namespace active::container;
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
|
using namespace connector::environment;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
@@ -33,14 +35,17 @@ GetDocumentInfo::GetDocumentInfo() : BridgeMethod{"GetDocumentInfo", [&]() {
|
|||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
std::unique_ptr<Cargo> GetDocumentInfo::run() const {
|
std::unique_ptr<Cargo> GetDocumentInfo::run() const {
|
||||||
auto docInfo = std::make_unique<DocumentInfo>();
|
auto docInfo = std::make_unique<DocumentInfo>();
|
||||||
if (auto project = connector()->getActiveProject().lock(); project) {
|
auto project = connector()->getActiveProject().lock();
|
||||||
auto info = project->getInfo();
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
docInfo->name = info.name;
|
if (!connectorProject)
|
||||||
if (info.path)
|
return nullptr;
|
||||||
docInfo->location = *info.path;
|
auto info = connectorProject->getInfo();
|
||||||
if (auto cardDatabase = connector()->getModelCardDatabase(); cardDatabase != nullptr)
|
docInfo->name = info.name;
|
||||||
docInfo->ID = cardDatabase->getStoreID();
|
if (info.path)
|
||||||
|
docInfo->location = *info.path;
|
||||||
|
if (auto cardDatabase = connectorProject->getModelCardDatabase(); cardDatabase != nullptr)
|
||||||
|
docInfo->ID = cardDatabase->getStoreID();
|
||||||
|
else
|
||||||
docInfo->ID = Guid{true}.operator String();
|
docInfo->ID = Guid{true}.operator String();
|
||||||
}
|
|
||||||
return std::make_unique<WrappedValue>(std::move(docInfo));
|
return std::make_unique<WrappedValue>(std::move(docInfo));
|
||||||
} //GetDocumentInfo::run
|
} //GetDocumentInfo::run
|
||||||
|
|||||||
@@ -1,15 +1,13 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Base/GetDocumentState.h"
|
#include "Connector/Interface/Browser/Bridge/Base/GetDocumentState.h"
|
||||||
|
|
||||||
#include "Active/Serialise/CargoHold.h"
|
|
||||||
#include "Connector/Connector.h"
|
#include "Connector/Connector.h"
|
||||||
#include "Connector/Record/Model/ModelCard.h"
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
#include "Connector/Database/ModelCardDatabase.h"
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
|
|
||||||
using namespace active::container;
|
using namespace active::container;
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
|
using namespace connector::environment;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
using namespace connector::database;
|
|
||||||
using namespace connector::record;
|
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
@@ -21,12 +19,16 @@ GetDocumentState::GetDocumentState() : BridgeMethod{"GetDocumentState", [&]() {
|
|||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Get the document info
|
Get the document model cards
|
||||||
|
|
||||||
return: The document info
|
return: The document model cards
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
std::unique_ptr<Cargo> GetDocumentState::run() const {
|
std::unique_ptr<Cargo> GetDocumentState::run() const {
|
||||||
if (auto modelCardDBase = connector()->getModelCardDatabase(); modelCardDBase != nullptr) {
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return nullptr;
|
||||||
|
if (auto modelCardDBase = connectorProject->getModelCardDatabase(); modelCardDBase != nullptr) {
|
||||||
return modelCardDBase->wrapper();
|
return modelCardDBase->wrapper();
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to retrieve the information about the active document
|
JS Function class to retrieve model cards stored in the current document
|
||||||
*/
|
*/
|
||||||
class GetDocumentState : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
class GetDocumentState : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
||||||
public:
|
public:
|
||||||
@@ -21,8 +21,8 @@ namespace connector::interfac::browser::bridge {
|
|||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Get the document info
|
Get the document model cards
|
||||||
@return The document info
|
@return The document model cards
|
||||||
*/
|
*/
|
||||||
std::unique_ptr<active::serialise::Cargo> run() const;
|
std::unique_ptr<active::serialise::Cargo> run() const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -0,0 +1,55 @@
|
|||||||
|
#include "Connector/Interface/Browser/Bridge/Base/HighlightModel.h"
|
||||||
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/ConnectorResource.h"
|
||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendError.h"
|
||||||
|
#include "Connector/Record/Model/SenderModelCard.h"
|
||||||
|
#include "Connector/Record/Model/Filter/SendFilter.h"
|
||||||
|
#include "Speckle/Interface/Browser/Bridge/BrowserBridge.h"
|
||||||
|
#include "Speckle/Record/Element/Element.h"
|
||||||
|
#include "Speckle/Database/BIMElementDatabase.h"
|
||||||
|
#include "Speckle/Environment/Project.h"
|
||||||
|
|
||||||
|
using namespace speckle::record::element;
|
||||||
|
using namespace connector::environment;
|
||||||
|
using namespace connector::interfac::browser::bridge;
|
||||||
|
using namespace connector::record;
|
||||||
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Default constructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
HighlightModel::HighlightModel() : BridgeMethod{"HighlightModel", [&](const HighlightModelArgs& args) {
|
||||||
|
run(args);
|
||||||
|
}} {}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Highlight elements linked to the model card selection
|
||||||
|
|
||||||
|
modelCardID: The ID of the target model card
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void HighlightModel::run(const String& modelCardID) const {
|
||||||
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return;
|
||||||
|
//Find the specified model card
|
||||||
|
auto modelCardDatabase = connectorProject->getModelCardDatabase();
|
||||||
|
auto modelCard = modelCardDatabase->getCard(modelCardID);
|
||||||
|
if (!modelCard) {
|
||||||
|
getBridge()->sendEvent("setModelError",
|
||||||
|
std::make_unique<SendError>(connector()->getLocalString(errorString, modelCardNotFoundID), modelCardID));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (auto senderCard = dynamic_cast<SenderModelCard*>(modelCard.get())) {
|
||||||
|
auto modelCardSelection = senderCard->getFilter().getElementIDs();
|
||||||
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
if (!project)
|
||||||
|
return; // TODO: is this OK? should this throw?
|
||||||
|
auto elementDatabase = project->getElementDatabase();
|
||||||
|
elementDatabase->clearSelection();
|
||||||
|
elementDatabase->setSelection(modelCardSelection);
|
||||||
|
}
|
||||||
|
} //HighlightModel::run
|
||||||
@@ -0,0 +1,39 @@
|
|||||||
|
#ifndef CONNECTOR_INTERFACE_BRIDGE_HIGHLIGHT_MODEL
|
||||||
|
#define CONNECTOR_INTERFACE_BRIDGE_HIGHLIGHT_MODEL
|
||||||
|
|
||||||
|
#include "Active/Serialise/CargoHold.h"
|
||||||
|
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
||||||
|
#include "Speckle/Interface/Browser/Bridge/BridgeMethod.h"
|
||||||
|
|
||||||
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
|
///Argument parameter for a string
|
||||||
|
using StringHold = active::serialise::CargoHold<active::serialise::ValueWrap<speckle::utility::String>, speckle::utility::String>;
|
||||||
|
///Argument type for this method
|
||||||
|
using HighlightModelArgs = speckle::interfac::browser::bridge::JSArgType<StringHold>;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
JS Function class to highlight elements from the selected model card in the open document
|
||||||
|
*/
|
||||||
|
class HighlightModel : public speckle::interfac::browser::bridge::BridgeMethod<HighlightModelArgs, void> {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// MARK: - Constructors
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Constructor
|
||||||
|
*/
|
||||||
|
HighlightModel();
|
||||||
|
|
||||||
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Highlight elements linked to the model card selection
|
||||||
|
@param modelCardID The ID of the target model card
|
||||||
|
*/
|
||||||
|
void run(const speckle::utility::String& modelCardID) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_INTERFACE_HIGHLIGHT_MODEL
|
||||||
@@ -0,0 +1,40 @@
|
|||||||
|
#include "Connector/Interface/Browser/Bridge/Base/HighlightObjects.h"
|
||||||
|
|
||||||
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
|
#include "Speckle/Database/BIMElementDatabase.h"
|
||||||
|
#include "Speckle/Environment/Project.h"
|
||||||
|
|
||||||
|
using namespace connector::environment;
|
||||||
|
using namespace connector::interfac::browser::bridge;
|
||||||
|
using namespace speckle::database;
|
||||||
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Default constructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
HighlightObjects::HighlightObjects() : BridgeMethod{"HighlightObjects", [&](const HighlightObjectArgs& args) {
|
||||||
|
run(args);
|
||||||
|
}} {}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Highlight specified objects
|
||||||
|
|
||||||
|
objectIDs: List of object IDs to be highlighted
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void HighlightObjects::run(const StringList& objectIDs) const {
|
||||||
|
BIMLinkList objectSelection;
|
||||||
|
for (const auto& text : objectIDs)
|
||||||
|
if (Guid guid{text}; !guid.empty())
|
||||||
|
objectSelection.emplace_back(guid);
|
||||||
|
if (objectSelection.empty())
|
||||||
|
return;
|
||||||
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return;
|
||||||
|
auto elementDatabase = project->getElementDatabase();
|
||||||
|
elementDatabase->clearSelection();
|
||||||
|
elementDatabase->setSelection(objectSelection);
|
||||||
|
} //HighlightObjects::run
|
||||||
@@ -0,0 +1,42 @@
|
|||||||
|
#ifndef CONNECTOR_INTERFACE_BRIDGE_HIGHLIGHT_OBJECTS
|
||||||
|
#define CONNECTOR_INTERFACE_BRIDGE_HIGHLIGHT_OBJECTS
|
||||||
|
|
||||||
|
#include "Active/Serialise/CargoHold.h"
|
||||||
|
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
||||||
|
#include "Active/Serialise/Package/Wrapper/ContainerWrap.h"
|
||||||
|
#include "Speckle/Interface/Browser/Bridge/BridgeMethod.h"
|
||||||
|
|
||||||
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
|
///List of strings
|
||||||
|
using StringList = std::vector<active::utility::String>;
|
||||||
|
///Argument parameter for a string
|
||||||
|
using StringListHold = active::serialise::CargoHold<active::serialise::ContainerWrap<StringList>, StringList>;
|
||||||
|
///Argument type for this method
|
||||||
|
using HighlightObjectArgs = speckle::interfac::browser::bridge::JSArgType<StringListHold>;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
JS Function class to highlight objects using passed application IDs
|
||||||
|
*/
|
||||||
|
class HighlightObjects : public speckle::interfac::browser::bridge::BridgeMethod<HighlightObjectArgs, void> {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// MARK: - Constructors
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Constructor
|
||||||
|
*/
|
||||||
|
HighlightObjects();
|
||||||
|
|
||||||
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Highlight specified objects
|
||||||
|
@param objectIDs List of object IDs to be highlighted
|
||||||
|
*/
|
||||||
|
void run(const StringList& objectIDs) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_INTERFACE_BRIDGE_HIGHLIGHT_OBJECTS
|
||||||
@@ -0,0 +1,24 @@
|
|||||||
|
#include "Connector/Interface/Browser/Bridge/Base/OpenUrl.h"
|
||||||
|
|
||||||
|
#include "Speckle/Environment/Platform.h"
|
||||||
|
|
||||||
|
using namespace connector::interfac::browser::bridge;
|
||||||
|
using namespace speckle::environment;
|
||||||
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Default constructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
OpenUrl::OpenUrl() : BridgeMethod{"OpenUrl", [&](const SendArgs& args) {
|
||||||
|
run(args);
|
||||||
|
}} {}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Opens an url
|
||||||
|
|
||||||
|
url: The URL to open
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void OpenUrl::run(const String& url) const {
|
||||||
|
platform()->openURL(url);
|
||||||
|
} //OpenUrl::run
|
||||||
@@ -0,0 +1,41 @@
|
|||||||
|
#ifndef CONNECTOR_INTERFACE_BRIDGE_OPEN_URL
|
||||||
|
#define CONNECTOR_INTERFACE_BRIDGE_OPEN_URL
|
||||||
|
|
||||||
|
#include "Active/Serialise/CargoHold.h"
|
||||||
|
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
||||||
|
#include "Speckle/Interface/Browser/Bridge/BridgeMethod.h"
|
||||||
|
|
||||||
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
|
class ConnectorConfig;
|
||||||
|
|
||||||
|
///Argument parameter for a string
|
||||||
|
using StringHold = active::serialise::CargoHold<active::serialise::ValueWrap<speckle::utility::String>, speckle::utility::String>;
|
||||||
|
///Argument type for this method
|
||||||
|
using SendArgs = speckle::interfac::browser::bridge::JSArgType<StringHold>;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
JS Function class to highlight elements from the selected model card in the open document
|
||||||
|
*/
|
||||||
|
class OpenUrl : public speckle::interfac::browser::bridge::BridgeMethod<SendArgs, void> {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// MARK: - Constructors
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Constructor
|
||||||
|
*/
|
||||||
|
OpenUrl();
|
||||||
|
|
||||||
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Opens an url
|
||||||
|
@param url The URL to open
|
||||||
|
*/
|
||||||
|
void run(const speckle::utility::String& url) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_INTERFACE_BRIDGE_OPEN_URL
|
||||||
@@ -1,22 +1,16 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Base/RemoveModel.h"
|
#include "Connector/Interface/Browser/Bridge/Base/RemoveModel.h"
|
||||||
|
|
||||||
#include "Connector/Connector.h"
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
#include "Connector/Database/ModelCardDatabase.h"
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/Arg/DocumentInfo.h"
|
|
||||||
|
|
||||||
using namespace active::container;
|
using namespace active::container;
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
using namespace connector::database;
|
using namespace connector::environment;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
using WrappedValue = active::serialise::CargoHold<PackageWrap, DocumentInfo>;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Default constructor
|
Default constructor
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
@@ -31,6 +25,10 @@ RemoveModel::RemoveModel() : BridgeMethod{"RemoveModel", [&](const ModelCardEven
|
|||||||
card: The card to add
|
card: The card to add
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
void RemoveModel::run(const ModelCard& card) const {
|
void RemoveModel::run(const ModelCard& card) const {
|
||||||
if (auto modelCardDBase = connector()->getModelCardDatabase(); modelCardDBase != nullptr)
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return;
|
||||||
|
if (auto modelCardDBase = connectorProject->getModelCardDatabase(); modelCardDBase != nullptr)
|
||||||
modelCardDBase->erase(card.getID());
|
modelCardDBase->erase(card.getID());
|
||||||
} //RemoveModel::run
|
} //RemoveModel::run
|
||||||
|
|||||||
@@ -8,13 +8,13 @@
|
|||||||
|
|
||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
///Argument parameter for a string
|
///Argument parameter for a model card
|
||||||
using CardHold = active::serialise::CargoHold<connector::record::CardMover, connector::record::ModelCard>;
|
using CardHold = active::serialise::CargoHold<connector::record::CardMover, connector::record::ModelCard>;
|
||||||
///Argument type for this method
|
///Argument type for this method
|
||||||
using ModelCardEventWrapper = speckle::interfac::browser::bridge::JSArgType<CardHold>;
|
using ModelCardEventWrapper = speckle::interfac::browser::bridge::JSArgType<CardHold>;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to add a model card to the document storage
|
JS Function class to remove a model card from the document storage
|
||||||
*/
|
*/
|
||||||
class RemoveModel : public speckle::interfac::browser::bridge::BridgeMethod<ModelCardEventWrapper, void> {
|
class RemoveModel : public speckle::interfac::browser::bridge::BridgeMethod<ModelCardEventWrapper, void> {
|
||||||
public:
|
public:
|
||||||
@@ -29,8 +29,8 @@ namespace connector::interfac::browser::bridge {
|
|||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Add a model card to document storage
|
Remove a model card from document storage
|
||||||
@param card The card to add
|
@param card The card to remove
|
||||||
*/
|
*/
|
||||||
void run(const connector::record::ModelCard& card) const;
|
void run(const connector::record::ModelCard& card) const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -2,11 +2,12 @@
|
|||||||
|
|
||||||
#include "Connector/Connector.h"
|
#include "Connector/Connector.h"
|
||||||
#include "Connector/Database/ModelCardDatabase.h"
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Base/Arg/DocumentInfo.h"
|
#include "Connector/Interface/Browser/Bridge/Base/Arg/DocumentInfo.h"
|
||||||
|
|
||||||
using namespace active::container;
|
using namespace active::container;
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
using namespace connector::database;
|
using namespace connector::environment;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
@@ -26,11 +27,15 @@ UpdateModel::UpdateModel() : BridgeMethod{"UpdateModel", [&](const ModelCardEven
|
|||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Add a model card to document storage
|
Update a model card in document storage
|
||||||
|
|
||||||
card: The card to add
|
card: The card to update
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
void UpdateModel::run(const ModelCard& card) const {
|
void UpdateModel::run(const ModelCard& card) const {
|
||||||
if (auto modelCardDBase = connector()->getModelCardDatabase(); modelCardDBase != nullptr)
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return;
|
||||||
|
if (auto modelCardDBase = connectorProject->getModelCardDatabase(); modelCardDBase != nullptr)
|
||||||
modelCardDBase->write(card);
|
modelCardDBase->write(card);
|
||||||
} //UpdateModel::run
|
} //UpdateModel::run
|
||||||
|
|||||||
@@ -8,13 +8,13 @@
|
|||||||
|
|
||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
///Argument parameter for a string
|
///Argument parameter for a model card
|
||||||
using CardHold = active::serialise::CargoHold<connector::record::CardMover, connector::record::ModelCard>;
|
using CardHold = active::serialise::CargoHold<connector::record::CardMover, connector::record::ModelCard>;
|
||||||
///Argument type for this method
|
///Argument type for this method
|
||||||
using ModelCardEventWrapper = speckle::interfac::browser::bridge::JSArgType<CardHold>;
|
using ModelCardEventWrapper = speckle::interfac::browser::bridge::JSArgType<CardHold>;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to add a model card to the document storage
|
JS Function class to update a model card in document storage
|
||||||
*/
|
*/
|
||||||
class UpdateModel : public speckle::interfac::browser::bridge::BridgeMethod<ModelCardEventWrapper, void> {
|
class UpdateModel : public speckle::interfac::browser::bridge::BridgeMethod<ModelCardEventWrapper, void> {
|
||||||
public:
|
public:
|
||||||
@@ -29,8 +29,8 @@ namespace connector::interfac::browser::bridge {
|
|||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Add a model card to document storage
|
Update a model card in document storage
|
||||||
@param card The card to add
|
@param card The card to update
|
||||||
*/
|
*/
|
||||||
void run(const connector::record::ModelCard& card) const;
|
void run(const connector::record::ModelCard& card) const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to retrieve the names of the methods supported by the bridge
|
JS Function class to retrieve the current display configuration settings
|
||||||
*/
|
*/
|
||||||
class GetConfig : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
class GetConfig : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
||||||
public:
|
public:
|
||||||
|
|||||||
@@ -9,11 +9,11 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
class ConnectorConfig;
|
class ConnectorConfig;
|
||||||
|
|
||||||
///Argument for a JS call to update the configuration
|
///Argument for a JS call to update the display configuration settings
|
||||||
using UpdateArgs = speckle::interfac::browser::bridge::JSArgType<ConnectorConfig>;
|
using UpdateArgs = speckle::interfac::browser::bridge::JSArgType<ConnectorConfig>;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to retrieve the names of the methods supported by the bridge
|
JS Function class to update the display configuration settings
|
||||||
*/
|
*/
|
||||||
class UpdateConfig : public speckle::interfac::browser::bridge::BridgeMethod<UpdateArgs, void> {
|
class UpdateConfig : public speckle::interfac::browser::bridge::BridgeMethod<UpdateArgs, void> {
|
||||||
public:
|
public:
|
||||||
@@ -22,7 +22,6 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Constructor
|
Constructor
|
||||||
@param bridge The parent bridge object (provides access to bridge methods)
|
|
||||||
*/
|
*/
|
||||||
UpdateConfig();
|
UpdateConfig();
|
||||||
|
|
||||||
|
|||||||
@@ -29,13 +29,9 @@ namespace {
|
|||||||
}
|
}
|
||||||
|
|
||||||
SelectionInfo::SelectionInfo() {
|
SelectionInfo::SelectionInfo() {
|
||||||
initialize();
|
|
||||||
}
|
|
||||||
|
|
||||||
void SelectionInfo::initialize() {
|
|
||||||
auto project = connector()->getActiveProject().lock();
|
auto project = connector()->getActiveProject().lock();
|
||||||
if (!project) {
|
if (!project) {
|
||||||
// TODO: is thi OK?
|
// TODO: is this OK?
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -51,6 +47,7 @@ void SelectionInfo::initialize() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Fill an inventory with the package items
|
Fill an inventory with the package items
|
||||||
|
|
||||||
@@ -83,7 +80,7 @@ Cargo::Unique SelectionInfo::getCargo(const Inventory::Item& item) const {
|
|||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
switch (item.index) {
|
switch (item.index) {
|
||||||
case selectedObjectIdsID:
|
case selectedObjectIdsID:
|
||||||
return std::make_unique<ContainerWrap<std::vector<active::utility::Guid>>>(m_selectedElementIds);
|
return std::make_unique<ContainerWrap<std::vector<active::utility::Guid>>>(m_selectedElementIds, false, fieldID[selectedObjectIdsID].name);
|
||||||
case summaryID:
|
case summaryID:
|
||||||
return std::make_unique<ValueWrap<active::utility::String>>(m_summary);
|
return std::make_unique<ValueWrap<active::utility::String>>(m_summary);
|
||||||
default:
|
default:
|
||||||
|
|||||||
@@ -39,10 +39,6 @@ namespace connector::interfac::browser::bridge {
|
|||||||
@return The requested cargo (nullptr on failure)
|
@return The requested cargo (nullptr on failure)
|
||||||
*/
|
*/
|
||||||
Cargo::Unique getCargo(const active::serialise::Inventory::Item& item) const override;
|
Cargo::Unique getCargo(const active::serialise::Inventory::Item& item) const override;
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
void initialize();
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,7 +12,6 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Constructor
|
Constructor
|
||||||
@param bridge The parent bridge object (provides access to bridge methods)
|
|
||||||
*/
|
*/
|
||||||
GetSelection();
|
GetSelection();
|
||||||
|
|
||||||
|
|||||||
@@ -14,11 +14,14 @@ SelectionBridge::SelectionBridge() : BrowserBridge{"selectionBinding"} {
|
|||||||
addMethod<GetSelection>();
|
addMethod<GetSelection>();
|
||||||
} //SelectionBridge::SelectionBridge
|
} //SelectionBridge::SelectionBridge
|
||||||
|
|
||||||
/*!
|
|
||||||
Handle the menu selection
|
/*--------------------------------------------------------------------
|
||||||
@param event The selection event
|
Handle a selection change
|
||||||
@return True if the event should be closed
|
|
||||||
*/
|
event: The selection event
|
||||||
|
|
||||||
|
return: True if the event should be closed
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
bool SelectionBridge::handle(const speckle::event::SelectionEvent& event) {
|
bool SelectionBridge::handle(const speckle::event::SelectionEvent& event) {
|
||||||
auto selectionInfo = std::make_unique<SelectionInfo>();
|
auto selectionInfo = std::make_unique<SelectionInfo>();
|
||||||
auto wrapped = std::make_unique<CargoHold<PackageWrap, SelectionInfo>>(std::move(selectionInfo));
|
auto wrapped = std::make_unique<CargoHold<PackageWrap, SelectionInfo>>(std::move(selectionInfo));
|
||||||
|
|||||||
@@ -8,7 +8,7 @@
|
|||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
A browser bridge to support sending model data to a Speckle server
|
A browser bridge to manage element selection information passed between the JS UI and the BIM application
|
||||||
*/
|
*/
|
||||||
class SelectionBridge : public speckle::interfac::browser::bridge::BrowserBridge, public speckle::event::SelectionSubscriber {
|
class SelectionBridge : public speckle::interfac::browser::bridge::BrowserBridge, public speckle::event::SelectionSubscriber {
|
||||||
public:
|
public:
|
||||||
@@ -27,7 +27,7 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
/*!
|
/*!
|
||||||
Handle the menu selection
|
Handle a selection change
|
||||||
@param event The selection event
|
@param event The selection event
|
||||||
@return True if the event should be closed
|
@return True if the event should be closed
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/ConversionResult.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/ConversionResult.h"
|
||||||
|
|
||||||
|
#include "Active/Serialise/CargoHold.h"
|
||||||
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
@@ -12,14 +13,30 @@ namespace {
|
|||||||
|
|
||||||
///Serialisation fields
|
///Serialisation fields
|
||||||
enum FieldIndex {
|
enum FieldIndex {
|
||||||
|
statusID,
|
||||||
|
srcID,
|
||||||
|
srcTypeID,
|
||||||
|
resID,
|
||||||
|
resTypeID,
|
||||||
errorID,
|
errorID,
|
||||||
cardID,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
///Serialisation field IDs
|
///Serialisation field IDs
|
||||||
static std::array fieldID = {
|
static std::array fieldID = {
|
||||||
|
Identity{"status"},
|
||||||
|
Identity{"sourceId"},
|
||||||
|
Identity{"sourceType"},
|
||||||
|
Identity{"resultId"},
|
||||||
|
Identity{"resultType"},
|
||||||
Identity{"error"},
|
Identity{"error"},
|
||||||
Identity{"modelCardId"},
|
};
|
||||||
|
|
||||||
|
///Conversion status enumerator names
|
||||||
|
std::array statusName{
|
||||||
|
"success",
|
||||||
|
"warning",
|
||||||
|
"info",
|
||||||
|
"error",
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -35,8 +52,12 @@ bool ConversionResult::fillInventory(active::serialise::Inventory& inventory) co
|
|||||||
using enum Entry::Type;
|
using enum Entry::Type;
|
||||||
inventory.merge(Inventory{
|
inventory.merge(Inventory{
|
||||||
{
|
{
|
||||||
{ fieldID[errorID], errorID, element },
|
{ fieldID[statusID], statusID, element },
|
||||||
{ fieldID[cardID], cardID, element },
|
{ fieldID[srcID], srcID, element, !sourceID.empty() },
|
||||||
|
{ fieldID[srcTypeID], srcTypeID, element, !sourceType.empty() },
|
||||||
|
{ fieldID[resID], resID, element, !resultID.empty() },
|
||||||
|
{ fieldID[resTypeID], resTypeID, element, !resultType.empty() },
|
||||||
|
{ fieldID[errorID], errorID, element, error.operator bool() },
|
||||||
},
|
},
|
||||||
}.withType(&typeid(ConversionResult)));
|
}.withType(&typeid(ConversionResult)));
|
||||||
return true;
|
return true;
|
||||||
@@ -55,11 +76,46 @@ Cargo::Unique ConversionResult::getCargo(const active::serialise::Inventory::Ite
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
switch (item.index) {
|
switch (item.index) {
|
||||||
|
case statusID:
|
||||||
|
return Cargo::Unique{new CargoHold<ValueWrap<uint16_t>, uint16_t>(static_cast<uint16_t>(status))};
|
||||||
|
case srcID:
|
||||||
|
return std::make_unique<ValueWrap<String>>(sourceID);
|
||||||
|
case srcTypeID:
|
||||||
|
return std::make_unique<ValueWrap<String>>(sourceType);
|
||||||
|
case resID:
|
||||||
|
return std::make_unique<ValueWrap<String>>(resultID);
|
||||||
|
case resTypeID:
|
||||||
|
return std::make_unique<ValueWrap<String>>(resultType);
|
||||||
case errorID:
|
case errorID:
|
||||||
return std::make_unique<ValueWrap<String>>(message);
|
return std::make_unique<PackageWrap>(*error);
|
||||||
case cardID:
|
|
||||||
return std::make_unique<ValueWrap<String>>(modelCardID);
|
|
||||||
default:
|
default:
|
||||||
return nullptr; //Requested an unknown index
|
return nullptr; //Requested an unknown index
|
||||||
}
|
}
|
||||||
} //ConversionResult::getCargo
|
} //ConversionResult::getCargo
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get a conversion status enumerator from text
|
||||||
|
|
||||||
|
text; The incoming text
|
||||||
|
|
||||||
|
return: The equivalent conversion status (nullopt on failure)
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
std::optional<ConversionResult::Status> connector::interfac::browser::bridge::toConversionStatus(const String& text) {
|
||||||
|
for (auto i = 0; i < statusName.size(); ++i)
|
||||||
|
if (text == statusName[i])
|
||||||
|
return static_cast<ConversionResult::Status>(i + 1);
|
||||||
|
return std::nullopt;
|
||||||
|
} //active::geometry::toAnchor2D
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get the text for a conversion status value
|
||||||
|
|
||||||
|
status: The incoming status
|
||||||
|
|
||||||
|
return: The conversion status as text
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
String connector::interfac::browser::bridge::fromConversionStatus(ConversionResult::Status status) {
|
||||||
|
return statusName.at(static_cast<size_t>(status) - 1);
|
||||||
|
} //active::geometry::fromAnchor2D
|
||||||
|
|||||||
@@ -1,47 +1,42 @@
|
|||||||
#ifndef CONNECTOR_INTERFACE_BRIDGE_SEND_CONVERSION_RESULT
|
#ifndef CONNECTOR_INTERFACE_BRIDGE_CONVERSION_RESULT
|
||||||
#define CONNECTOR_INTERFACE_BRIDGE_SEND_CONVERSION_RESULT
|
#define CONNECTOR_INTERFACE_BRIDGE_CONVERSION_RESULT
|
||||||
|
|
||||||
#include "Active/Serialise/Package/Wrapper/PackageWrap.h"
|
#include "Active/Serialise/Package/Package.h"
|
||||||
|
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendError.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendError.h"
|
||||||
#include "Speckle/Utility/String.h"
|
#include "Speckle/Utility/String.h"
|
||||||
|
|
||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
A send error to return to the JS in the event of an error
|
The result of a conversion process (BIM records to/from Speckle)
|
||||||
*/
|
*/
|
||||||
class ConversionResult final : public active::serialise::Package {
|
class ConversionResult : public active::serialise::Package {
|
||||||
public:
|
public:
|
||||||
enum class Status {
|
enum class Status : uint16_t {
|
||||||
success = 1,
|
success = 1, ///<The conversion was successful
|
||||||
info,
|
info, ///<Not in use yet, maybe later as discussed
|
||||||
warning,
|
warning, ///<Not in use yet, maybe later as discussed
|
||||||
error,
|
error, ///<An error occurred during conversion
|
||||||
};
|
};
|
||||||
|
|
||||||
// MARK: - Constructors
|
// MARK: - Constructors
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Constructor
|
Default constructor
|
||||||
@param errMess The error message
|
|
||||||
@param card The ID of the model card associated with the wrror
|
|
||||||
*/
|
*/
|
||||||
ConversionResult(const speckle::utility::String& errMess, const speckle::utility::String& card) : message{errMess}, modelCardID{card} {}
|
ConversionResult() {}
|
||||||
|
|
||||||
// MARK: - Public variables
|
// MARK: - Public variables
|
||||||
|
|
||||||
///The error message
|
|
||||||
speckle::utility::String message;
|
|
||||||
///The ID of the model card associated with the data
|
|
||||||
speckle::utility::String modelCardID;
|
|
||||||
///The element conversion status
|
///The element conversion status
|
||||||
Status status = Status::info;
|
Status status = Status::info;
|
||||||
///For receive conversion reports, this is the id of the speckle object. For send, it's the host app object id.
|
///For receive conversion reports, this is the id of the speckle object. For send, it's the host app object id.
|
||||||
speckle::utility::String sourceId;
|
speckle::utility::String sourceID;
|
||||||
///For receive conversion reports, this is the type of the speckle object. For send, it's the host app object type.
|
///For receive conversion reports, this is the type of the speckle object. For send, it's the host app object type.
|
||||||
speckle::utility::String sourceType;
|
speckle::utility::String sourceType;
|
||||||
///For receive conversion reports, this is the id of the host app object. For send, it's the speckle object id.
|
///For receive conversion reports, this is the id of the host app object. For send, it's the speckle object id.
|
||||||
speckle::utility::String resultId;
|
speckle::utility::String resultID;
|
||||||
///For receive conversion reports, this is the type of the host app object. For send, it's the speckle object type.
|
///For receive conversion reports, this is the type of the host app object. For send, it's the speckle object type.
|
||||||
speckle::utility::String resultType;
|
speckle::utility::String resultType;
|
||||||
///The exception (nullopt = no exception)
|
///The exception (nullopt = no exception)
|
||||||
@@ -63,6 +58,60 @@ namespace connector::interfac::browser::bridge {
|
|||||||
Cargo::Unique getCargo(const active::serialise::Inventory::Item& item) const override;
|
Cargo::Unique getCargo(const active::serialise::Inventory::Item& item) const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Get a conversion status enumerator from text
|
||||||
|
@param text The incoming text
|
||||||
|
@return The equivalent conversion status (nullopt on failure)
|
||||||
|
*/
|
||||||
|
std::optional<ConversionResult::Status> toConversionStatus(const speckle::utility::String& text);
|
||||||
|
/*!
|
||||||
|
Get the text for a conversion status value
|
||||||
|
@param status The incoming status
|
||||||
|
@return The conversion status as text
|
||||||
|
*/
|
||||||
|
speckle::utility::String fromConversionStatus(ConversionResult::Status status);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif //CONNECTOR_INTERFACE_BRIDGE_SEND_CONVERSION_RESULT
|
namespace active::serialise {
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Import the object from the specified string (specialisation for bool)
|
||||||
|
@param source The string to read
|
||||||
|
@return True if the data was successfully read
|
||||||
|
*/
|
||||||
|
template<> inline
|
||||||
|
bool ValueWrap<connector::interfac::browser::bridge::ConversionResult::Status>::read(const utility::String& source) {
|
||||||
|
auto converted = connector::interfac::browser::bridge::toConversionStatus(source);
|
||||||
|
if (!converted)
|
||||||
|
return false;
|
||||||
|
base::get() = *converted;
|
||||||
|
return true;
|
||||||
|
} //ValueWrap<bool>::read
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Import the object from the specified string (specialisation for bool)
|
||||||
|
@param source The string to read
|
||||||
|
@return True if the data was successfully read
|
||||||
|
*/
|
||||||
|
template<> inline
|
||||||
|
bool ValueWrap<std::optional<connector::interfac::browser::bridge::ConversionResult::Status>>::read(const utility::String& source) {
|
||||||
|
auto converted = connector::interfac::browser::bridge::toConversionStatus(source);
|
||||||
|
base::get() = converted;
|
||||||
|
return converted.operator bool();
|
||||||
|
} //ValueWrap<bool>::read
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Export the object to the specified string (specialisation for bool)
|
||||||
|
@param dest The string to write the data to
|
||||||
|
@return True if the data was successfully written
|
||||||
|
*/
|
||||||
|
template<> inline
|
||||||
|
bool ValueWrap<connector::interfac::browser::bridge::ConversionResult::Status>::write(utility::String& dest) const {
|
||||||
|
dest = connector::interfac::browser::bridge::fromConversionStatus(get());
|
||||||
|
return true;
|
||||||
|
} //ValueWrap<bool>::write
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_INTERFACE_BRIDGE_CONVERSION_RESULT
|
||||||
|
|||||||
@@ -0,0 +1,49 @@
|
|||||||
|
#ifndef CONNECTOR_INTERFACE_BRIDGE_SEND_CONVERSION_RESULT
|
||||||
|
#define CONNECTOR_INTERFACE_BRIDGE_SEND_CONVERSION_RESULT
|
||||||
|
|
||||||
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/ConversionResult.h"
|
||||||
|
#include "Speckle/Serialise/Collection/ConversionReporter.h"
|
||||||
|
|
||||||
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
|
/*!
|
||||||
|
A result from converting a record to Speckle
|
||||||
|
*/
|
||||||
|
class SendConversionResult : public ConversionResult {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// MARK: - Constructors
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Constructor
|
||||||
|
@param stat The send/conversion status of the target record
|
||||||
|
@param srcID The record application ID
|
||||||
|
@param srcType The record application type name
|
||||||
|
@param err An optional error report
|
||||||
|
*/
|
||||||
|
SendConversionResult(Status stat, speckle::utility::String srcID, speckle::utility::String srcType, SendError::Option err = std::nullopt) {
|
||||||
|
status = stat;
|
||||||
|
sourceID = srcID;
|
||||||
|
sourceType = srcType;
|
||||||
|
error = err;
|
||||||
|
}
|
||||||
|
/*!
|
||||||
|
Constructor
|
||||||
|
@param stat The send/conversion status of the target record
|
||||||
|
@param srcID The record application ID
|
||||||
|
@param srcType The record application type name
|
||||||
|
@param err An optional error report
|
||||||
|
*/
|
||||||
|
SendConversionResult(const speckle::database::BIMRecordID& srcID, const speckle::serialise::ConversionReporter::Data& data) {
|
||||||
|
status = data.status == speckle::serialise::ConversionReporter::Data::Status::success ?
|
||||||
|
ConversionResult::Status::success : ConversionResult::Status::error;
|
||||||
|
sourceID = srcID.operator speckle::utility::String();
|
||||||
|
sourceType = data.typeName;
|
||||||
|
if (!data.message.empty())
|
||||||
|
error = SendError{data.message};
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_INTERFACE_BRIDGE_SEND_CONVERSION_RESULT
|
||||||
@@ -12,14 +12,16 @@ namespace {
|
|||||||
|
|
||||||
///Serialisation fields
|
///Serialisation fields
|
||||||
enum FieldIndex {
|
enum FieldIndex {
|
||||||
errorID,
|
messageID,
|
||||||
cardID,
|
cardID,
|
||||||
|
stackID,
|
||||||
};
|
};
|
||||||
|
|
||||||
///Serialisation field IDs
|
///Serialisation field IDs
|
||||||
static std::array fieldID = {
|
static std::array fieldID = {
|
||||||
Identity{"error"},
|
Identity{"message"},
|
||||||
Identity{"modelCardId"},
|
Identity{"modelCardId"},
|
||||||
|
Identity{"stackTrace"},
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -35,8 +37,9 @@ bool SendError::fillInventory(active::serialise::Inventory& inventory) const {
|
|||||||
using enum Entry::Type;
|
using enum Entry::Type;
|
||||||
inventory.merge(Inventory{
|
inventory.merge(Inventory{
|
||||||
{
|
{
|
||||||
{ fieldID[errorID], errorID, element },
|
{ fieldID[messageID], messageID, element },
|
||||||
{ fieldID[cardID], cardID, element },
|
{ fieldID[cardID], cardID, element, !modelCardID.empty() },
|
||||||
|
{ fieldID[stackID], stackID, element, modelCardID.empty() }, //Field not included when a model card is sent
|
||||||
},
|
},
|
||||||
}.withType(&typeid(SendError)));
|
}.withType(&typeid(SendError)));
|
||||||
return true;
|
return true;
|
||||||
@@ -55,10 +58,12 @@ Cargo::Unique SendError::getCargo(const active::serialise::Inventory::Item& item
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
switch (item.index) {
|
switch (item.index) {
|
||||||
case errorID:
|
case messageID:
|
||||||
return std::make_unique<ValueWrap<String>>(message);
|
return std::make_unique<ValueWrap<String>>(message);
|
||||||
case cardID:
|
case cardID:
|
||||||
return std::make_unique<ValueWrap<String>>(modelCardID);
|
return std::make_unique<ValueWrap<String>>(modelCardID);
|
||||||
|
case stackID:
|
||||||
|
return std::make_unique<ValueWrap<String>>(stackTrace);
|
||||||
default:
|
default:
|
||||||
return nullptr; //Requested an unknown index
|
return nullptr; //Requested an unknown index
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ namespace connector::interfac::browser::bridge {
|
|||||||
@param errMess The error message
|
@param errMess The error message
|
||||||
@param card The ID of the model card associated with the wrror
|
@param card The ID of the model card associated with the wrror
|
||||||
*/
|
*/
|
||||||
SendError(const speckle::utility::String& errMess, const speckle::utility::String& card) : message{errMess}, modelCardID{card} {}
|
SendError(const speckle::utility::String& errMess, const speckle::utility::String& card = {}) : message{errMess}, modelCardID{card} {}
|
||||||
|
|
||||||
// MARK: - Public variables
|
// MARK: - Public variables
|
||||||
|
|
||||||
@@ -32,6 +32,8 @@ namespace connector::interfac::browser::bridge {
|
|||||||
speckle::utility::String message;
|
speckle::utility::String message;
|
||||||
///The ID of the model card associated with the data
|
///The ID of the model card associated with the data
|
||||||
speckle::utility::String modelCardID;
|
speckle::utility::String modelCardID;
|
||||||
|
///The error stack trace
|
||||||
|
speckle::utility::String stackTrace;
|
||||||
|
|
||||||
// MARK: - Serialisation
|
// MARK: - Serialisation
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,14 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendObject.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendObject.h"
|
||||||
|
|
||||||
#include "Active/Serialise/Package/Wrapper/ContainerWrap.h"
|
|
||||||
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
#include "Active/Serialise/Item/Wrapper/ValueWrap.h"
|
||||||
|
#include "Active/Serialise/Package/Wrapper/ContainerWrap.h"
|
||||||
|
#include "Connector/Record/Collection/ProjectCollection.h"
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
|
using namespace connector::record;
|
||||||
using namespace speckle::serialise;
|
using namespace speckle::serialise;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
@@ -67,3 +69,19 @@ Cargo::Unique SendObject::getCargo(const active::serialise::Inventory::Item& ite
|
|||||||
return nullptr; //Requested an unknown index
|
return nullptr; //Requested an unknown index
|
||||||
}
|
}
|
||||||
} //SendObject::getCargo
|
} //SendObject::getCargo
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get the conversion results from the send object serialisation
|
||||||
|
|
||||||
|
return: The serialisation conversion results
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
std::vector<SendConversionResult> SendObject::getConversionResults() const {
|
||||||
|
std::vector<SendConversionResult> convertResults;
|
||||||
|
auto collection = dynamic_cast<const ProjectCollection*>(m_object.get());
|
||||||
|
if (collection == nullptr)
|
||||||
|
return convertResults;
|
||||||
|
for (const auto& item : collection->getLog())
|
||||||
|
convertResults.emplace_back(SendConversionResult{item.first, item.second});
|
||||||
|
return convertResults;
|
||||||
|
} //SendObject::getConversionResults
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
#include "Active/Serialise/CargoHold.h"
|
#include "Active/Serialise/CargoHold.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Config/Arg/ConnectorConfig.h"
|
#include "Connector/Interface/Browser/Bridge/Config/Arg/ConnectorConfig.h"
|
||||||
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendConversionResult.h"
|
||||||
#include "Speckle/Database/Content/Record.h"
|
#include "Speckle/Database/Content/Record.h"
|
||||||
#include "Speckle/Interface/Browser/Bridge/BridgeMethod.h"
|
#include "Speckle/Interface/Browser/Bridge/BridgeMethod.h"
|
||||||
|
|
||||||
@@ -44,15 +45,20 @@ namespace connector::interfac::browser::bridge {
|
|||||||
*/
|
*/
|
||||||
Cargo::Unique getCargo(const active::serialise::Inventory::Item& item) const override;
|
Cargo::Unique getCargo(const active::serialise::Inventory::Item& item) const override;
|
||||||
/*!
|
/*!
|
||||||
Use a manager in (de)serialisation processes
|
Use a manager in (de)serialisation processes
|
||||||
@param management The management to use
|
@param management The management to use
|
||||||
*/
|
*/
|
||||||
void useManagement(active::serialise::Management* management) const override { m_object->useManagement(management); }
|
void useManagement(active::serialise::Management* management) const override { m_object->useManagement(management); }
|
||||||
/*!
|
/*!
|
||||||
Get the cargo management
|
Get the cargo management
|
||||||
@return The active management
|
@return The active management
|
||||||
*/
|
*/
|
||||||
active::serialise::Management* management() const override { return m_object->management(); }
|
active::serialise::Management* management() const override { return m_object->management(); }
|
||||||
|
/*!
|
||||||
|
Get the conversion results from the send object serialisation
|
||||||
|
@return The serialisation conversion results
|
||||||
|
*/
|
||||||
|
std::vector<SendConversionResult> getConversionResults() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
///The object to send
|
///The object to send
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendViaBrowserArgs.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendViaBrowserArgs.h"
|
||||||
|
|
||||||
|
#include "Active/Serialise/Package/Wrapper/ContainerWrap.h"
|
||||||
#include "Connector/Record/Model/ModelCard.h"
|
#include "Connector/Record/Model/ModelCard.h"
|
||||||
#include "Speckle/Record/Credentials/Account.h"
|
#include "Speckle/Record/Credentials/Account.h"
|
||||||
|
|
||||||
@@ -25,6 +26,7 @@ namespace {
|
|||||||
accID,
|
accID,
|
||||||
messageID,
|
messageID,
|
||||||
sendObjectID,
|
sendObjectID,
|
||||||
|
convResultID,
|
||||||
};
|
};
|
||||||
|
|
||||||
///Serialisation field IDs
|
///Serialisation field IDs
|
||||||
@@ -37,6 +39,7 @@ namespace {
|
|||||||
Identity{"accountId"},
|
Identity{"accountId"},
|
||||||
Identity{"message"},
|
Identity{"message"},
|
||||||
Identity{"sendObject"},
|
Identity{"sendObject"},
|
||||||
|
Identity{"sendConversionResults"},
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -47,11 +50,11 @@ namespace {
|
|||||||
modelCard: The model card to populate into the send info for the browser
|
modelCard: The model card to populate into the send info for the browser
|
||||||
account: The account linked to the send
|
account: The account linked to the send
|
||||||
object: The object to be sent
|
object: The object to be sent
|
||||||
|
results: The conversion results (reporting any conversion errors etc)
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
SendViaBrowserArgs::SendViaBrowserArgs(const ModelCard& modelCard, const Account& account, SendObject&& object) :
|
SendViaBrowserArgs::SendViaBrowserArgs(const ModelCard& modelCard, const Account& account, SendObject&& object) :
|
||||||
modelCardID(modelCard.getID()), projectID(modelCard.getProjectID()), modelID(modelCard.getModelID()), token{account.getToken()},
|
modelCardID(modelCard.getID()), projectID(modelCard.getProjectID()), modelID(modelCard.getModelID()), token{account.getToken()},
|
||||||
serverURL{account.getServerURL()}, accountID{account.getID()}, sendObject{std::move(object)} {
|
serverURL{account.getServerURL()}, accountID{account.getID()}, sendObject{std::move(object)} {
|
||||||
|
|
||||||
} //SendViaBrowserArgs::SendViaBrowserArgs
|
} //SendViaBrowserArgs::SendViaBrowserArgs
|
||||||
|
|
||||||
|
|
||||||
@@ -74,6 +77,7 @@ bool SendViaBrowserArgs::fillInventory(active::serialise::Inventory& inventory)
|
|||||||
{ fieldID[accID], accID, element },
|
{ fieldID[accID], accID, element },
|
||||||
{ fieldID[messageID], messageID, element },
|
{ fieldID[messageID], messageID, element },
|
||||||
{ fieldID[sendObjectID], sendObjectID, element },
|
{ fieldID[sendObjectID], sendObjectID, element },
|
||||||
|
{ fieldID[convResultID], convResultID, element },
|
||||||
},
|
},
|
||||||
}.withType(&typeid(SendViaBrowserArgs)));
|
}.withType(&typeid(SendViaBrowserArgs)));
|
||||||
return true;
|
return true;
|
||||||
@@ -108,6 +112,9 @@ Cargo::Unique SendViaBrowserArgs::getCargo(const active::serialise::Inventory::I
|
|||||||
return std::make_unique<StringWrap>(message);
|
return std::make_unique<StringWrap>(message);
|
||||||
case sendObjectID:
|
case sendObjectID:
|
||||||
return std::make_unique<PackageWrap>(sendObject);
|
return std::make_unique<PackageWrap>(sendObject);
|
||||||
|
case convResultID:
|
||||||
|
sendConversionResults = sendObject.getConversionResults();
|
||||||
|
return Cargo::Unique{new ContainerWrap{sendConversionResults}};
|
||||||
default:
|
default:
|
||||||
return nullptr; //Requested an unknown index
|
return nullptr; //Requested an unknown index
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
#include "Active/Serialise/Package/Package.h"
|
#include "Active/Serialise/Package/Package.h"
|
||||||
#include "Active/Utility/String.h"
|
#include "Active/Utility/String.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/ConversionResult.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendConversionResult.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendObject.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendObject.h"
|
||||||
#include "Speckle/Database/Identity/RecordID.h"
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
|
|
||||||
@@ -54,7 +54,7 @@ namespace connector::interfac::browser::bridge {
|
|||||||
///The send message
|
///The send message
|
||||||
speckle::utility::String message; //TODO: Clarify what this is used for
|
speckle::utility::String message; //TODO: Clarify what this is used for
|
||||||
///The conversion report (summarising the conversion results on an element-by-element basis)
|
///The conversion report (summarising the conversion results on an element-by-element basis)
|
||||||
std::vector<ConversionResult> sendConversionResults;
|
mutable std::vector<SendConversionResult> sendConversionResults;
|
||||||
///The commit content
|
///The commit content
|
||||||
SendObject sendObject;
|
SendObject sendObject;
|
||||||
|
|
||||||
|
|||||||
@@ -18,7 +18,6 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Constructor
|
Constructor
|
||||||
@param bridge The parent bridge object (provides access to bridge methods)
|
|
||||||
*/
|
*/
|
||||||
GetSendFilters();
|
GetSendFilters();
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ using namespace speckle::utility;
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
using WrappedValue = active::serialise::CargoHold<ContainerWrap<Vector<CardSetting>, PackageWrap>, Vector<CardSetting>>;
|
using WrappedValue = CargoHold<ContainerWrap<Vector<CardSetting>, PackageWrap>, Vector<CardSetting>>;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -26,9 +26,9 @@ GetSendSettings::GetSendSettings() : BridgeMethod{"GetSendSettings", [&]() {
|
|||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Get the send filters
|
Get send settings relevant to the host BIM application
|
||||||
|
|
||||||
return: The send filters
|
return: The send settings
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
std::unique_ptr<Cargo> GetSendSettings::run() const {
|
std::unique_ptr<Cargo> GetSendSettings::run() const {
|
||||||
auto filters = std::make_unique<Vector<CardSetting>>();
|
auto filters = std::make_unique<Vector<CardSetting>>();
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ namespace connector::interfac::browser::bridge {
|
|||||||
class ConnectorConfig;
|
class ConnectorConfig;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
JS Function class to retrieve the send filters
|
JS Function class to retrieve the send settings relevant to the host BIM application
|
||||||
*/
|
*/
|
||||||
class GetSendSettings : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
class GetSendSettings : public speckle::interfac::browser::bridge::BridgeMethod<void, active::serialise::Cargo> {
|
||||||
public:
|
public:
|
||||||
@@ -18,15 +18,14 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Constructor
|
Constructor
|
||||||
@param bridge The parent bridge object (provides access to bridge methods)
|
|
||||||
*/
|
*/
|
||||||
GetSendSettings();
|
GetSendSettings();
|
||||||
|
|
||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Get the send filters
|
Get send settings relevant to the host BIM application
|
||||||
@return The send filters
|
@return The send settings
|
||||||
*/
|
*/
|
||||||
std::unique_ptr<active::serialise::Cargo> run() const;
|
std::unique_ptr<active::serialise::Cargo> run() const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -5,34 +5,33 @@
|
|||||||
#include "Connector/Connector.h"
|
#include "Connector/Connector.h"
|
||||||
#include "Connector/ConnectorResource.h"
|
#include "Connector/ConnectorResource.h"
|
||||||
#include "Connector/Database/ModelCardDatabase.h"
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendError.h"
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendConversionResult.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendViaBrowserArgs.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Arg/SendViaBrowserArgs.h"
|
||||||
#include "Connector/Record/Collection/ProjectCollection.h"
|
#include "Connector/Record/Collection/ProjectCollection.h"
|
||||||
|
#include "Connector/Record/Model/SenderModelCard.h"
|
||||||
|
#include "Connector/Record/Model/Filter/SendFilter.h"
|
||||||
#include "Speckle/Database/AccountDatabase.h"
|
#include "Speckle/Database/AccountDatabase.h"
|
||||||
|
#include "Speckle/Database/BIMElementDatabase.h"
|
||||||
#include "Speckle/Database/Content/BIMRecord.h"
|
#include "Speckle/Database/Content/BIMRecord.h"
|
||||||
|
#include "Speckle/Environment/Project.h"
|
||||||
|
#include "Speckle/Environment/Host.h"
|
||||||
#include "Speckle/Interface/Browser/Bridge/BrowserBridge.h"
|
#include "Speckle/Interface/Browser/Bridge/BrowserBridge.h"
|
||||||
#include "Speckle/Record/Credentials/Account.h"
|
#include "Speckle/Record/Credentials/Account.h"
|
||||||
|
#include "Speckle/Record/Element/Element.h"
|
||||||
#include "Speckle/Serialise/Detached/Storage/DetachedMemoryStore.h"
|
#include "Speckle/Serialise/Detached/Storage/DetachedMemoryStore.h"
|
||||||
#include "Speckle/Utility/Exception.h"
|
#include "Speckle/Utility/Exception.h"
|
||||||
|
|
||||||
#include "Speckle/Database/BIMElementDatabase.h"
|
|
||||||
#include "Speckle/Environment/Project.h"
|
|
||||||
#include "Speckle/Record/Element/Element.h"
|
|
||||||
using namespace speckle::record::element;
|
|
||||||
|
|
||||||
#include <array>
|
|
||||||
|
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
|
using namespace connector::environment;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace speckle::database;
|
using namespace speckle::database;
|
||||||
|
using namespace speckle::environment;
|
||||||
|
using namespace speckle::record::element;
|
||||||
using namespace speckle::serialise;
|
using namespace speckle::serialise;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Default constructor
|
Default constructor
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
@@ -44,11 +43,23 @@ Send::Send() : BridgeMethod{"Send", [&](const SendArgs& args) {
|
|||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Send a specified model
|
Send a specified model
|
||||||
|
|
||||||
modelCardID: The ID of the model to send
|
modelCardID: The ID of the model card identifying the objects to send
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
void Send::run(const String& modelCardID) const {
|
void Send::run(const String& modelCardID) const {
|
||||||
|
//We can currently only send from the 3D model view
|
||||||
|
host()->makeModelViewActive(true);
|
||||||
|
//Get the active project
|
||||||
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
if (!project) {
|
||||||
|
getBridge()->sendEvent("setModelError",
|
||||||
|
std::make_unique<SendError>(connector()->getLocalString(errorString, noProjectOpenID), modelCardID));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return;
|
||||||
//Find the specified model card
|
//Find the specified model card
|
||||||
auto modelCardDatabase = connector()->getModelCardDatabase();
|
auto modelCardDatabase = connectorProject->getModelCardDatabase();
|
||||||
auto modelCard = modelCardDatabase->getCard(modelCardID);
|
auto modelCard = modelCardDatabase->getCard(modelCardID);
|
||||||
if (!modelCard) {
|
if (!modelCard) {
|
||||||
getBridge()->sendEvent("setModelError",
|
getBridge()->sendEvent("setModelError",
|
||||||
@@ -63,25 +74,23 @@ void Send::run(const String& modelCardID) const {
|
|||||||
std::make_unique<SendError>(connector()->getLocalString(errorString, accountNotFoundID), modelCardID));
|
std::make_unique<SendError>(connector()->getLocalString(errorString, accountNotFoundID), modelCardID));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//Get the active project
|
//Get the selected elements from the modelcard
|
||||||
auto project = connector()->getActiveProject().lock();
|
auto elementDatabase = project->getElementDatabase();
|
||||||
if (!project) {
|
ElementIDList selected{};
|
||||||
getBridge()->sendEvent("setModelError",
|
if (auto senderCard = dynamic_cast<SenderModelCard*>(modelCard.get())) {
|
||||||
std::make_unique<SendError>(connector()->getLocalString(errorString, noProjectOpenID), modelCardID));
|
selected = senderCard->getFilter().getElementIDs();
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
//Build a collection from the selected elements
|
//Build a collection from the selected elements
|
||||||
auto collection = std::make_unique<ProjectCollection>(project);
|
auto collection = std::make_unique<ProjectCollection>(project, modelCard->getID());
|
||||||
auto elementDatabase = project->getElementDatabase();
|
|
||||||
auto selected = elementDatabase->getSelection();
|
|
||||||
if (selected.empty()) {
|
|
||||||
getBridge()->sendEvent("setModelError",
|
|
||||||
std::make_unique<SendError>(connector()->getLocalString(errorString, noSelectedModelItemsID), modelCardID));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (const auto& link : selected) {
|
for (const auto& link : selected) {
|
||||||
if (auto element = elementDatabase->getElement(link); element)
|
if (auto element = elementDatabase->getElement(link); element)
|
||||||
collection->addElement(*element);
|
collection->addElement(*element);
|
||||||
|
else {
|
||||||
|
//Report failure to convert element
|
||||||
|
collection->logRecord(link, {ConversionReporter::Data::Status::failure, String{}, String{},
|
||||||
|
connector()->getLocalString(errorString, elementTypeNotConvertedID)}, false);
|
||||||
|
collection->incrementSkippedRecords();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
//Send the collected information
|
//Send the collected information
|
||||||
auto result = std::make_unique<SendViaBrowserArgs>(*modelCard, *account, SendObject{std::move(collection)});
|
auto result = std::make_unique<SendViaBrowserArgs>(*modelCard, *account, SendObject{std::move(collection)});
|
||||||
|
|||||||
@@ -25,7 +25,6 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Constructor
|
Constructor
|
||||||
@param bridge The parent bridge object (provides access to bridge methods)
|
|
||||||
*/
|
*/
|
||||||
Send();
|
Send();
|
||||||
|
|
||||||
@@ -33,7 +32,7 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Send a specified model
|
Send a specified model
|
||||||
@param modelCardID The ID of the model to send
|
@param modelCardID The ID of the model card identifying the objects to send
|
||||||
*/
|
*/
|
||||||
void run(const speckle::utility::String& modelCardID) const;
|
void run(const speckle::utility::String& modelCardID) const;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,10 +1,28 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Send/SendBridge.h"
|
#include "Connector/Interface/Browser/Bridge/Send/SendBridge.h"
|
||||||
|
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/GetSendFilters.h"
|
#include "Connector/Interface/Browser/Bridge/Send/GetSendFilters.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/GetSendSettings.h"
|
#include "Connector/Interface/Browser/Bridge/Send/GetSendSettings.h"
|
||||||
#include "Connector/Interface/Browser/Bridge/Send/Send.h"
|
#include "Connector/Interface/Browser/Bridge/Send/Send.h"
|
||||||
|
#include "Connector/Connector.h"
|
||||||
|
#include "Connector/ConnectorResource.h"
|
||||||
|
#include "Connector/Database/ModelCardDatabase.h"
|
||||||
|
#include "Connector/Environment/ConnectorProject.h"
|
||||||
|
#include "Speckle/Event/Type/ElementEvent.h"
|
||||||
|
#include "Speckle/Record/Element/Element.h"
|
||||||
|
#include "Speckle/Database/BIMElementDatabase.h"
|
||||||
|
#include "Speckle/Environment/Project.h"
|
||||||
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
|
#include "Active/Serialise/CargoHold.h"
|
||||||
|
#include "Active/Serialise/Package/Wrapper/ContainerWrap.h"
|
||||||
|
#include "Connector/Record/Model/SenderModelCard.h"
|
||||||
|
#include "Connector/Record/Model/Filter/SendFilter.h"
|
||||||
|
|
||||||
|
using namespace speckle::database;
|
||||||
|
using namespace connector::environment;
|
||||||
using namespace connector::interfac::browser::bridge;
|
using namespace connector::interfac::browser::bridge;
|
||||||
|
using namespace speckle::utility;
|
||||||
|
using namespace speckle::event;
|
||||||
|
using namespace active::serialise;
|
||||||
|
using namespace connector::record;
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Default constructor
|
Default constructor
|
||||||
@@ -15,3 +33,55 @@ SendBridge::SendBridge() : BrowserBridge{"sendBinding"} {
|
|||||||
addMethod<GetSendSettings>();
|
addMethod<GetSendSettings>();
|
||||||
addMethod<Send>();
|
addMethod<Send>();
|
||||||
} //SendBridge::SendBridge
|
} //SendBridge::SendBridge
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Handle an element change
|
||||||
|
|
||||||
|
event: The selection event
|
||||||
|
|
||||||
|
return: True if the event should be closed
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
bool SendBridge::handle(const ElementEvent& event) {
|
||||||
|
using enum ElementEvent::Type;
|
||||||
|
auto eventType = event.getEventType();
|
||||||
|
switch (eventType) {
|
||||||
|
case begin:
|
||||||
|
m_changedElements.clear();
|
||||||
|
break;
|
||||||
|
case end: {
|
||||||
|
auto project = connector()->getActiveProject().lock();
|
||||||
|
auto connectorProject = dynamic_cast<ConnectorProject*>(project.get());
|
||||||
|
if (!connectorProject)
|
||||||
|
return false;
|
||||||
|
auto modelCardDatabase = connectorProject->getModelCardDatabase();
|
||||||
|
auto modelCards = modelCardDatabase->getCards();
|
||||||
|
// POC: this is probably not efficient, should test, review and refactor it
|
||||||
|
RecordIDList expiredModelCardIds;
|
||||||
|
for (const auto& modelCard : modelCards) {
|
||||||
|
if (auto senderCard = dynamic_cast<SenderModelCard*>(modelCard.get())) {
|
||||||
|
auto modelCardSelection = senderCard->getFilter().getElementIDs();
|
||||||
|
for (const auto& elemId : modelCardSelection) {
|
||||||
|
if (std::find(m_changedElements.begin(), m_changedElements.end(), elemId) != m_changedElements.end()) {
|
||||||
|
expiredModelCardIds.push_back(modelCard->getID());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!expiredModelCardIds.empty()) {
|
||||||
|
auto wrapped = std::make_unique<CargoHold<ContainerWrap<RecordIDList>, RecordIDList>>(std::move(expiredModelCardIds));
|
||||||
|
sendEvent("setModelsExpired", std::move(wrapped));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case changeElem: case editElem: case deleteElem: {
|
||||||
|
if (event.getElmentID())
|
||||||
|
m_changedElements.push_back(*event.getElmentID());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
} //SendBridge::handle
|
||||||
|
|||||||
@@ -2,13 +2,14 @@
|
|||||||
#define CONNECTOR_INTERFACE_BRIDGE_SEND_BRIDGE
|
#define CONNECTOR_INTERFACE_BRIDGE_SEND_BRIDGE
|
||||||
|
|
||||||
#include "Speckle/Interface/Browser/Bridge/BrowserBridge.h"
|
#include "Speckle/Interface/Browser/Bridge/BrowserBridge.h"
|
||||||
|
#include "Speckle/Event/Subscriber/ElementSubscriber.h"
|
||||||
|
|
||||||
namespace connector::interfac::browser::bridge {
|
namespace connector::interfac::browser::bridge {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
A browser bridge to support sending model data to a Speckle server
|
A browser bridge to support sending model data to a Speckle server
|
||||||
*/
|
*/
|
||||||
class SendBridge : public speckle::interfac::browser::bridge::BrowserBridge {
|
class SendBridge : public speckle::interfac::browser::bridge::BrowserBridge, public speckle::event::ElementSubscriber {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// MARK: - Types
|
// MARK: - Types
|
||||||
@@ -22,6 +23,14 @@ namespace connector::interfac::browser::bridge {
|
|||||||
Default constructor
|
Default constructor
|
||||||
*/
|
*/
|
||||||
SendBridge();
|
SendBridge();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
/*!
|
||||||
|
Handle an element change
|
||||||
|
@param event The selection event
|
||||||
|
@return True if the event should be closed
|
||||||
|
*/
|
||||||
|
bool handle(const speckle::event::ElementEvent& event) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#ifndef CONNECTOR_INTERFACE_BRIDGE_GET_CONFIG
|
#ifndef CONNECTOR_INTERFACE_BRIDGE_GET_COMPLEX_TYPE
|
||||||
#define CONNECTOR_INTERFACE_BRIDGE_GET_CONFIG
|
#define CONNECTOR_INTERFACE_BRIDGE_GET_COMPLEX_TYPE
|
||||||
|
|
||||||
#include "Speckle/Interface/Browser/Bridge/BridgeMethod.h"
|
#include "Speckle/Interface/Browser/Bridge/BridgeMethod.h"
|
||||||
|
|
||||||
@@ -15,7 +15,6 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
Constructor
|
Constructor
|
||||||
@param bridge The parent bridge object (provides access to bridge methods)
|
|
||||||
*/
|
*/
|
||||||
GetComplexType();
|
GetComplexType();
|
||||||
|
|
||||||
@@ -30,4 +29,4 @@ namespace connector::interfac::browser::bridge {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif //CONNECTOR_INTERFACE_BRIDGE_GET_CONFIG
|
#endif //CONNECTOR_INTERFACE_BRIDGE_GET_COMPLEX_TYPE
|
||||||
|
|||||||
@@ -1,8 +1,9 @@
|
|||||||
#include "Connector/Interface/Browser/Bridge/Test/GoAway.h"
|
#include "Connector/Interface/Browser/Bridge/Test/GoAway.h"
|
||||||
|
|
||||||
using namespace connector::interfac::browser::bridge;
|
#include "Speckle/Environment/Platform.h"
|
||||||
|
|
||||||
#include <iostream>
|
using namespace connector::interfac::browser::bridge;
|
||||||
|
using namespace speckle::environment;
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Default constructor
|
Default constructor
|
||||||
@@ -16,5 +17,5 @@ GoAway::GoAway() : BridgeMethod{"GoAway", [&]() {
|
|||||||
Write a message to the console
|
Write a message to the console
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
void GoAway::run() const {
|
void GoAway::run() const {
|
||||||
std::cout << "Okay, going away.";
|
platform()->writeToConsole("Okay, going away.");
|
||||||
} //GoAway::run
|
} //GoAway::run
|
||||||
|
|||||||
@@ -17,6 +17,8 @@
|
|||||||
#include "Speckle/Event/Type/MenuEvent.h"
|
#include "Speckle/Event/Type/MenuEvent.h"
|
||||||
#include "Speckle/Interface/Browser/JSPortal.h"
|
#include "Speckle/Interface/Browser/JSPortal.h"
|
||||||
|
|
||||||
|
#include "Speckle/Event/Type/ProjectEvent.h"
|
||||||
|
|
||||||
#include <ACAPinc.h>
|
#include <ACAPinc.h>
|
||||||
#include <DGModule.hpp>
|
#include <DGModule.hpp>
|
||||||
#include <DGBrowser.hpp>
|
#include <DGBrowser.hpp>
|
||||||
@@ -108,7 +110,9 @@ ConnectorPalette::ConnectorPalette() {
|
|||||||
return: The subscription list (an empty list will put the subscriber into a suspended state)
|
return: The subscription list (an empty list will put the subscriber into a suspended state)
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
ConnectorPalette::Subscription ConnectorPalette::subscription() const {
|
ConnectorPalette::Subscription ConnectorPalette::subscription() const {
|
||||||
return { {toggleConnectorPaletteID} };
|
auto result = ProjectSubscriber::subscription();
|
||||||
|
result.insert(toggleConnectorPaletteID);
|
||||||
|
return result;
|
||||||
} //ConnectorPalette::subscription
|
} //ConnectorPalette::subscription
|
||||||
|
|
||||||
|
|
||||||
@@ -130,16 +134,49 @@ bool ConnectorPalette::start() {
|
|||||||
return: True if the event should be closed
|
return: True if the event should be closed
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
bool ConnectorPalette::receive(const active::event::Event& event) {
|
bool ConnectorPalette::receive(const active::event::Event& event) {
|
||||||
if (BrowserPalette::HasInstance() && BrowserPalette::GetInstance().IsVisible()) {
|
if (event == toggleConnectorPaletteID) {
|
||||||
BrowserPalette::GetInstance().Hide ();
|
if (BrowserPalette::HasInstance() && BrowserPalette::GetInstance().IsVisible()) {
|
||||||
} else {
|
BrowserPalette::GetInstance().Hide();
|
||||||
if (!BrowserPalette::HasInstance())
|
}
|
||||||
BrowserPalette::CreateInstance();
|
else {
|
||||||
BrowserPalette::GetInstance().Show();
|
if (!BrowserPalette::HasInstance())
|
||||||
|
BrowserPalette::CreateInstance();
|
||||||
|
BrowserPalette::GetInstance().Show();
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
|
return ProjectSubscriber::receive(event);
|
||||||
|
|
||||||
} //ConnectorPalette::receive
|
} //ConnectorPalette::receive
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Handle a project event
|
||||||
|
|
||||||
|
event: The project event
|
||||||
|
|
||||||
|
return: True if the event should be closed
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
bool ConnectorPalette::handle(const speckle::event::ProjectEvent& event) {
|
||||||
|
using enum speckle::event::ProjectEvent::Type;
|
||||||
|
switch (event.getType()) {
|
||||||
|
case open: {
|
||||||
|
if (BrowserPalette::HasInstance() && !BrowserPalette::GetInstance().IsVisible()) {
|
||||||
|
BrowserPalette::GetInstance().Show();
|
||||||
|
BrowserPalette::GetInstance().EnableItems();
|
||||||
|
}
|
||||||
|
} break;
|
||||||
|
case close: {
|
||||||
|
if (BrowserPalette::HasInstance() && BrowserPalette::GetInstance().IsVisible()) {
|
||||||
|
BrowserPalette::GetInstance().Hide();
|
||||||
|
}
|
||||||
|
} break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
} //ConnectorPalette::handle
|
||||||
|
|
||||||
|
|
||||||
//NB: Following is placeholder from GS example code - will be refactored to better suit our purposes
|
//NB: Following is placeholder from GS example code - will be refactored to better suit our purposes
|
||||||
|
|
||||||
@@ -166,15 +203,29 @@ BrowserPalette::BrowserPalette() :
|
|||||||
BeginEventProcessing();
|
BeginEventProcessing();
|
||||||
//Install required connector bridges
|
//Install required connector bridges
|
||||||
install<AccountBridge>();
|
install<AccountBridge>();
|
||||||
install<BaseBridge>();
|
|
||||||
|
if (auto ref = install<BaseBridge>(); ref) {
|
||||||
|
if (auto baseBridgeRef = std::dynamic_pointer_cast<BaseBridge>(ref); baseBridgeRef) {
|
||||||
|
connector::connector()->addWeak(baseBridgeRef);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
install<ConfigBridge>();
|
install<ConfigBridge>();
|
||||||
install<SendBridge>();
|
|
||||||
|
if (auto ref = install<SendBridge>(); ref) {
|
||||||
|
if (auto sendBridgeRef = std::dynamic_pointer_cast<SendBridge>(ref); sendBridgeRef) {
|
||||||
|
connector::connector()->addWeak(sendBridgeRef);
|
||||||
|
sendBridgeRef->start();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (auto ref = install<SelectionBridge>(); ref) {
|
if (auto ref = install<SelectionBridge>(); ref) {
|
||||||
if (auto selectionBridgeRef = std::dynamic_pointer_cast<SelectionBridge>(ref); selectionBridgeRef) {
|
if (auto selectionBridgeRef = std::dynamic_pointer_cast<SelectionBridge>(ref); selectionBridgeRef) {
|
||||||
connector::connector()->addWeak(selectionBridgeRef);
|
connector::connector()->addWeak(selectionBridgeRef);
|
||||||
selectionBridgeRef->start();
|
selectionBridgeRef->start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
install<TestBridge>();
|
install<TestBridge>();
|
||||||
InitBrowserControl();
|
InitBrowserControl();
|
||||||
}
|
}
|
||||||
@@ -214,8 +265,8 @@ void BrowserPalette::Hide() {
|
|||||||
|
|
||||||
void BrowserPalette::InitBrowserControl() {
|
void BrowserPalette::InitBrowserControl() {
|
||||||
#ifdef TESTING_MODE
|
#ifdef TESTING_MODE
|
||||||
browser->LoadURL("https://deploy-preview-3180--boisterous-douhua-e3cefb.netlify.app/");
|
|
||||||
//browser->LoadURL("https://boisterous-douhua-e3cefb.netlify.app/test");
|
//browser->LoadURL("https://boisterous-douhua-e3cefb.netlify.app/test");
|
||||||
|
browser->LoadURL("https://boisterous-douhua-e3cefb.netlify.app");
|
||||||
#else
|
#else
|
||||||
browser->LoadURL("https://boisterous-douhua-e3cefb.netlify.app/");
|
browser->LoadURL("https://boisterous-douhua-e3cefb.netlify.app/");
|
||||||
#endif
|
#endif
|
||||||
@@ -268,18 +319,10 @@ GSErrCode __ACENV_CALL BrowserPalette::PaletteControlCallBack(Int32, API_Palette
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case APIPalMsg_HidePalette_End:
|
case APIPalMsg_HidePalette_End:
|
||||||
if(HasInstance() && !GetInstance().IsVisible())
|
if (HasInstance() && !GetInstance().IsVisible())
|
||||||
|
{
|
||||||
GetInstance().Show();
|
GetInstance().Show();
|
||||||
break;
|
}
|
||||||
|
|
||||||
case APIPalMsg_DisableItems_Begin:
|
|
||||||
if(HasInstance() && GetInstance().IsVisible())
|
|
||||||
GetInstance().DisableItems();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case APIPalMsg_DisableItems_End:
|
|
||||||
if(HasInstance() && GetInstance().IsVisible())
|
|
||||||
GetInstance().EnableItems();
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case APIPalMsg_IsPaletteVisible:
|
case APIPalMsg_IsPaletteVisible:
|
||||||
|
|||||||
@@ -2,10 +2,11 @@
|
|||||||
#define CONNECTOR_CONNECTOR_PALETTE
|
#define CONNECTOR_CONNECTOR_PALETTE
|
||||||
|
|
||||||
#include "Active/Event/Subscriber.h"
|
#include "Active/Event/Subscriber.h"
|
||||||
|
#include "Speckle/Event/Subscriber/ProjectSubscriber.h"
|
||||||
|
|
||||||
namespace connector {
|
namespace connector {
|
||||||
|
|
||||||
class ConnectorPalette : public active::event::Subscriber {
|
class ConnectorPalette : public speckle::event::ProjectSubscriber {
|
||||||
public:
|
public:
|
||||||
/*!
|
/*!
|
||||||
Default constructor
|
Default constructor
|
||||||
@@ -32,6 +33,13 @@ namespace connector {
|
|||||||
@return True if the event should be closed
|
@return True if the event should be closed
|
||||||
*/
|
*/
|
||||||
bool receive(const active::event::Event& event) override;
|
bool receive(const active::event::Event& event) override;
|
||||||
|
protected:
|
||||||
|
/*!
|
||||||
|
Handle the project events
|
||||||
|
@param event The project event
|
||||||
|
@return True if the event should be closed
|
||||||
|
*/
|
||||||
|
bool handle(const speckle::event::ProjectEvent& event) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,8 +9,11 @@
|
|||||||
#include "Connector/Record/Collection/FinishProxy.h"
|
#include "Connector/Record/Collection/FinishProxy.h"
|
||||||
#include "Speckle/Database/BIMAttributeDatabase.h"
|
#include "Speckle/Database/BIMAttributeDatabase.h"
|
||||||
#include "Speckle/Database/BIMElementDatabase.h"
|
#include "Speckle/Database/BIMElementDatabase.h"
|
||||||
|
#include "Speckle/Record/Attribute/Finish.h"
|
||||||
#include "Speckle/Record/Element/Element.h"
|
#include "Speckle/Record/Element/Element.h"
|
||||||
|
|
||||||
|
#include <limits>
|
||||||
|
|
||||||
#ifdef ARCHICAD
|
#ifdef ARCHICAD
|
||||||
#include <ACAPinc.h>
|
#include <ACAPinc.h>
|
||||||
#include <ModelMaterial.hpp>
|
#include <ModelMaterial.hpp>
|
||||||
@@ -24,7 +27,7 @@ using namespace speckle::utility;
|
|||||||
|
|
||||||
#ifdef ARCHICAD
|
#ifdef ARCHICAD
|
||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
class ProjectCollection::FinishCache : public std::unordered_map<active::utility::Guid, Finish::Unique> {};
|
class ProjectCollection::FinishCache : public std::unordered_map<active::utility::Guid, Finish> {};
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -48,9 +51,12 @@ namespace {
|
|||||||
Constructor
|
Constructor
|
||||||
|
|
||||||
project: The source project
|
project: The source project
|
||||||
|
modelCardID: The model card ID for the send operation
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
ProjectCollection::ProjectCollection(speckle::environment::Project::Shared project) : base{project->getInfo().name, project},
|
ProjectCollection::ProjectCollection(speckle::environment::Project::Shared project, const RecordID& modelCardID) :
|
||||||
m_management{std::make_unique<Management>()} {
|
base{project->getInfo().name, project}, ConversionReporter{modelCardID}, m_management {
|
||||||
|
std::make_unique<Management>()
|
||||||
|
} {
|
||||||
m_management->push_back(this);
|
m_management->push_back(this);
|
||||||
m_finishes = std::make_unique<FinishCache>();
|
m_finishes = std::make_unique<FinishCache>();
|
||||||
base::useManagement(m_management.get());
|
base::useManagement(m_management.get());
|
||||||
@@ -102,7 +108,10 @@ bool ProjectCollection::addElement(const speckle::record::element::Element& elem
|
|||||||
RecordCollection* collection = this;
|
RecordCollection* collection = this;
|
||||||
for (const auto& childName : collectionNames)
|
for (const auto& childName : collectionNames)
|
||||||
collection = collection->getChild(childName);
|
collection = collection->getChild(childName);
|
||||||
return collection->addIndex(BIMIndex{element.getBIMID(), element.getTableID()});
|
if (!collection->addIndex(BIMIndex{element.getBIMID(), element.getTableID()}))
|
||||||
|
return false;
|
||||||
|
incrementProjectedRecords();
|
||||||
|
return true;
|
||||||
} //ProjectCollection::addElement
|
} //ProjectCollection::addElement
|
||||||
|
|
||||||
|
|
||||||
@@ -114,15 +123,14 @@ bool ProjectCollection::addElement(const speckle::record::element::Element& elem
|
|||||||
|
|
||||||
return: True if the material proxy was added (false typically means the record already exists)
|
return: True if the material proxy was added (false typically means the record already exists)
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
bool ProjectCollection::addMaterialProxy(const speckle::database::BIMIndex& materialIndex, const speckle::database::BIMRecordID& objectID) {
|
bool ProjectCollection::addFinishProxy(const speckle::database::BIMIndex& materialIndex, const speckle::database::BIMRecordID& objectID) {
|
||||||
auto iter = m_finishProxies.find(materialIndex);
|
auto iter = m_finishProxies.find(materialIndex);
|
||||||
if (iter == m_finishProxies.end())
|
if (iter == m_finishProxies.end())
|
||||||
iter = m_finishProxies.insert({materialIndex, {}}).first;
|
iter = m_finishProxies.insert({materialIndex, {}}).first;
|
||||||
return iter->second.insert(objectID).second;
|
return iter->second.insert(objectID).second;
|
||||||
} //ProjectCollection::addMaterialProxy
|
} //ProjectCollection::addFinishProxy
|
||||||
|
|
||||||
|
|
||||||
#ifdef ARCHICAD
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Add a ModelerAPI material to the collection (NB: These are not persistent so need to be captured by this method)
|
Add a ModelerAPI material to the collection (NB: These are not persistent so need to be captured by this method)
|
||||||
|
|
||||||
@@ -131,16 +139,12 @@ bool ProjectCollection::addMaterialProxy(const speckle::database::BIMIndex& mate
|
|||||||
|
|
||||||
return: True if the material proxy was added (false typically means the record already exists)
|
return: True if the material proxy was added (false typically means the record already exists)
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
bool ProjectCollection::addMaterialProxy(const ModelerAPI::Material& material, const speckle::database::BIMRecordID& objectID) {
|
bool ProjectCollection::addFinishProxy(const Finish& finish, const speckle::database::BIMRecordID& objectID) {
|
||||||
auto finishID = Guid::fromInt(material.GenerateHashValue());
|
auto iter = m_finishes->find(finish.getBIMID());
|
||||||
auto iter = m_finishes->find(finishID);
|
if (iter == m_finishes->end())
|
||||||
if (iter == m_finishes->end()) {
|
iter = m_finishes->insert({finish.getBIMID(), finish}).first;
|
||||||
auto finish = std::make_unique<Finish>(material);
|
return addFinishProxy(speckle::database::BIMIndex{finish.getBIMID()}, objectID);
|
||||||
iter = m_finishes->insert({ finishID, std::move(finish) }).first;
|
} //ProjectCollection::addFinishProxy
|
||||||
}
|
|
||||||
return addMaterialProxy(finishID, objectID);
|
|
||||||
} //ProjectCollection::addMaterialProxy
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
@@ -155,7 +159,7 @@ bool ProjectCollection::fillInventory(active::serialise::Inventory& inventory) c
|
|||||||
base::fillInventory(inventory);
|
base::fillInventory(inventory);
|
||||||
inventory.merge(Inventory{
|
inventory.merge(Inventory{
|
||||||
{
|
{
|
||||||
{ Identity{fieldID[finishProxyID]}, finishProxyID, 100, std::nullopt },
|
{ Identity{fieldID[finishProxyID]}, finishProxyID, std::numeric_limits<size_t>::max(), std::nullopt },
|
||||||
},
|
},
|
||||||
}.withType(&typeid(ProjectCollection)));
|
}.withType(&typeid(ProjectCollection)));
|
||||||
return true;
|
return true;
|
||||||
@@ -181,7 +185,7 @@ Cargo::Unique ProjectCollection::getCargo(const Inventory::Item& item) const {
|
|||||||
std::advance(iter, item.available);
|
std::advance(iter, item.available);
|
||||||
const Finish* finish = nullptr;
|
const Finish* finish = nullptr;
|
||||||
if (auto fin = m_finishes->find(iter->first); fin != m_finishes->end())
|
if (auto fin = m_finishes->find(iter->first); fin != m_finishes->end())
|
||||||
finish = fin->second.get();
|
finish = &fin->second;
|
||||||
else if (auto attribute = m_project->getAttributeDatabase()->getAttribute(iter->first, iter->first.tableID); attribute)
|
else if (auto attribute = m_project->getAttributeDatabase()->getAttribute(iter->first, iter->first.tableID); attribute)
|
||||||
finish = dynamic_cast<const Finish*>(attribute.get());
|
finish = dynamic_cast<const Finish*>(attribute.get());
|
||||||
if (finish != nullptr) {
|
if (finish != nullptr) {
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
#include "Connector/Record/Collection/RecordCollection.h"
|
#include "Connector/Record/Collection/RecordCollection.h"
|
||||||
#include "Speckle/Serialise/Collection/FinishCollector.h"
|
#include "Speckle/Serialise/Collection/FinishCollector.h"
|
||||||
|
#include "Speckle/Serialise/Collection/ConversionReporter.h"
|
||||||
|
|
||||||
#include <stack>
|
#include <stack>
|
||||||
|
|
||||||
@@ -25,7 +26,7 @@ namespace connector::record {
|
|||||||
- Other attributes, e.g. materials
|
- Other attributes, e.g. materials
|
||||||
Add all this supplementary data to the root container as required
|
Add all this supplementary data to the root container as required
|
||||||
*/
|
*/
|
||||||
class ProjectCollection : public RecordCollection, public speckle::serialise::FinishCollector {
|
class ProjectCollection : public RecordCollection, public speckle::serialise::FinishCollector, public speckle::serialise::ConversionReporter {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// MARK: - Types
|
// MARK: - Types
|
||||||
@@ -37,8 +38,9 @@ namespace connector::record {
|
|||||||
/*!
|
/*!
|
||||||
Constructor
|
Constructor
|
||||||
@param project The source project
|
@param project The source project
|
||||||
|
@param modelCardID The model card ID for the send operation
|
||||||
*/
|
*/
|
||||||
ProjectCollection(speckle::environment::Project::Shared project);
|
ProjectCollection(speckle::environment::Project::Shared project, const speckle::database::RecordID& modelCardID);
|
||||||
ProjectCollection(const ProjectCollection&) = delete;
|
ProjectCollection(const ProjectCollection&) = delete;
|
||||||
/*!
|
/*!
|
||||||
Destructor
|
Destructor
|
||||||
@@ -69,16 +71,14 @@ namespace connector::record {
|
|||||||
@param objectID The object the material is applied to
|
@param objectID The object the material is applied to
|
||||||
@return True if the material proxy was added (false typically means the record already exists)
|
@return True if the material proxy was added (false typically means the record already exists)
|
||||||
*/
|
*/
|
||||||
bool addMaterialProxy(const speckle::database::BIMIndex& materialIndex, const speckle::database::BIMRecordID& objectID) override;
|
bool addFinishProxy(const speckle::database::BIMIndex& materialIndex, const speckle::database::BIMRecordID& objectID) override;
|
||||||
#ifdef ARCHICAD
|
|
||||||
/*!
|
/*!
|
||||||
Add a ModelerAPI material to the collection (NB: These are not persistent so need to be captured by this method)
|
Add a ModelerAPI material to the collection (NB: These are not persistent so need to be captured by this method)
|
||||||
@param material A material
|
@param finish A finish
|
||||||
@param objectID The object the material is applied to
|
@param objectID The object the material is applied to
|
||||||
@return True if the material proxy was added (false typically means the record already exists)
|
@return True if the material proxy was added (false typically means the record already exists)
|
||||||
*/
|
*/
|
||||||
bool addMaterialProxy(const ModelerAPI::Material& material, const speckle::database::BIMRecordID& objectID) override;
|
bool addFinishProxy(const speckle::record::attribute::Finish& finish, const speckle::database::BIMRecordID& objectID) override;
|
||||||
#endif
|
|
||||||
|
|
||||||
// MARK: - Serialisation
|
// MARK: - Serialisation
|
||||||
|
|
||||||
@@ -101,11 +101,9 @@ namespace connector::record {
|
|||||||
std::unique_ptr<active::serialise::Management> m_management;
|
std::unique_ptr<active::serialise::Management> m_management;
|
||||||
///Finish proxies accumulated from meshes generated from the collection elements
|
///Finish proxies accumulated from meshes generated from the collection elements
|
||||||
FinishProxies m_finishProxies;
|
FinishProxies m_finishProxies;
|
||||||
#ifdef ARCHICAD
|
|
||||||
class FinishCache;
|
class FinishCache;
|
||||||
///Finishes cached from ModelerAPI materials
|
///Finishes cache
|
||||||
std::unique_ptr<FinishCache> m_finishes;
|
std::unique_ptr<FinishCache> m_finishes;
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,13 +1,9 @@
|
|||||||
/*!
|
|
||||||
Copyright 2024 Ralph Wessel and Hugh Wessel
|
|
||||||
Distributed under the MIT License (See accompanying file LICENSE.txt or copy at https://opensource.org/license/mit/)
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "Connector/Record/Model/CardMover.h"
|
#include "Connector/Record/Model/CardMover.h"
|
||||||
|
|
||||||
#include "Connector/Record/Model/ReceiverModelCard.h"
|
#include "Connector/Record/Model/ReceiverModelCard.h"
|
||||||
#include "Connector/Record/Model/SenderModelCard.h"
|
#include "Connector/Record/Model/SenderModelCard.h"
|
||||||
|
|
||||||
|
using namespace active::serialise;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
@@ -37,7 +33,7 @@ namespace {
|
|||||||
}
|
}
|
||||||
|
|
||||||
///The handler for model card packages
|
///The handler for model card packages
|
||||||
std::shared_ptr<active::serialise::Handler> CardMover::m_handler = std::make_shared<active::serialise::Handler>(attributeTag);
|
std::shared_ptr<Handler> CardMover::m_handler = std::make_shared<Handler>(attributeTag);
|
||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
|
|||||||
@@ -6,10 +6,10 @@
|
|||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Wrapper to box/unbox objects during (de)serialisation, including reading/writing a specified attribute to determine object type
|
Wrapper to box/unbox model cards during (de)serialisation
|
||||||
|
|
||||||
Note that a derived class could also define the package handler, allowing the wrapper to be created via a default constructor that is
|
Model cards are polymorphic - this class ensures the type information is included when a card is serialised
|
||||||
automatically bound to a set of internally defined object types
|
and the correct object type is constructed on deserialisation
|
||||||
*/
|
*/
|
||||||
class CardMover : public active::serialise::Mover {
|
class CardMover : public active::serialise::Mover {
|
||||||
public:
|
public:
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#ifndef CONNECTOR_RECORD_ARCHICAD_EVERYTHING_FILTER
|
#ifndef CONNECTOR_RECORD_ARCHICAD_EVERYTHING_FILTER
|
||||||
#define CONNECTOR_RECORD_ARCHICAD_EVERYTHING_FILTER
|
#define CONNECTOR_RECORD_ARCHICAD_EVERYTHING_FILTER
|
||||||
|
|
||||||
#include "Connector/Database/Identity/RecordID.h"
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
#include "Connector/Record/Model/Filter/EverythingSendFilter.h"
|
#include "Connector/Record/Model/Filter/EverythingSendFilter.h"
|
||||||
|
|
||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#ifndef CONNECTOR_RECORD_ARCHICAD_SELECTION_FILTER
|
#ifndef CONNECTOR_RECORD_ARCHICAD_SELECTION_FILTER
|
||||||
#define CONNECTOR_RECORD_ARCHICAD_SELECTION_FILTER
|
#define CONNECTOR_RECORD_ARCHICAD_SELECTION_FILTER
|
||||||
|
|
||||||
#include "Connector/Database/Identity/RecordID.h"
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
#include "Connector/Record/Model/Filter/DirectSelectionSendFilter.h"
|
#include "Connector/Record/Model/Filter/DirectSelectionSendFilter.h"
|
||||||
|
|
||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
using namespace connector::database;
|
using namespace speckle::database;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
@@ -56,7 +56,7 @@ Cargo::Unique DirectSelectionSendFilter::getCargo(const Inventory::Item& item) c
|
|||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
switch (item.index) {
|
switch (item.index) {
|
||||||
case selectedElemID:
|
case selectedElemID:
|
||||||
return std::make_unique<ContainerWrap<ElementIDList>>(m_selectedElements);
|
return std::make_unique<ContainerWrap<ElementIDList>>(m_selectedElements, false, fieldID[selectedElemID].name);
|
||||||
default:
|
default:
|
||||||
return nullptr; //Requested an unknown index
|
return nullptr; //Requested an unknown index
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#ifndef CONNECTOR_RECORD_DIRECT_SELECT_SEND_FILTER
|
#ifndef CONNECTOR_RECORD_DIRECT_SELECT_SEND_FILTER
|
||||||
#define CONNECTOR_RECORD_DIRECT_SELECT_SEND_FILTER
|
#define CONNECTOR_RECORD_DIRECT_SELECT_SEND_FILTER
|
||||||
|
|
||||||
#include "Connector/Database/Identity/RecordID.h"
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
#include "Connector/Record/Model/Filter/SendFilter.h"
|
#include "Connector/Record/Model/Filter/SendFilter.h"
|
||||||
|
|
||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
@@ -36,7 +36,7 @@ namespace connector::record {
|
|||||||
Get the filtered element IDs
|
Get the filtered element IDs
|
||||||
@return The filter elements
|
@return The filter elements
|
||||||
*/
|
*/
|
||||||
const database::ElementIDList& getElementIDs() const override { return m_selectedElements; }
|
const speckle::database::ElementIDList& getElementIDs() const override { return m_selectedElements; }
|
||||||
|
|
||||||
// MARK: - Serialisation
|
// MARK: - Serialisation
|
||||||
|
|
||||||
@@ -59,7 +59,7 @@ namespace connector::record {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
///A list of selected element IDs
|
///A list of selected element IDs
|
||||||
database::ElementIDList m_selectedElements;
|
speckle::database::ElementIDList m_selectedElements;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
using namespace connector::database;
|
using namespace speckle::database;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#ifndef CONNECTOR_RECORD_EVERYTHING_SEND_FILTER
|
#ifndef CONNECTOR_RECORD_EVERYTHING_SEND_FILTER
|
||||||
#define CONNECTOR_RECORD_EVERYTHING_SEND_FILTER
|
#define CONNECTOR_RECORD_EVERYTHING_SEND_FILTER
|
||||||
|
|
||||||
#include "Connector/Database/Identity/RecordID.h"
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
#include "Connector/Record/Model/Filter/SendFilter.h"
|
#include "Connector/Record/Model/Filter/SendFilter.h"
|
||||||
|
|
||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
@@ -36,13 +36,13 @@ namespace connector::record {
|
|||||||
Get the filtered element IDs
|
Get the filtered element IDs
|
||||||
@return The filter elements
|
@return The filter elements
|
||||||
*/
|
*/
|
||||||
const database::ElementIDList& getElementIDs() const override { return m_emptyList; }
|
const speckle::database::ElementIDList& getElementIDs() const override { return m_emptyList; }
|
||||||
/*!
|
/*!
|
||||||
Determine if the filter has expired because an element in the selection has changed
|
Determine if the filter has expired because an element in the selection has changed
|
||||||
@param changed The list of changed element IDs
|
@param changed The list of changed element IDs
|
||||||
@return True if the one of the changed elements is in the selection
|
@return True if the one of the changed elements is in the selection
|
||||||
*/
|
*/
|
||||||
virtual bool checkExpiry(const database::ElementIDList& changed) const override { return true; }
|
virtual bool checkExpiry(const speckle::database::ElementIDList& changed) const override { return true; }
|
||||||
|
|
||||||
// MARK: - Serialisation
|
// MARK: - Serialisation
|
||||||
|
|
||||||
@@ -65,7 +65,7 @@ namespace connector::record {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
///Enables a const empty list to be returned
|
///Enables a const empty list to be returned
|
||||||
database::ElementIDList m_emptyList;
|
speckle::database::ElementIDList m_emptyList;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,3 @@
|
|||||||
/*!
|
|
||||||
Copyright 2024 Ralph Wessel and Hugh Wessel
|
|
||||||
Distributed under the MIT License (See accompanying file LICENSE.txt or copy at https://opensource.org/license/mit/)
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "Connector/Record/Model/Filter/FilterMover.h"
|
#include "Connector/Record/Model/Filter/FilterMover.h"
|
||||||
|
|
||||||
#include "Connector/Record/Model/Filter/ArchicadEverythingFilter.h"
|
#include "Connector/Record/Model/Filter/ArchicadEverythingFilter.h"
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
using namespace connector::database;
|
using namespace speckle::database;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
#include "Active/Serialise/Package/Package.h"
|
#include "Active/Serialise/Package/Package.h"
|
||||||
#include "Active/Utility/Cloner.h"
|
#include "Active/Utility/Cloner.h"
|
||||||
#include "Connector/Database/Identity/RecordID.h"
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
#include "Speckle/Utility/String.h"
|
#include "Speckle/Utility/String.h"
|
||||||
|
|
||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
@@ -59,13 +59,13 @@ namespace connector::record {
|
|||||||
Get the filtered element IDs
|
Get the filtered element IDs
|
||||||
@return The filter elements
|
@return The filter elements
|
||||||
*/
|
*/
|
||||||
virtual const database::ElementIDList& getElementIDs() const = 0;
|
virtual const speckle::database::ElementIDList& getElementIDs() const = 0;
|
||||||
/*!
|
/*!
|
||||||
Determine if the filter has expired because an element in the selection has changed
|
Determine if the filter has expired because an element in the selection has changed
|
||||||
@param changed The list of changed element IDs
|
@param changed The list of changed element IDs
|
||||||
@return True if the one of the changed elements is in the selection
|
@return True if the one of the changed elements is in the selection
|
||||||
*/
|
*/
|
||||||
virtual bool checkExpiry(const database::ElementIDList& changed) const;
|
virtual bool checkExpiry(const speckle::database::ElementIDList& changed) const;
|
||||||
|
|
||||||
// MARK: - Serialisation
|
// MARK: - Serialisation
|
||||||
|
|
||||||
|
|||||||
@@ -11,7 +11,10 @@
|
|||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
A connector send filter
|
Base class for a Speckle model card
|
||||||
|
|
||||||
|
A model card captures key information about a model submitted to a Speckle server, e.g. the model ID, the target server
|
||||||
|
and account, and any settings or filters applicable to the host BIM application and open document
|
||||||
*/
|
*/
|
||||||
class ModelCard : public speckle::database::Record {
|
class ModelCard : public speckle::database::Record {
|
||||||
public:
|
public:
|
||||||
@@ -60,13 +63,13 @@ namespace connector::record {
|
|||||||
*/
|
*/
|
||||||
const speckle::utility::String& getModelID() const { return m_modelID; }
|
const speckle::utility::String& getModelID() const { return m_modelID; }
|
||||||
/*!
|
/*!
|
||||||
Get the setting type
|
Get the ID of the active BIM project
|
||||||
@return The setting type
|
@return The ID of the active BIM project
|
||||||
*/
|
*/
|
||||||
const speckle::utility::String& getProjectID() const { return m_projectID; }
|
const speckle::utility::String& getProjectID() const { return m_projectID; }
|
||||||
/*!
|
/*!
|
||||||
Get the setting type
|
Get the user account ID
|
||||||
@return The setting type
|
@return The user account ID
|
||||||
*/
|
*/
|
||||||
const speckle::utility::String& getAccountID() const { return m_accountID; }
|
const speckle::utility::String& getAccountID() const { return m_accountID; }
|
||||||
/*!
|
/*!
|
||||||
@@ -75,8 +78,8 @@ namespace connector::record {
|
|||||||
*/
|
*/
|
||||||
const speckle::utility::String& getMessage() const { return m_message; }
|
const speckle::utility::String& getMessage() const { return m_message; }
|
||||||
/*!
|
/*!
|
||||||
Get the setting type
|
Get the server URL
|
||||||
@return The setting type
|
@return The server URL
|
||||||
*/
|
*/
|
||||||
const speckle::utility::String& getServerURL() const { return m_serverURL; }
|
const speckle::utility::String& getServerURL() const { return m_serverURL; }
|
||||||
/*!
|
/*!
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
using namespace active::serialise;
|
using namespace active::serialise;
|
||||||
using namespace connector::database;
|
using namespace speckle::database;
|
||||||
using namespace connector::record;
|
using namespace connector::record;
|
||||||
using namespace speckle::database;
|
using namespace speckle::database;
|
||||||
using namespace speckle::utility;
|
using namespace speckle::utility;
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#ifndef CONNECTOR_RECORD_RECEIVER_MODEL_CARD
|
#ifndef CONNECTOR_RECORD_RECEIVER_MODEL_CARD
|
||||||
#define CONNECTOR_RECORD_RECEIVER_MODEL_CARD
|
#define CONNECTOR_RECORD_RECEIVER_MODEL_CARD
|
||||||
|
|
||||||
#include "Connector/Database/Identity/RecordID.h"
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
#include "Connector/Record/Model/ModelCard.h"
|
#include "Connector/Record/Model/ModelCard.h"
|
||||||
|
|
||||||
namespace connector::record {
|
namespace connector::record {
|
||||||
@@ -37,7 +37,7 @@ namespace connector::record {
|
|||||||
const speckle::database::RecordID& modelID, const speckle::utility::String& modelName,
|
const speckle::database::RecordID& modelID, const speckle::utility::String& modelName,
|
||||||
const speckle::database::RecordID& selectedVersion, const speckle::database::RecordID& latestVersion,
|
const speckle::database::RecordID& selectedVersion, const speckle::database::RecordID& latestVersion,
|
||||||
const speckle::database::RecordID& accountID, const speckle::utility::String& serverURL,
|
const speckle::database::RecordID& accountID, const speckle::utility::String& serverURL,
|
||||||
bool hasDimissedWarning, database::ElementIDList&& bakedObjects, const SettingList& settings) :
|
bool hasDimissedWarning, speckle::database::ElementIDList&& bakedObjects, const SettingList& settings) :
|
||||||
ModelCard{modelID, projectID, accountID, serverURL, settings},
|
ModelCard{modelID, projectID, accountID, serverURL, settings},
|
||||||
m_projectName{projectName}, m_modelName{modelName}, m_selectedVersionID{selectedVersion}, m_latestVersionID{latestVersion},
|
m_projectName{projectName}, m_modelName{modelName}, m_selectedVersionID{selectedVersion}, m_latestVersionID{latestVersion},
|
||||||
m_hasDismissedUpdateWarning{hasDimissedWarning}, m_bakedObjectIDs{bakedObjects} {}
|
m_hasDismissedUpdateWarning{hasDimissedWarning}, m_bakedObjectIDs{bakedObjects} {}
|
||||||
@@ -78,7 +78,7 @@ namespace connector::record {
|
|||||||
Get the IDs of objects accepted in the receive
|
Get the IDs of objects accepted in the receive
|
||||||
@return The accepted object IDs
|
@return The accepted object IDs
|
||||||
*/
|
*/
|
||||||
const database::ElementIDList& getBakedObjectIDs() const { return m_bakedObjectIDs; }
|
const speckle::database::ElementIDList& getBakedObjectIDs() const { return m_bakedObjectIDs; }
|
||||||
|
|
||||||
// MARK: - Serialisation
|
// MARK: - Serialisation
|
||||||
|
|
||||||
@@ -111,7 +111,7 @@ namespace connector::record {
|
|||||||
///True if the user has already dismissed an alert to update
|
///True if the user has already dismissed an alert to update
|
||||||
bool m_hasDismissedUpdateWarning = false;
|
bool m_hasDismissedUpdateWarning = false;
|
||||||
///IDs of objects accepted in the receive
|
///IDs of objects accepted in the receive
|
||||||
database::ElementIDList m_bakedObjectIDs;
|
speckle::database::ElementIDList m_bakedObjectIDs;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,5 +11,6 @@
|
|||||||
#include "Speckle.grc.rc2"
|
#include "Speckle.grc.rc2"
|
||||||
|
|
||||||
#include "ConnectorFix.grc.rc2"
|
#include "ConnectorFix.grc.rc2"
|
||||||
|
#include "ConnectorImagesFix.grc.rc2"
|
||||||
|
|
||||||
1 ICON LOADONCALL MOVEABLE IMPURE ACAP.ico
|
1 ICON LOADONCALL MOVEABLE IMPURE ACAP.ico
|
||||||
|
|||||||
@@ -0,0 +1,10 @@
|
|||||||
|
|
||||||
|
#ifdef macintosh
|
||||||
|
'GICN' 32500 "Speckle menu icon" {
|
||||||
|
"32500Mac"
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
'GICN' 32500 "Speckle menu icon" {
|
||||||
|
"32500Win"
|
||||||
|
}
|
||||||
|
#endif
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
<svg width="52" height="52" viewBox="0 0 52 52" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M9 10L2 4V44L9 50V10Z" stroke="black" stroke-width="3" stroke-linejoin="round"/>
|
||||||
|
<path d="M43 2L2 4L9 10L50 8L43 2Z" stroke="black" stroke-width="3" stroke-linejoin="round"/>
|
||||||
|
<path d="M50 8L9 10V50L50 48V8Z" stroke="black" stroke-width="3" stroke-linejoin="round"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 378 B |
@@ -0,0 +1,5 @@
|
|||||||
|
<svg width="48" height="48" viewBox="0 0 48 48" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M7 8L0 2V42L7 48V8Z" fill="#313BCF"/>
|
||||||
|
<path d="M41 0L0 2L7 8L48 6L41 0Z" fill="#7BBCFF"/>
|
||||||
|
<path d="M48 6L7 8V48L48 46V6Z" fill="#047EFB"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 251 B |
@@ -9,4 +9,5 @@
|
|||||||
/* [ 2] */ "The specified model card cannot be found. Try another card or create a new one"
|
/* [ 2] */ "The specified model card cannot be found. Try another card or create a new one"
|
||||||
/* [ 3] */ "Please open a project first"
|
/* [ 3] */ "Please open a project first"
|
||||||
/* [ 4] */ "The specified Speckle account cannot be found. Check that you have logged into your Speckle account with the Speckle Manager"
|
/* [ 4] */ "The specified Speckle account cannot be found. Check that you have logged into your Speckle account with the Speckle Manager"
|
||||||
|
/* [ 5] */ "Unsupported conversion"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
'STR#' 32500 "Connector Menu" {
|
'STR#' 32500 "Connector Menu" {
|
||||||
/*[ 1]*/ "Speckle Connector"
|
/*[ 1]*/ "Speckle Connector^E3^EL^ES^ED^EE^EI^EW^ET^32500"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
/* --- Dockable browser palette ----------------------------------------------*/
|
/* --- Dockable browser palette ----------------------------------------------*/
|
||||||
|
|
||||||
'GDLG' 32500 Palette | topCaption | close | grow 0 0 450 150 "Speckle Connector" {
|
'GDLG' 32500 Palette | topCaption | close | grow 0 0 350 150 "Speckle Connector" {
|
||||||
/* [ 1] */ Browser 0 0 450 150
|
/* [ 1] */ Browser 0 0 350 150
|
||||||
}
|
}
|
||||||
|
|
||||||
'DLGH' 32500 DLG_32500_Browser_Palette {
|
'DLGH' 32500 DLG_32500_Browser_Palette {
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
'STR#' 32700 "Speckle Title strings" {
|
'STR#' 32700 "Speckle Title strings" {
|
||||||
/* [ 1] */ "Untitled"
|
/* [ 1] */ "Untitled"
|
||||||
/* [ 2] */ "Unknown"
|
/* [ 2] */ "Unknown"
|
||||||
|
/* [ 3] */ "Converting elements"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,11 +31,6 @@ namespace speckle::database {
|
|||||||
|
|
||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
/*!
|
|
||||||
Get the current user attribute selection
|
|
||||||
@return A list of selected attribute IDs
|
|
||||||
*/
|
|
||||||
BIMLinkList getSelection() const;
|
|
||||||
/*!
|
/*!
|
||||||
Get a specified attribute
|
Get a specified attribute
|
||||||
@param attributeID The ID of the target attribute
|
@param attributeID The ID of the target attribute
|
||||||
|
|||||||
@@ -33,8 +33,9 @@ namespace speckle::database {
|
|||||||
};
|
};
|
||||||
|
|
||||||
///Element database storage declaration
|
///Element database storage declaration
|
||||||
class BIMElementDatabase::Store : public Storage<Element, UnboxedTransport, BIMRecordID, BIMRecordID, BIMRecordID, BIMRecordID> {
|
class BIMElementDatabase::Store : public Storage<Element, UnboxedTransport, BIMRecordID, BIMRecordID,
|
||||||
using base = Storage<Element, UnboxedTransport, BIMRecordID, BIMRecordID, BIMRecordID, BIMRecordID>;
|
BIMRecordID, BIMRecordID, ElementStorage::TableType> {
|
||||||
|
using base = Storage<Element, UnboxedTransport, BIMRecordID, BIMRecordID, BIMRecordID, BIMRecordID, ElementStorage::TableType>;
|
||||||
using base::base;
|
using base::base;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -75,6 +76,48 @@ BIMElementDatabase::BIMElementDatabase() {
|
|||||||
BIMElementDatabase::~BIMElementDatabase() {}
|
BIMElementDatabase::~BIMElementDatabase() {}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get the available element tables
|
||||||
|
|
||||||
|
targetType: An optional filtr for table type to retrieve, e.g. get all sections (nullopt = all table types)
|
||||||
|
|
||||||
|
return: A list of available tables
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
BIMRecordIDList BIMElementDatabase::getTables(std::optional<TableType> targetType) const {
|
||||||
|
return m_engine->getTables(targetType);
|
||||||
|
} //BIMElementDatabase::getTables
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get the default dbase table
|
||||||
|
|
||||||
|
return: The default dbase table (nullopt if no table is available)
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
std::optional<BIMRecordID> BIMElementDatabase::getDefaultTable() const {
|
||||||
|
return m_engine->getDefaultTable();
|
||||||
|
} //BIMElementDatabase::getDefaultTable
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Set the default dbase table
|
||||||
|
|
||||||
|
tableID: The new default dbase table
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMElementDatabase::setDefaultTable(const BIMRecordID& tableID) const {
|
||||||
|
m_engine->setDefaultTable(tableID);
|
||||||
|
} //BIMElementDatabase::setDefaultTable
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Bring the view of this database to the front (i.e. so the user sees it)
|
||||||
|
|
||||||
|
tableID: The ID of the table to bring to the front
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMElementDatabase::bringViewToFront(BIMRecordID tableID) const {
|
||||||
|
m_engine->bringViewToFront(tableID);
|
||||||
|
} //BIMElementDatabase::bringViewToFront
|
||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Get the current user element selection
|
Get the current user element selection
|
||||||
|
|
||||||
@@ -85,10 +128,43 @@ BIMLinkList BIMElementDatabase::getSelection() const {
|
|||||||
} //BIMElementDatabase::getSelection
|
} //BIMElementDatabase::getSelection
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Set the element selection
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMElementDatabase::setSelection(const BIMLinkList& elementIDs) const {
|
||||||
|
m_engine->setSelection(elementIDs);
|
||||||
|
} //BIMElementDatabase::setSelection
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Clear the element selection
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMElementDatabase::clearSelection() const {
|
||||||
|
m_engine->clearSelection();
|
||||||
|
} //BIMElementDatabase::clearSelection
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Find a filtered list of objects
|
||||||
|
|
||||||
|
filter: The object filter (nullptr = find all objects)
|
||||||
|
tableID: Optional table ID (defaults to the first table)
|
||||||
|
documentID: Optional document ID (filter for this document only - nullopt = all objects)
|
||||||
|
|
||||||
|
return: A list containing IDs of found elements (empty if none found)
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
BIMRecordIDList BIMElementDatabase::findElements(const Filter& filter, std::optional<BIMRecordID> tableID,
|
||||||
|
std::optional<BIMRecordID> documentID) const {
|
||||||
|
return m_engine->findObjects(filter, tableID, documentID);
|
||||||
|
} //BIMElementDatabase::findElements
|
||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Get a specified element
|
Get a specified element
|
||||||
|
|
||||||
elementID: The ID of the target element
|
elementID: The ID of the target element
|
||||||
|
tableID: Optional table ID (defaults to the first table)
|
||||||
|
documentID: Optional document ID (filter for this document only - nullopt = all objects)
|
||||||
|
|
||||||
return: The requested element (nullptr on failure)
|
return: The requested element (nullptr on failure)
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
@@ -101,10 +177,14 @@ Element::Unique BIMElementDatabase::getElement(const BIMRecordID& elementID, std
|
|||||||
/*--------------------------------------------------------------------
|
/*--------------------------------------------------------------------
|
||||||
Get all elements
|
Get all elements
|
||||||
|
|
||||||
|
tableID: Optional table ID (defaults to the first table)
|
||||||
|
documentID: Optional document ID (filter for this document only - nullopt = all objects)
|
||||||
|
|
||||||
return: All the elements
|
return: All the elements
|
||||||
--------------------------------------------------------------------*/
|
--------------------------------------------------------------------*/
|
||||||
Vector<Element> BIMElementDatabase::getElements() const {
|
Vector<Element> BIMElementDatabase::getElements(std::optional<BIMRecordID> tableID,
|
||||||
return m_store->getObjects();
|
std::optional<BIMRecordID> documentID) const {
|
||||||
|
return m_store->getObjects(tableID, documentID);
|
||||||
} //BIMElementDatabase::getElements
|
} //BIMElementDatabase::getElements
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
#define CONNECTOR_DATABASE_BIM_ELEMENT_DATABASE
|
#define CONNECTOR_DATABASE_BIM_ELEMENT_DATABASE
|
||||||
|
|
||||||
#include "Speckle/Database/Identity/BIMLink.h"
|
#include "Speckle/Database/Identity/BIMLink.h"
|
||||||
|
#include "Speckle/Database/Storage/Element/ElementStorage.h"
|
||||||
#include "Speckle/Record/Element/Element.h"
|
#include "Speckle/Record/Element/Element.h"
|
||||||
#include "Speckle/Record/Element/Interface/Part.h"
|
#include "Speckle/Record/Element/Interface/Part.h"
|
||||||
#include "Speckle/Utility/Guid.h"
|
#include "Speckle/Utility/Guid.h"
|
||||||
@@ -19,7 +20,7 @@ namespace speckle::database {
|
|||||||
/*!
|
/*!
|
||||||
Database of model elements relating to a specific project
|
Database of model elements relating to a specific project
|
||||||
*/
|
*/
|
||||||
class BIMElementDatabase {
|
class BIMElementDatabase : public ElementStorage {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// MARK: - Constructors
|
// MARK: - Constructors
|
||||||
@@ -36,11 +37,49 @@ namespace speckle::database {
|
|||||||
|
|
||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Get the available element tables
|
||||||
|
@param targetType An optional filtr for table type to retrieve, e.g. get all sections (nullopt = all table types)
|
||||||
|
@return A set of available tables
|
||||||
|
*/
|
||||||
|
BIMRecordIDList getTables(std::optional<TableType> targetType) const;
|
||||||
|
/*!
|
||||||
|
Get the default dbase table
|
||||||
|
@return The default dbase table (nullopt if no table is available)
|
||||||
|
*/
|
||||||
|
std::optional<BIMRecordID> getDefaultTable() const;
|
||||||
|
/*!
|
||||||
|
Set the default dbase table
|
||||||
|
@param tableID The new default dbase table
|
||||||
|
*/
|
||||||
|
void setDefaultTable(const BIMRecordID& tableID) const;
|
||||||
|
/*!
|
||||||
|
Bring the view of this database to the front (i.e. so the user sees it)
|
||||||
|
@param tableID The ID of the table to bring to the front
|
||||||
|
*/
|
||||||
|
void bringViewToFront(BIMRecordID tableID) const;
|
||||||
/*!
|
/*!
|
||||||
Get the current user element selection
|
Get the current user element selection
|
||||||
@return A list of selected element IDs
|
@return A list of selected element IDs
|
||||||
*/
|
*/
|
||||||
BIMLinkList getSelection() const;
|
BIMLinkList getSelection() const;
|
||||||
|
/*!
|
||||||
|
Set the element selection
|
||||||
|
*/
|
||||||
|
void setSelection(const BIMLinkList& elementIDs) const;
|
||||||
|
/*!
|
||||||
|
Clear the element selection
|
||||||
|
*/
|
||||||
|
void clearSelection() const;
|
||||||
|
/*!
|
||||||
|
Find a filtered list of objects
|
||||||
|
@param filter The object filter (nullptr = find all objects)
|
||||||
|
@param tableID Optional table ID (defaults to the first table)
|
||||||
|
@param documentID Optional document ID (filter for this document only - nullopt = all objects)
|
||||||
|
@return A list containing IDs of found elements (empty if none found)
|
||||||
|
*/
|
||||||
|
BIMRecordIDList findElements(const Filter& filter = nullptr, std::optional<BIMRecordID> tableID = std::nullopt,
|
||||||
|
std::optional<BIMRecordID> documentID = std::nullopt) const;
|
||||||
/*!
|
/*!
|
||||||
Get a specified element
|
Get a specified element
|
||||||
@param elementID The ID of the target element
|
@param elementID The ID of the target element
|
||||||
@@ -58,9 +97,12 @@ namespace speckle::database {
|
|||||||
std::unique_ptr<record::element::Element> getElement(const BIMLink& link) const { return getElement(link, link.tableID, link.docID); }
|
std::unique_ptr<record::element::Element> getElement(const BIMLink& link) const { return getElement(link, link.tableID, link.docID); }
|
||||||
/*!
|
/*!
|
||||||
Get all model elements
|
Get all model elements
|
||||||
|
@param tableID Optional table ID (defaults to the first table)
|
||||||
|
@param documentID Optional document ID (filter for this document only - nullopt = all objects)
|
||||||
@return All the elements
|
@return All the elements
|
||||||
*/
|
*/
|
||||||
active::container::Vector<record::element::Element> getElements() const;
|
active::container::Vector<record::element::Element> getElements(std::optional<BIMRecordID> tableID = std::nullopt,
|
||||||
|
std::optional<BIMRecordID> documentID = std::nullopt) const;
|
||||||
/*!
|
/*!
|
||||||
Get memo memo (supplementary) data for a specified element
|
Get memo memo (supplementary) data for a specified element
|
||||||
@param elementID The of the source element
|
@param elementID The of the source element
|
||||||
|
|||||||
@@ -0,0 +1,129 @@
|
|||||||
|
#include "Speckle/Database/BIMGroupDatabase.h"
|
||||||
|
|
||||||
|
#include "Active/Database/Storage/Storage.h"
|
||||||
|
#include "Active/Serialise/UnboxedTransport.h"
|
||||||
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
|
#include "Speckle/Database/Storage/ArchicadDBase/Property/ArchicadGroupDBaseEngine.h"
|
||||||
|
#include "Speckle/Record/Property/Setting.h"
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
|
||||||
|
using namespace active::container;
|
||||||
|
using namespace active::database;
|
||||||
|
using namespace active::event;
|
||||||
|
using namespace active::serialise;
|
||||||
|
using namespace speckle::database;
|
||||||
|
using namespace speckle::record;
|
||||||
|
using namespace speckle::record::property;
|
||||||
|
using namespace speckle::database;
|
||||||
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
namespace speckle::database {
|
||||||
|
|
||||||
|
///Define other platform engines here as required
|
||||||
|
#ifdef ARCHICAD
|
||||||
|
using GroupDatabaseEngine = ArchicadGroupDBaseEngine;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
///Group database engine declaration
|
||||||
|
class BIMGroupDatabase::Engine : public GroupDatabaseEngine {
|
||||||
|
using base = ArchicadGroupDBaseEngine;
|
||||||
|
using base::base;
|
||||||
|
};
|
||||||
|
|
||||||
|
///Group database storage declaration
|
||||||
|
class BIMGroupDatabase::Store : public Storage<Group, UnboxedTransport, BIMRecordID, BIMRecordID, BIMRecordID, BIMRecordID> {
|
||||||
|
using base = Storage<Group, UnboxedTransport, BIMRecordID, BIMRecordID, BIMRecordID, BIMRecordID>;
|
||||||
|
using base::base;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
///The database storage identifier for groups
|
||||||
|
const char* groupDBaseName = "speckle::database::BIMGroupDatabase";
|
||||||
|
///The primary groups table
|
||||||
|
const char* groupTableName = "Groups";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Constructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
BIMGroupDatabase::BIMGroupDatabase() {
|
||||||
|
m_engine = std::make_shared<Engine>(groupDBaseName,
|
||||||
|
//Schema
|
||||||
|
DBaseSchema{active::utility::String{groupDBaseName},
|
||||||
|
//Tables
|
||||||
|
{
|
||||||
|
//Model group table
|
||||||
|
{
|
||||||
|
groupTableName, 0, 0, {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
m_store = std::make_shared<Store>(m_engine);
|
||||||
|
} //BIMGroupDatabase::BIMGroupDatabase
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Destructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
BIMGroupDatabase::~BIMGroupDatabase() {}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get a specified group
|
||||||
|
|
||||||
|
groupID: The ID of the target group
|
||||||
|
|
||||||
|
return: The requested group (nullptr on failure)
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
Group::Unique BIMGroupDatabase::getGroup(const BIMRecordID& groupID, std::optional<BIMRecordID> tableID,
|
||||||
|
std::optional<BIMRecordID> documentID) const {
|
||||||
|
return m_engine->getObject(groupID, tableID, documentID);
|
||||||
|
} //BIMGroupDatabase::getGroup
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get a specified group
|
||||||
|
|
||||||
|
link: A link to the target group
|
||||||
|
|
||||||
|
return: The requested group (nullptr on failure)
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
Group::Unique BIMGroupDatabase::getGroup(const BIMLink& link) const {
|
||||||
|
return getGroup(link, link.tableID, link.docID);
|
||||||
|
} //BIMGroupDatabase::getGroup
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get all groups
|
||||||
|
|
||||||
|
return: All the groups
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
Vector<Group> BIMGroupDatabase::getGroups() const {
|
||||||
|
return m_store->getObjects();
|
||||||
|
} //BIMGroupDatabase::getGroups
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Write an group to storage
|
||||||
|
|
||||||
|
group: The group to write
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMGroupDatabase::write(const Group& group) const {
|
||||||
|
m_store->write(group);
|
||||||
|
} //BIMGroupDatabase::write
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Erase an group
|
||||||
|
|
||||||
|
groupID: The ID of the group to erase
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMGroupDatabase::erase(const Guid& groupID) const {
|
||||||
|
m_store->erase(groupID);
|
||||||
|
} //BIMGroupDatabase::erase
|
||||||
@@ -0,0 +1,77 @@
|
|||||||
|
#ifndef CONNECTOR_DATABASE_BIM_GROUP_DATABASE
|
||||||
|
#define CONNECTOR_DATABASE_BIM_GROUP_DATABASE
|
||||||
|
|
||||||
|
#include "Speckle/Database/Identity/BIMLink.h"
|
||||||
|
#include "Speckle/Record/Property/Group.h"
|
||||||
|
#include "Speckle/Utility/Guid.h"
|
||||||
|
|
||||||
|
namespace active::event {
|
||||||
|
class Subscriber;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace speckle::database {
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Database of group templates relating to a specific project
|
||||||
|
|
||||||
|
Note that this database manages just the group templates, not the values. Group values are attached to elements
|
||||||
|
*/
|
||||||
|
class BIMGroupDatabase {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// MARK: - Constructors
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Constructor
|
||||||
|
*/
|
||||||
|
BIMGroupDatabase();
|
||||||
|
BIMGroupDatabase(const BIMGroupDatabase&) = delete;
|
||||||
|
/*!
|
||||||
|
Destructor
|
||||||
|
*/
|
||||||
|
~BIMGroupDatabase();
|
||||||
|
|
||||||
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Get a specified group
|
||||||
|
@param groupID The ID of the target group
|
||||||
|
@param tableID Optional table ID (defaults to the floor plan)
|
||||||
|
@param documentID Optional document ID (when the object is bound to a specific document)
|
||||||
|
@return The requested group (nullptr on failure)
|
||||||
|
*/
|
||||||
|
record::property::Group::Unique getGroup(const BIMRecordID& groupID, std::optional<BIMRecordID> tableID = std::nullopt,
|
||||||
|
std::optional<BIMRecordID> documentID = std::nullopt) const;
|
||||||
|
/*!
|
||||||
|
Get a specified group
|
||||||
|
@param link A link to the target group
|
||||||
|
@return The requested group (nullptr on failure)
|
||||||
|
*/
|
||||||
|
record::property::Group::Unique getGroup(const BIMLink& link) const;
|
||||||
|
/*!
|
||||||
|
Get all model groups
|
||||||
|
@return All the groups
|
||||||
|
*/
|
||||||
|
active::container::Vector<record::property::Group> getGroups() const;
|
||||||
|
/*!
|
||||||
|
Write an group to storage
|
||||||
|
@param group The group to write
|
||||||
|
*/
|
||||||
|
void write(const record::property::Group& group) const;
|
||||||
|
/*!
|
||||||
|
Erase an group
|
||||||
|
@param groupID The ID of the group to erase
|
||||||
|
*/
|
||||||
|
void erase(const speckle::utility::Guid& groupID) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
class Engine;
|
||||||
|
class Store;
|
||||||
|
///Model group database storage
|
||||||
|
std::shared_ptr<Engine> m_engine;
|
||||||
|
std::shared_ptr<Store> m_store;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_DATABASE_BIM_GROUP_DATABASE
|
||||||
@@ -0,0 +1,141 @@
|
|||||||
|
#include "Speckle/Database/BIMPropertyDatabase.h"
|
||||||
|
|
||||||
|
#include "Active/Database/Storage/Storage.h"
|
||||||
|
#include "Active/Serialise/UnboxedTransport.h"
|
||||||
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
|
#include "Speckle/Database/Storage/ArchicadDBase/Property/ArchicadPropertyDBaseEngine.h"
|
||||||
|
#include "Speckle/Record/Property/Setting.h"
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
|
||||||
|
using namespace active::container;
|
||||||
|
using namespace active::database;
|
||||||
|
using namespace active::event;
|
||||||
|
using namespace active::serialise;
|
||||||
|
using namespace speckle::database;
|
||||||
|
using namespace speckle::record;
|
||||||
|
using namespace speckle::record::property;
|
||||||
|
using namespace speckle::database;
|
||||||
|
using namespace speckle::utility;
|
||||||
|
|
||||||
|
namespace speckle::database {
|
||||||
|
|
||||||
|
///Define other platform engines here as required
|
||||||
|
#ifdef ARCHICAD
|
||||||
|
using PropertyDatabaseEngine = ArchicadPropertyDBaseEngine;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
///Property database engine declaration
|
||||||
|
class BIMPropertyDatabase::Engine : public PropertyDatabaseEngine {
|
||||||
|
using base = ArchicadPropertyDBaseEngine;
|
||||||
|
using base::base;
|
||||||
|
};
|
||||||
|
|
||||||
|
///Property database storage declaration
|
||||||
|
class BIMPropertyDatabase::Store : public Storage<Template, UnboxedTransport, BIMRecordID, BIMRecordID, BIMRecordID, BIMRecordID> {
|
||||||
|
using base = Storage<Template, UnboxedTransport, BIMRecordID, BIMRecordID, BIMRecordID, BIMRecordID>;
|
||||||
|
using base::base;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
///The database storage identifier for properties
|
||||||
|
const char* propertyDBaseName = "speckle::database::BIMPropertyDatabase";
|
||||||
|
///The primary properties table
|
||||||
|
const char* propertyTableName = "Properties";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Constructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
BIMPropertyDatabase::BIMPropertyDatabase() {
|
||||||
|
m_engine = std::make_shared<Engine>(propertyDBaseName,
|
||||||
|
//Schema
|
||||||
|
DBaseSchema{active::utility::String{propertyDBaseName},
|
||||||
|
//Tables
|
||||||
|
{
|
||||||
|
//Model property table
|
||||||
|
{
|
||||||
|
propertyTableName, 0, 0, {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
m_store = std::make_shared<Store>(m_engine);
|
||||||
|
} //BIMPropertyDatabase::BIMPropertyDatabase
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Destructor
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
BIMPropertyDatabase::~BIMPropertyDatabase() {}
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get a specified property
|
||||||
|
|
||||||
|
propertyID: The ID of the target property
|
||||||
|
|
||||||
|
return: The requested property (nullptr on failure)
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
Template::Unique BIMPropertyDatabase::getProperty(const BIMRecordID& propertyID, std::optional<BIMRecordID> tableID,
|
||||||
|
std::optional<BIMRecordID> documentID) const {
|
||||||
|
return m_engine->getObject(propertyID, tableID, documentID);
|
||||||
|
} //BIMPropertyDatabase::getProperty
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get a specified property
|
||||||
|
|
||||||
|
link: A link to the target property
|
||||||
|
|
||||||
|
return: The requested property (nullptr on failure)
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
Template::Unique BIMPropertyDatabase::getProperty(const BIMLink& link) const {
|
||||||
|
return getProperty(link, link.tableID, link.docID);
|
||||||
|
} //BIMPropertyDatabase::getProperty
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Get all properties
|
||||||
|
|
||||||
|
return: All the properties
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
Vector<Template> BIMPropertyDatabase::getProperties() const {
|
||||||
|
return m_store->getObjects();
|
||||||
|
} //BIMPropertyDatabase::getPropertys
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Find all property templates linked to specified classifications
|
||||||
|
|
||||||
|
classifications: The classifications
|
||||||
|
|
||||||
|
return: A list of shared pointers to linked property templates
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
std::vector<std::shared_ptr<Template>> BIMPropertyDatabase::findTemplatesByClassification(const BIMRecordIDList& classifications) const {
|
||||||
|
return m_engine->findTemplatesByClassification(classifications);
|
||||||
|
} //BIMPropertyDatabase::findTemplatesByClassification
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Write an property to storage
|
||||||
|
|
||||||
|
property: The property to write
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMPropertyDatabase::write(const Template& property) const {
|
||||||
|
m_store->write(property);
|
||||||
|
} //BIMPropertyDatabase::write
|
||||||
|
|
||||||
|
|
||||||
|
/*--------------------------------------------------------------------
|
||||||
|
Erase an property
|
||||||
|
|
||||||
|
propertyID: The ID of the property to erase
|
||||||
|
--------------------------------------------------------------------*/
|
||||||
|
void BIMPropertyDatabase::erase(const Guid& propertyID) const {
|
||||||
|
m_store->erase(propertyID);
|
||||||
|
} //BIMPropertyDatabase::erase
|
||||||
@@ -0,0 +1,83 @@
|
|||||||
|
#ifndef CONNECTOR_DATABASE_BIM_PROPERTY_DATABASE
|
||||||
|
#define CONNECTOR_DATABASE_BIM_PROPERTY_DATABASE
|
||||||
|
|
||||||
|
#include "Speckle/Database/Identity/BIMLink.h"
|
||||||
|
#include "Speckle/Record/Property/Template.h"
|
||||||
|
#include "Speckle/Utility/Guid.h"
|
||||||
|
|
||||||
|
namespace active::event {
|
||||||
|
class Subscriber;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace speckle::database {
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Database of property templates relating to a specific project
|
||||||
|
|
||||||
|
Note that this database manages just the property templates, not the values. Property values are attached to elements
|
||||||
|
*/
|
||||||
|
class BIMPropertyDatabase {
|
||||||
|
public:
|
||||||
|
|
||||||
|
// MARK: - Constructors
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Constructor
|
||||||
|
*/
|
||||||
|
BIMPropertyDatabase();
|
||||||
|
BIMPropertyDatabase(const BIMPropertyDatabase&) = delete;
|
||||||
|
/*!
|
||||||
|
Destructor
|
||||||
|
*/
|
||||||
|
~BIMPropertyDatabase();
|
||||||
|
|
||||||
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
|
/*!
|
||||||
|
Get a specified property
|
||||||
|
@param propertyID The ID of the target property
|
||||||
|
@param tableID Optional table ID (defaults to the floor plan)
|
||||||
|
@param documentID Optional document ID (when the object is bound to a specific document)
|
||||||
|
@return The requested property (nullptr on failure)
|
||||||
|
*/
|
||||||
|
record::property::Template::Unique getProperty(const BIMRecordID& propertyID, std::optional<BIMRecordID> tableID = std::nullopt,
|
||||||
|
std::optional<BIMRecordID> documentID = std::nullopt) const;
|
||||||
|
/*!
|
||||||
|
Get a specified property
|
||||||
|
@param link A link to the target property
|
||||||
|
@return The requested property (nullptr on failure)
|
||||||
|
*/
|
||||||
|
record::property::Template::Unique getProperty(const BIMLink& link) const;
|
||||||
|
/*!
|
||||||
|
Get all model properties
|
||||||
|
@return All the properties
|
||||||
|
*/
|
||||||
|
active::container::Vector<record::property::Template> getProperties() const;
|
||||||
|
/*!
|
||||||
|
Find all property templates linked to specified classifications
|
||||||
|
@param classifications The classifications
|
||||||
|
@return A list of shared pointers to linked property templates
|
||||||
|
*/
|
||||||
|
std::vector<std::shared_ptr<record::property::Template>> findTemplatesByClassification(const BIMRecordIDList& classifications) const;
|
||||||
|
/*!
|
||||||
|
Write an property to storage
|
||||||
|
@param property The property to write
|
||||||
|
*/
|
||||||
|
void write(const record::property::Template& property) const;
|
||||||
|
/*!
|
||||||
|
Erase an property
|
||||||
|
@param propertyID The ID of the property to erase
|
||||||
|
*/
|
||||||
|
void erase(const speckle::utility::Guid& propertyID) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
class Engine;
|
||||||
|
class Store;
|
||||||
|
///Model property database storage
|
||||||
|
std::shared_ptr<Engine> m_engine;
|
||||||
|
std::shared_ptr<Store> m_store;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //CONNECTOR_DATABASE_BIM_PROPERTY_DATABASE
|
||||||
@@ -62,7 +62,7 @@ namespace speckle::database {
|
|||||||
Get a link to the BIM record
|
Get a link to the BIM record
|
||||||
@return The BIM record link
|
@return The BIM record link
|
||||||
*/
|
*/
|
||||||
BIMLink getBIMLink() const { return BIMLink{ BIMLink::base{m_applicationID, m_applicationTableID} }; }
|
virtual BIMLink getBIMLink() const { return BIMLink{BIMLink::base{m_applicationID, m_applicationTableID}}; }
|
||||||
/*!
|
/*!
|
||||||
Get the record unit type
|
Get the record unit type
|
||||||
@return The record unit type (nullopt if the record has no applicable unit type)
|
@return The record unit type (nullopt if the record has no applicable unit type)
|
||||||
|
|||||||
@@ -37,13 +37,13 @@ namespace speckle::database {
|
|||||||
*/
|
*/
|
||||||
virtual ~Record() {}
|
virtual ~Record() {}
|
||||||
|
|
||||||
// MARK: - Functions (const)
|
// MARK: - Functions (const)
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
Get the speckle type identifier
|
Get the speckle type identifier
|
||||||
@return The speckle type (relevant objects should override as required, but "Base" is still considered a type on its own)
|
@return The speckle type (relevant objects should override as required, but "Base" is still considered a type on its own)
|
||||||
*/
|
*/
|
||||||
virtual speckle::utility::String getSpeckleType() const { return "speckle::database::Record"; }
|
virtual speckle::utility::String getSpeckleType() const { return "Base"; }
|
||||||
|
|
||||||
// MARK: - Functions (mutating)
|
// MARK: - Functions (mutating)
|
||||||
|
|
||||||
|
|||||||
@@ -13,6 +13,9 @@ using namespace speckle::utility;
|
|||||||
BIMLink::BIMLink(const API_Neig& selected, const BIMRecordID& tableID) : base{Guid{selected.guid}, tableID} {
|
BIMLink::BIMLink(const API_Neig& selected, const BIMRecordID& tableID) : base{Guid{selected.guid}, tableID} {
|
||||||
//More info should be extracted from API_Neig in future (as required) - extract into link settings, e.g. selection target etc
|
//More info should be extracted from API_Neig in future (as required) - extract into link settings, e.g. selection target etc
|
||||||
} //Link::Link
|
} //Link::Link
|
||||||
|
|
||||||
|
BIMLinkList::BIMLinkList(const ElementIDList& elementIDList) {
|
||||||
|
for (const auto& id : elementIDList)
|
||||||
|
push_back(id);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -4,6 +4,7 @@
|
|||||||
#include "Active/Setting/SettingList.h"
|
#include "Active/Setting/SettingList.h"
|
||||||
#include "Active/Database/Identity/Link.h"
|
#include "Active/Database/Identity/Link.h"
|
||||||
#include "Speckle/Database/Identity/BIMRecordID.h"
|
#include "Speckle/Database/Identity/BIMRecordID.h"
|
||||||
|
#include "Speckle/Database/Identity/RecordID.h"
|
||||||
|
|
||||||
namespace speckle::database {
|
namespace speckle::database {
|
||||||
|
|
||||||
@@ -41,7 +42,18 @@ namespace speckle::database {
|
|||||||
};
|
};
|
||||||
|
|
||||||
//A list of links to BIM records
|
//A list of links to BIM records
|
||||||
using BIMLinkList = std::vector<BIMLink>;
|
//using BIMLinkList = std::vector<BIMLink>;
|
||||||
|
class BIMLinkList : public std::vector<BIMLink> {
|
||||||
|
public:
|
||||||
|
|
||||||
|
using base = std::vector<BIMLink>;
|
||||||
|
|
||||||
|
using base::base;
|
||||||
|
|
||||||
|
BIMLinkList() = default;
|
||||||
|
|
||||||
|
BIMLinkList(const ElementIDList& elementIDList);
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#include "Speckle/Utility/Guid.h"
|
#include "Speckle/Utility/Guid.h"
|
||||||
|
|
||||||
|
#include <unordered_set>
|
||||||
|
|
||||||
namespace speckle::database {
|
namespace speckle::database {
|
||||||
|
|
||||||
#ifdef ARCHICAD
|
#ifdef ARCHICAD
|
||||||
@@ -14,10 +16,14 @@ namespace speckle::database {
|
|||||||
using BIMDocID = speckle::utility::Guid;
|
using BIMDocID = speckle::utility::Guid;
|
||||||
//Common BIM database identifier type (e.g. model database, library database, attribute database)
|
//Common BIM database identifier type (e.g. model database, library database, attribute database)
|
||||||
using BIMDBaseID = speckle::utility::Guid;
|
using BIMDBaseID = speckle::utility::Guid;
|
||||||
|
//Common BIM record identifier pair type (e.g. pairing a record with a parent)
|
||||||
|
using BIMRecordIDPair = std::pair<speckle::utility::Guid, speckle::utility::Guid>;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//A list of BIM record IDs
|
//A list of BIM record IDs
|
||||||
using BIMRecordIDList = std::vector<BIMRecordID>;
|
using BIMRecordIDList = std::unordered_set<BIMRecordID>;
|
||||||
|
//A list of BIM record ID pairs
|
||||||
|
using BIMRecordIDPairList = std::unordered_set<BIMRecordIDPair>;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
#define SPECKLE_DATABASE_ID
|
#define SPECKLE_DATABASE_ID
|
||||||
|
|
||||||
#include "Speckle/Utility/String.h"
|
#include "Speckle/Utility/String.h"
|
||||||
|
#include "Speckle/Utility/Guid.h"
|
||||||
|
|
||||||
namespace speckle::database {
|
namespace speckle::database {
|
||||||
|
|
||||||
@@ -14,6 +15,12 @@ namespace speckle::database {
|
|||||||
|
|
||||||
//A list of record IDs
|
//A list of record IDs
|
||||||
using RecordIDList = std::vector<RecordID>;
|
using RecordIDList = std::vector<RecordID>;
|
||||||
|
|
||||||
|
//BIM element record identifier
|
||||||
|
using ElementID = speckle::utility::Guid;
|
||||||
|
|
||||||
|
//A list of element IDs
|
||||||
|
using ElementIDList = std::vector<ElementID>;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,6 @@
|
|||||||
#include "Active/Setting/SettingList.h"
|
#include "Active/Setting/SettingList.h"
|
||||||
#include "Active/Database/Storage/DBaseSchema.h"
|
#include "Active/Database/Storage/DBaseSchema.h"
|
||||||
#include "Active/Utility/NameID.h"
|
#include "Active/Utility/NameID.h"
|
||||||
#include "Speckle/Event/Subscriber/DocStoreSubscriber.h"
|
|
||||||
#include "Speckle/Event/Subscriber/ProjectSubscriber.h"
|
#include "Speckle/Event/Subscriber/ProjectSubscriber.h"
|
||||||
|
|
||||||
namespace speckle::database {
|
namespace speckle::database {
|
||||||
@@ -19,7 +18,7 @@ namespace speckle::database {
|
|||||||
|
|
||||||
Currently implement for Archicad Add-On Objects
|
Currently implement for Archicad Add-On Objects
|
||||||
*/
|
*/
|
||||||
class ArchicadDBaseCore {
|
class ArchicadDBaseCore : public event::ProjectSubscriber {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// MARK: - Types
|
// MARK: - Types
|
||||||
@@ -69,8 +68,12 @@ namespace speckle::database {
|
|||||||
|
|
||||||
// MARK: - Functions (mutating)
|
// MARK: - Functions (mutating)
|
||||||
|
|
||||||
protected:
|
/*!
|
||||||
|
Handle a project event
|
||||||
|
@param event The project event
|
||||||
|
@return True if the event should be closed
|
||||||
|
*/
|
||||||
|
bool handle(const event::ProjectEvent& event) override { return false; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
///The database schema
|
///The database schema
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user