The "eval_ngettext()" function has been orphaned since its last user was removed ina74b35081c(rebase: drop support for `--preserve-merges`, 2021-09-07). Seeb8fc9e43a7(i18n: rebase-interactive: mark here-doc strings for translation, 2016-06-17) for the commit that added these eval_ngettext() wrappers. Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			80 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
# This shell library is Git's interface to gettext.sh. See po/README
 | 
						|
# for usage instructions.
 | 
						|
#
 | 
						|
# Copyright (c) 2010 Ævar Arnfjörð Bjarmason
 | 
						|
#
 | 
						|
 | 
						|
# Export the TEXTDOMAIN* data that we need for Git
 | 
						|
TEXTDOMAIN=git
 | 
						|
export TEXTDOMAIN
 | 
						|
if test -z "$GIT_TEXTDOMAINDIR"
 | 
						|
then
 | 
						|
	TEXTDOMAINDIR="@@LOCALEDIR@@"
 | 
						|
else
 | 
						|
	TEXTDOMAINDIR="$GIT_TEXTDOMAINDIR"
 | 
						|
fi
 | 
						|
export TEXTDOMAINDIR
 | 
						|
 | 
						|
# First decide what scheme to use...
 | 
						|
GIT_INTERNAL_GETTEXT_SH_SCHEME=fallthrough
 | 
						|
if test -n "@@USE_GETTEXT_SCHEME@@"
 | 
						|
then
 | 
						|
	GIT_INTERNAL_GETTEXT_SH_SCHEME="@@USE_GETTEXT_SCHEME@@"
 | 
						|
elif test -n "$GIT_INTERNAL_GETTEXT_TEST_FALLBACKS"
 | 
						|
then
 | 
						|
	: no probing necessary
 | 
						|
elif type gettext.sh >/dev/null 2>&1
 | 
						|
then
 | 
						|
	# GNU libintl's gettext.sh
 | 
						|
	GIT_INTERNAL_GETTEXT_SH_SCHEME=gnu
 | 
						|
elif test "$(gettext -h 2>&1)" = "-h"
 | 
						|
then
 | 
						|
	# gettext binary exists but no gettext.sh. likely to be a gettext
 | 
						|
	# binary on a Solaris or something that is not GNU libintl and
 | 
						|
	# lack eval_gettext.
 | 
						|
	GIT_INTERNAL_GETTEXT_SH_SCHEME=gettext_without_eval_gettext
 | 
						|
fi
 | 
						|
export GIT_INTERNAL_GETTEXT_SH_SCHEME
 | 
						|
 | 
						|
# ... and then follow that decision.
 | 
						|
case "$GIT_INTERNAL_GETTEXT_SH_SCHEME" in
 | 
						|
gnu)
 | 
						|
	# Use libintl's gettext.sh, or fall back to English if we can't.
 | 
						|
	. gettext.sh
 | 
						|
	;;
 | 
						|
gettext_without_eval_gettext)
 | 
						|
	# Solaris has a gettext(1) but no eval_gettext(1)
 | 
						|
	eval_gettext () {
 | 
						|
		gettext "$1" | (
 | 
						|
			export PATH $(git sh-i18n--envsubst --variables "$1");
 | 
						|
			git sh-i18n--envsubst "$1"
 | 
						|
		)
 | 
						|
	}
 | 
						|
 | 
						|
	;;
 | 
						|
*)
 | 
						|
	gettext () {
 | 
						|
		printf "%s" "$1"
 | 
						|
	}
 | 
						|
 | 
						|
	eval_gettext () {
 | 
						|
		printf "%s" "$1" | (
 | 
						|
			export PATH $(git sh-i18n--envsubst --variables "$1");
 | 
						|
			git sh-i18n--envsubst "$1"
 | 
						|
		)
 | 
						|
	}
 | 
						|
 | 
						|
	;;
 | 
						|
esac
 | 
						|
 | 
						|
# Git-specific wrapper functions
 | 
						|
gettextln () {
 | 
						|
	gettext "$1"
 | 
						|
	echo
 | 
						|
}
 | 
						|
 | 
						|
eval_gettextln () {
 | 
						|
	eval_gettext "$1"
 | 
						|
	echo
 | 
						|
}
 |