-
Notifications
You must be signed in to change notification settings - Fork 114
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
fix(reset): Improve cycle detector #709
Conversation
Signed-off-by: Suleiman Dibirov <[email protected]>
Signed-off-by: Suleiman Dibirov <[email protected]>
// areInDifferentServices checks if two paths are in different service definitions | ||
func areInDifferentServices(path1, path2 string) bool { | ||
// Split paths into components | ||
parts1 := strings.Split(path1, ".") |
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.
nit: could use path.Parts() if you don't convert it to a string
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.
the function accepts strings and the field also has a list of strings visitedNodes map[*yaml.Node][]string
, do you suggest to use path everywhere? or to convert the strings inside the func into paths and use Parts()
? it looks like overhead, isn't it?
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.
some overhead indeed, but my point is that Path
abstraction allows to ignore "implementation details" like the dot notation and []
or *
patterns. I had in mind at some point we might want to use an alternate implementation vs string
as we actually have to split this string many times during parsing.
From an encapsulation point of view, I'd prefer we add more utility func to Path
to support required submatching.
ANYWAY I'm fine we merge this PR as a quick fix for this issue, and revisit this later
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.
@ndeloof agree, that sounds reasonable.
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.
Let's do a follow up PR for the improvements
Improved the cycle detector and added one more test case.
docker/compose#12247 (comment)