| Filename | C:/tmp64ng/perl/lib/ExtUtils/Liblist/Kid.pm | 
| Statements | Executed 4039 statements in 46.8ms | 
| Calls | P | F | Exclusive Time  | 
        Inclusive Time  | 
        Subroutine | 
|---|---|---|---|---|---|
| 183 | 1 | 1 | 15.6ms | 15.6ms | ExtUtils::Liblist::Kid::CORE:ftfile (opcode) | 
| 3 | 1 | 1 | 15.6ms | 46.8ms | ExtUtils::Liblist::Kid::_win32_ext | 
| 1 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::BEGIN@12 | 
| 1 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::BEGIN@13 | 
| 1 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::BEGIN@16 | 
| 1 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::BEGIN@17 | 
| 1 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::BEGIN@18 | 
| 1 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::BEGIN@19 | 
| 1 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::BEGIN@8 | 
| 63 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::CORE:ftdir (opcode) | 
| 522 | 8 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::CORE:match (opcode) | 
| 378 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::CORE:regcomp (opcode) | 
| 198 | 6 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::CORE:subst (opcode) | 
| 189 | 4 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::_debug | 
| 0 | 0 | 0 | 0s | 0s | ExtUtils::Liblist::Kid::_unix_os2_ext | 
| 0 | 0 | 0 | 0s | 0s | ExtUtils::Liblist::Kid::_vms_ext | 
| 126 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::_win32_attach_extensions | 
| 63 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::_win32_build_file_list | 
| 63 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::_win32_build_prefixed_list | 
| 3 | 1 | 1 | 0s | 15.6ms | ExtUtils::Liblist::Kid::_win32_default_search_paths | 
| 3 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::_win32_lib_extensions | 
| 3 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::_win32_make_lib_search_list | 
| 63 | 1 | 1 | 0s | 15.6ms | ExtUtils::Liblist::Kid::_win32_search_file | 
| 378 | 1 | 1 | 0s | 0s | ExtUtils::Liblist::Kid::_win32_try_attach_extension | 
| 3 | 1 | 1 | 0s | 46.8ms | ExtUtils::Liblist::Kid::ext | 
| Line | State ments  | 
      Time on line  | 
      Calls | Time in subs  | 
      Code | 
|---|---|---|---|---|---|
| 1 | package ExtUtils::Liblist::Kid; | ||||
| 2 | |||||
| 3 | # XXX Splitting this out into its own .pm is a temporary solution. | ||||
| 4 | |||||
| 5 | # This kid package is to be used by MakeMaker. It will not work if | ||||
| 6 | # $self is not a Makemaker. | ||||
| 7 | |||||
| 8 | 2 | 0s | 1 | 0s | # spent 0s within ExtUtils::Liblist::Kid::BEGIN@8 which was called:
#    once (0s+0s) by main::BEGIN@1 at line 8 # spent     0s making 1 call to ExtUtils::Liblist::Kid::BEGIN@8  | 
| 9 | |||||
| 10 | # Broken out of MakeMaker from version 4.11 | ||||
| 11 | |||||
| 12 | 2 | 0s | 2 | 0s | # spent 0s within ExtUtils::Liblist::Kid::BEGIN@12 which was called:
#    once (0s+0s) by main::BEGIN@1 at line 12 # spent     0s making 1 call to ExtUtils::Liblist::Kid::BEGIN@12
# spent     0s making 1 call to strict::import  | 
| 13 | 2 | 0s | 2 | 0s | # spent 0s within ExtUtils::Liblist::Kid::BEGIN@13 which was called:
#    once (0s+0s) by main::BEGIN@1 at line 13 # spent     0s making 1 call to ExtUtils::Liblist::Kid::BEGIN@13
# spent     0s making 1 call to warnings::import  | 
| 14 | 1 | 0s | our $VERSION = '7.04'; | ||
| 15 | |||||
| 16 | 2 | 0s | 2 | 0s | # spent 0s within ExtUtils::Liblist::Kid::BEGIN@16 which was called:
#    once (0s+0s) by main::BEGIN@1 at line 16 # spent     0s making 1 call to ExtUtils::Liblist::Kid::BEGIN@16
# spent     0s making 1 call to ExtUtils::MakeMaker::Config::import  | 
| 17 | 2 | 0s | 2 | 0s | # spent 0s within ExtUtils::Liblist::Kid::BEGIN@17 which was called:
#    once (0s+0s) by main::BEGIN@1 at line 17 # spent     0s making 1 call to Exporter::import
# spent     0s making 1 call to ExtUtils::Liblist::Kid::BEGIN@17  | 
| 18 | 2 | 0s | 2 | 0s | # spent 0s within ExtUtils::Liblist::Kid::BEGIN@18 which was called:
#    once (0s+0s) by main::BEGIN@1 at line 18 # spent     0s making 1 call to Exporter::import
# spent     0s making 1 call to ExtUtils::Liblist::Kid::BEGIN@18  | 
| 19 | 2 | 15.6ms | 1 | 0s | # spent 0s within ExtUtils::Liblist::Kid::BEGIN@19 which was called:
#    once (0s+0s) by main::BEGIN@1 at line 19 # spent     0s making 1 call to ExtUtils::Liblist::Kid::BEGIN@19  | 
| 20 | |||||
| 21 | # spent 46.8ms (0s+46.8) within ExtUtils::Liblist::Kid::ext which was called 3 times, avg 15.6ms/call:
# 3 times (0s+46.8ms) by ExtUtils::MM_Unix::extliblist at line 13 of ExtUtils/Liblist.pm, avg 15.6ms/call  | ||||
| 22 | 3 | 0s | 3 | 46.8ms |     if    ( $^O eq 'VMS' )     { return &_vms_ext; }     # spent  46.8ms making 3 calls to ExtUtils::Liblist::Kid::_win32_ext, avg 15.6ms/call  | 
| 23 | elsif ( $^O eq 'MSWin32' ) { return &_win32_ext; } | ||||
| 24 | else { return &_unix_os2_ext; } | ||||
| 25 | } | ||||
| 26 | |||||
| 27 | sub _unix_os2_ext { | ||||
| 28 | my ( $self, $potential_libs, $verbose, $give_libs ) = @_; | ||||
| 29 | $verbose ||= 0; | ||||
| 30 | |||||
| 31 | if ( $^O =~ /os2|android/ and $Config{perllibs} ) { | ||||
| 32 | |||||
| 33 | # Dynamic libraries are not transitive, so we may need including | ||||
| 34 | # the libraries linked against perl.dll/libperl.so again. | ||||
| 35 | |||||
| 36 | $potential_libs .= " " if $potential_libs; | ||||
| 37 | $potential_libs .= $Config{perllibs}; | ||||
| 38 | } | ||||
| 39 | return ( "", "", "", "", ( $give_libs ? [] : () ) ) unless $potential_libs; | ||||
| 40 | warn "Potential libraries are '$potential_libs':\n" if $verbose; | ||||
| 41 | |||||
| 42 | my ( $so ) = $Config{so}; | ||||
| 43 | my ( $libs ) = defined $Config{perllibs} ? $Config{perllibs} : $Config{libs}; | ||||
| 44 | my $Config_libext = $Config{lib_ext} || ".a"; | ||||
| 45 | my $Config_dlext = $Config{dlext}; | ||||
| 46 | |||||
| 47 | # compute $extralibs, $bsloadlibs and $ldloadlibs from | ||||
| 48 | # $potential_libs | ||||
| 49 | # this is a rewrite of Andy Dougherty's extliblist in perl | ||||
| 50 | |||||
| 51 | my ( @searchpath ); # from "-L/path" entries in $potential_libs | ||||
| 52 | my ( @libpath ) = split " ", $Config{'libpth'} || ''; | ||||
| 53 | my ( @ldloadlibs, @bsloadlibs, @extralibs, @ld_run_path, %ld_run_path_seen ); | ||||
| 54 | my ( @libs, %libs_seen ); | ||||
| 55 | my ( $fullname, @fullname ); | ||||
| 56 | my ( $pwd ) = cwd(); # from Cwd.pm | ||||
| 57 | my ( $found ) = 0; | ||||
| 58 | |||||
| 59 | foreach my $thislib ( split ' ', $potential_libs ) { | ||||
| 60 | my ( $custom_name ) = ''; | ||||
| 61 | |||||
| 62 | # Handle possible linker path arguments. | ||||
| 63 | if ( $thislib =~ s/^(-[LR]|-Wl,-R|-Wl,-rpath,)// ) { # save path flag type | ||||
| 64 | my ( $ptype ) = $1; | ||||
| 65 | unless ( -d $thislib ) { | ||||
| 66 | warn "$ptype$thislib ignored, directory does not exist\n" | ||||
| 67 | if $verbose; | ||||
| 68 | next; | ||||
| 69 | } | ||||
| 70 | my ( $rtype ) = $ptype; | ||||
| 71 | if ( ( $ptype eq '-R' ) or ( $ptype =~ m!^-Wl,-[Rr]! ) ) { | ||||
| 72 | if ( $Config{'lddlflags'} =~ /-Wl,-[Rr]/ ) { | ||||
| 73 | $rtype = '-Wl,-R'; | ||||
| 74 | } | ||||
| 75 | elsif ( $Config{'lddlflags'} =~ /-R/ ) { | ||||
| 76 | $rtype = '-R'; | ||||
| 77 | } | ||||
| 78 | } | ||||
| 79 | unless ( File::Spec->file_name_is_absolute( $thislib ) ) { | ||||
| 80 | warn "Warning: $ptype$thislib changed to $ptype$pwd/$thislib\n"; | ||||
| 81 | $thislib = $self->catdir( $pwd, $thislib ); | ||||
| 82 | } | ||||
| 83 | push( @searchpath, $thislib ); | ||||
| 84 | push( @extralibs, "$ptype$thislib" ); | ||||
| 85 | push( @ldloadlibs, "$rtype$thislib" ); | ||||
| 86 | next; | ||||
| 87 | } | ||||
| 88 | |||||
| 89 | if ( $thislib =~ m!^-Wl,! ) { | ||||
| 90 | push( @extralibs, $thislib ); | ||||
| 91 | push( @ldloadlibs, $thislib ); | ||||
| 92 | next; | ||||
| 93 | } | ||||
| 94 | |||||
| 95 | # Handle possible library arguments. | ||||
| 96 | if ( $thislib =~ s/^-l(:)?// ) { | ||||
| 97 | # Handle -l:foo.so, which means that the library will | ||||
| 98 | # actually be called foo.so, not libfoo.so. This | ||||
| 99 | # is used in Android by ExtUtils::Depends to allow one XS | ||||
| 100 | # module to link to another. | ||||
| 101 | $custom_name = $1 || ''; | ||||
| 102 | } | ||||
| 103 | else { | ||||
| 104 | warn "Unrecognized argument in LIBS ignored: '$thislib'\n"; | ||||
| 105 | next; | ||||
| 106 | } | ||||
| 107 | |||||
| 108 | my ( $found_lib ) = 0; | ||||
| 109 | foreach my $thispth ( @searchpath, @libpath ) { | ||||
| 110 | |||||
| 111 | # Try to find the full name of the library. We need this to | ||||
| 112 | # determine whether it's a dynamically-loadable library or not. | ||||
| 113 | # This tends to be subject to various os-specific quirks. | ||||
| 114 | # For gcc-2.6.2 on linux (March 1995), DLD can not load | ||||
| 115 | # .sa libraries, with the exception of libm.sa, so we | ||||
| 116 | # deliberately skip them. | ||||
| 117 | if ((@fullname = | ||||
| 118 | $self->lsdir($thispth, "^\Qlib$thislib.$so.\E[0-9]+")) || | ||||
| 119 | (@fullname = | ||||
| 120 | $self->lsdir($thispth, "^\Qlib$thislib.\E[0-9]+\Q\.$so"))) { | ||||
| 121 | # Take care that libfoo.so.10 wins against libfoo.so.9. | ||||
| 122 | # Compare two libraries to find the most recent version | ||||
| 123 | # number. E.g. if you have libfoo.so.9.0.7 and | ||||
| 124 | # libfoo.so.10.1, first convert all digits into two | ||||
| 125 | # decimal places. Then we'll add ".00" to the shorter | ||||
| 126 | # strings so that we're comparing strings of equal length | ||||
| 127 | # Thus we'll compare libfoo.so.09.07.00 with | ||||
| 128 | # libfoo.so.10.01.00. Some libraries might have letters | ||||
| 129 | # in the version. We don't know what they mean, but will | ||||
| 130 | # try to skip them gracefully -- we'll set any letter to | ||||
| 131 | # '0'. Finally, sort in reverse so we can take the | ||||
| 132 | # first element. | ||||
| 133 | |||||
| 134 | #TODO: iterate through the directory instead of sorting | ||||
| 135 | |||||
| 136 | $fullname = "$thispth/" . ( | ||||
| 137 | sort { | ||||
| 138 | my ( $ma ) = $a; | ||||
| 139 | my ( $mb ) = $b; | ||||
| 140 | $ma =~ tr/A-Za-z/0/s; | ||||
| 141 | $ma =~ s/\b(\d)\b/0$1/g; | ||||
| 142 | $mb =~ tr/A-Za-z/0/s; | ||||
| 143 | $mb =~ s/\b(\d)\b/0$1/g; | ||||
| 144 | while ( length( $ma ) < length( $mb ) ) { $ma .= ".00"; } | ||||
| 145 | while ( length( $mb ) < length( $ma ) ) { $mb .= ".00"; } | ||||
| 146 | |||||
| 147 | # Comparison deliberately backwards | ||||
| 148 | $mb cmp $ma; | ||||
| 149 | } @fullname | ||||
| 150 | )[0]; | ||||
| 151 | } | ||||
| 152 | elsif ( -f ( $fullname = "$thispth/lib$thislib.$so" ) | ||||
| 153 | && ( ( $Config{'dlsrc'} ne "dl_dld.xs" ) || ( $thislib eq "m" ) ) ) | ||||
| 154 | { | ||||
| 155 | } | ||||
| 156 | elsif (-f ( $fullname = "$thispth/lib${thislib}_s$Config_libext" ) | ||||
| 157 | && ( $Config{'archname'} !~ /RM\d\d\d-svr4/ ) | ||||
| 158 | && ( $thislib .= "_s" ) ) | ||||
| 159 | { # we must explicitly use _s version | ||||
| 160 | } | ||||
| 161 | elsif ( -f ( $fullname = "$thispth/lib$thislib$Config_libext" ) ) { | ||||
| 162 | } | ||||
| 163 | elsif ( defined( $Config_dlext ) | ||||
| 164 | && -f ( $fullname = "$thispth/lib$thislib.$Config_dlext" ) ) | ||||
| 165 | { | ||||
| 166 | } | ||||
| 167 | elsif ( -f ( $fullname = "$thispth/$thislib$Config_libext" ) ) { | ||||
| 168 | } | ||||
| 169 | elsif ( -f ( $fullname = "$thispth/lib$thislib.dll$Config_libext" ) ) { | ||||
| 170 | } | ||||
| 171 | elsif ( $^O eq 'cygwin' && -f ( $fullname = "$thispth/$thislib.dll" ) ) { | ||||
| 172 | } | ||||
| 173 | elsif ( -f ( $fullname = "$thispth/Slib$thislib$Config_libext" ) ) { | ||||
| 174 | } | ||||
| 175 | elsif ($^O eq 'dgux' | ||||
| 176 | && -l ( $fullname = "$thispth/lib$thislib$Config_libext" ) | ||||
| 177 | && readlink( $fullname ) =~ /^elink:/s ) | ||||
| 178 | { | ||||
| 179 | |||||
| 180 | # Some of DG's libraries look like misconnected symbolic | ||||
| 181 | # links, but development tools can follow them. (They | ||||
| 182 | # look like this: | ||||
| 183 | # | ||||
| 184 | # libm.a -> elink:${SDE_PATH:-/usr}/sde/\ | ||||
| 185 | # ${TARGET_BINARY_INTERFACE:-m88kdgux}/usr/lib/libm.a | ||||
| 186 | # | ||||
| 187 | # , the compilation tools expand the environment variables.) | ||||
| 188 | } | ||||
| 189 | elsif ( $custom_name && -f ( $fullname = "$thispth/$thislib" ) ) { | ||||
| 190 | } | ||||
| 191 | else { | ||||
| 192 | warn "$thislib not found in $thispth\n" if $verbose; | ||||
| 193 | next; | ||||
| 194 | } | ||||
| 195 | warn "'-l$thislib' found at $fullname\n" if $verbose; | ||||
| 196 | push @libs, $fullname unless $libs_seen{$fullname}++; | ||||
| 197 | $found++; | ||||
| 198 | $found_lib++; | ||||
| 199 | |||||
| 200 | # Now update library lists | ||||
| 201 | |||||
| 202 | # what do we know about this library... | ||||
| 203 | my $is_dyna = ( $fullname !~ /\Q$Config_libext\E\z/ ); | ||||
| 204 | my $in_perl = ( $libs =~ /\B-l:?\Q${thislib}\E\b/s ); | ||||
| 205 | |||||
| 206 | # include the path to the lib once in the dynamic linker path | ||||
| 207 | # but only if it is a dynamic lib and not in Perl itself | ||||
| 208 | my ( $fullnamedir ) = dirname( $fullname ); | ||||
| 209 | push @ld_run_path, $fullnamedir | ||||
| 210 | if $is_dyna | ||||
| 211 | && !$in_perl | ||||
| 212 | && !$ld_run_path_seen{$fullnamedir}++; | ||||
| 213 | |||||
| 214 | # Do not add it into the list if it is already linked in | ||||
| 215 | # with the main perl executable. | ||||
| 216 | # We have to special-case the NeXT, because math and ndbm | ||||
| 217 | # are both in libsys_s | ||||
| 218 | unless ( | ||||
| 219 | $in_perl | ||||
| 220 | || ( $Config{'osname'} eq 'next' | ||||
| 221 | && ( $thislib eq 'm' || $thislib eq 'ndbm' ) ) | ||||
| 222 | ) | ||||
| 223 | { | ||||
| 224 | push( @extralibs, "-l$custom_name$thislib" ); | ||||
| 225 | } | ||||
| 226 | |||||
| 227 | # We might be able to load this archive file dynamically | ||||
| 228 | if ( ( $Config{'dlsrc'} =~ /dl_next/ && $Config{'osvers'} lt '4_0' ) | ||||
| 229 | || ( $Config{'dlsrc'} =~ /dl_dld/ ) ) | ||||
| 230 | { | ||||
| 231 | |||||
| 232 | # We push -l$thislib instead of $fullname because | ||||
| 233 | # it avoids hardwiring a fixed path into the .bs file. | ||||
| 234 | # Mkbootstrap will automatically add dl_findfile() to | ||||
| 235 | # the .bs file if it sees a name in the -l format. | ||||
| 236 | # USE THIS, when dl_findfile() is fixed: | ||||
| 237 | # push(@bsloadlibs, "-l$thislib"); | ||||
| 238 | # OLD USE WAS while checking results against old_extliblist | ||||
| 239 | push( @bsloadlibs, "$fullname" ); | ||||
| 240 | } | ||||
| 241 | else { | ||||
| 242 | if ( $is_dyna ) { | ||||
| 243 | |||||
| 244 | # For SunOS4, do not add in this shared library if | ||||
| 245 | # it is already linked in the main perl executable | ||||
| 246 | push( @ldloadlibs, "-l$custom_name$thislib" ) | ||||
| 247 | unless ( $in_perl and $^O eq 'sunos' ); | ||||
| 248 | } | ||||
| 249 | else { | ||||
| 250 | push( @ldloadlibs, "-l$custom_name$thislib" ); | ||||
| 251 | } | ||||
| 252 | } | ||||
| 253 | last; # found one here so don't bother looking further | ||||
| 254 | } | ||||
| 255 | warn "Warning (mostly harmless): " . "No library found for -l$thislib\n" | ||||
| 256 | unless $found_lib > 0; | ||||
| 257 | } | ||||
| 258 | |||||
| 259 | unless ( $found ) { | ||||
| 260 | return ( '', '', '', '', ( $give_libs ? \@libs : () ) ); | ||||
| 261 | } | ||||
| 262 | else { | ||||
| 263 | return ( "@extralibs", "@bsloadlibs", "@ldloadlibs", join( ":", @ld_run_path ), ( $give_libs ? \@libs : () ) ); | ||||
| 264 | } | ||||
| 265 | } | ||||
| 266 | |||||
| 267 | # spent 46.8ms (15.6+31.2) within ExtUtils::Liblist::Kid::_win32_ext which was called 3 times, avg 15.6ms/call:
# 3 times (15.6ms+31.2ms) by ExtUtils::Liblist::Kid::ext at line 22, avg 15.6ms/call  | ||||
| 268 | |||||
| 269 | 3 | 0s | require Text::ParseWords; | ||
| 270 | |||||
| 271 | 3 | 0s | my ( $self, $potential_libs, $verbose, $give_libs ) = @_; | ||
| 272 | 3 | 0s | $verbose ||= 0; | ||
| 273 | |||||
| 274 | # If user did not supply a list, we punt. | ||||
| 275 | # (caller should probably use the list in $Config{libs}) | ||||
| 276 | 3 | 0s | return ( "", "", "", "", ( $give_libs ? [] : () ) ) unless $potential_libs; | ||
| 277 | |||||
| 278 | # TODO: make this use MM_Win32.pm's compiler detection | ||||
| 279 | 3 | 0s | my %libs_seen; | ||
| 280 | my @extralibs; | ||||
| 281 | 3 | 0s | my $cc = $Config{cc} || ''; | ||
| 282 | 3 | 0s | 3 | 0s |     my $VC = $cc =~ /\bcl\b/i;     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call  | 
| 283 | 3 | 0s | 3 | 0s |     my $GC = $cc =~ /\bgcc\b/i;     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call  | 
| 284 | |||||
| 285 | 3 | 0s | 3 | 0s |     my $libext     = _win32_lib_extensions();     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::_win32_lib_extensions, avg 0s/call  | 
| 286 | 3 | 0s | my @searchpath = ( '' ); # from "-L/path" entries in $potential_libs | ||
| 287 | 3 | 0s | 3 | 15.6ms |     my @libpath    = _win32_default_search_paths( $VC, $GC );     # spent  15.6ms making 3 calls to ExtUtils::Liblist::Kid::_win32_default_search_paths, avg 5.20ms/call  | 
| 288 | 3 | 0s | 3 | 0s |     my $pwd        = cwd();                                     # from Cwd.pm     # spent     0s making 3 calls to Cwd::_win32_cwd, avg 0s/call  | 
| 289 | 3 | 0s | my $search = 1; | ||
| 290 | |||||
| 291 | # compute @extralibs from $potential_libs | ||||
| 292 | 3 | 0s | 3 | 0s |     my @lib_search_list = _win32_make_lib_search_list( $potential_libs, $verbose );     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::_win32_make_lib_search_list, avg 0s/call  | 
| 293 | 3 | 0s | for ( @lib_search_list ) { | ||
| 294 | |||||
| 295 | 63 | 0s | my $thislib = $_; | ||
| 296 | |||||
| 297 | # see if entry is a flag | ||||
| 298 | 63 | 0s | 63 | 0s |         if ( /^:\w+$/ ) {         # spent     0s making 63 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call  | 
| 299 | $search = 0 if lc eq ':nosearch'; | ||||
| 300 | $search = 1 if lc eq ':search'; | ||||
| 301 | _debug( "Ignoring unknown flag '$thislib'\n", $verbose ) if !/^:(no)?(search|default)$/i; | ||||
| 302 | next; | ||||
| 303 | } | ||||
| 304 | |||||
| 305 | # if searching is disabled, do compiler-specific translations | ||||
| 306 | 63 | 0s | unless ( $search ) { | ||
| 307 | s/^-l(.+)$/$1.lib/ unless $GC; | ||||
| 308 | s/^-L/-libpath:/ if $VC; | ||||
| 309 | push( @extralibs, $_ ); | ||||
| 310 | next; | ||||
| 311 | } | ||||
| 312 | |||||
| 313 | # handle possible linker path arguments | ||||
| 314 | 63 | 15.6ms | 126 | 0s |         if ( s/^-L// and not -d ) {         # spent     0s making 63 calls to ExtUtils::Liblist::Kid::CORE:ftdir, avg 0s/call
        # spent     0s making 63 calls to ExtUtils::Liblist::Kid::CORE:subst, avg 0s/call  | 
| 315 | _debug( "$thislib ignored, directory does not exist\n", $verbose ); | ||||
| 316 | next; | ||||
| 317 | } | ||||
| 318 | elsif ( -d ) { | ||||
| 319 | unless ( File::Spec->file_name_is_absolute( $_ ) ) { | ||||
| 320 | warn "Warning: '$thislib' changed to '-L$pwd/$_'\n"; | ||||
| 321 | $_ = $self->catdir( $pwd, $_ ); | ||||
| 322 | } | ||||
| 323 | push( @searchpath, $_ ); | ||||
| 324 | next; | ||||
| 325 | } | ||||
| 326 | |||||
| 327 | 63 | 0s | my @paths = ( @searchpath, @libpath ); | ||
| 328 | 63 | 0s | 63 | 15.6ms |         my ( $fullname, $path ) = _win32_search_file( $thislib, $libext, \@paths, $verbose, $GC );         # spent  15.6ms making 63 calls to ExtUtils::Liblist::Kid::_win32_search_file, avg 248µs/call  | 
| 329 | |||||
| 330 | 63 | 0s | if ( !$fullname ) { | ||
| 331 | warn "Warning (mostly harmless): No library found for $thislib\n"; | ||||
| 332 | next; | ||||
| 333 | } | ||||
| 334 | |||||
| 335 | 63 | 0s | 63 | 0s |         _debug( "'$thislib' found as '$fullname'\n", $verbose );         # spent     0s making 63 calls to ExtUtils::Liblist::Kid::_debug, avg 0s/call  | 
| 336 | 63 | 0s | push( @extralibs, $fullname ); | ||
| 337 | 63 | 0s | $libs_seen{$fullname} = 1 if $path; # why is this a special case? | ||
| 338 | } | ||||
| 339 | |||||
| 340 | 3 | 0s | my @libs = keys %libs_seen; | ||
| 341 | |||||
| 342 | 3 | 0s | return ( '', '', '', '', ( $give_libs ? \@libs : () ) ) unless @extralibs; | ||
| 343 | |||||
| 344 | # make sure paths with spaces are properly quoted | ||||
| 345 | 3 | 0s | @extralibs = map { qq["$_"] } @extralibs; | ||
| 346 | 3 | 0s | @libs = map { qq["$_"] } @libs; | ||
| 347 | |||||
| 348 | 3 | 0s | my $lib = join( ' ', @extralibs ); | ||
| 349 | |||||
| 350 | # normalize back to backward slashes (to help braindead tools) | ||||
| 351 | # XXX this may break equally braindead GNU tools that don't understand | ||||
| 352 | # backslashes, either. Seems like one can't win here. Cursed be CP/M. | ||||
| 353 | 3 | 0s | 3 | 0s |     $lib =~ s,/,\\,g;     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::CORE:subst, avg 0s/call  | 
| 354 | |||||
| 355 | 3 | 0s | 3 | 0s |     _debug( "Result: $lib\n", $verbose );     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::_debug, avg 0s/call  | 
| 356 | 3 | 0s | wantarray ? ( $lib, '', $lib, '', ( $give_libs ? \@libs : () ) ) : $lib; | ||
| 357 | } | ||||
| 358 | |||||
| 359 | # spent 0s within ExtUtils::Liblist::Kid::_win32_make_lib_search_list which was called 3 times, avg 0s/call:
# 3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 292, avg 0s/call  | ||||
| 360 | 3 | 0s | my ( $potential_libs, $verbose ) = @_; | ||
| 361 | |||||
| 362 | # If Config.pm defines a set of default libs, we always | ||||
| 363 | # tack them on to the user-supplied list, unless the user | ||||
| 364 | # specified :nodefault | ||||
| 365 | 3 | 0s | my $libs = $Config{'perllibs'}; | ||
| 366 | 3 | 0s | 3 | 0s |     $potential_libs = join( ' ', $potential_libs, $libs ) if $libs and $potential_libs !~ /:nodefault/i;     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call  | 
| 367 | 3 | 0s | 3 | 0s |     _debug( "Potential libraries are '$potential_libs':\n", $verbose );     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::_debug, avg 0s/call  | 
| 368 | |||||
| 369 | 3 | 0s | 3 | 0s |     $potential_libs =~ s,\\,/,g;    # normalize to forward slashes     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::CORE:subst, avg 0s/call  | 
| 370 | |||||
| 371 | 3 | 0s | 3 | 0s |     my @list = Text::ParseWords::quotewords( '\s+', 0, $potential_libs );     # spent     0s making 3 calls to Text::ParseWords::quotewords, avg 0s/call  | 
| 372 | |||||
| 373 | 3 | 0s | return @list; | ||
| 374 | } | ||||
| 375 | |||||
| 376 | # spent 15.6ms (0s+15.6) within ExtUtils::Liblist::Kid::_win32_default_search_paths which was called 3 times, avg 5.20ms/call:
# 3 times (0s+15.6ms) by ExtUtils::Liblist::Kid::_win32_ext at line 287, avg 5.20ms/call  | ||||
| 377 | 3 | 0s | my ( $VC, $GC ) = @_; | ||
| 378 | |||||
| 379 | 3 | 0s | my $libpth = $Config{'libpth'} || ''; | ||
| 380 | 3 | 0s | 3 | 0s |     $libpth =~ s,\\,/,g;            # normalize to forward slashes     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::CORE:subst, avg 0s/call  | 
| 381 | |||||
| 382 | 3 | 0s | 3 | 15.6ms |     my @libpath = Text::ParseWords::quotewords( '\s+', 0, $libpth );     # spent  15.6ms making 3 calls to Text::ParseWords::quotewords, avg 5.20ms/call  | 
| 383 | 3 | 0s | push @libpath, "$Config{installarchlib}/CORE"; # add "$Config{installarchlib}/CORE" to default search path | ||
| 384 | |||||
| 385 | 3 | 0s | push @libpath, split /;/, $ENV{LIB} if $VC and $ENV{LIB}; | ||
| 386 | 3 | 0s | push @libpath, split /;/, $ENV{LIBRARY_PATH} if $GC and $ENV{LIBRARY_PATH}; | ||
| 387 | |||||
| 388 | 3 | 0s | return @libpath; | ||
| 389 | } | ||||
| 390 | |||||
| 391 | # spent 15.6ms (0s+15.6) within ExtUtils::Liblist::Kid::_win32_search_file which was called 63 times, avg 248µs/call:
# 63 times (0s+15.6ms) by ExtUtils::Liblist::Kid::_win32_ext at line 328, avg 248µs/call  | ||||
| 392 | 63 | 0s | my ( $thislib, $libext, $paths, $verbose, $GC ) = @_; | ||
| 393 | |||||
| 394 | 63 | 0s | 63 | 0s |     my @file_list = _win32_build_file_list( $thislib, $GC, $libext );     # spent     0s making 63 calls to ExtUtils::Liblist::Kid::_win32_build_file_list, avg 0s/call  | 
| 395 | |||||
| 396 | 63 | 0s | for my $lib_file ( @file_list ) { | ||
| 397 | 63 | 0s | for my $path ( @{$paths} ) { | ||
| 398 | 183 | 0s | my $fullname = $lib_file; | ||
| 399 | 183 | 0s | $fullname = "$path\\$fullname" if $path; | ||
| 400 | |||||
| 401 | 183 | 15.6ms | 183 | 15.6ms |             return ( $fullname, $path ) if -f $fullname;             # spent  15.6ms making 183 calls to ExtUtils::Liblist::Kid::CORE:ftfile, avg 85µs/call  | 
| 402 | |||||
| 403 | 120 | 0s | 120 | 0s |             _debug( "'$thislib' not found as '$fullname'\n", $verbose );             # spent     0s making 120 calls to ExtUtils::Liblist::Kid::_debug, avg 0s/call  | 
| 404 | } | ||||
| 405 | } | ||||
| 406 | |||||
| 407 | return; | ||||
| 408 | } | ||||
| 409 | |||||
| 410 | # spent 0s within ExtUtils::Liblist::Kid::_win32_build_file_list which was called 63 times, avg 0s/call:
# 63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_search_file at line 394, avg 0s/call  | ||||
| 411 | 63 | 0s | my ( $lib, $GC, $extensions ) = @_; | ||
| 412 | |||||
| 413 | 63 | 0s | 63 | 0s |     my @pre_fixed = _win32_build_prefixed_list( $lib, $GC );     # spent     0s making 63 calls to ExtUtils::Liblist::Kid::_win32_build_prefixed_list, avg 0s/call  | 
| 414 | 63 | 0s | 126 | 0s |     return map _win32_attach_extensions( $_, $extensions ), @pre_fixed;     # spent     0s making 126 calls to ExtUtils::Liblist::Kid::_win32_attach_extensions, avg 0s/call  | 
| 415 | } | ||||
| 416 | |||||
| 417 | # spent 0s within ExtUtils::Liblist::Kid::_win32_build_prefixed_list which was called 63 times, avg 0s/call:
# 63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_build_file_list at line 413, avg 0s/call  | ||||
| 418 | 63 | 0s | my ( $lib, $GC ) = @_; | ||
| 419 | |||||
| 420 | 63 | 0s | 63 | 0s |     return $lib if $lib !~ s/^-l//;     # spent     0s making 63 calls to ExtUtils::Liblist::Kid::CORE:subst, avg 0s/call  | 
| 421 | 63 | 0s | 63 | 0s |     return $lib if $lib =~ /^lib/ and !$GC;     # spent     0s making 63 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call  | 
| 422 | |||||
| 423 | 63 | 0s | 63 | 0s |     ( my $no_prefix = $lib ) =~ s/^lib//i;     # spent     0s making 63 calls to ExtUtils::Liblist::Kid::CORE:subst, avg 0s/call  | 
| 424 | 63 | 0s | $lib = "lib$lib" if $no_prefix eq $lib; | ||
| 425 | |||||
| 426 | 63 | 0s | return ( $lib, $no_prefix ) if $GC; | ||
| 427 | return ( $no_prefix, $lib ); | ||||
| 428 | } | ||||
| 429 | |||||
| 430 | # spent 0s within ExtUtils::Liblist::Kid::_win32_attach_extensions which was called 126 times, avg 0s/call:
# 126 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_build_file_list at line 414, avg 0s/call  | ||||
| 431 | 126 | 0s | my ( $lib, $extensions ) = @_; | ||
| 432 | 126 | 0s | 378 | 0s |     return map _win32_try_attach_extension( $lib, $_ ), @{$extensions};     # spent     0s making 378 calls to ExtUtils::Liblist::Kid::_win32_try_attach_extension, avg 0s/call  | 
| 433 | } | ||||
| 434 | |||||
| 435 | # spent 0s within ExtUtils::Liblist::Kid::_win32_try_attach_extension which was called 378 times, avg 0s/call:
# 378 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_attach_extensions at line 432, avg 0s/call  | ||||
| 436 | 378 | 0s | my ( $lib, $extension ) = @_; | ||
| 437 | |||||
| 438 | 378 | 0s | 756 | 0s |     return $lib if $lib =~ /\Q$extension\E$/i;     # spent     0s making 378 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call
    # spent     0s making 378 calls to ExtUtils::Liblist::Kid::CORE:regcomp, avg 0s/call  | 
| 439 | 378 | 0s | return "$lib$extension"; | ||
| 440 | } | ||||
| 441 | |||||
| 442 | # spent 0s within ExtUtils::Liblist::Kid::_win32_lib_extensions which was called 3 times, avg 0s/call:
# 3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 285, avg 0s/call  | ||||
| 443 | 3 | 0s | my @extensions; | ||
| 444 | 3 | 0s | push @extensions, $Config{'lib_ext'} if $Config{'lib_ext'}; | ||
| 445 | 6 | 0s | 3 | 0s |     push @extensions, '.dll.a' if grep { m!^\.a$! } @extensions;     # spent     0s making 3 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call  | 
| 446 | 9 | 0s | 6 | 0s |     push @extensions, '.lib' unless grep { m!^\.lib$! } @extensions;     # spent     0s making 6 calls to ExtUtils::Liblist::Kid::CORE:match, avg 0s/call  | 
| 447 | 3 | 0s | return \@extensions; | ||
| 448 | } | ||||
| 449 | |||||
| 450 | # spent 0s within ExtUtils::Liblist::Kid::_debug which was called 189 times, avg 0s/call:
# 120 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_search_file at line 403, avg 0s/call
#  63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 335, avg 0s/call
#   3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 355, avg 0s/call
#   3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_make_lib_search_list at line 367, avg 0s/call  | ||||
| 451 | 189 | 0s | my ( $message, $verbose ) = @_; | ||
| 452 | 189 | 0s | return if !$verbose; | ||
| 453 | warn $message; | ||||
| 454 | return; | ||||
| 455 | } | ||||
| 456 | |||||
| 457 | sub _vms_ext { | ||||
| 458 | my ( $self, $potential_libs, $verbose, $give_libs ) = @_; | ||||
| 459 | $verbose ||= 0; | ||||
| 460 | |||||
| 461 | my ( @crtls, $crtlstr ); | ||||
| 462 | @crtls = ( ( $Config{'ldflags'} =~ m-/Debug-i ? $Config{'dbgprefix'} : '' ) . 'PerlShr/Share' ); | ||||
| 463 | push( @crtls, grep { not /\(/ } split /\s+/, $Config{'perllibs'} ); | ||||
| 464 | push( @crtls, grep { not /\(/ } split /\s+/, $Config{'libc'} ); | ||||
| 465 | |||||
| 466 | # In general, we pass through the basic libraries from %Config unchanged. | ||||
| 467 | # The one exception is that if we're building in the Perl source tree, and | ||||
| 468 | # a library spec could be resolved via a logical name, we go to some trouble | ||||
| 469 | # to insure that the copy in the local tree is used, rather than one to | ||||
| 470 | # which a system-wide logical may point. | ||||
| 471 | if ( $self->{PERL_SRC} ) { | ||||
| 472 | my ( $locspec, $type ); | ||||
| 473 | foreach my $lib ( @crtls ) { | ||||
| 474 | if ( ( $locspec, $type ) = $lib =~ m{^([\w\$-]+)(/\w+)?} and $locspec =~ /perl/i ) { | ||||
| 475 | if ( lc $type eq '/share' ) { $locspec .= $Config{'exe_ext'}; } | ||||
| 476 | elsif ( lc $type eq '/library' ) { $locspec .= $Config{'lib_ext'}; } | ||||
| 477 | else { $locspec .= $Config{'obj_ext'}; } | ||||
| 478 | $locspec = $self->catfile( $self->{PERL_SRC}, $locspec ); | ||||
| 479 | $lib = "$locspec$type" if -e $locspec; | ||||
| 480 | } | ||||
| 481 | } | ||||
| 482 | } | ||||
| 483 | $crtlstr = @crtls ? join( ' ', @crtls ) : ''; | ||||
| 484 | |||||
| 485 | unless ( $potential_libs ) { | ||||
| 486 | warn "Result:\n\tEXTRALIBS: \n\tLDLOADLIBS: $crtlstr\n" if $verbose; | ||||
| 487 | return ( '', '', $crtlstr, '', ( $give_libs ? [] : () ) ); | ||||
| 488 | } | ||||
| 489 | |||||
| 490 | my ( %found, @fndlibs, $ldlib ); | ||||
| 491 | my $cwd = cwd(); | ||||
| 492 | my ( $so, $lib_ext, $obj_ext ) = @Config{ 'so', 'lib_ext', 'obj_ext' }; | ||||
| 493 | |||||
| 494 | # List of common Unix library names and their VMS equivalents | ||||
| 495 | # (VMS equivalent of '' indicates that the library is automatically | ||||
| 496 | # searched by the linker, and should be skipped here.) | ||||
| 497 | my ( @flibs, %libs_seen ); | ||||
| 498 | my %libmap = ( | ||||
| 499 | 'm' => '', | ||||
| 500 | 'f77' => '', | ||||
| 501 | 'F77' => '', | ||||
| 502 | 'V77' => '', | ||||
| 503 | 'c' => '', | ||||
| 504 | 'malloc' => '', | ||||
| 505 | 'crypt' => '', | ||||
| 506 | 'resolv' => '', | ||||
| 507 | 'c_s' => '', | ||||
| 508 | 'socket' => '', | ||||
| 509 | 'X11' => 'DECW$XLIBSHR', | ||||
| 510 | 'Xt' => 'DECW$XTSHR', | ||||
| 511 | 'Xm' => 'DECW$XMLIBSHR', | ||||
| 512 | 'Xmu' => 'DECW$XMULIBSHR' | ||||
| 513 | ); | ||||
| 514 | |||||
| 515 | warn "Potential libraries are '$potential_libs'\n" if $verbose; | ||||
| 516 | |||||
| 517 | # First, sort out directories and library names in the input | ||||
| 518 | my ( @dirs, @libs ); | ||||
| 519 | foreach my $lib ( split ' ', $potential_libs ) { | ||||
| 520 | push( @dirs, $1 ), next if $lib =~ /^-L(.*)/; | ||||
| 521 | push( @dirs, $lib ), next if $lib =~ /[:>\]]$/; | ||||
| 522 | push( @dirs, $lib ), next if -d $lib; | ||||
| 523 | push( @libs, $1 ), next if $lib =~ /^-l(.*)/; | ||||
| 524 | push( @libs, $lib ); | ||||
| 525 | } | ||||
| 526 | push( @dirs, split( ' ', $Config{'libpth'} ) ); | ||||
| 527 | |||||
| 528 | # Now make sure we've got VMS-syntax absolute directory specs | ||||
| 529 | # (We don't, however, check whether someone's hidden a relative | ||||
| 530 | # path in a logical name.) | ||||
| 531 | foreach my $dir ( @dirs ) { | ||||
| 532 | unless ( -d $dir ) { | ||||
| 533 | warn "Skipping nonexistent Directory $dir\n" if $verbose > 1; | ||||
| 534 | $dir = ''; | ||||
| 535 | next; | ||||
| 536 | } | ||||
| 537 | warn "Resolving directory $dir\n" if $verbose; | ||||
| 538 | if ( File::Spec->file_name_is_absolute( $dir ) ) { | ||||
| 539 | $dir = VMS::Filespec::vmspath( $dir ); | ||||
| 540 | } | ||||
| 541 | else { | ||||
| 542 | $dir = $self->catdir( $cwd, $dir ); | ||||
| 543 | } | ||||
| 544 | } | ||||
| 545 | @dirs = grep { length( $_ ) } @dirs; | ||||
| 546 | unshift( @dirs, '' ); # Check each $lib without additions first | ||||
| 547 | |||||
| 548 | LIB: foreach my $lib ( @libs ) { | ||||
| 549 | if ( exists $libmap{$lib} ) { | ||||
| 550 | next unless length $libmap{$lib}; | ||||
| 551 | $lib = $libmap{$lib}; | ||||
| 552 | } | ||||
| 553 | |||||
| 554 | my ( @variants, $cand ); | ||||
| 555 | my ( $ctype ) = ''; | ||||
| 556 | |||||
| 557 | # If we don't have a file type, consider it a possibly abbreviated name and | ||||
| 558 | # check for common variants. We try these first to grab libraries before | ||||
| 559 | # a like-named executable image (e.g. -lperl resolves to perlshr.exe | ||||
| 560 | # before perl.exe). | ||||
| 561 | if ( $lib !~ /\.[^:>\]]*$/ ) { | ||||
| 562 | push( @variants, "${lib}shr", "${lib}rtl", "${lib}lib" ); | ||||
| 563 | push( @variants, "lib$lib" ) if $lib !~ /[:>\]]/; | ||||
| 564 | } | ||||
| 565 | push( @variants, $lib ); | ||||
| 566 | warn "Looking for $lib\n" if $verbose; | ||||
| 567 | foreach my $variant ( @variants ) { | ||||
| 568 | my ( $fullname, $name ); | ||||
| 569 | |||||
| 570 | foreach my $dir ( @dirs ) { | ||||
| 571 | my ( $type ); | ||||
| 572 | |||||
| 573 | $name = "$dir$variant"; | ||||
| 574 | warn "\tChecking $name\n" if $verbose > 2; | ||||
| 575 | $fullname = VMS::Filespec::rmsexpand( $name ); | ||||
| 576 | if ( defined $fullname and -f $fullname ) { | ||||
| 577 | |||||
| 578 | # It's got its own suffix, so we'll have to figure out the type | ||||
| 579 | if ( $fullname =~ /(?:$so|exe)$/i ) { $type = 'SHR'; } | ||||
| 580 | elsif ( $fullname =~ /(?:$lib_ext|olb)$/i ) { $type = 'OLB'; } | ||||
| 581 | elsif ( $fullname =~ /(?:$obj_ext|obj)$/i ) { | ||||
| 582 | warn "Warning (mostly harmless): " . "Plain object file $fullname found in library list\n"; | ||||
| 583 | $type = 'OBJ'; | ||||
| 584 | } | ||||
| 585 | else { | ||||
| 586 | warn "Warning (mostly harmless): " . "Unknown library type for $fullname; assuming shared\n"; | ||||
| 587 | $type = 'SHR'; | ||||
| 588 | } | ||||
| 589 | } | ||||
| 590 | elsif (-f ( $fullname = VMS::Filespec::rmsexpand( $name, $so ) ) | ||||
| 591 | or -f ( $fullname = VMS::Filespec::rmsexpand( $name, '.exe' ) ) ) | ||||
| 592 | { | ||||
| 593 | $type = 'SHR'; | ||||
| 594 | $name = $fullname unless $fullname =~ /exe;?\d*$/i; | ||||
| 595 | } | ||||
| 596 | elsif ( | ||||
| 597 | not length( $ctype ) and # If we've got a lib already, | ||||
| 598 | ( -f ( $fullname = VMS::Filespec::rmsexpand( $name, $lib_ext ) ) or -f ( $fullname = VMS::Filespec::rmsexpand( $name, '.olb' ) ) ) | ||||
| 599 | |||||
| 600 | ) | ||||
| 601 | { | ||||
| 602 | $type = 'OLB'; | ||||
| 603 | $name = $fullname unless $fullname =~ /olb;?\d*$/i; | ||||
| 604 | } | ||||
| 605 | elsif ( | ||||
| 606 | not length( $ctype ) and # If we've got a lib already, | ||||
| 607 | ( -f ( $fullname = VMS::Filespec::rmsexpand( $name, $obj_ext ) ) or -f ( $fullname = VMS::Filespec::rmsexpand( $name, '.obj' ) ) ) | ||||
| 608 | |||||
| 609 | ) | ||||
| 610 | { | ||||
| 611 | warn "Warning (mostly harmless): " . "Plain object file $fullname found in library list\n"; | ||||
| 612 | $type = 'OBJ'; | ||||
| 613 | $name = $fullname unless $fullname =~ /obj;?\d*$/i; | ||||
| 614 | } | ||||
| 615 | if ( defined $type ) { | ||||
| 616 | $ctype = $type; | ||||
| 617 | $cand = $name; | ||||
| 618 | last if $ctype eq 'SHR'; | ||||
| 619 | } | ||||
| 620 | } | ||||
| 621 | if ( $ctype ) { | ||||
| 622 | |||||
| 623 | push @{ $found{$ctype} }, $cand; | ||||
| 624 | warn "\tFound as $cand (really $fullname), type $ctype\n" | ||||
| 625 | if $verbose > 1; | ||||
| 626 | push @flibs, $name unless $libs_seen{$fullname}++; | ||||
| 627 | next LIB; | ||||
| 628 | } | ||||
| 629 | } | ||||
| 630 | warn "Warning (mostly harmless): " . "No library found for $lib\n"; | ||||
| 631 | } | ||||
| 632 | |||||
| 633 | push @fndlibs, @{ $found{OBJ} } if exists $found{OBJ}; | ||||
| 634 | push @fndlibs, map { "$_/Library" } @{ $found{OLB} } if exists $found{OLB}; | ||||
| 635 | push @fndlibs, map { "$_/Share" } @{ $found{SHR} } if exists $found{SHR}; | ||||
| 636 | my $lib = join( ' ', @fndlibs ); | ||||
| 637 | |||||
| 638 | $ldlib = $crtlstr ? "$lib $crtlstr" : $lib; | ||||
| 639 | $ldlib =~ s/^\s+|\s+$//g; | ||||
| 640 | warn "Result:\n\tEXTRALIBS: $lib\n\tLDLOADLIBS: $ldlib\n" if $verbose; | ||||
| 641 | wantarray ? ( $lib, '', $ldlib, '', ( $give_libs ? \@flibs : () ) ) : $lib; | ||||
| 642 | } | ||||
| 643 | |||||
| 644 | 1 | 0s | 1; | ||
# spent 0s within ExtUtils::Liblist::Kid::CORE:ftdir which was called 63 times, avg 0s/call:
# 63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 314, avg 0s/call  | |||||
# spent 15.6ms within ExtUtils::Liblist::Kid::CORE:ftfile which was called 183 times, avg 85µs/call:
# 183 times (15.6ms+0s) by ExtUtils::Liblist::Kid::_win32_search_file at line 401, avg 85µs/call  | |||||
# spent 0s within ExtUtils::Liblist::Kid::CORE:match which was called 522 times, avg 0s/call:
# 378 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_try_attach_extension at line 438, avg 0s/call
#  63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_build_prefixed_list at line 421, avg 0s/call
#  63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 298, avg 0s/call
#   6 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_lib_extensions at line 446, avg 0s/call
#   3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 282, avg 0s/call
#   3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_lib_extensions at line 445, avg 0s/call
#   3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 283, avg 0s/call
#   3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_make_lib_search_list at line 366, avg 0s/call  | |||||
# spent 0s within ExtUtils::Liblist::Kid::CORE:regcomp which was called 378 times, avg 0s/call:
# 378 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_try_attach_extension at line 438, avg 0s/call  | |||||
# spent 0s within ExtUtils::Liblist::Kid::CORE:subst which was called 198 times, avg 0s/call:
# 63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 314, avg 0s/call
# 63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_build_prefixed_list at line 420, avg 0s/call
# 63 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_build_prefixed_list at line 423, avg 0s/call
#  3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_ext at line 353, avg 0s/call
#  3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_default_search_paths at line 380, avg 0s/call
#  3 times (0s+0s) by ExtUtils::Liblist::Kid::_win32_make_lib_search_list at line 369, avg 0s/call  |