NAME
Fedora::RPM::Spec::License - Class for handle Fedora license string.
SYNOPSIS
use Fedora::RPM::Spec::License;
my $obj = Fedora::RPM::Spec::License->new(%params);
my @exceptions = $obj->exceptions;
my $fedora_license_format = $obj->format;
my @licenses = $obj->licenses;
$obj->parse($fedora_license_string);
$obj->reset;
DESCRIPTION
Fedora license string is used in Fedora RPM spec files in License field. There are two versions of this string. One is old version and new one with SPDX identifiers.
METHODS
new
my $obj = Fedora::RPM::Spec::License->new(%params);
Constructor.
Returns instance of object.
exceptions
my @exceptions = $obj->exceptions;
Get exceptions used in the Fedora license string sorted alphabetically.
Returns array of strings.
format
my $fedora_license_format = $obj->format;
Get Fedora license string format. Possible values:
1 - Old RPM Fedora format.
2 - New RPM Fedora format with SPDX license ids.
Returns number.
licenses
my @licenses = $obj->licenses;
Get licenses used in the Fedora license string sorted alphabetically.
Returns array of strings.
parse
$obj->parse($fedora_license_string);
Parse Fedora license string and set object internal structures. If string is valid for format 1 and 2 as well, format 2 is preferred. Example is 'MIT' license string.
Returns undef.
reset
$obj->reset;
Reset object.
Returns undef.
ERRORS
new():
From Class::Utils::set_params():
Unknown parameter '%s'.
format():
No Fedora license string processed.
licenses():
No Fedora license string processed.
parse():
License '%s' isn't SPDX license.
License '%s' isn't SPDX license exception.
EXAMPLE
use strict;
use warnings;
use Fedora::RPM::Spec::License;
if (@ARGV < 1) {
print STDERR "Usage: $0 fedora_license_string\n";
exit 1;
}
my $fedora_license_string = $ARGV[0];
# Object.
my $obj = Fedora::RPM::Spec::License->new;
# Parse license.
$obj->parse($fedora_license_string);
# Print out.
print "Fedora license string: $fedora_license_string\n";
print 'Format: '.$obj->format."\n";
print "Contain licenses:\n";
print join "\n", map { '- '. $_ } $obj->licenses;
print "\n";
if ($obj->exceptions) {
print "Contain exceptions:\n";
print join "\n", map { '- '. $_ } $obj->exceptions;
print "\n";
}
# Output with 'MIT' input:
# Fedora license string: MIT
# Format: 2
# Contain licenses:
# - MIT
# Output with 'MIT AND FSFAP' input:
# Fedora license string: MIT AND FSFAP
# Format: 2
# Contain licenses:
# - FSFAP
# - MIT
# Output with '(GPL+ or Artistic) and Artistic 2.0 and (MIT or GPLv2)' input:
# Fedora license string: (GPL+ or Artistic) and Artistic 2.0 and (MIT or GPLv2)
# Format: 1
# Contain licenses:
# - Artistic
# - Artistic 2.0
# - GPL+
# - GPLv2
# - MIT
# Output with 'LGPL-3.0-only WITH LGPL-3.0-linking-exception' input:
# Fedora license string: LGPL-3.0-only WITH LGPL-3.0-linking-exception
# Format: 2
# Contain licenses:
# - LGPL-3.0-only
# Contain exceptions:
# - LGPL-3.0-linking-exception
DEPENDENCIES
Class::Utils, English, Error::Pure, License::SPDX, List::Util, Parse::RecDescent, Readonly.
SEE ALSO
- rpm-spec-license
-
Tool for working with RPM spec file licenses.
REPOSITORY
https://github.com/michal-josef-spacek/Fedora-RPM-Spec-License
AUTHOR
Michal Josef Špaček mailto:skim@cpan.org
LICENSE AND COPYRIGHT
© 2023 Michal Josef Špaček
BSD 2-Clause License
VERSION
0.03