diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
index d5626c8b3..f92377b1d 100644
--- a/.github/workflows/build.yml
+++ b/.github/workflows/build.yml
@@ -384,3 +384,121 @@ jobs:
test-package-base-name: "CesiumForUnreal-54"
visual-studio-version: "2022"
visual-studio-components: "Microsoft.VisualStudio.Component.VC.14.34.17.4.x86.x64,Microsoft.VisualStudio.Component.Windows10SDK.18362"
+ Windows55:
+ uses: ./.github/workflows/buildWindows.yml
+ secrets: inherit
+ with:
+ runner-label: "windows-2022"
+ unreal-engine-version: "5.5.0"
+ unreal-engine-zip: "s3://cesium-unreal-engine/5.5.0/UE_5.5.zip"
+ unreal-program-name: "UE_5.5"
+ upload-package-base-name: "CesiumForUnreal-55-windows"
+ # These are specified in the Unreal Engine release notes under "IDE Version the Build farm compiles against"
+ # and using them ensures we're compiling our plugin in the exact same way that Unreal Engine itself is compiled.
+ cmake-generator: "Visual Studio 17 2022"
+ cmake-toolchain: "version=14.38"
+ cmake-platform: "x64,version=10.0.22621.0"
+ visual-studio-version: "2022"
+ visual-studio-components: "Microsoft.VisualStudio.Component.VC.14.38.17.8.x86.x64,Microsoft.VisualStudio.Component.Windows11SDK.22621"
+ TestWindows55:
+ needs: [Windows55]
+ uses: ./.github/workflows/testWindows.yml
+ secrets: inherit
+ with:
+ runner-label: windows-2022
+ unreal-engine-zip: "s3://cesium-unreal-engine/5.5.0/UE_5.5.zip"
+ unreal-program-name: "UE_5.5"
+ test-package-base-name: "CesiumForUnreal-55-windows"
+ Android55:
+ uses: ./.github/workflows/buildAndroid.yml
+ secrets: inherit
+ with:
+ runner-label: windows-2022
+ unreal-engine-version: "5.5.0"
+ unreal-engine-zip: "s3://cesium-unreal-engine/5.5.0/UE_5.5.zip"
+ unreal-program-name: "UE_5.5"
+ upload-package-base-name: "CesiumForUnreal-55-android"
+ android-ndk-version: "r25b"
+ Linux55:
+ uses: ./.github/workflows/buildLinux.yml
+ secrets: inherit
+ with:
+ runner-label: ubuntu-22.04
+ unreal-engine-version: "5.5.0"
+ unreal-engine-zip: "s3://cesium-unreal-engine/5.5.0/Linux_Unreal_Engine_5.5.0.zip"
+ unreal-program-name: "UE_5.5"
+ upload-package-base-name: "CesiumForUnreal-55-linux"
+ clang-version: "v23_clang-18.1.0-rockylinux8"
+ Apple55:
+ uses: ./.github/workflows/buildApple.yml
+ secrets: inherit
+ with:
+ runner-label: macos-14
+ unreal-engine-version: "5.5.0"
+ unreal-engine-zip: "s3://cesium-unreal-engine/5.5.0/UE_55_macOS.zip"
+ unreal-program-name: "UE_5.5"
+ upload-package-base-name: "CesiumForUnreal-55-apple"
+ xcode-version: "15.4"
+ Combine55:
+ runs-on: ubuntu-latest
+ needs: [Windows55, Android55, Linux55, Apple55]
+ steps:
+ - name: Check out repository code
+ uses: actions/checkout@v4
+ - name: Set environment variables
+ run: |
+ export CESIUM_UNREAL_VERSION=$GITHUB_REF_NAME
+ export BUILD_CESIUM_UNREAL_PACKAGE_NAME="CesiumForUnreal-55-${CESIUM_UNREAL_VERSION}"
+ export BUILD_CESIUM_UNREAL_SOURCE_ONLY_PACKAGE_NAME="CesiumForUnreal-55-SourceOnly-${CESIUM_UNREAL_VERSION}"
+ # Make these available to subsequent steps
+ echo "CESIUM_UNREAL_VERSION=$CESIUM_UNREAL_VERSION" >> $GITHUB_ENV
+ echo "BUILD_CESIUM_UNREAL_PACKAGE_NAME=$BUILD_CESIUM_UNREAL_PACKAGE_NAME" >> $GITHUB_ENV
+ echo "BUILD_CESIUM_UNREAL_SOURCE_ONLY_PACKAGE_NAME=$BUILD_CESIUM_UNREAL_SOURCE_ONLY_PACKAGE_NAME" >> $GITHUB_ENV
+ - name: Download Apple build
+ uses: actions/download-artifact@v4
+ with:
+ name: CesiumForUnreal-55-apple-${{ env.CESIUM_UNREAL_VERSION}}
+ path: combine
+ - name: Download Android build
+ uses: actions/download-artifact@v4
+ with:
+ name: CesiumForUnreal-55-android-${{ env.CESIUM_UNREAL_VERSION}}
+ path: combine
+ - name: Download Linux build
+ uses: actions/download-artifact@v4
+ with:
+ name: CesiumForUnreal-55-linux-${{ env.CESIUM_UNREAL_VERSION}}
+ path: combine
+ - name: Download Windows build
+ uses: actions/download-artifact@v4
+ with:
+ name: CesiumForUnreal-55-windows-${{ env.CESIUM_UNREAL_VERSION}}
+ path: combine
+ - name: Publish combined package artifact
+ if: ${{ success() }}
+ uses: actions/upload-artifact@v4
+ with:
+ name: ${{ env.BUILD_CESIUM_UNREAL_PACKAGE_NAME}}
+ path: combine
+ - name: Publish combined package artifact for the Unreal Marketplace
+ if: ${{ success() }}
+ uses: actions/upload-artifact@v4
+ with:
+ name: ${{ env.BUILD_CESIUM_UNREAL_SOURCE_ONLY_PACKAGE_NAME}}
+ path: |
+ combine
+ # These are built by Epic, and including them seems to confuse their process.
+ !combine/CesiumForUnreal/Binaries/**/*
+ !combine/CesiumForUnreal/Intermediate/**/*
+ TestPackage55:
+ needs: [Combine55]
+ uses: ./.github/workflows/testPackageOnWindows.yml
+ secrets: inherit
+ with:
+ runner-label: windows-2022
+ unreal-engine-zip: "s3://cesium-unreal-engine/5.5.0/UE_5.5.zip"
+ unreal-program-name: "UE_5.5"
+ unreal-engine-association: "5.5"
+ test-package-base-name: "CesiumForUnreal-55"
+ visual-studio-version: "2022"
+ visual-studio-components: "Microsoft.VisualStudio.Component.VC.14.38.17.8.x86.x64,Microsoft.VisualStudio.Component.Windows11SDK.22621"
diff --git a/.github/workflows/buildApple.yml b/.github/workflows/buildApple.yml
index 157b6d268..86b1173b3 100644
--- a/.github/workflows/buildApple.yml
+++ b/.github/workflows/buildApple.yml
@@ -25,6 +25,15 @@ jobs:
build:
runs-on: ${{ inputs.runner-label }}
steps:
+ - name: Customize BuildConfiguration.xml
+ run: |
+ mkdir -p ~/.config/Unreal\ Engine/UnrealBuildTool
+ # - We limit parallel actions because our builds use a lot more memory than UBT thinks they will.
+ # - We set the source code control Provider to None so UBT includes all files in the unity build.
+ printf '\n\n \n 2\n \n None\n\n' > ~/.config/Unreal\ Engine/UnrealBuildTool/BuildConfiguration.xml
+ # In UE 5.5, UBT apparently loads from ~/Documents instead of ~/.config
+ mkdir -p ~/Documents/Unreal\ Engine/UnrealBuildTool
+ cp ~/.config/Unreal\ Engine/UnrealBuildTool/BuildConfiguration.xml ~/Documents/Unreal\ Engine/UnrealBuildTool/BuildConfiguration.xml
- name: Make some more disk space
run: |
df -h
@@ -121,12 +130,6 @@ jobs:
- name: Remove extern directory
run: |
rm -rf extern
- - name: Customize BuildConfiguration.xml
- run: |
- mkdir -p ~/.config/Unreal\ Engine/UnrealBuildTool
- # - We limit parallel actions because our builds use a lot more memory than UBT thinks they will.
- # - We set the source code control Provider to None so UBT includes all files in the unity build.
- printf '\n\n \n 2\n \n None\n\n' > ~/.config/Unreal\ Engine/UnrealBuildTool/BuildConfiguration.xml
- name: Build plugin for macOS and iOS
run: |
sed -i '' 's/\"EngineVersion\": \"5.2.0\"/\"EngineVersion\": \"${{ inputs.unreal-engine-version }}\"/g' CesiumForUnreal.uplugin
diff --git a/.github/workflows/buildLinux.yml b/.github/workflows/buildLinux.yml
index 11a83db52..9ddea5628 100644
--- a/.github/workflows/buildLinux.yml
+++ b/.github/workflows/buildLinux.yml
@@ -34,10 +34,12 @@ jobs:
sudo swapon --show
cat /proc/meminfo
apt list --installed
+ sudo dpkg-query -Wf '${Installed-Size}\t${Package}\n' | sort -n
+ sudo snap list
- name: Removed unneeded packages to gain disk space
run: |
sudo apt update
- sudo apt remove google-chrome-stable clang-13 clang-14 clang-15 llvm-13-dev llvm-13-linker-tools llvm-13-runtime llvm-13-tools llvm-13 llvm-14-dev llvm-14-linker-tools llvm-14-runtime llvm-14-tools llvm-14 llvm-15-dev llvm-15-linker-tools llvm-15-runtime llvm-15-tools llvm-15 x11-common xserver-common aspnetcore-runtime-6.0 aspnetcore-runtime-7.0 aspnetcore-runtime-8.0 aspnetcore-targeting-pack-6.0 aspnetcore-targeting-pack-7.0 aspnetcore-targeting-pack-8.0 docker-ce-cli docker-ce dotnet-apphost-pack-6.0 dotnet-apphost-pack-7.0 dotnet-apphost-pack-8.0 dotnet-host dotnet-hostfxr-6.0 dotnet-hostfxr-7.0 dotnet-hostfxr-8.0 dotnet-runtime-6.0 dotnet-runtime-7.0 dotnet-runtime-8.0 dotnet-runtime-deps-6.0 dotnet-runtime-deps-7.0 dotnet-runtime-deps-8.0 dotnet-sdk-6.0 dotnet-sdk-7.0 dotnet-sdk-8.0 dotnet-targeting-pack-6.0 dotnet-targeting-pack-7.0 dotnet-targeting-pack-8.0 eatmydata emacsen-common firebird3.0-common-doc firebird3.0-common firefox kubectl mercurial-common mercurial microsoft-edge-stable mssql-tools mysql-client-8.0 mysql-client-core-8.0 mysql-client mysql-common mysql-server-8.0 php8.1 postgresql-14
+ sudo apt remove google-chrome-stable clang-13 clang-14 clang-15 llvm-13-dev llvm-13-linker-tools llvm-13-runtime llvm-13-tools llvm-13 llvm-14-dev llvm-14-linker-tools llvm-14-runtime llvm-14-tools llvm-14 llvm-15-dev llvm-15-linker-tools llvm-15-runtime llvm-15-tools llvm-15 x11-common xserver-common aspnetcore-runtime-6.0 aspnetcore-runtime-7.0 aspnetcore-runtime-8.0 aspnetcore-targeting-pack-6.0 aspnetcore-targeting-pack-7.0 aspnetcore-targeting-pack-8.0 docker-ce-cli docker-ce dotnet-apphost-pack-6.0 dotnet-apphost-pack-7.0 dotnet-apphost-pack-8.0 dotnet-host dotnet-hostfxr-6.0 dotnet-hostfxr-7.0 dotnet-hostfxr-8.0 dotnet-runtime-6.0 dotnet-runtime-7.0 dotnet-runtime-8.0 dotnet-runtime-deps-6.0 dotnet-runtime-deps-7.0 dotnet-runtime-deps-8.0 dotnet-sdk-6.0 dotnet-sdk-7.0 dotnet-sdk-8.0 dotnet-targeting-pack-6.0 dotnet-targeting-pack-7.0 dotnet-targeting-pack-8.0 eatmydata emacsen-common firebird3.0-common-doc firebird3.0-common firefox kubectl mercurial-common mercurial microsoft-edge-stable mssql-tools mysql-client-8.0 mysql-client-core-8.0 mysql-client mysql-common mysql-server-8.0 php8.1 postgresql-14 azure-cli microsoft-edge-stable google-cloud-cli temurin-21-jdk temurin-17-jdk temurin-11-jdk temurin-8-jdk powershell google-cloud-cli-anthoscli mysql-server-core-8.0 containerd.io libllvm15 libllvm14 libllvm13 mono-devel libclang-common-15-dev libclang-common-14-dev libclang-common-13-dev
df -h
- name: Create some space to work in /mnt
run: |
diff --git a/CHANGES.md b/CHANGES.md
index 760195366..f3f8b5d62 100644
--- a/CHANGES.md
+++ b/CHANGES.md
@@ -2,8 +2,11 @@
### ? - 2024-12-02
+This is the last release of Cesium for Unreal that will support Unreal Engine v5.2. Future versions will require Unreal Engine v5.3+.
+
##### Additions :tada:
+- Added support for Unreal Engine 5.5.
- Added a "From Ellipsoid" option to `Cesium3DTileset` to generate a tileset by tesselating the surface of the ellipsoid, producing a simple globe tileset without terrain features.
##### Fixes :wrench:
diff --git a/Shaders/Private/CesiumPointAttenuationVertexFactory.ush b/Shaders/Private/CesiumPointAttenuationVertexFactory.ush
index 6574e9c04..c48406820 100644
--- a/Shaders/Private/CesiumPointAttenuationVertexFactory.ush
+++ b/Shaders/Private/CesiumPointAttenuationVertexFactory.ush
@@ -4,6 +4,14 @@
CesiumPointAttenuationVertexFactory.ush: point attenuation vertex factory shader code.
=============================================================================*/
+#ifndef ENGINE_VERSION_5_4_OR_HIGHER
+#define ENGINE_VERSION_5_4_OR_HIGHER 0
+#endif
+
+#ifndef ENGINE_VERSION_5_5_OR_HIGHER
+#define ENGINE_VERSION_5_5_OR_HIGHER 0
+#endif
+
#include "/Engine/Private/Common.ush"
#include "/Engine/Private/VertexFactoryCommon.ush"
@@ -40,7 +48,7 @@ struct FVertexFactoryInput
#endif
};
-/**
+/**
* Per-vertex inputs. Used by passes with a trimmed down position-only shader.
*/
struct FPositionOnlyVertexFactoryInput
@@ -54,7 +62,7 @@ struct FPositionOnlyVertexFactoryInput
#endif
};
-/**
+/**
* Per-vertex inputs. Used by passes with a trimmed down position-and-normal-only shader.
*/
struct FPositionAndNormalOnlyVertexFactoryInput
@@ -83,7 +91,7 @@ struct FVertexFactoryIntermediates
half TangentToWorldSign;
half4 Color;
-
+
/** Cached primitive and instance data */
FSceneDataIntermediates SceneData;
};
@@ -119,7 +127,7 @@ half3x3 CalculateTangentToLocal(uint PointIndex, out float TangentSign)
{
half3 TangentInputX = PackedTangentsBuffer[2 * PointIndex + 0].xyz;
half4 TangentInputZ = PackedTangentsBuffer[2 * PointIndex + 1].xyzw;
-
+
half3 TangentX = TangentBias(TangentInputX);
half4 TangentZ = TangentBias(TangentInputZ);
@@ -127,7 +135,7 @@ half3x3 CalculateTangentToLocal(uint PointIndex, out float TangentSign)
// Derive the binormal by getting the cross product of the normal and tangent
half3 TangentY = cross(TangentZ.xyz, TangentX) * TangentZ.w;
-
+
// Recalculate TangentX off of the other two vectors
// This corrects quantization errors since TangentX was passed in as a quantized vertex input
half3x3 Result;
@@ -158,7 +166,7 @@ FVertexFactoryIntermediates GetVertexFactoryIntermediates(FVertexFactoryInput In
{
FVertexFactoryIntermediates Intermediates = (FVertexFactoryIntermediates)0;
Intermediates.SceneData = VF_GPUSCENE_GET_INTERMEDIATES(Input);
-
+
uint PointIndex = Input.VertexId / 4;
uint CornerIndex = Input.VertexId - (PointIndex * 4);
@@ -213,19 +221,19 @@ FVertexFactoryInterpolantsVSToPS VertexFactoryGetInterpolantsVSToPS(
Interpolants.TangentToWorld0 = float4(Intermediates.TangentToWorld[0], 0);
Interpolants.TangentToWorld2 = float4(Intermediates.TangentToWorld[2], Intermediates.TangentToWorldSign);
Interpolants.Color = Intermediates.Color;
-
+
#if NUM_TEX_COORD_INTERPOLATORS
float2 CustomizedUVs[NUM_TEX_COORD_INTERPOLATORS];
GetMaterialCustomizedUVs(VertexParameters, CustomizedUVs);
GetCustomInterpolators(VertexParameters, CustomizedUVs);
-
+
UNROLL
for (int CoordinateIndex = 0; CoordinateIndex < NUM_TEX_COORD_INTERPOLATORS; CoordinateIndex++)
{
SetUV(Interpolants, CoordinateIndex, CustomizedUVs[CoordinateIndex]);
}
#endif
-
+
#if INSTANCED_STEREO
Interpolants.EyeIndex = 0;
#endif
@@ -253,6 +261,13 @@ float4 VertexFactoryGetWorldPosition(FPositionAndNormalOnlyVertexFactoryInput In
return GetWorldPosition(Input.VertexId);
}
+// local position relative to instance
+float3 VertexFactoryGetInstanceSpacePosition(FVertexFactoryInput Input, FVertexFactoryIntermediates Intermediates)
+{
+ // No support for instancing, so instance == primitive
+ return Intermediates.Position;
+}
+
float3 VertexFactoryGetWorldNormal(FPositionAndNormalOnlyVertexFactoryInput Input)
{
float3 PointNormal = GetPointNormal(Input.VertexId);
@@ -275,6 +290,13 @@ float4 VertexFactoryGetPreviousWorldPosition(FVertexFactoryInput Input, FVertexF
#endif
}
+// local position relative to instance
+float3 VertexFactoryGetPreviousInstanceSpacePosition(FVertexFactoryInput Input, FVertexFactoryIntermediates Intermediates)
+{
+ // No support for instancing, so instance == primitive
+ return Intermediates.Position;
+}
+
float4 ApplyAttenuation(float4 WorldPosition, uint CornerIndex) {
// These offsets generate the quad like so:
// 1 --- 2
@@ -333,10 +355,24 @@ FMaterialVertexParameters GetMaterialVertexParameters(
FVertexFactoryInput Input,
FVertexFactoryIntermediates Intermediates,
float3 WorldPosition,
- half3x3 TangentToLocal)
+ half3x3 TangentToLocal,
+ bool bIsPreviousFrame = false)
{
+#if ENGINE_VERSION_5_5_OR_HIGHER
+ FMaterialVertexParameters Result = MakeInitializedMaterialVertexParameters();
+ if (bIsPreviousFrame)
+ {
+ Result.PositionInstanceSpace = VertexFactoryGetPreviousInstanceSpacePosition(Input, Intermediates);
+ }
+ else
+ {
+ Result.PositionInstanceSpace = VertexFactoryGetInstanceSpacePosition(Input, Intermediates);
+ }
+ Result.PositionPrimitiveSpace = Result.PositionInstanceSpace; // No support for instancing, so instance == primitive
+#else
FMaterialVertexParameters Result = (FMaterialVertexParameters)0;
-
+#endif
+
Result.SceneData = Intermediates.SceneData;
Result.WorldPosition = WorldPosition;
Result.TangentToWorld = Intermediates.TangentToWorld;
@@ -354,6 +390,10 @@ FMaterialVertexParameters GetMaterialVertexParameters(
}
#endif
+#if ENGINE_VERSION_5_4_OR_HIGHER
+ Result.LWCData = MakeMaterialLWCData(Result);
+#endif
+
return Result;
}
@@ -439,7 +479,7 @@ FVertexFactoryRayTracingInterpolants VertexFactoryInterpolate(
float bInterp)
{
FVertexFactoryRayTracingInterpolants O;
-
+
INTERPOLATE_MEMBER(InterpolantsVSToPS.TangentToWorld0.xyz);
INTERPOLATE_MEMBER(InterpolantsVSToPS.TangentToWorld2);
diff --git a/Source/CesiumRuntime/Private/Cesium3DTileset.cpp b/Source/CesiumRuntime/Private/Cesium3DTileset.cpp
index 4bf046a1b..28f6ea89b 100644
--- a/Source/CesiumRuntime/Private/Cesium3DTileset.cpp
+++ b/Source/CesiumRuntime/Private/Cesium3DTileset.cpp
@@ -2178,9 +2178,6 @@ void ACesium3DTileset::Tick(float DeltaTime) {
updateTilesetOptionsFromProperties();
std::vector cameras = this->GetCameras();
- if (cameras.empty()) {
- return;
- }
glm::dmat4 ueTilesetToUeWorld =
VecMath::createMatrix4D(this->GetActorTransform().ToMatrixWithScale());
diff --git a/Source/CesiumRuntime/Private/CesiumBingMapsRasterOverlay.cpp b/Source/CesiumRuntime/Private/CesiumBingMapsRasterOverlay.cpp
index a538e8c69..bcc7c0046 100644
--- a/Source/CesiumRuntime/Private/CesiumBingMapsRasterOverlay.cpp
+++ b/Source/CesiumRuntime/Private/CesiumBingMapsRasterOverlay.cpp
@@ -43,6 +43,5 @@ UCesiumBingMapsRasterOverlay::CreateOverlay(
TCHAR_TO_UTF8(*this->BingMapsKey),
mapStyle,
"",
- CesiumGeospatial::Ellipsoid::WGS84,
options);
}
diff --git a/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.cpp b/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.cpp
index 9528d8734..6c18d36d8 100644
--- a/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.cpp
+++ b/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.cpp
@@ -524,13 +524,13 @@ EncodedPropertyTable encodePropertyTableAnyThreadPart(
CesiumEncodedMetadataParseColorFromString::encode(
*pDescription,
property,
- gsl::span(pImage->pixelData),
+ std::span(pImage->pixelData),
encodedFormat.bytesPerChannel * encodedFormat.channels);
} else /* info.Conversion == ECesiumEncodedMetadataConversion::Coerce */ {
CesiumEncodedMetadataCoerce::encode(
*pDescription,
property,
- gsl::span(pImage->pixelData),
+ std::span(pImage->pixelData),
encodedFormat.bytesPerChannel * encodedFormat.channels);
}
diff --git a/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.h b/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.h
index 0bb838505..45f3ece2b 100644
--- a/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.h
+++ b/Source/CesiumRuntime/Private/CesiumEncodedFeaturesMetadata.h
@@ -11,6 +11,7 @@
#include "Templates/SharedPointer.h"
#include "Templates/UniquePtr.h"
#include
+#include
#include
struct FCesiumFeatureIdSet;
diff --git a/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.cpp b/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.cpp
index 3384878a2..7ac5a7b4b 100644
--- a/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.cpp
+++ b/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.cpp
@@ -135,7 +135,7 @@ template
void coerceAndEncodeArrays(
const FCesiumPropertyTablePropertyDescription& propertyDescription,
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize) {
int64 propertySize =
UCesiumPropertyTablePropertyBlueprintLibrary::GetPropertySize(property);
@@ -180,7 +180,7 @@ void coerceAndEncodeArrays(
template
void coerceAndEncodeScalars(
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData) {
+ const std::span& textureData) {
int64 propertySize =
UCesiumPropertyTablePropertyBlueprintLibrary::GetPropertySize(property);
if (textureData.size() < propertySize * sizeof(T)) {
@@ -208,7 +208,7 @@ void coerceAndEncodeScalars(
template
void coerceAndEncodeVec2s(
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize) {
int64 propertySize =
UCesiumPropertyTablePropertyBlueprintLibrary::GetPropertySize(property);
@@ -254,7 +254,7 @@ void coerceAndEncodeVec2s(
template
void coerceAndEncodeVec3s(
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize) {
int64 propertySize =
UCesiumPropertyTablePropertyBlueprintLibrary::GetPropertySize(property);
@@ -298,7 +298,7 @@ void coerceAndEncodeVec3s(
template
void coerceAndEncodeVec4s(
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize) {
int64 propertySize =
UCesiumPropertyTablePropertyBlueprintLibrary::GetPropertySize(property);
@@ -383,7 +383,7 @@ bool CesiumEncodedMetadataCoerce::canEncode(
void CesiumEncodedMetadataCoerce::encode(
const FCesiumPropertyTablePropertyDescription& propertyDescription,
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize) {
if (propertyDescription.PropertyDetails.bIsArray) {
if (propertyDescription.EncodingDetails.ComponentType ==
@@ -497,7 +497,7 @@ glm::u8vec3 getRgbColorFromString(const FString& rgbString) {
template
void parseAndEncodeColors(
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize) {
int64 propertySize =
UCesiumPropertyTablePropertyBlueprintLibrary::GetPropertySize(property);
@@ -555,7 +555,7 @@ bool CesiumEncodedMetadataParseColorFromString::canEncode(
void CesiumEncodedMetadataParseColorFromString::encode(
const FCesiumPropertyTablePropertyDescription& propertyDescription,
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize) {
if (propertyDescription.EncodingDetails.ComponentType ==
ECesiumEncodedMetadataComponentType::Uint8) {
diff --git a/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.h b/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.h
index 09ad5fb60..d3ed133e6 100644
--- a/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.h
+++ b/Source/CesiumRuntime/Private/CesiumEncodedMetadataConversions.h
@@ -3,7 +3,7 @@
#pragma once
#include "HAL/Platform.h"
-#include
+#include
enum class ECesiumMetadataType : uint8;
enum class ECesiumEncodedMetadataType : uint8;
@@ -80,7 +80,7 @@ struct CesiumEncodedMetadataCoerce {
static void encode(
const FCesiumPropertyTablePropertyDescription& propertyDescription,
const FCesiumPropertyTableProperty& property,
- const gsl::span& pTextureData,
+ const std::span& pTextureData,
size_t pixelSize);
};
@@ -113,6 +113,6 @@ struct CesiumEncodedMetadataParseColorFromString {
static void encode(
const FCesiumPropertyTablePropertyDescription& propertyDescription,
const FCesiumPropertyTableProperty& property,
- const gsl::span& textureData,
+ const std::span& textureData,
size_t pixelSize);
};
diff --git a/Source/CesiumRuntime/Private/CesiumGltfComponent.cpp b/Source/CesiumRuntime/Private/CesiumGltfComponent.cpp
index b2781a59a..c502adb2a 100644
--- a/Source/CesiumRuntime/Private/CesiumGltfComponent.cpp
+++ b/Source/CesiumRuntime/Private/CesiumGltfComponent.cpp
@@ -1715,6 +1715,12 @@ static void loadPrimitive(
LODResources.bHasReversedIndices = false;
LODResources.bHasReversedDepthOnlyIndices = false;
+#if ENGINE_VERSION_5_5_OR_HIGHER
+ // UE 5.5 requires that we do this in order to avoid a crash when ray tracing
+ // is enabled.
+ RenderData->InitializeRayTracingRepresentationFromRenderingLODs();
+#endif
+
primitiveResult.meshIndex = options.pMeshOptions->meshIndex;
primitiveResult.primitiveIndex = options.primitiveIndex;
primitiveResult.RenderData = std::move(RenderData);
@@ -3387,6 +3393,10 @@ void UCesiumGltfComponent::AttachRasterTile(
EMaterialParameterAssociation::LayerParameter,
i),
translationAndScale);
+ check(
+ textureCoordinateID >= 0 &&
+ textureCoordinateID <
+ primData.overlayTextureCoordinateIDToUVIndex.size());
pMaterial->SetScalarParameterValueByInfo(
FMaterialParameterInfo(
"TextureCoordinateIndex",
diff --git a/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.cpp b/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.cpp
index dcf34fcbc..3e887424d 100644
--- a/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.cpp
+++ b/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.cpp
@@ -171,6 +171,19 @@ bool FCesiumPointAttenuationVertexFactory::ShouldCompilePermutation(
Parameters.MaterialParameters.bIsSpecialEngineMaterial;
}
+void FCesiumPointAttenuationVertexFactory::ModifyCompilationEnvironment(
+ const FVertexFactoryShaderPermutationParameters& Parameters,
+ FShaderCompilerEnvironment& OutEnvironment) {
+ FLocalVertexFactory::ModifyCompilationEnvironment(Parameters, OutEnvironment);
+#if ENGINE_VERSION_5_4_OR_HIGHER
+ OutEnvironment.SetDefine(TEXT("ENGINE_VERSION_5_4_OR_HIGHER"), TEXT("1"));
+#endif
+
+#if ENGINE_VERSION_5_5_OR_HIGHER
+ OutEnvironment.SetDefine(TEXT("ENGINE_VERSION_5_5_OR_HIGHER"), TEXT("1"));
+#endif
+}
+
void FCesiumPointAttenuationVertexFactory::INIT_RHI_SIGNATURE {
FVertexDeclarationElementList Elements;
Elements.Add(AccessStreamComponent(
diff --git a/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.h b/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.h
index 2afe0cab6..0b09a7900 100644
--- a/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.h
+++ b/Source/CesiumRuntime/Private/CesiumPointAttenuationVertexFactory.h
@@ -70,6 +70,10 @@ class FCesiumPointAttenuationVertexFactory : public FLocalVertexFactory {
static bool ShouldCompilePermutation(
const FVertexFactoryShaderPermutationParameters& Parameters);
+ static void ModifyCompilationEnvironment(
+ const FVertexFactoryShaderPermutationParameters& Parameters,
+ FShaderCompilerEnvironment& OutEnvironment);
+
private:
virtual void INIT_RHI_SIGNATURE override;
virtual void ReleaseRHI() override;
diff --git a/Source/CesiumRuntime/Private/CesiumSunSky.cpp b/Source/CesiumRuntime/Private/CesiumSunSky.cpp
index 6d24f79c7..4f09410e8 100644
--- a/Source/CesiumRuntime/Private/CesiumSunSky.cpp
+++ b/Source/CesiumRuntime/Private/CesiumSunSky.cpp
@@ -224,6 +224,8 @@ void ACesiumSunSky::EndPlay(const EEndPlayReason::Type EndPlayReason) {
this->_transformUpdatedSubscription);
this->_transformUpdatedSubscription.Reset();
}
+
+ Super::EndPlay(EndPlayReason);
}
void ACesiumSunSky::Serialize(FArchive& Ar) {
diff --git a/Source/CesiumRuntime/Private/CesiumWebMapTileServiceRasterOverlay.cpp b/Source/CesiumRuntime/Private/CesiumWebMapTileServiceRasterOverlay.cpp
index bd9a63fed..ecefeca4c 100644
--- a/Source/CesiumRuntime/Private/CesiumWebMapTileServiceRasterOverlay.cpp
+++ b/Source/CesiumRuntime/Private/CesiumWebMapTileServiceRasterOverlay.cpp
@@ -57,8 +57,7 @@ UCesiumWebMapTileServiceRasterOverlay::CreateOverlay(
wmtsOptions.tileWidth = this->TileWidth;
wmtsOptions.tileHeight = this->TileHeight;
- const CesiumGeospatial::Ellipsoid& ellipsoid =
- options.ellipsoid.value_or(CesiumGeospatial::Ellipsoid::WGS84);
+ const CesiumGeospatial::Ellipsoid& ellipsoid = options.ellipsoid;
if (this->Projection ==
ECesiumWebMapTileServiceRasterOverlayProjection::Geographic) {
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumCameraManager.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumCameraManager.spec.cpp
index f1372ef20..a852d540c 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumCameraManager.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumCameraManager.spec.cpp
@@ -8,7 +8,9 @@
BEGIN_DEFINE_SPEC(
FCesiumCameraManagerSpec,
"Cesium.Unit.CameraManager",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
END_DEFINE_SPEC(FCesiumCameraManagerSpec)
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdAttribute.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdAttribute.spec.cpp
index 4cb47a251..0abfb1ca8 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdAttribute.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdAttribute.spec.cpp
@@ -8,7 +8,9 @@
BEGIN_DEFINE_SPEC(
FCesiumFeatureIdAttributeSpec,
"Cesium.Unit.FeatureIdAttribute",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
CesiumGltf::Model model;
CesiumGltf::MeshPrimitive* pPrimitive;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdSet.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdSet.spec.cpp
index 881fe1d0c..7da2be043 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdSet.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdSet.spec.cpp
@@ -10,7 +10,9 @@
BEGIN_DEFINE_SPEC(
FCesiumFeatureIdSetSpec,
"Cesium.Unit.FeatureIdSet",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
CesiumGltf::Model model;
CesiumGltf::MeshPrimitive* pPrimitive;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdTexture.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdTexture.spec.cpp
index 370dd3688..982d475a6 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdTexture.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumFeatureIdTexture.spec.cpp
@@ -11,7 +11,9 @@
BEGIN_DEFINE_SPEC(
FCesiumFeatureIdTextureSpec,
"Cesium.Unit.FeatureIdTexture",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
CesiumGltf::Model model;
CesiumGltf::MeshPrimitive* pPrimitive;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumGeoreference.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumGeoreference.spec.cpp
index 779b24cb0..754b26e42 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumGeoreference.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumGeoreference.spec.cpp
@@ -13,7 +13,9 @@ using namespace CesiumUtility;
BEGIN_DEFINE_SPEC(
FCesiumGeoreferenceSpec,
"Cesium.Unit.Georeference",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
TObjectPtr pGeoreferenceNullIsland;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumGlobeAnchor.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumGlobeAnchor.spec.cpp
index 6d51c2ddd..897ab41fb 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumGlobeAnchor.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumGlobeAnchor.spec.cpp
@@ -9,7 +9,9 @@
BEGIN_DEFINE_SPEC(
FCesiumGlobeAnchorSpec,
"Cesium.Unit.GlobeAnchor",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
TObjectPtr pActor;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumMetadataPickingBlueprintLibrary.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumMetadataPickingBlueprintLibrary.spec.cpp
index ff8c52312..099c59381 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumMetadataPickingBlueprintLibrary.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumMetadataPickingBlueprintLibrary.spec.cpp
@@ -13,7 +13,9 @@
BEGIN_DEFINE_SPEC(
FCesiumMetadataPickingSpec,
"Cesium.Unit.MetadataPicking",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
CesiumGltf::Model model;
CesiumGltf::MeshPrimitive* pPrimitive;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumMetadataValue.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumMetadataValue.spec.cpp
index 49858c73e..be829c7e3 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumMetadataValue.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumMetadataValue.spec.cpp
@@ -9,7 +9,9 @@
BEGIN_DEFINE_SPEC(
FCesiumMetadataValueSpec,
"Cesium.Unit.MetadataValue",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
END_DEFINE_SPEC(FCesiumMetadataValueSpec)
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumOriginShiftComponent.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumOriginShiftComponent.spec.cpp
index e9a2d1efd..1b6e4be11 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumOriginShiftComponent.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumOriginShiftComponent.spec.cpp
@@ -18,7 +18,9 @@
BEGIN_DEFINE_SPEC(
FCesiumOriginShiftComponentSpec,
"Cesium.Unit.OriginShiftComponent",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
TObjectPtr pWorld;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumPrimitiveFeatures.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumPrimitiveFeatures.spec.cpp
index 63fac56c6..7dd21d9f1 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumPrimitiveFeatures.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumPrimitiveFeatures.spec.cpp
@@ -8,7 +8,9 @@
BEGIN_DEFINE_SPEC(
FCesiumPrimitiveFeaturesSpec,
"Cesium.Unit.PrimitiveFeatures",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
CesiumGltf::Model model;
CesiumGltf::MeshPrimitive* pPrimitive;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumPropertyArray.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumPropertyArray.spec.cpp
index 6eae0eb5d..1c5e51b02 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumPropertyArray.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumPropertyArray.spec.cpp
@@ -7,7 +7,9 @@
BEGIN_DEFINE_SPEC(
FCesiumPropertyArraySpec,
"Cesium.Unit.PropertyArray",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
END_DEFINE_SPEC(FCesiumPropertyArraySpec)
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumPropertyTable.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumPropertyTable.spec.cpp
index 5b90f4261..d04e56a61 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumPropertyTable.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumPropertyTable.spec.cpp
@@ -10,7 +10,9 @@
BEGIN_DEFINE_SPEC(
FCesiumPropertyTableSpec,
"Cesium.Unit.PropertyTable",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
CesiumGltf::Model model;
CesiumGltf::ExtensionModelExtStructuralMetadata* pExtension;
diff --git a/Source/CesiumRuntime/Private/Tests/CesiumPropertyTableProperty.spec.cpp b/Source/CesiumRuntime/Private/Tests/CesiumPropertyTableProperty.spec.cpp
index a36ac49cb..e158006f3 100644
--- a/Source/CesiumRuntime/Private/Tests/CesiumPropertyTableProperty.spec.cpp
+++ b/Source/CesiumRuntime/Private/Tests/CesiumPropertyTableProperty.spec.cpp
@@ -9,7 +9,9 @@
BEGIN_DEFINE_SPEC(
FCesiumPropertyTablePropertySpec,
"Cesium.Unit.PropertyTableProperty",
- EAutomationTestFlags::ApplicationContextMask |
+ EAutomationTestFlags::EditorContext | EAutomationTestFlags::ClientContext |
+ EAutomationTestFlags::ServerContext |
+ EAutomationTestFlags::CommandletContext |
EAutomationTestFlags::ProductFilter)
END_DEFINE_SPEC(FCesiumPropertyTablePropertySpec)
@@ -96,7 +98,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
@@ -177,7 +179,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
@@ -239,9 +241,9 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
size,
- gsl::span(data.data(), data.size()),
- gsl::span(),
- gsl::span(),
+ std::span(data.data(), data.size()),
+ std::span(),
+ std::span(),
PropertyComponentType::None,
PropertyComponentType::None);
@@ -305,11 +307,11 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
size,
- gsl::span(data.data(), data.size()),
- gsl::span(
+ std::span(data.data(), data.size()),
+ std::span(
offsetsData.data(),
offsetsData.size()),
- gsl::span(),
+ std::span(),
PropertyComponentType::Uint16,
PropertyComponentType::None);
@@ -382,7 +384,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
@@ -497,7 +499,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
@@ -693,7 +695,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(8),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -729,7 +731,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(8),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -786,9 +788,9 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()),
- gsl::span(),
- gsl::span(offsetsData.data(), offsetsData.size()),
+ std::span(data.data(), data.size()),
+ std::span(),
+ std::span(offsetsData.data(), offsetsData.size()),
PropertyComponentType::None,
PropertyComponentType::Uint32);
@@ -844,7 +846,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -880,7 +882,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -917,7 +919,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -961,7 +963,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1023,7 +1025,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1063,7 +1065,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1106,7 +1108,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1150,7 +1152,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1216,7 +1218,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1256,7 +1258,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1297,7 +1299,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1341,7 +1343,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1405,7 +1407,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1441,7 +1443,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1482,7 +1484,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1531,7 +1533,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1585,7 +1587,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1625,7 +1627,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1663,7 +1665,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1720,9 +1722,9 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()),
- gsl::span(),
- gsl::span(offsetsData.data(), offsetsData.size()),
+ std::span(data.data(), data.size()),
+ std::span(),
+ std::span(offsetsData.data(), offsetsData.size()),
PropertyComponentType::None,
PropertyComponentType::Uint8);
FCesiumPropertyTableProperty property(propertyView);
@@ -1771,7 +1773,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1829,7 +1831,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1874,7 +1876,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1915,7 +1917,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -1965,7 +1967,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2030,7 +2032,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2075,7 +2077,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2117,7 +2119,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2175,9 +2177,9 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()),
- gsl::span(),
- gsl::span(offsetsData.data(), offsetsData.size()),
+ std::span(data.data(), data.size()),
+ std::span(),
+ std::span(offsetsData.data(), offsetsData.size()),
PropertyComponentType::None,
PropertyComponentType::Uint8);
FCesiumPropertyTableProperty property(propertyView);
@@ -2229,7 +2231,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2291,7 +2293,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2336,7 +2338,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2378,7 +2380,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2433,7 +2435,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2498,7 +2500,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2543,7 +2545,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2585,7 +2587,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2640,7 +2642,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2702,7 +2704,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2747,7 +2749,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2789,7 +2791,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2851,9 +2853,9 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()),
- gsl::span(),
- gsl::span(offsetsData.data(), offsetsData.size()),
+ std::span(data.data(), data.size()),
+ std::span(),
+ std::span(offsetsData.data(), offsetsData.size()),
PropertyComponentType::None,
PropertyComponentType::Uint8);
FCesiumPropertyTableProperty property(propertyView);
@@ -2905,7 +2907,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -2967,7 +2969,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3012,7 +3014,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3058,7 +3060,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3125,9 +3127,9 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()),
- gsl::span(),
- gsl::span(offsetsData.data(), offsetsData.size()),
+ std::span(data.data(), data.size()),
+ std::span(),
+ std::span(offsetsData.data(), offsetsData.size()),
PropertyComponentType::None,
PropertyComponentType::Uint8);
FCesiumPropertyTableProperty property(propertyView);
@@ -3179,7 +3181,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3252,7 +3254,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3308,7 +3310,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3371,7 +3373,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3424,7 +3426,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3474,7 +3476,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3537,7 +3539,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"status",
@@ -3588,7 +3590,7 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
static_cast(values.size()),
- gsl::span(data.data(), data.size()));
+ std::span(data.data(), data.size()));
FCesiumPropertyTableProperty property(propertyView);
TestEqual(
"PropertyTablePropertyStatus",
@@ -3652,9 +3654,9 @@ void FCesiumPropertyTablePropertySpec::Define() {
propertyTableProperty,
classProperty,
size,
- gsl::span(data.data(), data.size()),
- gsl::span