git@vger.kernel.org mailing list mirror (one of many)
 help / color / mirror / code / Atom feed
blob fcb6bfaa2c8de3c01820b0b71384e98db7787056 2493 bytes (raw)
name: gettext.h 	 # note: path name is non-authoritative(*)

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
 
/*
 * Copyright (c) 2010-2011 Ævar Arnfjörð Bjarmason
 *
 * This is a skeleton no-op implementation of gettext for Git.
 * You can replace it with something that uses libintl.h and wraps
 * gettext() to try out the translations.
 */

#ifndef GETTEXT_H
#define GETTEXT_H

#if defined(_) || defined(Q_)
#error "namespace conflict: '_' or 'Q_' is pre-defined?"
#endif

#ifndef NO_GETTEXT
#	include <libintl.h>
#else
#	ifdef gettext
#		undef gettext
#	endif
#	define gettext(s) (s)
#	ifdef ngettext
#		undef ngettext
#	endif
#	define ngettext(s, p, n) ((n == 1) ? (s) : (p))
#endif

#define FORMAT_PRESERVING(n) __attribute__((format_arg(n)))

#ifndef NO_GETTEXT
extern void git_setup_gettext(void);
extern int gettext_width(const char *s);
#else
static inline void git_setup_gettext(void)
{
}
static inline int gettext_width(const char *s)
{
	return strlen(s);
}
#endif

#ifdef GETTEXT_POISON
enum poison_mode {
	poison_mode_uninitialized = -1,
	poison_mode_none = 0,
	poison_mode_default
};

extern enum poison_mode use_gettext_poison(void);

#define GETTEXT_POISON_MAGIC "# GETTEXT POISON #"
#endif

static inline FORMAT_PRESERVING(1) const char *_(const char *msgid)
{
	if (!*msgid)
		return "";
#ifdef GETTEXT_POISON
	if (use_gettext_poison() == poison_mode_default)
		return GETTEXT_POISON_MAGIC;
#endif
	return gettext(msgid);
}

static inline FORMAT_PRESERVING(1) FORMAT_PRESERVING(2)
const char *Q_(const char *msgid, const char *plu, unsigned long n)
{
#ifdef GETTEXT_POISON
	if (use_gettext_poison() == poison_mode_default)
		return GETTEXT_POISON_MAGIC;
#endif
	return ngettext(msgid, plu, n);
}

/* Mark msgid for translation but do not translate it. */
#if !USE_PARENS_AROUND_GETTEXT_N
#define N_(msgid) msgid
#else
/*
 * Strictly speaking, this will lead to invalid C when
 * used this way:
 *	static const char s[] = N_("FOO");
 * which will expand to
 *	static const char s[] = ("FOO");
 * and in valid C, the initializer on the right hand side must
 * be without the parentheses.  But many compilers do accept it
 * as a language extension and it will allow us to catch mistakes
 * like:
 *	static const char *msgs[] = {
 *		N_("one")
 *		N_("two"),
 *		N_("three"),
 *		NULL
 *	};
 * (notice the missing comma on one of the lines) by forcing
 * a compilation error, because parenthesised ("one") ("two")
 * will not get silently turned into ("onetwo").
 */
#define N_(msgid) (msgid)
#endif

const char *get_preferred_languages(void);
extern int is_utf8_locale(void);

#endif

debug log:

solving fcb6bfaa2c ...
found fcb6bfaa2c in https://public-inbox.org/git/20181022202241.18629-7-szeder.dev@gmail.com/
found 8e279622f6 in https://public-inbox.org/git/20181022202241.18629-6-szeder.dev@gmail.com/
found c658942f7d in https://public-inbox.org/git/20181022202241.18629-5-szeder.dev@gmail.com/
found 7eee64a34f in https://80x24.org/mirrors/git.git
preparing index
index prepared:
100644 7eee64a34fa0a5e922606e6351b29d08cb26fe6b	gettext.h

applying [1/3] https://public-inbox.org/git/20181022202241.18629-5-szeder.dev@gmail.com/
diff --git a/gettext.h b/gettext.h
index 7eee64a34f..c658942f7d 100644


applying [2/3] https://public-inbox.org/git/20181022202241.18629-6-szeder.dev@gmail.com/
diff --git a/gettext.h b/gettext.h
index c658942f7d..8e279622f6 100644


applying [3/3] https://public-inbox.org/git/20181022202241.18629-7-szeder.dev@gmail.com/
diff --git a/gettext.h b/gettext.h
index 8e279622f6..fcb6bfaa2c 100644

Checking patch gettext.h...
Applied patch gettext.h cleanly.
Checking patch gettext.h...
Applied patch gettext.h cleanly.
Checking patch gettext.h...
Applied patch gettext.h cleanly.

index at:
100644 fcb6bfaa2c8de3c01820b0b71384e98db7787056	gettext.h

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://80x24.org/mirrors/git.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).