Skip to content

Commit

Permalink
SceneAlgo : ObjectProcessor object history fix
Browse files Browse the repository at this point in the history
  • Loading branch information
ericmehl committed Oct 31, 2023
1 parent 1b156f8 commit e4410a8
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 2 deletions.
1 change: 1 addition & 0 deletions Changes.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ Fixes
- Fixed a bug preventing anything except strings from being copied and pasted.
- Fixed likely cause of crash when resizing Spreadsheet column width (#5296).
- Reference : Fixed rare reloading error.
- SceneAlgo : Fixed computation of `ScenePlug.object` in networks with nodes derived from `ObjectProcessor`. These include : `CameraTweaks`, `ClosestPointSampler`, `CollectPrimitiveVariables`, `CopyPrimitiveVariables`, `CurveSampler`, `DeleteCurves`, `DeleteFaces`, `DeletePoints`, `MapOffset`, `MapProjection`, `MeshDistortion`, `MeshNormals`, `MeshSegments`, `MeshTangents`, `MeshToPoints`, `MeshType`, `Orientation`, `PointsType`, `PrimitiveSampler`, `PrimitiveVariables`, `ReverseWinding`, `ShufflePrimitiveVariables` and `UVSampler`.

API
---
Expand Down
32 changes: 32 additions & 0 deletions python/GafferSceneTest/SceneAlgoTest.py
Original file line number Diff line number Diff line change
Expand Up @@ -404,6 +404,38 @@ def testHistoryPerformanceAlreadyCached( self ) :
h = h.predecessors[-1]
self.assertEqual( h.context["seed"], 5 )

def testObjectProcessorHistory( self ) :

plane = GafferScene.Plane()

meshType = GafferScene.MeshType()
meshType["in"].setInput( plane["out"] )

def runTest() :

history = GafferScene.SceneAlgo.history( meshType["out"]["object"], "/plane" )

for plug, scenePath in [
( meshType["out"], "/plane" ),
( meshType["in"], "/plane" ),
( plane["out"], "/plane" ),
] :
self.assertEqual( history.scene, plug )
self.assertEqual( GafferScene.ScenePlug.pathToString( history.context["scene:path"] ), scenePath )
history = history.predecessors[0] if history.predecessors else None

self.assertIsNone( history )

runTest()

# Test running the test while everything is already cached still works, and doesn't add any
# new entries to the cache
Gaffer.ValuePlug.clearHashCache()
runTest()
before = Gaffer.ValuePlug.hashCacheTotalUsage()
runTest()
self.assertEqual( Gaffer.ValuePlug.hashCacheTotalUsage(), before )

def testHistoryWithNoComputes( self ) :

switch = Gaffer.Switch()
Expand Down
12 changes: 10 additions & 2 deletions src/GafferScene/SceneAlgo.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -400,6 +400,8 @@ struct CapturedProcess

};

const InternedString g_processedObjectPlugName( "__processedObject" );

/// \todo Perhaps add this to the Gaffer module as a
/// public class, and expose it within the stats app?
/// Give a bit more thought to the CapturedProcess
Expand Down Expand Up @@ -432,7 +434,10 @@ class CapturingMonitor : public Monitor

CapturedProcess::Ptr capturedProcess;
ProcessOrScope entry;
if( !p->parent<ScenePlug>() || p->getName() != m_scenePlugChildName )
if(
( !p->parent<ScenePlug>() || p->getName() != m_scenePlugChildName ) &&
( (Gaffer::TypeId)p->typeId() != Gaffer::ObjectPlugTypeId || p->getName() != g_processedObjectPlugName )
)
{
// Parents may spawn other processes in support of the requested plug. This is one
// of these other plugs that isn't directly the requested plug. Instead of creating
Expand Down Expand Up @@ -493,7 +498,10 @@ class CapturingMonitor : public Monitor
{
if(
processType == g_hashProcessType &&
plug->parent<ScenePlug>() && plug->getName() == m_scenePlugChildName
(
( plug->parent<ScenePlug>() && plug->getName() == m_scenePlugChildName ) ||
( (Gaffer::TypeId)plug->typeId() == Gaffer::TypeId::ObjectPlugTypeId && plug->getName() == g_processedObjectPlugName )
)
)
{
return true;
Expand Down

0 comments on commit e4410a8

Please sign in to comment.