1
0

Implement as normal filter

This commit is contained in:
dump_stack() 2023-05-11 22:17:31 +00:00
parent 2e6ce1e8f9
commit ad0a3706cb
Signed by: dump_stack
GPG Key ID: BE44DA8C062D87DC
2 changed files with 21 additions and 22 deletions

View File

@ -36,28 +36,16 @@ func GetDebianKernel(version string) (dk DebianKernel, err error) {
regex := `^linux-(image|headers)-[a-z+~0-9\.\-]*-(amd64|amd64-unsigned)$` regex := `^linux-(image|headers)-[a-z+~0-9\.\-]*-(amd64|amd64-unsigned)$`
pkgs, err := snapshot.Packages("linux", version, "amd64", regex) filter := []string{
if err != nil {
return
}
// FIXME correct regex
var packages []snapshot.Package
for _, p := range pkgs {
skip := false
for _, s := range []string{
"rt-amd64", "rt-amd64",
"cloud-amd64", "cloud-amd64",
"all-amd64", "all-amd64",
} {
if strings.Contains(p.Name, s) {
skip = true
break
}
}
if !skip {
packages = append(packages, p)
} }
packages, err := snapshot.Packages("linux", version, "amd64",
regex, filter)
if err != nil {
return
} }
if len(packages) == 0 { if len(packages) == 0 {

View File

@ -283,7 +283,18 @@ func contains(pkgs []Package, pkg Package) bool {
return false return false
} }
func Packages(srcname, version, arch, regex string) (pkgs []Package, err error) { func filtered(s string, filter []string) bool {
for _, f := range filter {
if strings.Contains(s, f) {
return true
}
}
return false
}
func Packages(srcname, version, arch, regex string,
filter []string) (pkgs []Package, err error) {
binpkgs, err := mr.GetBinpackages(srcname, version) binpkgs, err := mr.GetBinpackages(srcname, version)
if err == mr.ErrNotFound { if err == mr.ErrNotFound {
err = nil err = nil
@ -296,7 +307,7 @@ func Packages(srcname, version, arch, regex string) (pkgs []Package, err error)
r := regexp.MustCompile(regex) r := regexp.MustCompile(regex)
for _, res := range binpkgs.Result { for _, res := range binpkgs.Result {
if !r.MatchString(res.Name) { if !r.MatchString(res.Name) || filtered(res.Name, filter) {
continue continue
} }