blob: e502648cd32df9ad06f403c3bdb11beb90d1c6ac [file] [log] [blame] [edit]
// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
package parser2v3
import (
"fmt"
"github.com/spdx/tools-golang/spdx/common"
"github.com/spdx/tools-golang/spdx/v2_3"
)
func (parser *tvParser2_3) parsePairFromFile2_3(tag string, value string) error {
// expire fileAOP for anything other than an AOPHomePage or AOPURI
// (we'll actually handle the HomePage and URI further below)
if tag != "ArtifactOfProjectHomePage" && tag != "ArtifactOfProjectURI" {
parser.fileAOP = nil
}
switch tag {
// tag for creating new file section
case "FileName":
// check if the previous file contained an spdx Id or not
if parser.file != nil && parser.file.FileSPDXIdentifier == nullSpdxElementId2_3 {
return fmt.Errorf("file with FileName %s does not have SPDX identifier", parser.file.FileName)
}
parser.file = &v2_3.File{}
parser.file.FileName = value
// tag for creating new package section and going back to parsing Package
case "PackageName":
parser.st = psPackage2_3
// check if the previous file contained an spdx Id or not
if parser.file != nil && parser.file.FileSPDXIdentifier == nullSpdxElementId2_3 {
return fmt.Errorf("file with FileName %s does not have SPDX identifier", parser.file.FileName)
}
parser.file = nil
return parser.parsePairFromPackage2_3(tag, value)
// tag for going on to snippet section
case "SnippetSPDXID":
parser.st = psSnippet2_3
return parser.parsePairFromSnippet2_3(tag, value)
// tag for going on to other license section
case "LicenseID":
parser.st = psOtherLicense2_3
return parser.parsePairFromOtherLicense2_3(tag, value)
// tags for file data
case "SPDXID":
eID, err := extractElementID(value)
if err != nil {
return err
}
parser.file.FileSPDXIdentifier = eID
if parser.pkg == nil {
if parser.doc.Files == nil {
parser.doc.Files = []*v2_3.File{}
}
parser.doc.Files = append(parser.doc.Files, parser.file)
} else {
if parser.pkg.Files == nil {
parser.pkg.Files = []*v2_3.File{}
}
parser.pkg.Files = append(parser.pkg.Files, parser.file)
}
case "FileType":
parser.file.FileTypes = append(parser.file.FileTypes, value)
case "FileChecksum":
subkey, subvalue, err := extractSubs(value)
if err != nil {
return err
}
if parser.file.Checksums == nil {
parser.file.Checksums = []common.Checksum{}
}
switch common.ChecksumAlgorithm(subkey) {
case common.SHA1,
common.SHA224,
common.SHA256,
common.SHA384,
common.SHA512,
common.MD2,
common.MD4,
common.MD5,
common.MD6,
common.SHA3_256,
common.SHA3_384,
common.SHA3_512,
common.BLAKE2b_256,
common.BLAKE2b_384,
common.BLAKE2b_512,
common.BLAKE3,
common.ADLER32:
algorithm := common.ChecksumAlgorithm(subkey)
parser.file.Checksums = append(parser.file.Checksums, common.Checksum{Algorithm: algorithm, Value: subvalue})
default:
return fmt.Errorf("got unknown checksum type %s", subkey)
}
case "LicenseConcluded":
parser.file.LicenseConcluded = value
case "LicenseInfoInFile":
parser.file.LicenseInfoInFiles = append(parser.file.LicenseInfoInFiles, value)
case "LicenseComments":
parser.file.LicenseComments = value
case "FileCopyrightText":
parser.file.FileCopyrightText = value
case "ArtifactOfProjectName":
parser.fileAOP = &v2_3.ArtifactOfProject{}
parser.file.ArtifactOfProjects = append(parser.file.ArtifactOfProjects, parser.fileAOP)
parser.fileAOP.Name = value
case "ArtifactOfProjectHomePage":
if parser.fileAOP == nil {
return fmt.Errorf("no current ArtifactOfProject found")
}
parser.fileAOP.HomePage = value
case "ArtifactOfProjectURI":
if parser.fileAOP == nil {
return fmt.Errorf("no current ArtifactOfProject found")
}
parser.fileAOP.URI = value
case "FileComment":
parser.file.FileComment = value
case "FileNotice":
parser.file.FileNotice = value
case "FileContributor":
parser.file.FileContributors = append(parser.file.FileContributors, value)
case "FileDependency":
parser.file.FileDependencies = append(parser.file.FileDependencies, value)
case "FileAttributionText":
parser.file.FileAttributionTexts = append(parser.file.FileAttributionTexts, value)
// for relationship tags, pass along but don't change state
case "Relationship":
parser.rln = &v2_3.Relationship{}
parser.doc.Relationships = append(parser.doc.Relationships, parser.rln)
return parser.parsePairForRelationship2_3(tag, value)
case "RelationshipComment":
return parser.parsePairForRelationship2_3(tag, value)
// for annotation tags, pass along but don't change state
case "Annotator":
parser.ann = &v2_3.Annotation{}
parser.doc.Annotations = append(parser.doc.Annotations, parser.ann)
return parser.parsePairForAnnotation2_3(tag, value)
case "AnnotationDate":
return parser.parsePairForAnnotation2_3(tag, value)
case "AnnotationType":
return parser.parsePairForAnnotation2_3(tag, value)
case "SPDXREF":
return parser.parsePairForAnnotation2_3(tag, value)
case "AnnotationComment":
return parser.parsePairForAnnotation2_3(tag, value)
// tag for going on to review section (DEPRECATED)
case "Reviewer":
parser.st = psReview2_3
return parser.parsePairFromReview2_3(tag, value)
default:
return fmt.Errorf("received unknown tag %v in File section", tag)
}
return nil
}