i18n of multi-line advice messages
Advice messages are by definition meant for human end-users, and prime candidates for i18n/l10n. They tend to also be more verbose to be helpful, and need to be longer than just one line. Although we do not have parameterized multi-line advice messages yet, once we do, we cannot emit such a message like this: advise(_("Please rename %s to something else"), gostak); advise(_("so that we can avoid distimming %s unnecessarily."), doshes); because some translations may need to have the replacement of 'gostak' on the second line (or 'doshes' on the first line). Some languages may even need to use three lines in order to fit the same message within a reasonable width. Instead, it has to be a single advise() construct, like this: advise(_("Please rename %s to something else\n" "so that we can avoid distimming %s unnecessarily."), gostak, doshes); Update the advise() function and its existing callers to - take a format string that can be multi-line and translatable as a whole; - use the string and the parameters to form a localized message; and - show each line in the result with the localization of the "hint: ". Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
2ce0edcd78
commit
23cb5bf3b3
23
advice.c
23
advice.c
@ -21,11 +21,21 @@ static struct {
|
|||||||
|
|
||||||
void advise(const char *advice, ...)
|
void advise(const char *advice, ...)
|
||||||
{
|
{
|
||||||
|
struct strbuf buf = STRBUF_INIT;
|
||||||
va_list params;
|
va_list params;
|
||||||
|
const char *cp, *np;
|
||||||
|
|
||||||
va_start(params, advice);
|
va_start(params, advice);
|
||||||
vreportf("hint: ", advice, params);
|
strbuf_addf(&buf, advice, params);
|
||||||
va_end(params);
|
va_end(params);
|
||||||
|
|
||||||
|
for (cp = buf.buf; *cp; cp = np) {
|
||||||
|
np = strchrnul(cp, '\n');
|
||||||
|
fprintf(stderr, _("hint: %.*s\n"), (int)(np - cp), cp);
|
||||||
|
if (*np)
|
||||||
|
np++;
|
||||||
|
}
|
||||||
|
strbuf_release(&buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
int git_default_advice_config(const char *var, const char *value)
|
int git_default_advice_config(const char *var, const char *value)
|
||||||
@ -46,16 +56,15 @@ int git_default_advice_config(const char *var, const char *value)
|
|||||||
int error_resolve_conflict(const char *me)
|
int error_resolve_conflict(const char *me)
|
||||||
{
|
{
|
||||||
error("'%s' is not possible because you have unmerged files.", me);
|
error("'%s' is not possible because you have unmerged files.", me);
|
||||||
if (advice_resolve_conflict) {
|
if (advice_resolve_conflict)
|
||||||
/*
|
/*
|
||||||
* Message used both when 'git commit' fails and when
|
* Message used both when 'git commit' fails and when
|
||||||
* other commands doing a merge do.
|
* other commands doing a merge do.
|
||||||
*/
|
*/
|
||||||
advise("Fix them up in the work tree,");
|
advise(_("Fix them up in the work tree,\n"
|
||||||
advise("and then use 'git add/rm <file>' as");
|
"and then use 'git add/rm <file>' as\n"
|
||||||
advise("appropriate to mark resolution and make a commit,");
|
"appropriate to mark resolution and make a commit,\n"
|
||||||
advise("or use 'git commit -a'.");
|
"or use 'git commit -a'."));
|
||||||
}
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -332,11 +332,10 @@ static void print_advice(int show_hint)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (show_hint) {
|
if (show_hint)
|
||||||
advise("after resolving the conflicts, mark the corrected paths");
|
advise(_("after resolving the conflicts, mark the corrected paths\n"
|
||||||
advise("with 'git add <paths>' or 'git rm <paths>'");
|
"with 'git add <paths>' or 'git rm <paths>'\n"
|
||||||
advise("and commit the result with 'git commit'");
|
"and commit the result with 'git commit'"));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void write_message(struct strbuf *msgbuf, const char *filename)
|
static void write_message(struct strbuf *msgbuf, const char *filename)
|
||||||
|
Loading…
Reference in New Issue
Block a user