Provided by: perl-cross-debian_0.0.5_all 

NAME
perl-cross-staging - Long term maintenance of cross-build support for the Debian configuration of perl
SYNOPSIS
perl-cross-staging
perl-cross-staging takes no commands or options.
DESCRIPTION
perl-cross-staging supports the long term maintenance of cross-build support for the Debian configuration
of perl.
perl-cross-staging assists in the producuction of config files from the current perl build tree to update
existing perl-cross-debian support by staging native builds of perl patched to support
perl-cross-staging.
Config files generated by perl-cross-staging need substantial manual editing and updating before being
usable for a cross-build or inclusion into perl-cross-debian.
UPDATING CROSS CONFIG FILES
Each new version of perl introduces and rearranges the existing config values and the config.h and
config.sh files for each variant need to be updated.
Some sections simply need to be moved around within the file for easier comparison, some sections will be
new (and may need adjustment if the new values are architecture-sensitive) and some may need to be
removed. Some values include the version string of the perl version being built. Some values include the
name of the compiler or preprocessor. There are values which specify the original build directory and
these need to be replaced with PERL_BUILD_DIR:
installarchlib='PERL_BUILD_DIR/debian/tmp/usr/lib/perl/5.16'
Missing values will be easiest to spot as these cause the build to fail with invalid preprocessing
directives.
config.h:2229:3: error: invalid preprocessing directive #HAS_STATIC_INLINE
config.h:2766:3: error: invalid preprocessing directive #HAS_SOCKADDR_SA_LEN
config.h:2773:3: error: invalid preprocessing directive #HAS_SIN6_SCOPE_ID
config.h:3614:3: error: invalid preprocessing directive #HAS_PRCTL
config.h:3615:3: error: invalid preprocessing directive #HAS_PRCTL_SET_NAME
Probably the biggest problem is reorganisation of the files which arises because the files are all
generated, rather than edited. This can easily lead to sections being added in one place of the file and
being repeated (with differing values) elsewhere. Use a comparison tool like meld to push snippets in and
out of the staged files with usable previous/next search/find regexp support.
Once one of the variant files has been updated, merge the changes into the other staged variants before
comparing those with the files from the previous version of perl.
Old perl version strings also need to be updated.
ARCHITECTURE
Typically, perl-cross-staging is run for the native architecture on the expectation that most of the
updates to the staged files will include changes for the cross architecture. e.g. updates for 5.16.2 were
prepared by staging amd64 and porting the updates into the cross architecture files for 5.14.2.
perl-cross-staging does support attempting to stage a cross build but this has not been tested. Please
report success or failure.
UPSTREAM SUPPORT
Note that work is ongoing to get perl cross-building upstream and this is not complete.
perl-cross-staging will need changes once this work is complete. The aim is to make it easier to obtain
the configuration value cache for architectures where real hardware or an emulation model can be accessed
over a network. This work takes place at
https://github.com/codehelp/perl/tree/jrobinson/configure-for-cross which is intermittently pulled into
the main cross-configure branch at https://github.com/castaway/perl/tree/jrobinson/configure-for-cross
BUGS
Currently perl-cross-staging does not substitute the working directory for PERL_BUILD_DIR in the .sh
scripts - this is left as one of the manual steps required before including the generated files into
perl-cross-debian.
AUTHOR
Neil Williams <codehelp@debian.org>
Wrote this manpage for the Debian system.
COPYRIGHT
Copyright © 2012 Neil Williams
This manual page was written for the Debian system (and may be used by others).
Permission is granted to copy, distribute and/or modify this document under the terms of the GNU General
Public License, Version 2 or (at your option) any later version published by the Free Software
Foundation.
On Debian systems, the complete text of the GNU General Public License can be found in
/usr/share/common-licenses/GPL.
perl-cross-staging 05/19/2013 PERL-CROSS-STAGING(1)