1Syntax(3) User Contributed Perl Documentation Syntax(3)
2
3
4
6 License::Syntax - Coding and Decoding of License strings using SPDX and
7 SUSE syntax.
8
10 Version 0.13
11
13 This implements the SUSE License Syntax.
14
15 use License::Syntax;
16
17 my $obj = new License::Syntax licensemap => 'licenselist.csv;as';
18 my $obj = new License::Syntax map => { 'GNU General Public License V2.0' => 'GPLv2' };
19 my $obj = new License::Syntax 'pathname.sqlite;table(alias,name)';
20 $obj->loadmap_csv($filename_csv);
21 $obj->loadmap_sqlite($filename_sqlite, $table_name, $alias_col, $name_col);
22 $obj->savemap_csv($filename_csv, scalar(localtime));
23 $obj->savemap_sqlite($filename_sqlite, $table_name, $alias_col, $name_col, 'TRUNCATE');
24 $obj->add_alias($alias, $canonical_name);
25 $name = $obj->canonical_name($alias, $disambiguate);
26 $tree = $obj->tokenize('GPLv2 & Apache 1.1; LGPLv2.1 | BSD4c<<ex(UCB); Any Noncommercial', $disambiguate);
27 $name = $obj->format_tokens($tree);
28
30 new
31 License::Syntax is an object oriented module. When constructing new
32 License::Syntax objects, you can provide a mapping table for license
33 names. The table is used for recognizing alternate alias names for the
34 licenses (left hand side) and also defines the canonical short names of
35 the licenses (right hand side). The mapping table is consulted twice,
36 before and after decoding the syntax. (Thus non-terminal mappings may
37 actually be followed.)
38
39 The mapping table can be provided either
40
41 • as a CSV files of two columns. Column seperator is a comma (,)
42
43 • as a hash, or
44
45 • as table in an sqlite database using the given columns as left hand
46 side and right hand side respectivly.
47
48 As an alternative to specifying a mapping with new(), or additionally,
49 mappings can also be provided via loadmap_sqlite(), loadmap_csv(), or
50 add_alias() methods. Earlier mappings take precedence over later
51 mappings.
52
53 canonical_name
54 $name = $obj->canonical_name($alias);
55 is equivalent to
56 $name = $obj->format_tokens($obj->tokenize($alias));
57
58 savemap_csv
59 $obj->savemap_csv('filename.csv', scalar(localtime));
60
61 Writes the current mapping table as a comma seperated file.
62
63 set_rejects
64 $obj->set_rejects('REJECT', ...);
65
66 define the license names to be rejected. Per default, exactly one name
67 'REJECT' is rejected.
68
69 add_alias
70 $obj->add_alias($alias,$name); $obj->add_alias(undef,$name);
71 $obj->add_alias('',$name);
72
73 adds $name (and optionally $alias) to the objects licensemap. Both,
74 lower case and exact mappings are maintained. (add_url is used in
75 loadmap_csv)
76
77 add_alias() takes care to extend to the right. That is, if it's right
78 hand side parameter is already known to be an alias, the new alias is
79 added pointing to the old alias's canonical name (rahter than to the
80 old alias that the caller provided).
81
82 CAVEAT: add_alias() does not maintain full tranitivity, as it does not
83 extend to the left. If its left hand side is already known to be a
84 canonical name, a warning is issued, but the situation cannot be
85 corrected, as this would require rewriting existing entries. This is
86 non-obvious, as mappings are applied more than once during
87 format_tokens(), so indirect mappings involving non-terminal names, may
88 or may not work. A two step mapping currently works reliably, though.
89
90 add_alias() does nothing, if it would directly redo an existing
91 mapping.
92
93 See also new() for more details about mappings.
94
95 add_url
96 $obj->add_url($urls, $name);
97
98 Add one or multiple URLs to the canonical license name. URLs can be
99 seperated by comma or whitespace. May be called multiple times for the
100 same name, and fills an array of urls. (add_url is used in
101 loadmap_csv)
102
103 set_compat_class $obj->set_compat_class($cc, $name);
104 Specify the compatibility class, for a canonical license name.
105 compatibility classes are numerical. These classes allow to derive
106 certain compatibility issues amongst liceses. Some classes are always
107 incompatible (even amongst themselves), other classes are always
108 comaptible, and for some other classses, compatibility is uncertain.
109 The exact semantics are to be defined. (set_compat_class is used in
110 loadmap_csv).
111
112 savemap_sqlite
113 $obj->savemap_sqlite('filename.sqlite', 'lic_map', 'alias',
114 'shortname', $trunc_flag);
115
116 # sqlite3 filename.sqlite
117 sqlite> select * from lic_map
118 alias | shortname
119 ------|----------
120 ...
121
122 If $trunc_flag is true and the table previously exists, the table is
123 truncated before it is written to; otherwise new contents merges over
124 old contents, if any.
125
126 loadmap_sqlite
127 See also new() for more details about mappings.
128
129 tokenize
130 $tree_arr = $obj->tokenize($complex_license_expr); $tree_arr =
131 $obj->tokenize($complex_license_expr, 1);
132
133 Returns an array reference containing tokens and sub-arrays, describing
134 how the $complex_license_expr is parsed. If a second parameter
135 disambiguate is provided and is true, extra parenthesis are inserted to
136 unambiguiusly show how the complex expression is interpreted. If names
137 have been loaded with add_alias, before calling tokenize, all names and
138 aliases are recognized as one token. E.g. "GPL 2.0 or later" would be
139 split as ["GPL 2.0", "or", "later"] otherwise. No name mapping is
140 performed here.
141
142 format_tokens
143 reverse operation of tokenize()
144
145 loadmap_csv
146 $obj->loadmap_csv('license_map.csv', 'as');
147 $obj->loadmap_csv('synopsis.csv', 'lauaas#c');
148
149 Object method to load (or merge) contents of a CVS table into the
150 object. This uses a trivial csv parser. Field seperator must be ;
151 linebreaks are record seperators, and the first line is ignored, if it
152 starts with '#'. Fields can be surrounded by doublequotes, if a comma
153 may be embedded.
154
155 The second parameter is a field template, defining what the meaning of
156 the fields is.
157 l Long name (none or once). This is a speaking name of the License:
158 Example "Creative Commons Attribution 1.0"
159 a Alias name (any number). Any other name by which the license is
160 known: Example: "CC-BY 1.0"
161 s Short name (once). The canonical (unique) short license
162 identifiner: Example: "CC-BY-1"
163 u URL (any). Multiple URLs can also be written in one filed,
164 seperated by whitespace.
165 # License classification number (none or once). (1..5)
166 c Comment (none or once) The default template is "as", an alias,
167 followed by the canonical short name. Empty fields are ignored, as
168 well as fields that contian only one '?'. Thus you can use records like
169 "","Name" to pass in a valid name without an alias.
170
171 See also new() for more details about mappings.
172
174 Juergen Weigert, "<jw at suse.de>"
175
177 This module defines a different syntax than
178 http://rpmlint.zarb.org/cgi-bin/trac.cgi/browser/trunk/TagsCheck.py
179
180 Please report any bugs or feature requests to "bug-rpm-license at
181 rt.cpan.org", or through the web interface at
182 <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=License-Syntax>. I
183 will be notified, and then you'll automatically be notified of progress
184 on your bug as I make changes.
185
187 You can find documentation for this module with the perldoc command.
188
189 perldoc License::Syntax
190
191 You can also look for information at:
192
193 • RT: CPAN's request tracker
194
195 <http://rt.cpan.org/NoAuth/Bugs.html?Dist=License-Syntax>
196
197 • AnnoCPAN: Annotated CPAN documentation
198
199 <http://annocpan.org/dist/License-Syntax>
200
201 • CPAN Ratings
202
203 <http://cpanratings.perl.org/d/License-Syntax>
204
205 • Search CPAN
206
207 <http://search.cpan.org/dist/License-Syntax/>
208
211 Copyright 2009 Juergen Weigert.
212
213 This program is free software; you can redistribute it and/or modify it
214 under the terms of either: the GNU General Public License as published
215 by the Free Software Foundation; or the Artistic License.
216
217 See http://dev.perl.org/licenses/ for more information.
218
219
220
221perl v5.36.0 2022-07-22 Syntax(3)