Skip to content

Commit

Permalink
Fix dependency calculation
Browse files Browse the repository at this point in the history
Eliminate common dependencies (eg. Python)
Fix direct dependencies inheriting non-direct dependencies
  • Loading branch information
Naatan committed Jul 3, 2024
1 parent 77fd569 commit 0797ffb
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 6 deletions.
18 changes: 12 additions & 6 deletions internal/runbits/dependencies/changesummary.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,16 +33,18 @@ func OutputChangeSummary(out output.Outputer, newBuildPlan *buildplan.BuildPlan,
v := fmt.Sprintf("%s@%s", a.Name(), a.Version())
addedString = append(addedLocale, v)
addedLocale = append(addedLocale, fmt.Sprintf("[ACTIONABLE]%s[/RESET]", v))
}
for _, i := range a.Ingredients {
dependencies = append(dependencies, i.RuntimeDependencies(true)...)
directDependencies = append(dependencies, i.RuntimeDependencies(false)...)

for _, i := range a.Ingredients {
dependencies = append(dependencies, i.RuntimeDependencies(true)...)
directDependencies = append(directDependencies, i.RuntimeDependencies(false)...)
}
}
}

dependencies = sliceutils.UniqueByProperty(dependencies, func(i *buildplan.Ingredient) any { return i.IngredientID })
directDependencies = sliceutils.UniqueByProperty(directDependencies, func(i *buildplan.Ingredient) any { return i.IngredientID })
numIndirect := len(dependencies) - len(directDependencies)
commonDependencies := directDependencies.CommonRuntimeDependencies().ToIDMap()
numIndirect := len(dependencies) - len(directDependencies) - len(commonDependencies)

sort.SliceStable(directDependencies, func(i, j int) bool {
return directDependencies[i].Name < directDependencies[j].Name
Expand Down Expand Up @@ -79,8 +81,12 @@ func OutputChangeSummary(out output.Outputer, newBuildPlan *buildplan.BuildPlan,
prefix = " └─"
}

// Retrieve runtime dependencies, and then filter out any dependencies that are common between all added ingredients.
runtimeDeps := ingredient.RuntimeDependencies(true)
runtimeDeps = runtimeDeps.Filter(func(i *buildplan.Ingredient) bool { _, ok := commonDependencies[i.IngredientID]; return !ok })

subdependencies := ""
if numSubs := len(ingredient.RuntimeDependencies(true)); numSubs > 0 {
if numSubs := len(runtimeDeps); numSubs > 0 {
subdependencies = fmt.Sprintf(" ([ACTIONABLE]%s[/RESET] dependencies)", // intentional leading space
strconv.Itoa(numSubs))
}
Expand Down
25 changes: 25 additions & 0 deletions pkg/buildplan/ingredient.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,31 @@ func (i Ingredients) ToNameMap() IngredientNameMap {
return result
}

// CommonRuntimeDependencies returns the set of runtime dependencies that are common between all ingredients.
// For example, given a set of python ingredients this will return at the very least the python language ingredient.
func (i Ingredients) CommonRuntimeDependencies() Ingredients {
counts := map[strfmt.UUID]int{}

for _, ig := range i {
runtimeDeps := ig.RuntimeDependencies(true)
for _, rd := range runtimeDeps {
if _, ok := counts[rd.IngredientID]; !ok {
counts[rd.IngredientID] = 0
}
counts[rd.IngredientID]++
}
}

common := Ingredients{}
for _, ig := range i {
if counts[ig.IngredientID] == len(i) {
common = append(common, ig)
}
}

return common
}

func (i *Ingredient) RuntimeDependencies(recursive bool) Ingredients {
dependencies := i.runtimeDependencies(recursive, make(map[strfmt.UUID]struct{}))
return sliceutils.UniqueByProperty(dependencies, func(i *Ingredient) any { return i.IngredientID })
Expand Down

0 comments on commit 0797ffb

Please sign in to comment.