summaryrefslogtreecommitdiffstats
path: root/Configure
diff options
context:
space:
mode:
authorRichard Levitte <levitte@openssl.org>2021-02-25 16:55:39 +0100
committerRichard Levitte <levitte@openssl.org>2021-03-03 14:47:01 +0100
commit3f399e3787788b1cc3832e254c53cda42873d847 (patch)
tree9eb93a058ff17e99b3c1b66926b77ff25f036134 /Configure
parentDOCS: Fix provider-mac.pod and the docs of our implementations (diff)
downloadopenssl-3f399e3787788b1cc3832e254c53cda42873d847.tar.xz
openssl-3f399e3787788b1cc3832e254c53cda42873d847.zip
build.info: Add the possibility to add dependencies on raw targets
We need to add something for the 'tests' target to depend on, so a special syntax for those is introduced: DEPEND[|tests|]=fipsmodule.cnf Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/14320)
Diffstat (limited to 'Configure')
-rwxr-xr-xConfigure22
1 files changed, 16 insertions, 6 deletions
diff --git a/Configure b/Configure
index 12911d988a..e24564311e 100755
--- a/Configure
+++ b/Configure
@@ -2330,12 +2330,22 @@ EOF
foreach (keys %depends) {
my $dest = $_;
- my $ddest = $dest eq "" ? "" : cleanfile($sourced, $_, $blddir);
+ my $ddest = $dest;
+
+ if ($dest =~ /^\|(.*)\|$/) {
+ # Collect the raw target
+ $unified_info{targets}->{$1} = 1;
+ $ddest = $1;
+ } elsif ($dest eq '') {
+ $ddest = '';
+ } else {
+ $ddest = cleanfile($sourced, $_, $blddir);
- # If the destination doesn't exist in source, it can only be
- # a generated file in the build tree.
- if ($ddest ne "" && ($ddest eq $src_configdata || ! -f $ddest)) {
- $ddest = cleanfile($buildd, $_, $blddir);
+ # If the destination doesn't exist in source, it can only be
+ # a generated file in the build tree.
+ if ($ddest eq $src_configdata || ! -f $ddest) {
+ $ddest = cleanfile($buildd, $_, $blddir);
+ }
}
foreach (@{$depends{$dest}}) {
my $d = cleanfile($sourced, $_, $blddir);
@@ -2628,7 +2638,7 @@ EOF
### Make unified_info a bit more efficient
# One level structures
- foreach (("programs", "libraries", "modules", "scripts")) {
+ foreach (("programs", "libraries", "modules", "scripts", "targets")) {
$unified_info{$_} = [ sort keys %{$unified_info{$_}} ];
}
# Two level structures