| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
package ExtUtils::Mksymlists; |
|
2
|
|
|
|
|
|
|
|
|
3
|
1
|
|
|
1
|
|
7474
|
use 5.006; |
|
|
1
|
|
|
|
|
4
|
|
|
4
|
1
|
|
|
1
|
|
5
|
use strict qw[ subs refs ]; |
|
|
1
|
|
|
|
|
1
|
|
|
|
1
|
|
|
|
|
35
|
|
|
5
|
|
|
|
|
|
|
# no strict 'vars'; # until filehandles are exempted |
|
6
|
1
|
|
|
1
|
|
4
|
use warnings; |
|
|
1
|
|
|
|
|
1
|
|
|
|
1
|
|
|
|
|
39
|
|
|
7
|
|
|
|
|
|
|
|
|
8
|
1
|
|
|
1
|
|
6
|
use Carp; |
|
|
1
|
|
|
|
|
2
|
|
|
|
1
|
|
|
|
|
71
|
|
|
9
|
1
|
|
|
1
|
|
6
|
use Exporter; |
|
|
1
|
|
|
|
|
1
|
|
|
|
1
|
|
|
|
|
48
|
|
|
10
|
1
|
|
|
1
|
|
5
|
use Config; |
|
|
1
|
|
|
|
|
2
|
|
|
|
1
|
|
|
|
|
2217
|
|
|
11
|
|
|
|
|
|
|
|
|
12
|
|
|
|
|
|
|
our @ISA = qw(Exporter); |
|
13
|
|
|
|
|
|
|
our @EXPORT = qw(&Mksymlists); |
|
14
|
|
|
|
|
|
|
our $VERSION = '7.66'; |
|
15
|
|
|
|
|
|
|
$VERSION =~ tr/_//d; |
|
16
|
|
|
|
|
|
|
|
|
17
|
|
|
|
|
|
|
sub Mksymlists { |
|
18
|
0
|
|
|
0
|
0
|
|
my(%spec) = @_; |
|
19
|
0
|
|
|
|
|
|
my($osname) = $^O; |
|
20
|
|
|
|
|
|
|
|
|
21
|
|
|
|
|
|
|
croak("Insufficient information specified to Mksymlists") |
|
22
|
|
|
|
|
|
|
unless ( $spec{NAME} or |
|
23
|
0
|
0
|
0
|
|
|
|
($spec{FILE} and ($spec{DL_FUNCS} or $spec{FUNCLIST})) ); |
|
|
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
24
|
|
|
|
|
|
|
|
|
25
|
0
|
0
|
|
|
|
|
$spec{DL_VARS} = [] unless $spec{DL_VARS}; |
|
26
|
0
|
0
|
|
|
|
|
($spec{FILE} = $spec{NAME}) =~ s/.*::// unless $spec{FILE}; |
|
27
|
0
|
0
|
|
|
|
|
$spec{FUNCLIST} = [] unless $spec{FUNCLIST}; |
|
28
|
|
|
|
|
|
|
$spec{DL_FUNCS} = { $spec{NAME} => [] } |
|
29
|
0
|
|
|
|
|
|
unless ( ($spec{DL_FUNCS} and keys %{$spec{DL_FUNCS}}) or |
|
30
|
0
|
0
|
0
|
|
|
|
@{$spec{FUNCLIST}}); |
|
|
0
|
|
0
|
|
|
|
|
|
31
|
0
|
0
|
|
|
|
|
if (defined $spec{DL_FUNCS}) { |
|
32
|
0
|
|
|
|
|
|
foreach my $package (sort keys %{$spec{DL_FUNCS}}) { |
|
|
0
|
|
|
|
|
|
|
|
33
|
0
|
|
|
|
|
|
my($packprefix,$bootseen); |
|
34
|
0
|
|
|
|
|
|
($packprefix = $package) =~ s/\W/_/g; |
|
35
|
0
|
|
|
|
|
|
foreach my $sym (@{$spec{DL_FUNCS}->{$package}}) { |
|
|
0
|
|
|
|
|
|
|
|
36
|
0
|
0
|
|
|
|
|
if ($sym =~ /^boot_/) { |
|
37
|
0
|
|
|
|
|
|
push(@{$spec{FUNCLIST}},$sym); |
|
|
0
|
|
|
|
|
|
|
|
38
|
0
|
|
|
|
|
|
$bootseen++; |
|
39
|
|
|
|
|
|
|
} |
|
40
|
|
|
|
|
|
|
else { |
|
41
|
0
|
|
|
|
|
|
push(@{$spec{FUNCLIST}},"XS_${packprefix}_$sym"); |
|
|
0
|
|
|
|
|
|
|
|
42
|
|
|
|
|
|
|
} |
|
43
|
|
|
|
|
|
|
} |
|
44
|
0
|
0
|
|
|
|
|
push(@{$spec{FUNCLIST}},"boot_$packprefix") unless $bootseen; |
|
|
0
|
|
|
|
|
|
|
|
45
|
|
|
|
|
|
|
} |
|
46
|
|
|
|
|
|
|
} |
|
47
|
|
|
|
|
|
|
|
|
48
|
|
|
|
|
|
|
# We'll need this if we ever add any OS which uses mod2fname |
|
49
|
|
|
|
|
|
|
# not as pseudo-builtin. |
|
50
|
|
|
|
|
|
|
# require DynaLoader; |
|
51
|
0
|
0
|
0
|
|
|
|
if (defined &DynaLoader::mod2fname and not $spec{DLBASE}) { |
|
52
|
0
|
|
|
|
|
|
$spec{DLBASE} = DynaLoader::mod2fname([ split(/::/,$spec{NAME}) ]); |
|
53
|
|
|
|
|
|
|
} |
|
54
|
|
|
|
|
|
|
|
|
55
|
0
|
0
|
|
|
|
|
if ($osname eq 'aix') { _write_aix(\%spec); } |
|
|
0
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
56
|
0
|
|
|
|
|
|
elsif ($osname eq 'MacOS'){ _write_aix(\%spec) } |
|
57
|
0
|
|
|
|
|
|
elsif ($osname eq 'VMS') { _write_vms(\%spec) } |
|
58
|
0
|
|
|
|
|
|
elsif ($osname eq 'os2') { _write_os2(\%spec) } |
|
59
|
0
|
|
|
|
|
|
elsif ($osname eq 'MSWin32') { _write_win32(\%spec) } |
|
60
|
|
|
|
|
|
|
else { |
|
61
|
0
|
|
|
|
|
|
croak("Don't know how to create linker option file for $osname\n"); |
|
62
|
|
|
|
|
|
|
} |
|
63
|
|
|
|
|
|
|
} |
|
64
|
|
|
|
|
|
|
|
|
65
|
|
|
|
|
|
|
|
|
66
|
|
|
|
|
|
|
sub _write_aix { |
|
67
|
0
|
|
|
0
|
|
|
my($data) = @_; |
|
68
|
|
|
|
|
|
|
|
|
69
|
0
|
|
|
|
|
|
rename "$data->{FILE}.exp", "$data->{FILE}.exp_old"; |
|
70
|
|
|
|
|
|
|
|
|
71
|
0
|
0
|
|
|
|
|
open( my $exp, ">", "$data->{FILE}.exp") |
|
72
|
|
|
|
|
|
|
or croak("Can't create $data->{FILE}.exp: $!\n"); |
|
73
|
0
|
0
|
|
|
|
|
print $exp join("\n",@{$data->{DL_VARS}}, "\n") if @{$data->{DL_VARS}}; |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
74
|
0
|
0
|
|
|
|
|
print $exp join("\n",@{$data->{FUNCLIST}}, "\n") if @{$data->{FUNCLIST}}; |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
75
|
0
|
|
|
|
|
|
close $exp; |
|
76
|
|
|
|
|
|
|
} |
|
77
|
|
|
|
|
|
|
|
|
78
|
|
|
|
|
|
|
|
|
79
|
|
|
|
|
|
|
sub _write_os2 { |
|
80
|
0
|
|
|
0
|
|
|
my($data) = @_; |
|
81
|
0
|
|
|
|
|
|
require Config; |
|
82
|
0
|
0
|
|
|
|
|
my $threaded = ($Config::Config{archname} =~ /-thread/ ? " threaded" : ""); |
|
83
|
|
|
|
|
|
|
|
|
84
|
0
|
0
|
|
|
|
|
if (not $data->{DLBASE}) { |
|
85
|
0
|
|
|
|
|
|
($data->{DLBASE} = $data->{NAME}) =~ s/.*:://; |
|
86
|
0
|
|
|
|
|
|
$data->{DLBASE} = substr($data->{DLBASE},0,7) . '_'; |
|
87
|
|
|
|
|
|
|
} |
|
88
|
0
|
|
0
|
|
|
|
my $distname = $data->{DISTNAME} || $data->{NAME}; |
|
89
|
0
|
|
|
|
|
|
$distname = "Distribution $distname"; |
|
90
|
0
|
|
0
|
|
|
|
my $patchlevel = " pl$Config{perl_patchlevel}" || ''; |
|
91
|
|
|
|
|
|
|
my $comment = sprintf "Perl (v%s%s%s) module %s", |
|
92
|
0
|
|
|
|
|
|
$Config::Config{version}, $threaded, $patchlevel, $data->{NAME}; |
|
93
|
0
|
|
|
|
|
|
chomp $comment; |
|
94
|
0
|
0
|
0
|
|
|
|
if ($data->{INSTALLDIRS} and $data->{INSTALLDIRS} eq 'perl') { |
|
95
|
0
|
|
|
|
|
|
$distname = 'perl5-porters@perl.org'; |
|
96
|
0
|
|
|
|
|
|
$comment = "Core $comment"; |
|
97
|
|
|
|
|
|
|
} |
|
98
|
0
|
|
|
|
|
|
$comment = "$comment (Perl-config: $Config{config_args})"; |
|
99
|
0
|
0
|
|
|
|
|
$comment = substr($comment, 0, 200) . "...)" if length $comment > 203; |
|
100
|
0
|
|
|
|
|
|
rename "$data->{FILE}.def", "$data->{FILE}_def.old"; |
|
101
|
|
|
|
|
|
|
|
|
102
|
0
|
0
|
|
|
|
|
open(my $def, ">", "$data->{FILE}.def") |
|
103
|
|
|
|
|
|
|
or croak("Can't create $data->{FILE}.def: $!\n"); |
|
104
|
0
|
|
|
|
|
|
print $def "LIBRARY '$data->{DLBASE}' INITINSTANCE TERMINSTANCE\n"; |
|
105
|
0
|
|
|
|
|
|
print $def "DESCRIPTION '\@#$distname:$data->{VERSION}#\@ $comment'\n"; |
|
106
|
0
|
|
|
|
|
|
print $def "CODE LOADONCALL\n"; |
|
107
|
0
|
|
|
|
|
|
print $def "DATA LOADONCALL NONSHARED MULTIPLE\n"; |
|
108
|
0
|
|
|
|
|
|
print $def "EXPORTS\n "; |
|
109
|
0
|
0
|
|
|
|
|
print $def join("\n ",@{$data->{DL_VARS}}, "\n") if @{$data->{DL_VARS}}; |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
110
|
0
|
0
|
|
|
|
|
print $def join("\n ",@{$data->{FUNCLIST}}, "\n") if @{$data->{FUNCLIST}}; |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
111
|
0
|
|
|
|
|
|
_print_imports($def, $data); |
|
112
|
0
|
|
|
|
|
|
close $def; |
|
113
|
|
|
|
|
|
|
} |
|
114
|
|
|
|
|
|
|
|
|
115
|
|
|
|
|
|
|
sub _print_imports { |
|
116
|
0
|
|
|
0
|
|
|
my ($def, $data)= @_; |
|
117
|
|
|
|
|
|
|
my $imports= $data->{IMPORTS} |
|
118
|
0
|
0
|
|
|
|
|
or return; |
|
119
|
0
|
0
|
|
|
|
|
if ( keys %$imports ) { |
|
120
|
0
|
|
|
|
|
|
print $def "IMPORTS\n"; |
|
121
|
0
|
|
|
|
|
|
foreach my $name (sort keys %$imports) { |
|
122
|
0
|
|
|
|
|
|
print $def " $name=$imports->{$name}\n"; |
|
123
|
|
|
|
|
|
|
} |
|
124
|
|
|
|
|
|
|
} |
|
125
|
|
|
|
|
|
|
} |
|
126
|
|
|
|
|
|
|
|
|
127
|
|
|
|
|
|
|
sub _write_win32 { |
|
128
|
0
|
|
|
0
|
|
|
my($data) = @_; |
|
129
|
|
|
|
|
|
|
|
|
130
|
0
|
|
|
|
|
|
require Config; |
|
131
|
0
|
0
|
|
|
|
|
if (not $data->{DLBASE}) { |
|
132
|
0
|
|
|
|
|
|
($data->{DLBASE} = $data->{NAME}) =~ s/.*:://; |
|
133
|
0
|
|
|
|
|
|
$data->{DLBASE} = substr($data->{DLBASE},0,7) . '_'; |
|
134
|
|
|
|
|
|
|
} |
|
135
|
0
|
|
|
|
|
|
rename "$data->{FILE}.def", "$data->{FILE}_def.old"; |
|
136
|
|
|
|
|
|
|
|
|
137
|
0
|
0
|
|
|
|
|
open( my $def, ">", "$data->{FILE}.def" ) |
|
138
|
|
|
|
|
|
|
or croak("Can't create $data->{FILE}.def: $!\n"); |
|
139
|
|
|
|
|
|
|
# put library name in quotes (it could be a keyword, like 'Alias') |
|
140
|
0
|
0
|
|
|
|
|
if ($Config::Config{'cc'} !~ /\bgcc/i) { |
|
141
|
0
|
|
|
|
|
|
print $def "LIBRARY \"$data->{DLBASE}\"\n"; |
|
142
|
|
|
|
|
|
|
} |
|
143
|
0
|
|
|
|
|
|
print $def "EXPORTS\n "; |
|
144
|
0
|
|
|
|
|
|
my @syms; |
|
145
|
|
|
|
|
|
|
# Export public symbols both with and without underscores to |
|
146
|
|
|
|
|
|
|
# ensure compatibility between DLLs from Borland C and Visual C |
|
147
|
|
|
|
|
|
|
# NOTE: DynaLoader itself only uses the names without underscores, |
|
148
|
|
|
|
|
|
|
# so this is only to cover the case when the extension DLL may be |
|
149
|
|
|
|
|
|
|
# linked to directly from C. GSAR 97-07-10 |
|
150
|
|
|
|
|
|
|
|
|
151
|
|
|
|
|
|
|
#bcc dropped in 5.16, so dont create useless extra symbols for export table |
|
152
|
0
|
0
|
|
|
|
|
unless("$]" >= 5.016) { |
|
153
|
0
|
0
|
|
|
|
|
if ($Config::Config{'cc'} =~ /^bcc/i) { |
|
154
|
|
|
|
|
|
|
push @syms, "_$_", "$_ = _$_" |
|
155
|
0
|
|
|
|
|
|
for (@{$data->{DL_VARS}}, @{$data->{FUNCLIST}}); |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
156
|
|
|
|
|
|
|
} |
|
157
|
|
|
|
|
|
|
else { |
|
158
|
|
|
|
|
|
|
push @syms, "$_", "_$_ = $_" |
|
159
|
0
|
|
|
|
|
|
for (@{$data->{DL_VARS}}, @{$data->{FUNCLIST}}); |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
160
|
|
|
|
|
|
|
} |
|
161
|
|
|
|
|
|
|
} else { |
|
162
|
|
|
|
|
|
|
push @syms, "$_" |
|
163
|
0
|
|
|
|
|
|
for (@{$data->{DL_VARS}}, @{$data->{FUNCLIST}}); |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
164
|
|
|
|
|
|
|
} |
|
165
|
0
|
0
|
|
|
|
|
print $def join("\n ",@syms, "\n") if @syms; |
|
166
|
0
|
|
|
|
|
|
_print_imports($def, $data); |
|
167
|
0
|
|
|
|
|
|
close $def; |
|
168
|
|
|
|
|
|
|
} |
|
169
|
|
|
|
|
|
|
|
|
170
|
|
|
|
|
|
|
|
|
171
|
|
|
|
|
|
|
sub _write_vms { |
|
172
|
0
|
|
|
0
|
|
|
my($data) = @_; |
|
173
|
|
|
|
|
|
|
|
|
174
|
0
|
|
|
|
|
|
require Config; # a reminder for once we do $^O |
|
175
|
0
|
|
|
|
|
|
require ExtUtils::XSSymSet; |
|
176
|
|
|
|
|
|
|
|
|
177
|
0
|
|
|
|
|
|
my($isvax) = $Config::Config{'archname'} =~ /VAX/i; |
|
178
|
0
|
|
|
|
|
|
my($set) = new ExtUtils::XSSymSet; |
|
179
|
|
|
|
|
|
|
|
|
180
|
0
|
|
|
|
|
|
rename "$data->{FILE}.opt", "$data->{FILE}.opt_old"; |
|
181
|
|
|
|
|
|
|
|
|
182
|
0
|
0
|
|
|
|
|
open(my $opt,">", "$data->{FILE}.opt") |
|
183
|
|
|
|
|
|
|
or croak("Can't create $data->{FILE}.opt: $!\n"); |
|
184
|
|
|
|
|
|
|
|
|
185
|
|
|
|
|
|
|
# Options file declaring universal symbols |
|
186
|
|
|
|
|
|
|
# Used when linking shareable image for dynamic extension, |
|
187
|
|
|
|
|
|
|
# or when linking PerlShr into which we've added this package |
|
188
|
|
|
|
|
|
|
# as a static extension |
|
189
|
|
|
|
|
|
|
# We don't do anything to preserve order, so we won't relax |
|
190
|
|
|
|
|
|
|
# the GSMATCH criteria for a dynamic extension |
|
191
|
|
|
|
|
|
|
|
|
192
|
|
|
|
|
|
|
print $opt "case_sensitive=yes\n" |
|
193
|
0
|
0
|
|
|
|
|
if $Config::Config{d_vms_case_sensitive_symbols}; |
|
194
|
|
|
|
|
|
|
|
|
195
|
0
|
|
|
|
|
|
foreach my $sym (@{$data->{FUNCLIST}}) { |
|
|
0
|
|
|
|
|
|
|
|
196
|
0
|
|
|
|
|
|
my $safe = $set->addsym($sym); |
|
197
|
0
|
0
|
|
|
|
|
if ($isvax) { print $opt "UNIVERSAL=$safe\n" } |
|
|
0
|
|
|
|
|
|
|
|
198
|
0
|
|
|
|
|
|
else { print $opt "SYMBOL_VECTOR=($safe=PROCEDURE)\n"; } |
|
199
|
|
|
|
|
|
|
} |
|
200
|
|
|
|
|
|
|
|
|
201
|
0
|
|
|
|
|
|
foreach my $sym (@{$data->{DL_VARS}}) { |
|
|
0
|
|
|
|
|
|
|
|
202
|
0
|
|
|
|
|
|
my $safe = $set->addsym($sym); |
|
203
|
0
|
|
|
|
|
|
print $opt "PSECT_ATTR=${sym},PIC,OVR,RD,NOEXE,WRT,NOSHR\n"; |
|
204
|
0
|
0
|
|
|
|
|
if ($isvax) { print $opt "UNIVERSAL=$safe\n" } |
|
|
0
|
|
|
|
|
|
|
|
205
|
0
|
|
|
|
|
|
else { print $opt "SYMBOL_VECTOR=($safe=DATA)\n"; } |
|
206
|
|
|
|
|
|
|
} |
|
207
|
|
|
|
|
|
|
|
|
208
|
0
|
|
|
|
|
|
close $opt; |
|
209
|
|
|
|
|
|
|
} |
|
210
|
|
|
|
|
|
|
|
|
211
|
|
|
|
|
|
|
1; |
|
212
|
|
|
|
|
|
|
|
|
213
|
|
|
|
|
|
|
__END__ |
|
214
|
|
|
|
|
|
|
|
|
215
|
|
|
|
|
|
|
=head1 NAME |
|
216
|
|
|
|
|
|
|
|
|
217
|
|
|
|
|
|
|
ExtUtils::Mksymlists - write linker options files for dynamic extension |
|
218
|
|
|
|
|
|
|
|
|
219
|
|
|
|
|
|
|
=head1 SYNOPSIS |
|
220
|
|
|
|
|
|
|
|
|
221
|
|
|
|
|
|
|
use ExtUtils::Mksymlists; |
|
222
|
|
|
|
|
|
|
Mksymlists( NAME => $name , |
|
223
|
|
|
|
|
|
|
DL_VARS => [ $var1, $var2, $var3 ], |
|
224
|
|
|
|
|
|
|
DL_FUNCS => { $pkg1 => [ $func1, $func2 ], |
|
225
|
|
|
|
|
|
|
$pkg2 => [ $func3 ] ); |
|
226
|
|
|
|
|
|
|
|
|
227
|
|
|
|
|
|
|
=head1 DESCRIPTION |
|
228
|
|
|
|
|
|
|
|
|
229
|
|
|
|
|
|
|
C<ExtUtils::Mksymlists> produces files used by the linker under some OSs |
|
230
|
|
|
|
|
|
|
during the creation of shared libraries for dynamic extensions. It is |
|
231
|
|
|
|
|
|
|
normally called from a MakeMaker-generated Makefile when the extension |
|
232
|
|
|
|
|
|
|
is built. The linker option file is generated by calling the function |
|
233
|
|
|
|
|
|
|
C<Mksymlists>, which is exported by default from C<ExtUtils::Mksymlists>. |
|
234
|
|
|
|
|
|
|
It takes one argument, a list of key-value pairs, in which the following |
|
235
|
|
|
|
|
|
|
keys are recognized: |
|
236
|
|
|
|
|
|
|
|
|
237
|
|
|
|
|
|
|
=over 4 |
|
238
|
|
|
|
|
|
|
|
|
239
|
|
|
|
|
|
|
=item DLBASE |
|
240
|
|
|
|
|
|
|
|
|
241
|
|
|
|
|
|
|
This item specifies the name by which the linker knows the |
|
242
|
|
|
|
|
|
|
extension, which may be different from the name of the |
|
243
|
|
|
|
|
|
|
extension itself (for instance, some linkers add an '_' to the |
|
244
|
|
|
|
|
|
|
name of the extension). If it is not specified, it is derived |
|
245
|
|
|
|
|
|
|
from the NAME attribute. It is presently used only by OS2 and Win32. |
|
246
|
|
|
|
|
|
|
|
|
247
|
|
|
|
|
|
|
=item DL_FUNCS |
|
248
|
|
|
|
|
|
|
|
|
249
|
|
|
|
|
|
|
This is identical to the DL_FUNCS attribute available via MakeMaker, |
|
250
|
|
|
|
|
|
|
from which it is usually taken. Its value is a reference to an |
|
251
|
|
|
|
|
|
|
associative array, in which each key is the name of a package, and |
|
252
|
|
|
|
|
|
|
each value is an a reference to an array of function names which |
|
253
|
|
|
|
|
|
|
should be exported by the extension. For instance, one might say |
|
254
|
|
|
|
|
|
|
C<DL_FUNCS =E<gt> { Homer::Iliad =E<gt> [ qw(trojans greeks) ], |
|
255
|
|
|
|
|
|
|
Homer::Odyssey =E<gt> [ qw(travellers family suitors) ] }>. The |
|
256
|
|
|
|
|
|
|
function names should be identical to those in the XSUB code; |
|
257
|
|
|
|
|
|
|
C<Mksymlists> will alter the names written to the linker option |
|
258
|
|
|
|
|
|
|
file to match the changes made by F<xsubpp>. In addition, if |
|
259
|
|
|
|
|
|
|
none of the functions in a list begin with the string B<boot_>, |
|
260
|
|
|
|
|
|
|
C<Mksymlists> will add a bootstrap function for that package, |
|
261
|
|
|
|
|
|
|
just as xsubpp does. (If a B<boot_E<lt>pkgE<gt>> function is |
|
262
|
|
|
|
|
|
|
present in the list, it is passed through unchanged.) If |
|
263
|
|
|
|
|
|
|
DL_FUNCS is not specified, it defaults to the bootstrap |
|
264
|
|
|
|
|
|
|
function for the extension specified in NAME. |
|
265
|
|
|
|
|
|
|
|
|
266
|
|
|
|
|
|
|
=item DL_VARS |
|
267
|
|
|
|
|
|
|
|
|
268
|
|
|
|
|
|
|
This is identical to the DL_VARS attribute available via MakeMaker, |
|
269
|
|
|
|
|
|
|
and, like DL_FUNCS, it is usually specified via MakeMaker. Its |
|
270
|
|
|
|
|
|
|
value is a reference to an array of variable names which should |
|
271
|
|
|
|
|
|
|
be exported by the extension. |
|
272
|
|
|
|
|
|
|
|
|
273
|
|
|
|
|
|
|
=item FILE |
|
274
|
|
|
|
|
|
|
|
|
275
|
|
|
|
|
|
|
This key can be used to specify the name of the linker option file |
|
276
|
|
|
|
|
|
|
(minus the OS-specific extension), if for some reason you do not |
|
277
|
|
|
|
|
|
|
want to use the default value, which is the last word of the NAME |
|
278
|
|
|
|
|
|
|
attribute (I<e.g.> for C<Tk::Canvas>, FILE defaults to C<Canvas>). |
|
279
|
|
|
|
|
|
|
|
|
280
|
|
|
|
|
|
|
=item FUNCLIST |
|
281
|
|
|
|
|
|
|
|
|
282
|
|
|
|
|
|
|
This provides an alternate means to specify function names to be |
|
283
|
|
|
|
|
|
|
exported from the extension. Its value is a reference to an |
|
284
|
|
|
|
|
|
|
array of function names to be exported by the extension. These |
|
285
|
|
|
|
|
|
|
names are passed through unaltered to the linker options file. |
|
286
|
|
|
|
|
|
|
Specifying a value for the FUNCLIST attribute suppresses automatic |
|
287
|
|
|
|
|
|
|
generation of the bootstrap function for the package. To still create |
|
288
|
|
|
|
|
|
|
the bootstrap name you have to specify the package name in the |
|
289
|
|
|
|
|
|
|
DL_FUNCS hash: |
|
290
|
|
|
|
|
|
|
|
|
291
|
|
|
|
|
|
|
Mksymlists( NAME => $name , |
|
292
|
|
|
|
|
|
|
FUNCLIST => [ $func1, $func2 ], |
|
293
|
|
|
|
|
|
|
DL_FUNCS => { $pkg => [] } ); |
|
294
|
|
|
|
|
|
|
|
|
295
|
|
|
|
|
|
|
|
|
296
|
|
|
|
|
|
|
=item IMPORTS |
|
297
|
|
|
|
|
|
|
|
|
298
|
|
|
|
|
|
|
This attribute is used to specify names to be imported into the |
|
299
|
|
|
|
|
|
|
extension. It is currently only used by OS/2 and Win32. |
|
300
|
|
|
|
|
|
|
|
|
301
|
|
|
|
|
|
|
=item NAME |
|
302
|
|
|
|
|
|
|
|
|
303
|
|
|
|
|
|
|
This gives the name of the extension (I<e.g.> C<Tk::Canvas>) for which |
|
304
|
|
|
|
|
|
|
the linker option file will be produced. |
|
305
|
|
|
|
|
|
|
|
|
306
|
|
|
|
|
|
|
=back |
|
307
|
|
|
|
|
|
|
|
|
308
|
|
|
|
|
|
|
When calling C<Mksymlists>, one should always specify the NAME |
|
309
|
|
|
|
|
|
|
attribute. In most cases, this is all that's necessary. In |
|
310
|
|
|
|
|
|
|
the case of unusual extensions, however, the other attributes |
|
311
|
|
|
|
|
|
|
can be used to provide additional information to the linker. |
|
312
|
|
|
|
|
|
|
|
|
313
|
|
|
|
|
|
|
=head1 AUTHOR |
|
314
|
|
|
|
|
|
|
|
|
315
|
|
|
|
|
|
|
Charles Bailey I<E<lt>bailey@newman.upenn.eduE<gt>> |
|
316
|
|
|
|
|
|
|
|
|
317
|
|
|
|
|
|
|
=head1 REVISION |
|
318
|
|
|
|
|
|
|
|
|
319
|
|
|
|
|
|
|
Last revised 14-Feb-1996, for Perl 5.002. |