Makefile: consistently use @PLACEHOLDER@ to substitute
We have a bunch of placeholders in our scripts that we replace at build time, for example by using sed(1). These placeholders come in three different formats: @PLACEHOLDER@, @@PLACEHOLDER@@ and ++PLACEHOLDER++. Next to being inconsistent it also creates a bit of a problem with CMake, which only supports the first syntax in its `configure_file()` function. To work around that we instead manually replace placeholders via string operations, which is a hassle and removes safeguards that CMake has to verify that we didn't forget to replace any placeholders. Besides that, other build systems like Meson also support the CMake syntax. Unify our codebase to consistently use the syntax supported by such build systems. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
4638e8806e
commit
dbe46c0feb
@ -1 +1 @@
|
||||
use lib (split(/@@PATHSEP@@/, $ENV{GITPERLLIB} || '@@INSTLIBDIR@@'));
|
||||
use lib (split(/@PATHSEP@/, $ENV{GITPERLLIB} || '@INSTLIBDIR@'));
|
||||
|
@ -3,7 +3,7 @@
|
||||
# This finds our Git::* libraries relative to the script's runtime path.
|
||||
sub __git_system_path {
|
||||
my ($relpath) = @_;
|
||||
my $gitexecdir_relative = '@@GITEXECDIR_REL@@';
|
||||
my $gitexecdir_relative = '@GITEXECDIR_REL@';
|
||||
|
||||
# GIT_EXEC_PATH is supplied by `git` or the test suite.
|
||||
my $exec_path;
|
||||
@ -24,11 +24,11 @@ sub __git_system_path {
|
||||
}
|
||||
|
||||
BEGIN {
|
||||
use lib split /@@PATHSEP@@/,
|
||||
use lib split /@PATHSEP@/,
|
||||
(
|
||||
$ENV{GITPERLLIB} ||
|
||||
do {
|
||||
my $perllibdir = __git_system_path('@@PERLLIBDIR_REL@@');
|
||||
my $perllibdir = __git_system_path('@PERLLIBDIR_REL@');
|
||||
(-e $perllibdir) || die("Invalid system path ($relpath): $path");
|
||||
$perllibdir;
|
||||
}
|
||||
@ -36,7 +36,7 @@ BEGIN {
|
||||
|
||||
# Export the system locale directory to the I18N module. The locale directory
|
||||
# is only installed if NO_GETTEXT is set.
|
||||
$Git::I18N::TEXTDOMAINDIR = __git_system_path('@@LOCALEDIR_REL@@');
|
||||
$Git::I18N::TEXTDOMAINDIR = __git_system_path('@LOCALEDIR_REL@');
|
||||
}
|
||||
|
||||
# END RUNTIME_PREFIX generated code.
|
||||
|
Reference in New Issue
Block a user