userDaniel Pcancel

2,818 Commits over 700 Days - 0.17cph!

38 Minutes Ago
Optim: cache FogMachine invokes - StartFogging, EnableFogFieldCB, DisableNozzleCB, FinishFoggingCB There were invoked in StartFogging, which can oscilate with power. Tests: none, trivial changes
1 Hour Ago
Optim: skip BeeSwarmMaster.StartDie call if already dying Saves on ActuallyDie invoke and allocation Tests: none, trivial change
1 Hour Ago
Optim: avoid repeated invoke scheduling in BeeSwarmAI - SetOnFire gets skipped if bees are already on fire (saves StartDie scheduling) - StartDie gets skipped if bees are already dying (saves Egress scheduling) Tests: none, trivial changes
2 Hours Ago
Bugfix: fix caching of DiveSiteBuoy.updateAction Tests: checked IL
2 Hours Ago
Optim: cache Sprinkler.DoSplash invoke Tests: none, trivial change
2 Hours Ago
Optim: cache HBHFSensor.UpdatePassthroughAmount invoke Tests: none, trivial change
2 Hours Ago
Optim: cache ElectricBattery.TickUsage invoke Tests: none, trivial change
2 Hours Ago
Optim: cache ElectricBattery.AddCharge invoke Tests: none, trivial change
3 Hours Ago
Optim: cache CoalingTower.CheckWagonLinedUp invoke Tests: none, trivial change
3 Hours Ago
Optim: Cache StrobeLight.SelfDamage invoke Tests: none, trivial change
3 Hours Ago
Optim: cache SamSite.WeaponTick invoke Tests: none, trivial change
Today
Merge: from fullserverdemo_removal - Clean: Remove FullServerDemo implementation (RustRelay will take us to the promised land) Tests: compiles, recorded client and server demos and was able to play them back
Today
Merge: from main
Today
Clean: get rid of Network.ServerInfo Was added for FullServerDemo support, no longer needed Tests: compiles
Today
Clean(editor): rip out DemoSever framework It could technically emulate server state from client demos, but required too much compromising, so not worth it. Tests: compiles
Today
Clean: delete Demos folder from Facepunch.Network Tests: compiles
Today
Clean: delete full-server-demo convars Tests: compiles
Today
Clean: remove IServerCallback save request support Keeping the core functionality on SaveRestore Tests: compiles
Today
Clean: remove FullServerDemos.cs Tests: compiles
Today
Clean: remove BaseNetwork.SupportsServerDemos Tests: compiles
Today
Clean: remove demo.full_server_demo - rip out a bunch of stuff related to it, including transient entity serialization - remove MessageType.DemoDisconnect and DemoTransientEntities (no need for protocol change) Tests: compiles
Today
Clean(editor): remove ServerDemoPlayer Tests: compiles
Today
Clean: remove AntiHackDemoProcessor - drive by deprecated API fixup Starting process of removing full server demos Tests: compiles
Yesterday
Resave TimeManager Tests: nothing specific, but have been running with this changed for a couple days
Yesterday
Merge: from waterlevel_deepsea_sample_fix - Bugfix for water level queries incorrectly mixing deep sea and overworld states - Bugfix for deep sea ocean sim using overworld heightmap - Simplified TerrainHeightMap API Tests: ran unit tests, booted into craggy, explored deep sea and swam around
Yesterday
Bugfix: avoid NRE when ocean sim is not initialized and we don't need it Tests: booted into craggy
Yesterday
Merge: from main
Yesterday
Clean: simplifyy WaterSystemBurst.GetHeightArray_Burst Tests: none, trivial changes
Yesterday
Bugfix: OceanSimulation.GetHeightAttenuation - handle positions in deep sea Tests: WaterLevel unit tests pass
Yesterday
Bugfix: Rewrite WaterLevel.GetWaterLevel to properly take in deep sea state Tests: ran unit tests, water level consistency tests fail due to bug on OceanSimulation side, serial path, will fix next
Yesterday
Update: TerrainHeightMap.GetQueryStructure now takes in a flag for deep sea data - got rid of bespoke height and normal sampling from HeightMapQueryStructure - bugfix: buoyancy - WaterSystemBurst.GetHeightArray_Burst now samples relevant heightfields instead of assuming deepsea heightfield is a single const Last duplicate is gone, yay. Can finally look at fixing WaterLevel.GetWaterLevel and other spots Tests: booted into craggy, generated deepsea and teleported to it - swam around, went to the islands, went to scientist tugboats
Yesterday
Clean: rip out TerrainHeightMap.GetHeightsFastIndirect GetHeightsIndirect is similarly fast(~10%) and consistent at borders with GetHeight Tests: ran water level tests (but they're falsely passing)
Yesterday
Clean: remove TerrainHeightMap.GetHeightFast, replace with GetHeight - added GetHeight(Vec2) overloads to avoid accidental GetHeight(Vec3) call via implicit conversion GetHeightFast is ~55% faster in managed land, but it's not used in very hot loops, so doubt we'll notice the difference. If we really care, we can replace it with available burst jobs. Tests: ran unit tests
Yesterday
Update(tests): add TestGetHeightsIndirect_UV_Overworld and TestGetHeightsIndirect_UV_DeepSea tests Tests: ran all unit tests
Yesterday
Update: TerrainHeightMap - redirect all height and normal calcs to go via HeightMapData impl - Renamed HeightMapData.GetHeight -> GetHeight01 Tests: all unit tests pass, perf tests results seem same
Yesterday
Update: fill in some missing overloads in TerrainHeightMap - get rid of commented methods Tests: ran unit tests
Yesterday
Clean: replace GetHeightsFastIndirect with GetHeightsIndirect - also fix a bug with invalid indexing - TerrainMap<T> now exposes internal src buffer as a ReadOnly view Starting cleanup effort, rough path ahead Tests: ran unit tests
2 Days Ago
Clean: remove Perf.TestGetHeightFastIndirectOld and related bits Tests: none, trivial change
2 Days Ago
Update: switch GetHeightsFastJobIndirect to use HeightMapData.GetHeight instead of inlined logic - removed extra 4 madds by using Fast's index calculation It's slightly slower on 512x512 test (0.9ms -> 1ms) due to Clamp01 calls, but we can afford consistency with GetHeight - will allos us to promote "fast" as "normal" and deduplicate Tests: ran perf tests, compared asm
2 Days Ago
Update: rewrite TerrainHeightMapJobs.GetHeightsFastJobIndirect to use HeightMapData - temporarily added Perf.TestGetHeightFastIndirectOld for easier assembly comparison Generates the same assembly, so same perf Tests: ran perf tests
2 Days Ago
Update(tests): add perf tests for TerrainHeightMap GetHeight family Surprisingly, the *Fast versions are faster even in burst jobs. I want to rip them out(too many dupes), so going to try to replicate the benefits to common family Tests: ran all unit tests
2 Days Ago
Clean: redirect a couple calls via GetHeight01/GetNormal(..., NativeArray.ReadOnly) Tests: none, trivial change
2 Days Ago
Bugfix: TerrainHeightMap.GetNormalsIndirect - reimplement using HeightMapData core - also slightly refactored HeightMapCore height logic Fixes it not knowing about deep sea Tests: all TerrainHeightMap unit tests pass
2 Days Ago
Update(tests): add TestGetNormalsIndirect_Deferred Conceptually it's same logic underneath, but routed through different code, so worth a unit test Tests: ran new unit test - fails on deep sea indices as expected
2 Days Ago
Bugfix: TerrainHeightMap.GetNormal(float, float) now checks for deep sea - added utility funcs that sample user provided NativeArray<short>.ReadOnly - regenerated validation normals for unit tests from TestGetNormal Tests: TestGetNormal passes, TestGetNormalsIndirect fails as expected
2 Days Ago
Bugfix: TerrainHeightMap.GetHeightsIndirect - rewrite using HeightMapData core This fixes missing deep sea lookups Tests: ran TestGetHeightsIndirect - passes
2 Days Ago
Update: refactor core of GetHeight logic into it's own struct - updated GetHeights to use it Tests: TestGetHeights passes
2 Days Ago
Bugfix: TerrainHeightMap.GetHeights - clamp to border when interpolating heightmap samples Tests: TestGetHeights passes
3 Days Ago
Update(tests): add TerrainHeightMap unit tests that cover GetHeight + GetNormal and their variants Tests: ran unit tests, some failures are unexpected
3 Days Ago
Update(tests): add support to generate test positions in deep sea bounds - updated TestWaterLevelsConsistency to use those extra positions, but surprisingly the test passes - documented everything(I think?) that's wrong with WaterLevel.GetWaterLevels Tests: ran updated unit test