Skip to content

Commit

Permalink
Refactor Overwriting Combinations in Matrix
Browse files Browse the repository at this point in the history
This commit refactors the overwriting combinations function within fanning out the Matrix to reduce the number of calls as requested by Priti in PR: #6341.
  • Loading branch information
EmmaMunley committed Mar 29, 2023
1 parent 9ff6034 commit 6593acf
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 20 deletions.
16 changes: 6 additions & 10 deletions pkg/apis/pipeline/v1/matrix_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ func (m *Matrix) FanOut() []Params {
for _, parameter := range m.Params {
combinations = combinations.fanOutMatrixParams(parameter)
}
combinations = combinations.overwriteCombinations(includeCombinations)
combinations.overwriteCombinations(includeCombinations)
combinations = combinations.addNewCombinations(includeCombinations)
return combinations.toParams()
}
Expand All @@ -84,7 +84,11 @@ func (cs Combinations) overwriteCombinations(ics Combinations) Combinations {
for _, paramCombination := range cs {
for _, includeCombination := range ics {
if paramCombination.contains(includeCombination) {
includeCombination.overwrite(paramCombination)
// overwrite the parameter name and value in existing combination
// with the include combination
for name, val := range includeCombination {
paramCombination[name] = val
}
}
}
}
Expand Down Expand Up @@ -115,14 +119,6 @@ func (c Combination) contains(includeCombination Combination) bool {
return true
}

// overwrite the parameter name and value exists in combination with the include combination
func (c Combination) overwrite(oldCombination Combination) Combination {
for name, val := range c {
oldCombination[name] = val
}
return oldCombination
}

// shouldAddNewCombination returns true if the include parameter name exists but the value is
// missing from combinations
func (cs Combinations) shouldAddNewCombination(includeCombination map[string]string) bool {
Expand Down
16 changes: 6 additions & 10 deletions pkg/apis/pipeline/v1beta1/matrix_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ func (m *Matrix) FanOut() []Params {
for _, parameter := range m.Params {
combinations = combinations.fanOutMatrixParams(parameter)
}
combinations = combinations.overwriteCombinations(includeCombinations)
combinations.overwriteCombinations(includeCombinations)
combinations = combinations.addNewCombinations(includeCombinations)
return combinations.toParams()
}
Expand All @@ -84,7 +84,11 @@ func (cs Combinations) overwriteCombinations(ics Combinations) Combinations {
for _, paramCombination := range cs {
for _, includeCombination := range ics {
if paramCombination.contains(includeCombination) {
includeCombination.overwrite(paramCombination)
// overwrite the parameter name and value in existing combination
// with the include combination
for name, val := range includeCombination {
paramCombination[name] = val
}
}
}
}
Expand Down Expand Up @@ -115,14 +119,6 @@ func (c Combination) contains(includeCombination Combination) bool {
return true
}

// overwrite the parameter name and value exists in combination with the include combination
func (c Combination) overwrite(oldCombination Combination) Combination {
for name, val := range c {
oldCombination[name] = val
}
return oldCombination
}

// shouldAddNewCombination returns true if the include parameter name exists but the value is
// missing from combinations
func (cs Combinations) shouldAddNewCombination(includeCombination map[string]string) bool {
Expand Down

0 comments on commit 6593acf

Please sign in to comment.