fix(graph): prevent cyclic dependencies in graph following ReactFlow examples#2439
Merged
waleedlatif1 merged 2 commits intostagingfrom Dec 18, 2025
Merged
fix(graph): prevent cyclic dependencies in graph following ReactFlow examples#2439waleedlatif1 merged 2 commits intostagingfrom
waleedlatif1 merged 2 commits intostagingfrom
Conversation
|
The latest updates on your projects. Learn more about Vercel for GitHub. |
fbef731 to
61d96ad
Compare
Contributor
Greptile SummaryThis PR implements cycle detection for the workflow graph by adding a Key changes:
Implementation is sound:
Minor observation:
Confidence Score: 5/5
Important Files Changed
Sequence DiagramsequenceDiagram
participant User
participant Handle as WorkflowBlock Handle
participant ReactFlow
participant OnConnect as workflow.tsx onConnect
participant Store as useWorkflowStore
participant Utils as wouldCreateCycle
User->>Handle: Drag connection from source to target
Handle->>Utils: isValidConnection(connection)
Utils->>Store: getState().edges
Store-->>Utils: current edges[]
Utils->>Utils: Check if source === target
alt Self-connection
Utils-->>Handle: false (reject)
else Valid so far
Utils->>Utils: Build adjacency list from edges
Utils->>Utils: DFS from target to find source
alt Cycle would be created
Utils-->>Handle: false (reject)
else No cycle
Utils-->>Handle: true (allow UI)
end
end
alt Connection allowed by UI
User->>ReactFlow: Drop connection
ReactFlow->>OnConnect: onConnect(connection)
OnConnect->>OnConnect: Validate container boundaries
OnConnect->>Store: addEdge(edge)
Store->>Utils: wouldCreateCycle(edges, source, target)
Utils->>Utils: Run cycle detection again
alt Cycle detected
Utils-->>Store: true
Store->>Store: Log warning and return early
else No cycle
Utils-->>Store: false
Store->>Store: Check for duplicates
Store->>Store: Add edge to store
end
end
|
apps/sim/app/workspace/[workspaceId]/w/[workflowId]/workflow.tsx
Outdated
Show resolved
Hide resolved
Collaborator
Author
|
@greptile |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
Type of Change
Testing
Tested manually
Checklist