userDaniel Pcancel

699 Commits over 215 Days - 0.14cph!

5 Months Ago
Backout: bring back all the scenes Without this, editor bootstrap workflow dies. Tests: none, trivial change
5 Months Ago
Update: Reducing which scenes we have set for build in Build Settings Our internal build macros only build 2 scenes, while Test Runner tries to build all (incl disabled) scenes set in the Build Settings. This allows us to run Player-mode tests without extra steps. Tests: With PerfFwk enabled, ran pool perf tests in Player mode - it ran and gathered results.
5 Months Ago
Update: Reorganization of the perf test framework - Unity.PerformanceTesting is marked as auto-referenced (this is another modification of original package) - Added a "Rust Editor/Performance Framework/Active" menu toggle to enable/disable perf test scripts - controls RUST_PERF_FWK define - Renamed and moved PerfFwk assembly to Plugins/ (as that's it's design) - Moved existing perf tests outside to the root assembly (Scipts/PerfTests) so that we can access gameplay code The goal is to both isolate the perf framework code from the codebase as much as possible(don't ship to players or unity devs to load stuff that's not sueful), while also being able to work with our main game scripts directly. Tests: - Switch the toggle on and off - no editor errors. - Built client&server with framework being enabled - it passed. -- Found no PerfFwk references in main game assembly for both client and server and no references to test classes
5 Months Ago
Buildfix: isolating perf test scripts into it's own assembly - For the time being stores existing perf tests - will reorganize when the structure is more clear in the future. Tests: Unity booted without errors, confirmed perf tests presence in Test Runner
5 Months Ago
Merge: from main Tests: none
5 Months Ago
Update: enable sound pooling by default If something goes derp, can be disabled via audio.enablesoundpooling 0 Tests: was explicitly enabled over last 3 days while running all recent changes
5 Months Ago
Merge: from main Tests: ran around on craggy with logs
5 Months Ago
Bugfix: don't leak looping sounds when quick-switching It's possible that equipped items with sound effects (setup via sound player) can enable-then-disable across 2 frames, before SoundManager picks up the pending play request. If it's a looping sound(like torches burn loop) it would stay alive forever. Now we cleanup the pending requests on disable of sound player. Tests: mousewheel quickswitched between rock and a torch and observed numbers in audio.printsounds - the burn loop is no longer accumulating.
5 Months Ago
Update: SoundManager pools internal lists The pooling effect is minimal, but it achieves 2 small improvements: - we don't hold lists in memory for sounds that don't reapper for a while - those can be reused in other parts of the code - audio.printsounds no longer reports 0 active sounds per definintion Tests: On craggy quickswitched between equipped items. Saw the various sounds appear and disapper in the logs.
5 Months Ago
Update: microphone drops any sounds it has accumulated on destroy Tests: tested by playing the flute when exploding the microphone stand connected to a speaker
5 Months Ago
Update: MiningQuarry drops sound assets when destoyed (though it's invulnerable) Tests: none, trivial change (same type of changes as previous)
5 Months Ago
Update: modular car's engine drops all sound resources on disable Tests: blew up a modular car
5 Months Ago
Update: AmbianceWaveSounds recycles sounds on disable Tests: none targetted(same type of change as before), but have been live on my branch for 2d while testing and working on other changes.
5 Months Ago
Update: Engine blend loop drops it's sound resources on disable Tests: none, trivial change (same type of change as previous)
5 Months Ago
Update: Tree now drops it's sound resources on client destruction - It also drops the Gain mod when fading out sound loop during fall Tests: cut down a tree, saw relevant audio events in logs
5 Months Ago
Update: Traveling Vendor drops it's sound resources on client destruction Tests: none, trivial change (same type of change as previous)
5 Months Ago
Update: Parachute and Sled drop their sound resources on destroy Tests: none, trivial changes (same type of change as previous)
5 Months Ago
Update: CCTV and SpinnerWheel drop their sound resources on disable/destroy Tests: none, trivial change (same type of change as previous)
5 Months Ago
Update: Sub, Snowmobile, Tugboar and Train drop their sound resources on disable/kill - In Snowmobile's case Ski audio was previously (accidentally?) retained when sim stopped - Train engine used to retain damage and engine reflection sounds (assume an accident/bug) Tests: none, trivial changes (same type of changes as previously)
5 Months Ago
Update: CargoShip drops sounds resources on disable - Also added a couple convenience StopXSound methods, since it has a bunch of different sounds. Tests: none, trivial change (same type of change as before)
5 Months Ago
Update: Ferry drops it's sound resources when disabled Tests: none, trivial change (same type of change as previous)
5 Months Ago
Bugfix: PatrolHeli now releases modulators alongside the sounds Tests: none, trivial change
5 Months Ago
Bugfix: Drone now releases pitch modulator on destruction Tests: none, trivial change
5 Months Ago
Update: Modular Vehicle drops sound resources on destruction Tests: plugged in engine comps on Craggy's spawned vehicle, drove around in it. Put some timed c4 and drove until explosion - confirmed resources got released via logs.
5 Months Ago
Update: Helicopter now drops sound resources when disabled/retired - Also fixed a potential NRE when requesting a sound fails Tests: spawned an attack heli and flew around in it with jumping out at various stages. Also destroyed it to trigger sound recycling.
5 Months Ago
Bugfix: Bicycle now uses it's coasting sound when not pedaling Tests: rode the bicycle with pedaling on and off.
5 Months Ago
Update: Bycicle drops all sound resources when sound definition changes - Previously it tried to manage lifetime of modulators internally, but since we can pool it'll happen automatically now. Tests: rode the bike with jumping off during different moments. Noclipped away and back, redid same actions - all stable.
5 Months Ago
Update: DPV stops all sounds when no longer simulating In theory, there were edge cases where previously it was possible that some sounds would not be cleaned up. Tests: rode the DPV, jumped off at various points, picked it up and redeployed. Noclipped around the area
5 Months Ago
Update: MovementSounds releases sound resources on disable - Also got rid of IOnParentDestroying implementation - it's handled by OnDisable now Tests: ran in water. Killed self mid run to test onDisable - all good
5 Months Ago
Update: Minigun and Fishing Rod drop their sounds on destroy/cleanup Tests: Spooled up and fired the minigun with switching in between. Fished with switching at various stages(holding, throwing, fish catching, fish pulling).
5 Months Ago
Bugfix: Ignore sound fadeout requests on retired sounds Because sound is a shared-ownership resource and we have scenarios where owners don't know that the sound sometimes has been retired, we need to be a bit more permissive with existing cleanup logic. Tests: Had a fish bite with the fishing rod, started pulling then switched over to a different item, then tried fishing again - with sound pooling this would sometimes throw, but not anymore. Confirmed with audio logs that bad scenario did happen but didn't fail.
5 Months Ago
Bugfix: AmbienceEmitter now drops occlusion modulator on fade-out Tests: noclipped around Craggy with audio recycling logs on - no NREs
5 Months Ago
Merge: from item_pooling Fixes NRE when saving a player that was killed while crafting items and returned items would stack with existing inventory items Tests: crafted low grade fuel with 1 extra fat in the inventory, killed before finishing the craft and saved the session on the server - no NRE
5 Months Ago
Merge: from main Tests: editor build
5 Months Ago
Clean: remove CancelTask ReturnItems param Param was always set to true. Tests: Crafted to completion and with cancellation (voluntary + killing)
5 Months Ago
Update: rewrite the same bugfix a bit better - More explicitly explained why it's needed Tests: none, trivial change
5 Months Ago
Bugfix: Release items that we've moved from crafting tasks back to inventory. Tests: Crafted low grade fuel with 4 fat in inventory, then killed self mid-craft and saved - no NRE
5 Months Ago
Update: GameSetup can load save with double-quotes Makes it friendly with explorer's "copy as path" action. Tests: loaded a procedural save
5 Months Ago
Merge: from main Tests: none, trivial changes
5 Months Ago
Update: Implementing retiring of SoundModifier Tests: none, trivial change
5 Months Ago
Optim: Recycle footsteps earlier Previously sound would get recycled when the effect would be destroyed(1.7s), but it happens much later(instead of 0.5s) Tests: Ran around on craggy - coast, grasslands, water.
5 Months Ago
Update: Log Sound stop-and-recycle requests - Log level 3 for Audio Tests: observed logs when running around (footsteps)
5 Months Ago
Update: updating audio debug output to make cross-referencing easier Tests: Rode a zipline on Craggy, was able to track the looping sound
5 Months Ago
Bugfix: Zipline stops playing audio when reaching the end This avoids trying to fade out a sound that was already recycled due GO being destroyed by server. Haven't found a better solution. Tests: on Craggy with sound pooling enabled, used the zipline twice, then noclipped out in the distance, and rode the zipline twice - no NREs. Logs also didn't show double-retire
5 Months Ago
Update: rewrote the comment Forgot to press save in VS before submitting. Tests: none, trivial change
5 Months Ago
Update: Allow use of client-side commands for GameSetup in Editor context This simplifies some testing scenarios. Tests: Boted craggy with a couple client-only debug commands - they changed as required
5 Months Ago
Update: add sound logging under audio category Tests: Ran in editor, confirmed output
5 Months Ago
Merge: from main Tests: built in editor
5 Months Ago
Merge: from soundmodulator_leak Fixing zipline NRE that my previous change caused. When not pooling, retail the modulators instead of trying to recreate them, since some scripts don't clear them properly. Tests: rode the zipline twice on Craggy, then noclipped around the island to destroy sounds, then rode the zipline twice again - no NREs
5 Months Ago
Bugfix: don't clear modulators when not pooling, fixes zipline NRE This was caused by my previous fix Tests: rode the zipline twice on Craggy, then noclipped away from the island, and rode the zipline again - no NREs