mirror of
https://github.com/anchore/syft.git
synced 2026-04-05 22:30:35 +02:00
* add location annotations + deb evidence annotations Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * rename LocationData struct and Annotation helper function Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add failing integration test for evidence coverage Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add evidence to aplm cataloger locations Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * change location annotation helper to return a location copy Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * add evidence to binary cataloger locations Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * updated remaining catalogers with location annotations Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * fix unit tests Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * fix linting Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * bump json schema Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * partial addressing of review comments Signed-off-by: Alex Goodman <alex.goodman@anchore.com> * rename location.WithAnnotation Signed-off-by: Alex Goodman <alex.goodman@anchore.com> --------- Signed-off-by: Alex Goodman <alex.goodman@anchore.com>
60 lines
1.5 KiB
Go
60 lines
1.5 KiB
Go
package haskell
|
|
|
|
import (
|
|
"bufio"
|
|
"errors"
|
|
"fmt"
|
|
"io"
|
|
"strings"
|
|
|
|
"github.com/anchore/syft/syft/artifact"
|
|
"github.com/anchore/syft/syft/pkg"
|
|
"github.com/anchore/syft/syft/pkg/cataloger/generic"
|
|
"github.com/anchore/syft/syft/source"
|
|
)
|
|
|
|
var _ generic.Parser = parseCabalFreeze
|
|
|
|
// parseCabalFreeze is a parser function for cabal.project.freeze contents, returning all packages discovered.
|
|
func parseCabalFreeze(_ source.FileResolver, _ *generic.Environment, reader source.LocationReadCloser) ([]pkg.Package, []artifact.Relationship, error) {
|
|
r := bufio.NewReader(reader)
|
|
var pkgs []pkg.Package
|
|
for {
|
|
line, err := r.ReadString('\n')
|
|
switch {
|
|
case errors.Is(io.EOF, err):
|
|
return pkgs, nil, nil
|
|
case err != nil:
|
|
return nil, nil, fmt.Errorf("failed to parse cabal.project.freeze file: %w", err)
|
|
}
|
|
|
|
if !strings.Contains(line, "any.") {
|
|
continue
|
|
}
|
|
|
|
line = strings.TrimSpace(line)
|
|
startPkgEncoding, endPkgEncoding := strings.Index(line, "any.")+4, strings.Index(line, ",")
|
|
// case where comma not found for last package in constraint list
|
|
if endPkgEncoding == -1 {
|
|
endPkgEncoding = len(line)
|
|
}
|
|
if startPkgEncoding >= endPkgEncoding || startPkgEncoding < 0 {
|
|
continue
|
|
}
|
|
|
|
line = line[startPkgEncoding:endPkgEncoding]
|
|
fields := strings.Split(line, " ==")
|
|
|
|
pkgName, pkgVersion := fields[0], fields[1]
|
|
pkgs = append(
|
|
pkgs,
|
|
newPackage(
|
|
pkgName,
|
|
pkgVersion,
|
|
nil,
|
|
reader.Location.WithAnnotation(pkg.EvidenceAnnotationKey, pkg.PrimaryEvidenceAnnotation),
|
|
),
|
|
)
|
|
}
|
|
}
|