Skip to content

Commit

Permalink
Merge pull request #6137 from ericmehl/dropReadOnlyPathFilterFix
Browse files Browse the repository at this point in the history
PathFilter : Fix dropping paths onto read-only nodes
  • Loading branch information
murraystevenson authored Nov 19, 2024
2 parents 57a21be + 42f7ab3 commit 535a1b8
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 8 deletions.
4 changes: 4 additions & 0 deletions Changes.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
1.4.15.x (relative to 1.4.15.1)
========

Fixes
-----

- PathFilter : Fixed bug allowing dropping paths onto read-only `PathFilter` nodes in the graph.
- VectorDataWidget : Fixed bug allowing dropping paths onto read-only widgets.

1.4.15.1 (relative to 1.4.15.0)
========
Expand Down
23 changes: 19 additions & 4 deletions python/GafferSceneUI/PathFilterUI.py
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ def __popupMenu( menuDefinition, plugValueWidget ) :
GafferUI.Pointer.registerPointer( "removeObjects", GafferUI.Pointer( "removeObjects.png", imath.V2i( 53, 14 ) ) )
GafferUI.Pointer.registerPointer( "replaceObjects", GafferUI.Pointer( "replaceObjects.png", imath.V2i( 53, 14 ) ) )

__DropMode = enum.Enum( "__DropMode", [ "None_", "Add", "Remove", "Replace" ] )
__DropMode = enum.Enum( "__DropMode", [ "None_", "Add", "Remove", "Replace", "NotEditable" ] )

__originalDragPointer = None

Expand All @@ -255,9 +255,14 @@ def __filterPlug( node ) :
return filterPlugs[0]
return None

def __editable( plug ) :

return not Gaffer.MetadataAlgo.readOnly( plug ) and plug.settable()

def __dropMode( nodeGadget, event ) :

if __pathsPlug( nodeGadget.node() ) is None :
pathsPlug = __pathsPlug( nodeGadget.node() )
if pathsPlug is None :
filter = None

filterPlug = __filterPlug( nodeGadget.node() )
Expand All @@ -267,9 +272,13 @@ def __dropMode( nodeGadget, event ) :
if filterPlug.getInput() is not None :
filter = filterPlug.source().node()
if filter is None :
return __DropMode.Replace
return __DropMode.Replace if __editable( filterPlug ) else __DropMode.NotEditable
elif not isinstance( filter, GafferScene.PathFilter ) :
return __DropMode.None_
pathsPlug = __pathsPlug( filter )

if not __editable( pathsPlug ) :
return __DropMode.NotEditable

if event.modifiers & event.Modifiers.Shift :
return __DropMode.Add
Expand Down Expand Up @@ -342,7 +351,10 @@ def __dragMove( nodeGadget, event ) :
if __originalDragPointer is None :
return False

GafferUI.Pointer.setCurrent( __dropMode( nodeGadget, event ).name.lower() + "Objects" )
dropMode = __dropMode( nodeGadget, event )
GafferUI.Pointer.setCurrent(
dropMode.name.lower() + "Objects" if dropMode != __DropMode.NotEditable else "notEditable"
)

return True

Expand All @@ -352,6 +364,9 @@ def __drop( nodeGadget, event ) :
if __originalDragPointer is None :
return False

if __dropMode( nodeGadget, event ) == __DropMode.NotEditable :
return True

pathsPlug = __pathsPlug( nodeGadget.node() )
if pathsPlug is None :
pathsPlug = __pathsPlug( __filterPlug( nodeGadget.node() ).source().node() )
Expand Down
14 changes: 10 additions & 4 deletions python/GafferSceneUI/SetFilterUI.py
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@
GafferUI.Pointer.registerPointer( "removeSets", GafferUI.Pointer( "pointerRemoveSets.png", imath.V2i( 53, 14 ) ) )
GafferUI.Pointer.registerPointer( "replaceSets", GafferUI.Pointer( "pointerReplaceSets.png", imath.V2i( 53, 14 ) ) )

__DropMode = enum.Enum( "__DropMode", [ "None_", "Add", "Remove", "Replace" ] )
__DropMode = enum.Enum( "__DropMode", [ "None_", "Add", "Remove", "Replace", "NotEditable" ] )

__originalDragPointer = None

Expand Down Expand Up @@ -146,13 +146,13 @@ def __dropMode( nodeGadget, event ) :
if nodeGadget.node()["filter"].getInput() is not None :
filter = nodeGadget.node()["filter"].source().node()
if filter is None :
return __DropMode.Replace if __editable( nodeGadget.node()["filter"] ) else __DropMode.None_
return __DropMode.Replace if __editable( nodeGadget.node()["filter"] ) else __DropMode.NotEditable
elif not isinstance( filter, GafferScene.SetFilter ) :
return __DropMode.None_
setsPlug = filter["setExpression"]

if not __editable( setsPlug ) :
return __DropMode.None_
return __DropMode.NotEditable

if event.modifiers & event.Modifiers.Shift :
return __DropMode.Add
Expand Down Expand Up @@ -201,7 +201,10 @@ def __dragMove( nodeGadget, event ) :
if __originalDragPointer is None :
return False

GafferUI.Pointer.setCurrent( __dropMode( nodeGadget, event ).name.lower() + "Sets" )
dropMode = __dropMode( nodeGadget, event )
GafferUI.Pointer.setCurrent(
dropMode.name.lower() + "Sets" if dropMode != __DropMode.NotEditable else "notEditable"
)

return True

Expand All @@ -211,6 +214,9 @@ def __drop( nodeGadget, event ) :
if __originalDragPointer is None :
return False

if __dropMode( nodeGadget, event ) == __DropMode.NotEditable :
return True

setsPlug = __setsPlug( nodeGadget.node() )
if setsPlug is None :
setsPlug = __setsPlug( nodeGadget.node()["filter"].source().node() )
Expand Down
3 changes: 3 additions & 0 deletions python/GafferUI/VectorDataWidget.py
Original file line number Diff line number Diff line change
Expand Up @@ -621,6 +621,9 @@ def __addRows( self, button ) :

def __dragEnter( self, widget, event ) :

if not self.getEditable() :
return False

if event.sourceWidget is self.__tableViewHolder and widget is not self.__buttonRow[1]:
# we don't accept drags from ourself unless the target is the remove button
return False
Expand Down

0 comments on commit 535a1b8

Please sign in to comment.