我对xgettext工具如何解析C源文件有一些误解 并收集字符串以供进一步翻译。
我使用xgettext工具版本0.10.35和 事实证明,在解析过程中它无法识别像宏一样定义的字符串。
例如,我们有test_xgettext.c文件,其中包含下一个内容:
#include <stdio.h>
#define _(str) str
#define STRING_1 _("string 1")
int main(void)
{
printf(STRING_1);
printf(_("string 2"));
return 0;
}
如果我们运行
xgettext.exe test_xgettext.c -o test_xgettext.pot -k _
我们将在test_xgettext.pot文件中包含下一个内容:
# SOME DESCRIPTIVE TITLE.
# Copyright (C) YEAR Free Software Foundation, Inc.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"POT-Creation-Date: 2016-09-01 12:39+0300\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=CHARSET\n"
"Content-Transfer-Encoding: ENCODING\n"
#: test_xgettext.c:10
msgid "string 2"
msgstr ""
这里我们在POT文件中只有“string 2”,我的目标是 收集“字符串1”和“字符串2”。
提前感谢您的帮助。
答案 0 :(得分:0)
如果我们使用数组而不是宏,它适用于 xgettext 0.10.35 。
修改后的源文件:
#include <stdio.h>
#define _(str) str
char STRING_1[] = _("string 1");
int main(void)
{
printf(STRING_1);
printf(_("string 2"));
return 0;
}
在这种情况下,我们在POT文件中有下一个输出(我没有留下重要的行):
#: test_xgettext.c:5
msgid "string 1"
msgstr ""
#: test_xgettext.c:10
msgid "string 2"
msgstr ""
事实证明它的工作方式与xgettext版本0.19.8.1(Windows 7 Professional)最初的预期相同。源文件:
#include <stdio.h>
#define _(str) str
#define STRING_1 _("string 1")
int main(void)
{
printf(STRING_1);
printf(_("string 2"));
return 0;
}
生成的POT文件:
#: test_xgettext.c:5
msgid "string 1"
msgstr ""
#: test_xgettext.c:10
#, c-format
msgid "string 2"
msgstr ""