Merge branch 'mm/maint-config-explicit-bool-display' into maint
[git/jnareb-git.git] / gettext.h
blob24d91824e5a810cb3f2cbc4ca0514ec68725597d
1 /*
2 * Copyright (c) 2010-2011 Ævar Arnfjörð Bjarmason
4 * This is a skeleton no-op implementation of gettext for Git.
5 * You can replace it with something that uses libintl.h and wraps
6 * gettext() to try out the translations.
7 */
9 #ifndef GETTEXT_H
10 #define GETTEXT_H
12 #if defined(_) || defined(Q_)
13 #error "namespace conflict: '_' or 'Q_' is pre-defined?"
14 #endif
16 #define FORMAT_PRESERVING(n) __attribute__((format_arg(n)))
18 #ifdef GETTEXT_POISON
19 extern int use_gettext_poison(void);
20 #else
21 #define use_gettext_poison() 0
22 #endif
24 static inline FORMAT_PRESERVING(1) const char *_(const char *msgid)
26 return use_gettext_poison() ? "# GETTEXT POISON #" : msgid;
29 static inline FORMAT_PRESERVING(1) FORMAT_PRESERVING(2)
30 const char *Q_(const char *msgid, const char *plu, unsigned long n)
32 if (use_gettext_poison())
33 return "# GETTEXT POISON #";
34 return n == 1 ? msgid : plu;
37 /* Mark msgid for translation but do not translate it. */
38 #define N_(msgid) msgid
40 #endif