8 *import = \&Exporter::import;
10 # Exporter 5.57 which supports this invocation was
11 # released with perl 5.8.3
12 Exporter->import('import');
16 our @EXPORT = qw(__ __n);
17 our @EXPORT_OK = @EXPORT;
19 sub __bootstrap_locale_messages {
20 our $TEXTDOMAIN = 'git';
21 our $TEXTDOMAINDIR = $ENV{GIT_TEXTDOMAINDIR} || '++LOCALEDIR++';
24 POSIX->import(qw(setlocale));
25 # Non-core prerequisite module
26 require Locale::Messages;
27 Locale::Messages->import(qw(:locale_h :libintl_h));
29 setlocale(LC_MESSAGES(), '');
30 setlocale(LC_CTYPE(), '');
31 textdomain($TEXTDOMAIN);
32 bindtextdomain($TEXTDOMAIN => $TEXTDOMAINDIR);
39 # Used by our test script to see if it should test fallbacks or
41 our $__HAS_LIBRARY = 1;
45 __bootstrap_locale_messages();
46 *__ = \&Locale::Messages::gettext;
47 *__n = \&Locale::Messages::ngettext;
50 # Tell test.pl that we couldn't load the gettext library.
51 $Git::I18N::__HAS_LIBRARY = 0;
53 # Just a fall-through no-op
54 *__ = sub ($) { $_[0] };
55 *__n = sub ($$$) { $_[2] == 1 ? $_[0] : $_[1] };
65 Git::I18N - Perl interface to Git's Gettext localizations
71 print __("Welcome to Git!\n");
73 printf __("The following error occurred: %s\n"), $error;
75 printf __n("commited %d file\n", "commited %d files\n", $files), $files;
79 Git's internal Perl interface to gettext via L<Locale::Messages>. If
80 L<Locale::Messages> can't be loaded (it's not a core module) we
81 provide stub passthrough fallbacks.
83 This is a distilled interface to gettext, see C<info '(gettext)Perl'>
84 for the full interface. This module implements only a small part of
91 L<Locale::Messages>'s gettext function if all goes well, otherwise our
92 passthrough fallback function.
96 L<Locale::Messages>'s ngettext function or passthrough fallback function.
100 E<AElig>var ArnfjE<ouml>rE<eth> Bjarmason <avarab@gmail.com>
104 Copyright 2010 E<AElig>var ArnfjE<ouml>rE<eth> Bjarmason <avarab@gmail.com>