Report for CGI-AppToolkit-0.051

Back
From: metabase:user:314402c4-2aae-11df-837a-5e0a49663a4f
Subject: UNKNOWN CGI-AppToolkit-0.051 v5.24.1 RC3 FreeBSD
Date: 2016-09-10T10:11:43Z

This distribution has been tested as part of the CPAN Testers
project, supporting the Perl programming language.  See
http://wiki.cpantesters.org/ for more information or email
questions to cpan-testers-discuss@perl.org


--
Dear Rob Giseburt,

This is a computer-generated report for CGI-AppToolkit-0.051
on perl 5.24.1, created by CPAN-Reporter-1.2018.

Thank you for uploading your work to CPAN.  However, attempting to
test your distribution gave an inconclusive result.

This could be because your distribution had an error during the make/build
stage, did not define tests, tests could not be found, because your tests were
interrupted before they finished, or because the results of the tests could not
be parsed.  You may wish to consult the CPAN Testers Wiki:

http://wiki.cpantesters.org/wiki/CPANAuthorNotes

Sections of this report:

    * Tester comments
    * Program output
    * Prerequisites
    * Environment and other context

------------------------------
TESTER COMMENTS
------------------------------

Additional comments from tester:

none provided

------------------------------
PROGRAM OUTPUT
------------------------------

Output from '/usr/bin/make':

cp lib/CGI/AppToolkit/Data/SQLObject.pm blib/lib/CGI/AppToolkit/Data/SQLObject.pm
cp lib/CGI/AppToolkit.pm blib/lib/CGI/AppToolkit.pm
cp lib/CGI/AppToolkit/Template/Filter/BR.pm blib/lib/CGI/AppToolkit/Template/Filter/BR.pm
cp lib/CGI/AppToolkit/Data/Object.pm blib/lib/CGI/AppToolkit/Data/Object.pm
cp lib/CGI/AppToolkit/Template.pm blib/lib/CGI/AppToolkit/Template.pm
cp lib/CGI/AppToolkit/Data/Automorph.pm blib/lib/CGI/AppToolkit/Data/Automorph.pm
cp lib/CGI/AppToolkit/Template/Filter.pm blib/lib/CGI/AppToolkit/Template/Filter.pm
cp lib/CGI/AppToolkit/Template/Filter/Money.pm blib/lib/CGI/AppToolkit/Template/Filter/Money.pm
cp lib/CGI/AppToolkit/Template/Filter/Abs.pm blib/lib/CGI/AppToolkit/Template/Filter/Abs.pm
cp lib/CGI/AppToolkit/Template/TemplateC.pm blib/lib/CGI/AppToolkit/Template/TemplateC.pm
cp lib/CGI/AppToolkit/Template/Filter/HTML.pm blib/lib/CGI/AppToolkit/Template/Filter/HTML.pm
cp lib/CGI/AppToolkit/Data/TestSQLObject.pm blib/lib/CGI/AppToolkit/Data/TestSQLObject.pm
cp lib/CGI/AppToolkit/Template/Filter/URL.pm blib/lib/CGI/AppToolkit/Template/Filter/URL.pm
cd Template && make all
c++ -c    -DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2 -O2 -pipe    -DVERSION=\"\"  -DXS_VERSION=\"\" -DPIC -fPIC "-I/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE"   DecisionNode.cpp
c++ -c    -DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2 -O2 -pipe    -DVERSION=\"\"  -DXS_VERSION=\"\" -DPIC -fPIC "-I/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE"   RepeatNode.cpp
c++ -c    -DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2 -O2 -pipe    -DVERSION=\"\"  -DXS_VERSION=\"\" -DPIC -fPIC "-I/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE"   TemplateC.cpp
TemplateC.cpp:422:18: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                if (word_pos = get_token('$', temp_pos)) {
                                    ~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:422:18: note: place parentheses around the assignment to silence this warning
                                if (word_pos = get_token('$', temp_pos)) {
                                             ^
                                    (                                  )
TemplateC.cpp:422:18: note: use '==' to turn this assignment into an equality comparison
                                if (word_pos = get_token('$', temp_pos)) {
                                             ^
                                             ==
TemplateC.cpp:428:21: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                        if (filter_pos = get_filter(temp_pos, filter_end_pos, array)) {
                                            ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:428:21: note: place parentheses around the assignment to silence this warning
                                        if (filter_pos = get_filter(temp_pos, filter_end_pos, array)) {
                                                       ^
                                            (                                                       )
TemplateC.cpp:428:21: note: use '==' to turn this assignment into an equality comparison
                                        if (filter_pos = get_filter(temp_pos, filter_end_pos, array)) {
                                                       ^
                                                       ==
TemplateC.cpp:616:25: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                } else if (word_pos = get_token('@', temp_pos)) {
                                           ~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:616:25: note: place parentheses around the assignment to silence this warning
                                } else if (word_pos = get_token('@', temp_pos)) {
                                                    ^
                                           (                                  )
TemplateC.cpp:616:25: note: use '==' to turn this assignment into an equality comparison
                                } else if (word_pos = get_token('@', temp_pos)) {
                                                    ^
                                                    ==
TemplateC.cpp:689:19: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                        if (word_pos = get_token('$', temp_pos)) {
                                            ~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:689:19: note: place parentheses around the assignment to silence this warning
                                        if (word_pos = get_token('$', temp_pos)) {
                                                     ^
                                            (                                  )
TemplateC.cpp:689:19: note: use '==' to turn this assignment into an equality comparison
                                        if (word_pos = get_token('$', temp_pos)) {
                                                     ^
                                                     ==
TemplateC.cpp:776:26: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                        } else if (word_pos = get_token('@', temp_pos)) {
                                                   ~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:776:26: note: place parentheses around the assignment to silence this warning
                                        } else if (word_pos = get_token('@', temp_pos)) {
                                                            ^
                                                   (                                  )
TemplateC.cpp:776:26: note: use '==' to turn this assignment into an equality comparison
                                        } else if (word_pos = get_token('@', temp_pos)) {
                                                            ^
                                                            ==
TemplateC.cpp:881:29: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                           ~~~~~~~~~^~~~~~~~~~~~~~~~~~~
TemplateC.cpp:881:29: note: place parentheses around the assignment to silence this warning
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                           (                           )
TemplateC.cpp:881:29: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                                    ==
TemplateC.cpp:909:25: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                        if (filter_pos = get_filter(try_pos, filter_end_pos, array)) {
                                                                            ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:909:25: note: place parentheses around the assignment to silence this warning
                                                                        if (filter_pos = get_filter(try_pos, filter_end_pos, array)) {
                                                                                       ^
                                                                            (                                                      )
TemplateC.cpp:909:25: note: use '==' to turn this assignment into an equality comparison
                                                                        if (filter_pos = get_filter(try_pos, filter_end_pos, array)) {
                                                                                       ^
                                                                                       ==
TemplateC.cpp:924:31: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (filter_pos = get_filter(try_pos, filter_end_pos, array)) {                                                                   
                                                                           ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:924:31: note: place parentheses around the assignment to silence this warning
                                                                } else if (filter_pos = get_filter(try_pos, filter_end_pos, array)) {                                                                   
                                                                                      ^
                                                                           (                                                      )
TemplateC.cpp:924:31: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (filter_pos = get_filter(try_pos, filter_end_pos, array)) {                                                                   
                                                                                      ^
                                                                                      ==
TemplateC.cpp:1006:29: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                           ~~~~~~~~~^~~~~~~~~~~~~~~~~~~
TemplateC.cpp:1006:29: note: place parentheses around the assignment to silence this warning
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                           (                           )
TemplateC.cpp:1006:29: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                                    ==
TemplateC.cpp:1037:31: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (string_pos = get_word_number(try_pos)) {                                                                     
                                                                           ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:1037:31: note: place parentheses around the assignment to silence this warning
                                                                } else if (string_pos = get_word_number(try_pos)) {                                                                     
                                                                                      ^
                                                                           (                                    )
TemplateC.cpp:1037:31: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (string_pos = get_word_number(try_pos)) {                                                                     
                                                                                      ^
                                                                                      ==
TemplateC.cpp:1077:30: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (temp2_pos = get_word_number(try_pos)) {                                                                      
                                                                           ~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:1077:30: note: place parentheses around the assignment to silence this warning
                                                                } else if (temp2_pos = get_word_number(try_pos)) {                                                                      
                                                                                     ^
                                                                           (                                   )
TemplateC.cpp:1077:30: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (temp2_pos = get_word_number(try_pos)) {                                                                      
                                                                                     ^
                                                                                     ==
TemplateC.cpp:1124:30: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (temp2_pos = get_word_number(try_pos)) {                                                                      
                                                                           ~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:1124:30: note: place parentheses around the assignment to silence this warning
                                                                } else if (temp2_pos = get_word_number(try_pos)) {                                                                      
                                                                                     ^
                                                                           (                                   )
TemplateC.cpp:1124:30: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (temp2_pos = get_word_number(try_pos)) {                                                                      
                                                                                     ^
                                                                                     ==
TemplateC.cpp:1325:29: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                           ~~~~~~~~~^~~~~~~~~~~~~~~~~~~
TemplateC.cpp:1325:29: note: place parentheses around the assignment to silence this warning
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                           (                           )
TemplateC.cpp:1325:29: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                                    ==
TemplateC.cpp:1471:29: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                           ~~~~~~~~~^~~~~~~~~~~~~~~~~~~
TemplateC.cpp:1471:29: note: place parentheses around the assignment to silence this warning
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                           (                           )
TemplateC.cpp:1471:29: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (word_pos = get_word(try_pos)) {
                                                                                    ^
                                                                                    ==
TemplateC.cpp:1501:31: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
                                                                } else if (string_pos = get_word_number(try_pos)) {                                                                     
                                                                           ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
TemplateC.cpp:1501:31: note: place parentheses around the assignment to silence this warning
                                                                } else if (string_pos = get_word_number(try_pos)) {                                                                     
                                                                                      ^
                                                                           (                                    )
TemplateC.cpp:1501:31: note: use '==' to turn this assignment into an equality comparison
                                                                } else if (string_pos = get_word_number(try_pos)) {                                                                     
                                                                                      ^
                                                                                      ==
TemplateC.cpp:1610:14: warning: '&&' within '||' [-Wlogical-op-parentheses]
        if (!failed && mystack.size() > 1 || in_variable_text) {
            ~~~~~~~~^~~~~~~~~~~~~~~~~~~~~ ~~
TemplateC.cpp:1610:14: note: place parentheses around the '&&' expression to silence this warning
        if (!failed && mystack.size() > 1 || in_variable_text) {
                    ^
            (                            )
TemplateC.cpp:1617:15: warning: conversion from string literal to 'char *' is deprecated [-Wc++11-compat-deprecated-writable-strings]
                        typecode = "@";
                                   ^
TemplateC.cpp:1618:20: warning: conversion from string literal to 'char *' is deprecated [-Wc++11-compat-deprecated-writable-strings]
                        typecode_html = "repeattoken";
                                        ^
TemplateC.cpp:1620:15: warning: conversion from string literal to 'char *' is deprecated [-Wc++11-compat-deprecated-writable-strings]
                        typecode = "$";
                                   ^
TemplateC.cpp:1621:20: warning: conversion from string literal to 'char *' is deprecated [-Wc++11-compat-deprecated-writable-strings]
                        typecode_html = "iftoken";
                                        ^
20 warnings generated.
c++ -c    -DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2 -O2 -pipe    -DVERSION=\"\"  -DXS_VERSION=\"\" -DPIC -fPIC "-I/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE"   TemplateNode.cpp
TemplateNode.cpp:47:9: warning: expression which evaluates to zero treated as a null pointer constant of type 'char *' [-Wnon-literal-null-conversion]
        return '\0';
               ^~~~
1 warning generated.
c++ -c    -DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2 -O2 -pipe    -DVERSION=\"\"  -DXS_VERSION=\"\" -DPIC -fPIC "-I/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE"   TextNode.cpp
c++ -c    -DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2 -O2 -pipe    -DVERSION=\"\"  -DXS_VERSION=\"\" -DPIC -fPIC "-I/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE"   TokenNode.cpp
ar cr libtemplatelib.a DecisionNode.o  RepeatNode.o  TemplateC.o  TemplateNode.o  TextNode.o  TokenNode.o
: libtemplatelib.a
Running Mkbootstrap for TemplateC ()
chmod 644 "TemplateC.bs"
"/usr/perl5.24.1-RC3p/bin/perl" -MExtUtils::Command::MM -e 'cp_nonempty' -- TemplateC.bs ../blib/arch/auto/CGI/AppToolkit/Template/TemplateC/TemplateC.bs 644
"/usr/perl5.24.1-RC3p/bin/perl" "/usr/perl5.24.1-RC3p/lib/5.24.1/ExtUtils/xsubpp"  -typemap '/usr/perl5.24.1-RC3p/lib/5.24.1/ExtUtils/typemap' -typemap '/home/cpansand/.cpan/build/2016091009/CGI-AppToolkit-0.051-1/Template/typemap'  TemplateC.xs > TemplateC.xsc
mv TemplateC.xsc TemplateC.c
c++ -c    -DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2 -O2 -pipe    -DVERSION=\"0.01\"  -DXS_VERSION=\"0.01\" -DPIC -fPIC "-I/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE"   TemplateC.c
c++: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated
TemplateC.c:179:37: error: cast from pointer to smaller type 'I32' (aka 'int') loses information
            sv_setref_iv( RETVALSV, CLASS, (I32)RETVAL );
                                           ^~~~~~~~~~~
/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE/embed.h:669:57: note: expanded from macro 'sv_setref_iv'
#define sv_setref_iv(a,b,c)     Perl_sv_setref_iv(aTHX_ a,b,c)
                                                            ^
TemplateC.c:319:1: warning: duplicate 'extern' declaration specifier [-Wduplicate-decl-specifier]
XS_EXTERNAL(boot_CGI__AppToolkit__Template__TemplateC); /* prototype to pass -Wmissing-prototypes */
^
/usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd/CORE/XSUB.h:146:33: note: expanded from macro 'XS_EXTERNAL'
#      define XS_EXTERNAL(name) extern "C" XSPROTO(name)
                                ^
1 warning and 1 error generated.
*** Error code 1

Stop.
make[1]: stopped in /home/cpansand/.cpan/build/2016091009/CGI-AppToolkit-0.051-1/Template
*** Error code 1

Stop.
make: stopped in /home/cpansand/.cpan/build/2016091009/CGI-AppToolkit-0.051-1

------------------------------
PREREQUISITES
------------------------------

Prerequisite modules loaded:

requires:

    Module              Need Have 
    ------------------- ---- -----
    CGI                 0    4.32 
    DBI                 0    1.636

build_requires:

    Module              Need Have 
    ------------------- ---- -----
    ExtUtils::MakeMaker 0    7.22 


------------------------------
ENVIRONMENT AND OTHER CONTEXT
------------------------------

Environment variables:

    LC_ALL = de_DE.ISO8859-1
    PATH = /usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/sbin:/home/cpansand/bin/freebsd10.1:/home/cpansand/bin/sh:/home/cpansand/bin:/usr/games:/home/cpansand/devel:/home/eserte/src/srezic-misc/scripts
    PERL = /usr/perl5.24.1-RC3p/bin/perl
    PERL5LIB = 
    PERL5OPT = 
    PERL5_CPANPLUS_IS_RUNNING = 8516
    PERL5_CPAN_IS_RUNNING = 8516
    PERL5_CPAN_IS_RUNNING_IN_RECURSION = 8274,8516
    PERLDOC = -MPod::Perldoc::ToTextOverstrike
    PERL_BATCH = yes
    PERL_CANARY_STABILITY_NOPROMPT = 1
    PERL_CPAN_REPORTER_CONFIG = /var/tmp/cpansmoker-1023/2016091009/cpanreporter_004_config.ini
    PERL_EXTUTILS_AUTOINSTALL = --defaultdeps
    SHELL = /usr/local/bin/zsh
    TERM = screen
    TMPDIR = /var/tmp/cpansmoker-1023/2016091009

Perl special variables (and OS-specific diagnostics, for MSWin32):

    $^X = /usr/perl5.24.1-RC3p/bin/perl
    $UID/$EUID = 1023 / 1023
    $GID = 1023 1023
    $EGID = 1023 1023

Perl module toolchain versions installed:

    Module              Have      
    ------------------- ----------
    CPAN                2.14      
    CPAN::Meta          2.150010  
    Cwd                 3.63_01   
    ExtUtils::CBuilder  0.280225  
    ExtUtils::Command   7.22      
    ExtUtils::Install   2.04      
    ExtUtils::MakeMaker 7.22      
    ExtUtils::Manifest  1.70      
    ExtUtils::ParseXS   3.31      
    File::Spec          3.63_01   
    JSON                2.90      
    JSON::PP            2.27300_01
    Module::Build       0.4220    
    Module::Signature   0.80      
    Parse::CPAN::Meta   2.150010  
    Test::Harness       3.36_01   
    Test::More          1.302052  
    YAML                1.18      
    YAML::Syck          1.29      
    version             0.9917    


--

Summary of my perl5 (revision 5 version 24 subversion 1) configuration:
   
  Platform:
    osname=freebsd, osvers=10.1-release, archname=amd64-freebsd
    uname='freebsd cvrsnica-freebsd-101.herceg.de 10.1-release freebsd 10.1-release #0 r274401: tue nov 11 21:02:49 utc 2014 root@releng1.nyi.freebsd.org:usrobjusrsrcsysgeneric amd64 '
    config_args='-ds -e -Dprefix=/usr/perl5.24.1-RC3p -Dcf_email=srezic@cpan.org -Doptimize=-O2 -pipe'
    hint=recommended, useposix=true, d_sigaction=define
    useithreads=undef, usemultiplicity=undef
    use64bitint=define, use64bitall=define, uselongdouble=undef
    usemymalloc=n, bincompat5005=undef
  Compiler:
    cc='cc', ccflags ='-DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include -D_FORTIFY_SOURCE=2',
    optimize='-O2 -pipe',
    cppflags='-DHAS_FPSETMASK -DHAS_FLOATINGPOINT_H -fno-strict-aliasing -pipe -fstack-protector -I/usr/local/include'
    ccversion='', gccversion='4.2.1 Compatible FreeBSD Clang 3.4.1 (tags/RELEASE_34/dot1-final 208032)', gccosandvers=''
    intsize=4, longsize=8, ptrsize=8, doublesize=8, byteorder=12345678, doublekind=3
    d_longlong=define, longlongsize=8, d_longdbl=define, longdblsize=16, longdblkind=3
    ivtype='long', ivsize=8, nvtype='double', nvsize=8, Off_t='off_t', lseeksize=8
    alignbytes=8, prototype=define
  Linker and Libraries:
    ld='cc', ldflags ='-pthread -Wl,-E  -fstack-protector -L/usr/local/lib'
    libpth=/usr/lib /usr/local/lib /usr/include/clang/3.4.1 /usr/lib
    libs=-lpthread -lgdbm -lm -lcrypt -lutil -lc
    perllibs=-lpthread -lm -lcrypt -lutil -lc
    libc=, so=so, useshrplib=false, libperl=libperl.a
    gnulibc_version=''
  Dynamic Linking:
    dlsrc=dl_dlopen.xs, dlext=so, d_dlsymun=undef, ccdlflags=' '
    cccdlflags='-DPIC -fPIC', lddlflags='-shared  -L/usr/local/lib -fstack-protector'


Characteristics of this binary (from libperl): 
  Compile-time options: HAS_TIMES PERLIO_LAYERS PERL_COPY_ON_WRITE
                        PERL_DONT_CREATE_GVSV
                        PERL_HASH_FUNC_ONE_AT_A_TIME_HARD PERL_MALLOC_WRAP
                        PERL_PRESERVE_IVUV USE_64_BIT_ALL USE_64_BIT_INT
                        USE_LARGE_FILES USE_LOCALE USE_LOCALE_COLLATE
                        USE_LOCALE_CTYPE USE_LOCALE_NUMERIC USE_LOCALE_TIME
                        USE_PERLIO USE_PERL_ATOF
  Locally applied patches:
	RC3
  Built under freebsd
  Compiled at Aug 19 2016 19:51:18
  %ENV:
    PERL="/usr/perl5.24.1-RC3p/bin/perl"
    PERL5LIB=""
    PERL5OPT=""
    PERL5_CPANPLUS_IS_RUNNING="8516"
    PERL5_CPAN_IS_RUNNING="8516"
    PERL5_CPAN_IS_RUNNING_IN_RECURSION="8274,8516"
    PERLDOC="-MPod::Perldoc::ToTextOverstrike"
    PERL_BATCH="yes"
    PERL_CANARY_STABILITY_NOPROMPT="1"
    PERL_CPAN_REPORTER_CONFIG="/var/tmp/cpansmoker-1023/2016091009/cpanreporter_004_config.ini"
    PERL_EXTUTILS_AUTOINSTALL="--defaultdeps"
  @INC:
    /usr/perl5.24.1-RC3p/lib/site_perl/5.24.1/amd64-freebsd
    /usr/perl5.24.1-RC3p/lib/site_perl/5.24.1
    /usr/perl5.24.1-RC3p/lib/5.24.1/amd64-freebsd
    /usr/perl5.24.1-RC3p/lib/5.24.1
    .