-
Notifications
You must be signed in to change notification settings - Fork 635
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
DYN-2286: fix for crash upon unresolved node undo #10315
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -22,7 +22,7 @@ public enum PortType { Input, Output }; | |
/// <summary> | ||
/// PortModel represents Dynamo ports. | ||
/// </summary> | ||
public class PortModel : ModelBase | ||
public class PortModel : ModelBase, IEquatable<PortModel> | ||
{ | ||
#region private fields | ||
ObservableCollection<ConnectorModel> connectors = new ObservableCollection<ConnectorModel>(); | ||
|
@@ -369,6 +369,23 @@ protected override void DeserializeCore(XmlElement nodeElement, SaveContext cont | |
} | ||
|
||
#endregion | ||
|
||
public bool Equals(PortModel other) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. last time I tried overriding There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. In this case, I'm checking for guid equality only if reference equality fails. From what I see in other nodemodel types, it looks like the equality check will either be true or false in both cases (reference equality + guid equality) since if the same port model is being reused, both conditions will be true, and if a new port model is created, still both conditions will be false, unless the new ports are created using the same guids as the old ones, which is what I'm enforcing here explicitly for dummy nodes. |
||
{ | ||
if (other == null) return false; | ||
|
||
if (this == other) return true; | ||
|
||
if (GUID == other.GUID) return true; | ||
|
||
return false; | ||
} | ||
|
||
public override int GetHashCode() | ||
{ | ||
return GUID.GetHashCode(); | ||
} | ||
|
||
} | ||
|
||
/// <summary> | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
{ | ||
"Uuid": "0e5aec87-f0db-46dc-a7a0-e13d05b74a76", | ||
"IsCustomNode": false, | ||
"Description": null, | ||
"Name": "TestUnresolvedCodeBlockNodeUndo", | ||
"ElementResolver": { | ||
"ResolutionMap": {} | ||
}, | ||
"Inputs": [], | ||
"Outputs": [], | ||
"Nodes": [ | ||
{ | ||
"ConcreteType": "Dynamo.Graph.Nodes.ZeroTouch.DSFunction, DynamoCore", | ||
"NodeType": "FunctionNode", | ||
"FunctionSignature": "Lists.Manage.ReplaceNulls@var,var", | ||
"Id": "50580245505a483b994b14d1b38d691c", | ||
"Inputs": [ | ||
{ | ||
"Id": "45071948e0ca4de7b7e7854a11256693", | ||
"Name": "Data", | ||
"Description": "var", | ||
"UsingDefaultValue": false, | ||
"Level": 2, | ||
"UseLevels": false, | ||
"KeepListStructure": false | ||
}, | ||
{ | ||
"Id": "c1a7e3f5ed9f43a6ab26c6d6f59f74fa", | ||
"Name": "ReplaceWith", | ||
"Description": "var", | ||
"UsingDefaultValue": false, | ||
"Level": 2, | ||
"UseLevels": false, | ||
"KeepListStructure": false | ||
} | ||
], | ||
"Outputs": [ | ||
{ | ||
"Id": "3dca242246fd45048bb743b957909984", | ||
"Name": "var[]..[]", | ||
"Description": "var[]..[]", | ||
"UsingDefaultValue": false, | ||
"Level": 2, | ||
"UseLevels": false, | ||
"KeepListStructure": false | ||
} | ||
], | ||
"Replication": "Auto", | ||
"Description": "Manage.ReplaceNulls (Data: var, ReplaceWith: var): var[]..[]" | ||
} | ||
], | ||
"Connectors": [], | ||
"Dependencies": [], | ||
"NodeLibraryDependencies": [], | ||
"Bindings": [], | ||
"View": { | ||
"Dynamo": { | ||
"ScaleFactor": 1.0, | ||
"HasRunWithoutCrash": true, | ||
"IsVisibleInDynamoLibrary": true, | ||
"Version": "2.6.0.7481", | ||
"RunType": "Manual", | ||
"RunPeriod": "1000" | ||
}, | ||
"Camera": { | ||
"Name": "Background Preview", | ||
"EyeX": -17.0, | ||
"EyeY": 24.0, | ||
"EyeZ": 50.0, | ||
"LookX": 12.0, | ||
"LookY": -13.0, | ||
"LookZ": -58.0, | ||
"UpX": 0.0, | ||
"UpY": 1.0, | ||
"UpZ": 0.0 | ||
}, | ||
"NodeViews": [ | ||
{ | ||
"ShowGeometry": true, | ||
"Name": "Manage.ReplaceNulls", | ||
"Id": "50580245505a483b994b14d1b38d691c", | ||
"IsSetAsInput": false, | ||
"IsSetAsOutput": false, | ||
"Excluded": false, | ||
"X": 1465.785850242029, | ||
"Y": 338.9393205772858 | ||
} | ||
], | ||
"Annotations": [], | ||
"X": -790.23067822776329, | ||
"Y": 4.6725830650765374, | ||
"Zoom": 1.0 | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,108 @@ | ||
<Commands ExitAfterPlayback="true" PauseAfterPlaybackInMs="10" CommandIntervalInMs="20"> | ||
<OpenFileCommand XmlFilePath=".\TestUnresolvedCodeBlockNodeUndo.dyn" /> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>00000000-0000-0000-0000-000000000000</ModelGuid> | ||
</SelectModelCommand> | ||
<CreateNodeCommand X="1248.23067822776" Y="375.327416934923" DefaultPosition="false" TransformCoordinates="true"> | ||
<ModelGuid>739d4254-1347-421e-bf14-c146f60ac45b</ModelGuid> | ||
<Dynamo.Graph.Nodes.CodeBlockNodeModel guid="739d4254-1347-421e-bf14-c146f60ac45b" type="Dynamo.Graph.Nodes.CodeBlockNodeModel" nickname="Code Block" x="1156" y="344" isVisible="true" lacing="Disabled" isSelectedInput="False" isSelectedOutput="False" IsFrozen="false" isPinned="false" CodeText="safsd;" ShouldFocus="false"> | ||
<PortInfo index="0" default="False" name="safsd" /> | ||
<OutPortInfo LineIndex="0" /> | ||
</Dynamo.Graph.Nodes.CodeBlockNodeModel> | ||
</CreateNodeCommand> | ||
<UpdateModelValueCommand Name="Code" Value="safsd" WorkspaceGuid="0e5aec87-f0db-46dc-a7a0-e13d05b74a76"> | ||
<ModelGuid>739d4254-1347-421e-bf14-c146f60ac45b</ModelGuid> | ||
</UpdateModelValueCommand> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>00000000-0000-0000-0000-000000000000</ModelGuid> | ||
</SelectModelCommand> | ||
<CreateNodeCommand X="1229.23067822776" Y="505.327416934923" DefaultPosition="false" TransformCoordinates="true"> | ||
<ModelGuid>4fcc7262-5953-4e3c-8186-0a60f523c542</ModelGuid> | ||
<Dynamo.Graph.Nodes.CodeBlockNodeModel guid="4fcc7262-5953-4e3c-8186-0a60f523c542" type="Dynamo.Graph.Nodes.CodeBlockNodeModel" nickname="Code Block" x="1137" y="474" isVisible="true" lacing="Disabled" isSelectedInput="False" isSelectedOutput="False" IsFrozen="false" isPinned="false" CodeText="0;" ShouldFocus="false"> | ||
<OutPortInfo LineIndex="0" /> | ||
</Dynamo.Graph.Nodes.CodeBlockNodeModel> | ||
</CreateNodeCommand> | ||
<UpdateModelValueCommand Name="Code" Value="0" WorkspaceGuid="0e5aec87-f0db-46dc-a7a0-e13d05b74a76"> | ||
<ModelGuid>4fcc7262-5953-4e3c-8186-0a60f523c542</ModelGuid> | ||
</UpdateModelValueCommand> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>00000000-0000-0000-0000-000000000000</ModelGuid> | ||
</SelectModelCommand> | ||
<CreateNodeCommand X="1847.23067822776" Y="324.327416934923" DefaultPosition="false" TransformCoordinates="true"> | ||
<ModelGuid>83063f49-2d6c-4f05-b370-0cf03d60cb09</ModelGuid> | ||
<Dynamo.Graph.Nodes.CodeBlockNodeModel guid="83063f49-2d6c-4f05-b370-0cf03d60cb09" type="Dynamo.Graph.Nodes.CodeBlockNodeModel" nickname="Code Block" x="1755" y="293" isVisible="true" lacing="Disabled" isSelectedInput="False" isSelectedOutput="False" IsFrozen="false" isPinned="false" CodeText="sdafd;" ShouldFocus="false"> | ||
<PortInfo index="0" default="False" name="sdafd" /> | ||
<OutPortInfo LineIndex="0" /> | ||
</Dynamo.Graph.Nodes.CodeBlockNodeModel> | ||
</CreateNodeCommand> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>00000000-0000-0000-0000-000000000000</ModelGuid> | ||
</SelectModelCommand> | ||
<UpdateModelValueCommand Name="Code" Value="sdafd" WorkspaceGuid="0e5aec87-f0db-46dc-a7a0-e13d05b74a76"> | ||
<ModelGuid>83063f49-2d6c-4f05-b370-0cf03d60cb09</ModelGuid> | ||
</UpdateModelValueCommand> | ||
<MakeConnectionCommand PortIndex="0" Type="1" ConnectionMode="0"> | ||
<ModelGuid>50580245-505a-483b-994b-14d1b38d691c</ModelGuid> | ||
</MakeConnectionCommand> | ||
<MakeConnectionCommand PortIndex="0" Type="0" ConnectionMode="1"> | ||
<ModelGuid>83063f49-2d6c-4f05-b370-0cf03d60cb09</ModelGuid> | ||
</MakeConnectionCommand> | ||
<MakeConnectionCommand PortIndex="0" Type="1" ConnectionMode="0"> | ||
<ModelGuid>739d4254-1347-421e-bf14-c146f60ac45b</ModelGuid> | ||
</MakeConnectionCommand> | ||
<MakeConnectionCommand PortIndex="0" Type="0" ConnectionMode="1"> | ||
<ModelGuid>50580245-505a-483b-994b-14d1b38d691c</ModelGuid> | ||
</MakeConnectionCommand> | ||
<MakeConnectionCommand PortIndex="0" Type="1" ConnectionMode="0"> | ||
<ModelGuid>4fcc7262-5953-4e3c-8186-0a60f523c542</ModelGuid> | ||
</MakeConnectionCommand> | ||
<MakeConnectionCommand PortIndex="1" Type="0" ConnectionMode="1"> | ||
<ModelGuid>50580245-505a-483b-994b-14d1b38d691c</ModelGuid> | ||
</MakeConnectionCommand> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>50580245-505a-483b-994b-14d1b38d691c</ModelGuid> | ||
</SelectModelCommand> | ||
<DragSelectionCommand X="1642.23067822776" Y="429.327416934923" DragOperation="0" /> | ||
<DragSelectionCommand X="1697.23067822776" Y="204.327416934923" DragOperation="1" /> | ||
<UndoRedoCommand CmdOperation="0" /> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>83063f49-2d6c-4f05-b370-0cf03d60cb09</ModelGuid> | ||
</SelectModelCommand> | ||
<DragSelectionCommand X="1814.23067822776" Y="364.327416934923" DragOperation="0" /> | ||
<DragSelectionCommand X="1846.23067822776" Y="533.327416934923" DragOperation="1" /> | ||
<UndoRedoCommand CmdOperation="0" /> | ||
<PausePlaybackCommand Tag="Undo_1" PauseDurationInMs="100" /> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>50580245-505a-483b-994b-14d1b38d691c</ModelGuid> | ||
</SelectModelCommand> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>00000000-0000-0000-0000-000000000000</ModelGuid> | ||
</SelectModelCommand> | ||
<SelectInRegionCommand X="1539.23067822776" Y="454.327416934923" Width="3" Height="3" IsCrossSelection="true" /> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>50580245-505a-483b-994b-14d1b38d691c</ModelGuid> | ||
</SelectModelCommand> | ||
<DragSelectionCommand X="1537.23067822776" Y="449.327416934923" DragOperation="0" /> | ||
<DragSelectionCommand X="1481.23067822776" Y="273.327416934923" DragOperation="1" /> | ||
<UndoRedoCommand CmdOperation="0" /> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>4fcc7262-5953-4e3c-8186-0a60f523c542</ModelGuid> | ||
</SelectModelCommand> | ||
<DragSelectionCommand X="1204.23067822776" Y="544.327416934923" DragOperation="0" /> | ||
<DragSelectionCommand X="1325.23067822776" Y="685.327416934923" DragOperation="1" /> | ||
<UndoRedoCommand CmdOperation="0" /> | ||
<PausePlaybackCommand Tag="Undo_2" PauseDurationInMs="100" /> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>50580245-505a-483b-994b-14d1b38d691c</ModelGuid> | ||
</SelectModelCommand> | ||
<DragSelectionCommand X="1519.23067822776" Y="445.327416934923" DragOperation="0" /> | ||
<DragSelectionCommand X="1459.23067822776" Y="308.327416934923" DragOperation="1" /> | ||
<UndoRedoCommand CmdOperation="0" /> | ||
<SelectModelCommand Modifiers="0"> | ||
<ModelGuid>739d4254-1347-421e-bf14-c146f60ac45b</ModelGuid> | ||
</SelectModelCommand> | ||
<DragSelectionCommand X="1258.23067822776" Y="412.327416934923" DragOperation="0" /> | ||
<DragSelectionCommand X="1190.23067822776" Y="250.327416934923" DragOperation="1" /> | ||
<UndoRedoCommand CmdOperation="0" /> | ||
<PausePlaybackCommand Tag="Undo_3" PauseDurationInMs="100" /> | ||
</Commands> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
if childNodes is null - this will throw an exception - I think you should keep the if
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
https://stackoverflow.com/questions/3088147/why-does-net-foreach-loop-throw-nullrefexception-when-collection-is-null
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Resharper tells me that expression will always be true.