1PAR::Dist(3) User Contributed Perl Documentation PAR::Dist(3)
2
3
4
6 PAR::Dist - Create and manipulate PAR distributions
7
9 This document describes version 0.47 of PAR::Dist, released November
10 29, 2009.
11
13 As a shell command:
14
15 % perl -MPAR::Dist -eblib_to_par
16
17 In programs:
18
19 use PAR::Dist;
20
21 my $dist = blib_to_par(); # make a PAR file using ./blib/
22 install_par($dist); # install it into the system
23 uninstall_par($dist); # uninstall it from the system
24 sign_par($dist); # sign it using Module::Signature
25 verify_par($dist); # verify it using Module::Signature
26
27 install_par("http://foo.com/DBI-1.37-MSWin32-5.8.0.par"); # works too
28 install_par("http://foo.com/DBI-1.37"); # auto-appends archname + perlver
29 install_par("cpan://SMUELLER/PAR-Packer-0.975"); # uses CPAN author directory
30
32 This module creates and manipulates PAR distributions. They are
33 architecture-specific PAR files, containing everything under blib/ of
34 CPAN distributions after their "make" or "Build" stage, a META.yml
35 describing metadata of the original CPAN distribution, and a MANIFEST
36 detailing all files within it. Digitally signed PAR distributions will
37 also contain a SIGNATURE file.
38
39 The naming convention for such distributions is:
40
41 $NAME-$VERSION-$ARCH-$PERL_VERSION.par
42
43 For example, "PAR-Dist-0.01-i386-freebsd-5.8.0.par" corresponds to the
44 0.01 release of "PAR-Dist" on CPAN, built for perl 5.8.0 running on
45 "i386-freebsd".
46
48 Several functions are exported by default. Unless otherwise noted,
49 they can take either a hash of named arguments, a single argument
50 (taken as $path by "blib_to_par" and $dist by other functions), or no
51 arguments (in which case the first PAR file in the current directory is
52 used).
53
54 Therefore, under a directory containing only a single test.par, all
55 invocations below are equivalent:
56
57 % perl -MPAR::Dist -e"install_par( dist => 'test.par' )"
58 % perl -MPAR::Dist -e"install_par( 'test.par' )"
59 % perl -MPAR::Dist -einstall_par;
60
61 If $dist resembles a URL, "LWP::Simple::mirror" is called to mirror it
62 locally under $ENV{PAR_TEMP} (or "$TEMP/par/" if unspecified), and the
63 function will act on the fetched local file instead. If the URL begins
64 with "cpan://AUTHOR/", it will be expanded automatically to the
65 author's CPAN directory (e.g.
66 "http://www.cpan.org/modules/by-authors/id/A/AU/AUTHOR/").
67
68 If $dist does not have a file extension beginning with a letter or
69 underscore, a dash and $suffix ($ARCH-$PERL_VERSION.par by default)
70 will be appended to it.
71
72 blib_to_par
73 Takes key/value pairs as parameters or a single parameter indicating
74 the path that contains the blib/ subdirectory.
75
76 Builds a PAR distribution from the blib/ subdirectory under "path", or
77 under the current directory if unspecified. If blib/ does not exist,
78 it automatically runs Build, make, Build.PL or Makefile.PL to create
79 it.
80
81 Returns the filename of the generated PAR distribution.
82
83 Valid parameters are:
84
85 path
86 Sets the path which contains the blib/ subdirectory from which the
87 PAR distribution will be generated.
88
89 name, version, suffix
90 These attributes set the name, version and platform specific suffix
91 of the distribution. Name and version can be automatically determined
92 from the distributions META.yml or Makefile.PL files.
93
94 The suffix is generated from your architecture name and your version
95 of perl by default.
96
97 dist
98 The output filename for the PAR distribution.
99
100 quiet
101 Set to true to suppress as much output as possible.
102
103 install_par
104 Installs a PAR distribution into the system, using
105 "ExtUtils::Install::install_default".
106
107 If only a single parameter is given, it is treated as the value for the
108 "dist" parameter.
109
110 Valid named parameters are:
111
112 dist
113 The .par file to install. The heuristics outlined in the FUNCTIONS
114 section above apply.
115
116 prefix
117 This string will be prepended to all installation paths. If it isn't
118 specified, the environment variable "PERL_INSTALL_ROOT" is used as a
119 prefix.
120
121 uninstall_shadows
122 This corresponds to the "uninstall_shadows" option of
123 ExtUtils::Install. Quoting its manual: If "uninstall_shadows" is set
124 to true, any differing versions throughout @INC will be uninstalled.
125 This is "make install UNINST=1".
126
127 verbose
128 This corresponds to the "verbose" option of ExtUtils::Install.
129 According to its manual: If "verbose" is true, will print out each
130 file removed. This is "make install VERBINST=1". "verbose" values
131 going up to 5 show increasingly more diagnostics output.
132
133 Default verbosity for PAR::Dist is 1.
134
135 If you're just going to install into the running perl like everything
136 else, you can stop reading the rest of this section now.
137
138 Additionally, you can use several parameters to change the default
139 installation destinations. You don't usually have to worry about this
140 unless you are installing into a user-local directory. The following
141 section outlines the parameter names and default settings:
142
143 Parameter From To
144 inst_lib blib/lib $Config{installsitelib} (*)
145 inst_archlib blib/arch $Config{installsitearch}
146 inst_script blib/script $Config{installscript}
147 inst_bin blib/bin $Config{installbin}
148 inst_man1dir blib/man1 $Config{installman1dir}
149 inst_man3dir blib/man3 $Config{installman3dir}
150 packlist_read $Config{sitearchexp}/auto/$name/.packlist
151 packlist_write $Config{installsitearch}/auto/$name/.packlist
152
153 The "packlist_write" parameter is used to control where the .packlist
154 file is written to. (Necessary for uninstallation.) The
155 "packlist_read" parameter specifies a .packlist file to merge in if it
156 exists. By setting any of the above installation targets to "undef",
157 you can remove that target altogether. For example, passing
158 "inst_man1dir => undef, inst_man3dir => undef" means that the contained
159 manual pages won't be installed. This is not available for the
160 packlists.
161
162 Again, the defaults will be the normal site paths from %Config.
163
164 (*) If the ".par"'s inst_archlib section (normally "blib/arch") isn't
165 empty, the code in inst_lib (normally "blib/lib") is also installed
166 into the inst_archlib path. This makes sense for XS modules. If,
167 however, you override "inst_lib", this automatic conversion is also
168 overridden! You can use the named parameter "auto_inst_lib_conversion
169 => 1" to re-enable the conversion for custom inst_lib's.
170
171 Finally, you may specify a "custom_targets" parameter. Its value should
172 be a reference to a hash of custom installation targets such as
173
174 custom_targets => { 'blib/my_data' => '/some/path/my_data' }
175
176 You can use this to install the .par archives contents to arbitrary
177 locations.
178
179 uninstall_par
180 Uninstalls all previously installed contents of a PAR distribution,
181 using "ExtUtils::Install::uninstall".
182
183 Takes almost the same parameters as "install_par", but naturally, the
184 installation target parameters do not apply. The only exception to this
185 is the "packlist_read" parameter which specifies the .packlist file to
186 read the list of installed files from. It defaults to
187 "$Config::Config{installsitearch}/auto/$name/.packlist".
188
189 Additionally, the "uninstall_shadows" parameter of "install_par" isn't
190 available.
191
192 sign_par
193 Digitally sign a PAR distribution using "gpg" or Crypt::OpenPGP, via
194 Module::Signature.
195
196 verify_par
197 Verify the digital signature of a PAR distribution using "gpg" or
198 Crypt::OpenPGP, via Module::Signature.
199
200 Returns a boolean value indicating whether verification passed; $! is
201 set to the return code of "Module::Signature::verify".
202
203 merge_par
204 Note: Since version 0.32 of PAR::Dist, this function requires a YAML
205 reader. The order of precedence is:
206
207 YAML:XS YAML YAML::Syck YAML::Tiny
208
209 Merges two or more PAR distributions into one. First argument must be
210 the name of the distribution you want to merge all others into. Any
211 following arguments will be interpreted as the file names of further
212 PAR distributions to merge into the first one.
213
214 merge_par('foo.par', 'bar.par', 'baz.par')
215
216 This will merge the distributions "foo.par", "bar.par" and "baz.par"
217 into the distribution "foo.par". "foo.par" will be overwritten!
218
219 The original META.yml of "foo.par" is retained, but augmented with any
220 "provides", "requires", "recommends", "build_requires", and
221 "configure_requires" sections from the other ".par" files.
222
223 remove_man
224 Remove the man pages from a PAR distribution. Takes one named
225 parameter: dist which should be the name (and path) of the PAR
226 distribution file. The calling conventions outlined in the "FUNCTIONS"
227 section above apply.
228
229 The PAR archive will be extracted, stripped of all "man\d?" and "html"
230 subdirectories and then repackaged into the original file.
231
232 get_meta
233 Opens a PAR archive and extracts the contained META.yml file. Returns
234 the META.yml file as a string.
235
236 Takes one named parameter: dist. If only one parameter is passed, it is
237 treated as the dist parameter. (Have a look at the description in the
238 "FUNCTIONS" section above.)
239
240 Returns undef if no PAR archive or no META.yml within the archive were
241 found.
242
243 parse_dist_name
244 First argument must be a distribution file name. The file name is
245 parsed into distribution name, distribution version, architecture name,
246 and perl version.
247
248 Returns the results as a list in the above order. If any or all of the
249 above cannot be determined, returns undef instead of the undetermined
250 elements.
251
252 Supported formats are:
253
254 Math-Symbolic-0.502-x86_64-linux-gnu-thread-multi-5.8.7
255
256 Math-Symbolic-0.502
257
258 The ".tar.gz" or ".par" extensions as well as any preceding paths are
259 stripped before parsing. Starting with "PAR::Dist" 0.22, versions
260 containing a preceding "v" are parsed correctly.
261
262 This function is not exported by default.
263
264 generate_blib_stub
265 Creates a blib/lib subdirectory in the current directory and prepares a
266 META.yml with meta information for a new PAR distribution. First
267 argument should be the name of the PAR distribution in a format
268 understood by "parse_dist_name()". Alternatively, named arguments
269 resembling those of "blib_to_par" are accepted.
270
271 After running "generate_blib_stub" and injecting files into the blib
272 directory, you can create a PAR distribution using "blib_to_par". This
273 function is useful for creating custom PAR distributions from scratch.
274 (I.e. not from an unpacked CPAN distribution) Example:
275
276 use PAR::Dist;
277 use File::Copy 'copy';
278
279 generate_blib_stub(
280 name => 'MyApp', version => '1.00'
281 );
282 copy('MyApp.pm', 'blib/lib/MyApp.pm');
283 blib_to_par(); # generates the .par file!
284
285 "generate_blib_stub" will not overwrite existing files.
286
287 contains_binaries
288 This function is not exported by default.
289
290 Opens a PAR archive tries to determine whether that archive contains
291 platform-specific binary code.
292
293 Takes one named parameter: dist. If only one parameter is passed, it is
294 treated as the dist parameter. (Have a look at the description in the
295 "FUNCTIONS" section above.)
296
297 Throws a fatal error if the PAR archive could not be found.
298
299 Returns one if the PAR was found to contain binary code and zero
300 otherwise.
301
303 PAR, ExtUtils::Install, Module::Signature, LWP::Simple
304
306 Audrey Tang <cpan@audreyt.org> 2003-2007
307
308 Steffen Mueller <smueller@cpan.org> 2005-2011
309
310 PAR has a mailing list, <par@perl.org>, that you can write to; send an
311 empty mail to <par-subscribe@perl.org> to join the list and participate
312 in the discussion.
313
314 Please send bug reports to <bug-par@rt.cpan.org>.
315
317 Copyright 2003-2011 by Audrey Tang <autrijus@autrijus.org>.
318
319 This program is free software; you can redistribute it and/or modify it
320 under the same terms as Perl itself.
321
322 See <http://www.perl.com/perl/misc/Artistic.html>
323
324
325
326perl v5.30.0 2019-07-26 PAR::Dist(3)