Build libasn1 as a DLL
In addition to building libasn1 as a DLL also add a build target so that a list of exports can be generated and used to check with the .def file whether any exports are being left out.
This commit is contained in:

committed by
Love Hornquist Astrand

parent
2df5c26c00
commit
9072a62729
77
cf/w32-list-externs-from-objs.pl
Normal file
77
cf/w32-list-externs-from-objs.pl
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
my $show_module_name = 1;
|
||||||
|
my $use_indent = 1;
|
||||||
|
my $strip_leading_underscore = 0;
|
||||||
|
|
||||||
|
# Dump all symbols for the given object file that are defined and have
|
||||||
|
# external scope.
|
||||||
|
|
||||||
|
sub dump_symbols_for_file($)
|
||||||
|
{
|
||||||
|
$fn = shift;
|
||||||
|
|
||||||
|
print STDERR "Opening dump of object [$fn]\n";
|
||||||
|
|
||||||
|
open(SP, '-|', "dumpbin /symbols \"".$fn."\"") or die "Can't open pipe for $fn";
|
||||||
|
|
||||||
|
LINE:
|
||||||
|
while (<SP>) {
|
||||||
|
# 008 00000000 SECT3 notype () External | _encode_AccessDescription
|
||||||
|
|
||||||
|
/^[[:xdigit:]]{3,}\s[[:xdigit:]]{8,}\s(\w+)\s+\w*\s+\(\)\s+(\w+)\s+\|\s+(\w+)$/ && do {
|
||||||
|
my ($section, $visibility, $symbol) = ($1, $2, $3);
|
||||||
|
|
||||||
|
if ($section ne "UNDEF" && $visibility eq "External") {
|
||||||
|
print $fn if $show_module_name;
|
||||||
|
print "\t" if $use_indent || $show_module_name;
|
||||||
|
|
||||||
|
if ($strip_leading_underscore && $symbol =~ /_(.*)/) {
|
||||||
|
$symbol = $1;
|
||||||
|
}
|
||||||
|
print $symbol;
|
||||||
|
print "\n";
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
close SP;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub use_response_file($)
|
||||||
|
{
|
||||||
|
$fn = shift;
|
||||||
|
|
||||||
|
open (RF, '<', $fn) or die "Can't open response file $fn";
|
||||||
|
|
||||||
|
while (<RF>) {
|
||||||
|
/(\S+)/ && do {
|
||||||
|
dump_symbols_for_file($1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
close RF;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (@ARGV) {
|
||||||
|
ARG: {
|
||||||
|
/-q/ && do {
|
||||||
|
$show_module_name = 0;
|
||||||
|
last ARG;
|
||||||
|
};
|
||||||
|
|
||||||
|
/-1/ && do {
|
||||||
|
$use_indent = 0;
|
||||||
|
last ARG;
|
||||||
|
};
|
||||||
|
|
||||||
|
/-u/ && do {
|
||||||
|
$strip_leading_underscore = 1;
|
||||||
|
last ARG;
|
||||||
|
};
|
||||||
|
|
||||||
|
/@(.*)/ && do {
|
||||||
|
use_response_file($1);
|
||||||
|
last ARG;
|
||||||
|
};
|
||||||
|
|
||||||
|
dump_symbols_for_file($_);
|
||||||
|
}
|
||||||
|
}
|
@@ -470,7 +470,7 @@ gen_files_kx509 = \
|
|||||||
$(OBJ)\asn1_Kx509Response.x \
|
$(OBJ)\asn1_Kx509Response.x \
|
||||||
$(OBJ)\asn1_Kx509Request.x
|
$(OBJ)\asn1_Kx509Request.x
|
||||||
|
|
||||||
asn1_binaries = \
|
ASN1_BINARIES = \
|
||||||
$(BINDIR)\asn1_compile.exe \
|
$(BINDIR)\asn1_compile.exe \
|
||||||
$(BINDIR)\asn1_print.exe \
|
$(BINDIR)\asn1_print.exe \
|
||||||
$(BINDIR)\asn1_gen.exe
|
$(BINDIR)\asn1_gen.exe
|
||||||
@@ -517,7 +517,7 @@ $(BINDIR)\asn1_gen.exe: $(OBJ)\asn1_gen.obj $(LIBASN1)
|
|||||||
$(_VC_MANIFEST_CLEAN)
|
$(_VC_MANIFEST_CLEAN)
|
||||||
$(_CODESIGN)
|
$(_CODESIGN)
|
||||||
|
|
||||||
$(LIBASN1): \
|
LIBASN1_OBJS= \
|
||||||
$(OBJ)\der.obj \
|
$(OBJ)\der.obj \
|
||||||
$(OBJ)\der_get.obj \
|
$(OBJ)\der_get.obj \
|
||||||
$(OBJ)\der_put.obj \
|
$(OBJ)\der_put.obj \
|
||||||
@@ -538,13 +538,35 @@ $(LIBASN1): \
|
|||||||
$(gen_files_digest:.x=.obj) \
|
$(gen_files_digest:.x=.obj) \
|
||||||
$(gen_files_kx509:.x=.obj) \
|
$(gen_files_kx509:.x=.obj) \
|
||||||
$(OBJ)\asn1_err.obj
|
$(OBJ)\asn1_err.obj
|
||||||
$(LIBCON_C) /OUT:$@ @<<
|
|
||||||
|
LIBASN1_LIBS=\
|
||||||
|
$(LIBROKEN) \
|
||||||
|
$(LIBCOMERR)
|
||||||
|
|
||||||
|
$(LIBASN1): $(BINDIR)\libasn1.dll
|
||||||
|
|
||||||
|
$(BINDIR)\libasn1.dll: $(LIBASN1_OBJS)
|
||||||
|
$(DLLGUILINK_C) /OUT:$@ /DEF:libasn1-exports.def /IMPLIB:$(LIBASN1) $(LIBASN1_LIBS) @<<
|
||||||
$(**: =
|
$(**: =
|
||||||
)
|
)
|
||||||
<<
|
<<
|
||||||
|
$(DLLPREP)
|
||||||
|
|
||||||
clean::
|
clean::
|
||||||
-$(RM) $(LIBASN1)
|
-$(RM) $(LIBASN1)
|
||||||
|
-$(RM) $(BINDIR)\libasn1.dll
|
||||||
|
|
||||||
|
#
|
||||||
|
# Generate list of exports
|
||||||
|
#
|
||||||
|
# This target is only used during development to generate a list of
|
||||||
|
# symbols that are exported from all the object files in LIBASN1_OBJS.
|
||||||
|
#
|
||||||
|
exports-list.txt: $(LIBASN1_OBJS)
|
||||||
|
$(PERL) ..\..\cf\w32-list-externs-from-objs.pl -q -u @<< > $@
|
||||||
|
$(**: =
|
||||||
|
)
|
||||||
|
<<
|
||||||
|
|
||||||
$(gen_files_k5:.x=.c) : $$(@R).x
|
$(gen_files_k5:.x=.c) : $$(@R).x
|
||||||
|
|
||||||
@@ -681,7 +703,7 @@ $(OBJ)\der-protos.h: $(libasn1_SOURCES:der-protos.h=)
|
|||||||
clean::
|
clean::
|
||||||
-$(RM) $(INCDIR)\der-protos.h
|
-$(RM) $(INCDIR)\der-protos.h
|
||||||
|
|
||||||
all:: $(INCFILES) $(GENINCFILES) $(LIBASN1) $(asn1_binaries)
|
all:: $(INCFILES) $(ASN1_BINARIES) $(GENINCFILES) $(LIBASN1)
|
||||||
|
|
||||||
TEST_BINARIES=\
|
TEST_BINARIES=\
|
||||||
$(OBJ)\check-der.exe \
|
$(OBJ)\check-der.exe \
|
||||||
|
1498
lib/asn1/libasn1-exports.def
Normal file
1498
lib/asn1/libasn1-exports.def
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user