Big rafactoring : code split in several modules and some other best practices
This commit is contained in:
parent
e07ce016c4
commit
bea8e5aba8
16 changed files with 506 additions and 386 deletions
27
job/utils.go
Normal file
27
job/utils.go
Normal file
|
@ -0,0 +1,27 @@
|
|||
package job
|
||||
|
||||
// KeepOldestOnly filters a job list and keeps only the most recent entry for a job name
|
||||
func KeepOldestOnly(jobs []Job) []Job {
|
||||
tmpMap := make(map[string]Job)
|
||||
for _, elt := range jobs {
|
||||
prev, exists := tmpMap[elt.Name]
|
||||
if !exists || (exists && prev.Timestamp < elt.Timestamp) {
|
||||
tmpMap[elt.Name] = elt
|
||||
}
|
||||
}
|
||||
values := make([]Job, 0, len(tmpMap))
|
||||
for _, value := range tmpMap {
|
||||
values = append(values, value)
|
||||
}
|
||||
return values
|
||||
}
|
||||
|
||||
// KeepSuccessOnly returns only the successful jobs from a job list (suiatble to write a new spool file)
|
||||
func KeepSuccessOnly(jobs []Job) (result []Job) {
|
||||
for _, job := range jobs {
|
||||
if job.Success {
|
||||
result = append(result, job)
|
||||
}
|
||||
}
|
||||
return
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue