msgfmtポーランドのテキストの「不正なマルチバイト列」エラー
-
23-08-2019 - |
質問
完全なC ++ I18Nのgettext()の「Hello World」私の例では、「es_MX
」に「pl_PL
」からのテキストからロケールを変更し、「こんにちは、世界!」 「無効な入力。少なくとも20文字の文字列を入力します。」。ポーランド語翻訳はmsgfmt、「łąźó」から「不正なマルチバイト列」エラーを引き起こすいくつかの文字が含まれています。翻訳されたテキストは、ウェブページからコピーされました。
私はUTF8が問題であると推定します。もしそうなら、何を代わりに使用すべきですか?
cat >plt.cxx <<EOF
// plt.cxx
#include <libintl.h>
#include <locale.h>
#include <iostream>
int main (){
setlocale(LC_ALL, "");
bindtextdomain("plt", ".");
textdomain( "plt");
std::cout << gettext("Invalid input. Enter a string at least 20 characters long.") << std::endl;
}
EOF
g++ -o plt plt.cxx
xgettext --package-name plt --package-version 1.2 --default-domain plt --output plt.pot plt.cxx
msginit --no-translator --locale pl_PL --output-file plt_polish.po --input plt.pot
sed --in-place plt_polish.po --expression='/#: /,$ s/""/"Nieprawidłowo wprowadzone dane. Wprowadź ciąg przynajmniej 20 znaków."/'
mkdir --parents ./pl_PL.utf8/LC_MESSAGES
msgfmt --check --verbose --output-file ./pl_PL.utf8/LC_MESSAGES/plt.mo plt_polish.po
LANGUAGE=pl_PL.utf8 ./plt
解決
の編集plt_polish.po
と "コンテンツタイプ:テキスト/平野;のcharset = UTF-8 \ n" はにContent-Typeのラインを変更します(ASCIIからUTF-8に文字セットを変更)
所属していません StackOverflow