#include <cstdio> #include "XLIFFFile.h" #include "ValuesFile.h" #include "localize.h" #include <stdio.h> int pseudolocalize_xliff(XLIFFFile* xliff, bool expand); static int test_filename(const string& file, const string& locale, const string& expected) { string result = translated_file_name(file, locale); if (result != expected) { fprintf(stderr, "translated_file_name test failed\n"); fprintf(stderr, " locale='%s'\n", locale.c_str()); fprintf(stderr, " expected='%s'\n", expected.c_str()); fprintf(stderr, " result='%s'\n", result.c_str()); return 1; } else { if (false) { fprintf(stderr, "translated_file_name test passed\n"); fprintf(stderr, " locale='%s'\n", locale.c_str()); fprintf(stderr, " expected='%s'\n", expected.c_str()); fprintf(stderr, " result='%s'\n", result.c_str()); } return 0; } } static int translated_file_name_test() { bool all = true; int err = 0; if (all) err |= test_filename("//device/samples/NotePad/res/values/strings.xml", "zz_ZZ", "//device/samples/NotePad/res/values-zz-rZZ/strings.xml"); if (all) err |= test_filename("//device/samples/NotePad/res/values/strings.xml", "zz", "//device/samples/NotePad/res/values-zz/strings.xml"); if (all) err |= test_filename("//device/samples/NotePad/res/values/strings.xml", "", "//device/samples/NotePad/res/values/strings.xml"); return err; } bool return_false(const string&, const TransUnit& unit, void* cookie) { return false; } static int delete_trans_units() { XLIFFFile* xliff = XLIFFFile::Parse("testdata/strip_xliff.xliff"); if (xliff == NULL) { printf("couldn't read file\n"); return 1; } if (false) { printf("XLIFF was [[%s]]\n", xliff->ToString().c_str()); } xliff->Filter(return_false, NULL); if (false) { printf("XLIFF is [[%s]]\n", xliff->ToString().c_str()); set<StringResource> const& strings = xliff->GetStringResources(); printf("strings.size=%zd\n", strings.size()); for (set<StringResource>::iterator it=strings.begin(); it!=strings.end(); it++) { const StringResource& str = *it; printf("STRING!!! id=%s value='%s' pos=%s file=%s version=%d(%s)\n", str.id.c_str(), str.value->ContentsToString(ANDROID_NAMESPACES).c_str(), str.pos.ToString().c_str(), str.file.c_str(), str.version, str.versionString.c_str()); } } return 0; } static int filter_trans_units() { XLIFFFile* xliff = XLIFFFile::Parse("testdata/strip_xliff.xliff"); if (xliff == NULL) { printf("couldn't read file\n"); return 1; } if (false) { printf("XLIFF was [[%s]]\n", xliff->ToString().c_str()); } Settings setting; xliff->Filter(keep_this_trans_unit, &setting); if (false) { printf("XLIFF is [[%s]]\n", xliff->ToString().c_str()); set<StringResource> const& strings = xliff->GetStringResources(); printf("strings.size=%zd\n", strings.size()); for (set<StringResource>::iterator it=strings.begin(); it!=strings.end(); it++) { const StringResource& str = *it; printf("STRING!!! id=%s value='%s' pos=%s file=%s version=%d(%s)\n", str.id.c_str(), str.value->ContentsToString(ANDROID_NAMESPACES).c_str(), str.pos.ToString().c_str(), str.file.c_str(), str.version, str.versionString.c_str()); } } return 0; } static int settings_test() { int err; map<string,Settings> settings; map<string,Settings>::iterator it; err = read_settings("testdata/config.xml", &settings, "//asdf"); if (err != 0) { return err; } if (false) { for (it=settings.begin(); it!=settings.end(); it++) { const Settings& setting = it->second; printf("CONFIG:\n"); printf(" id='%s'\n", setting.id.c_str()); printf(" oldVersion='%s'\n", setting.oldVersion.c_str()); printf(" currentVersion='%s'\n", setting.currentVersion.c_str()); int i=0; for (vector<string>::const_iterator app=setting.apps.begin(); app!=setting.apps.end(); app++) { printf(" apps[%02d]='%s'\n", i, app->c_str()); i++; } i=0; for (vector<Reject>::const_iterator reject=setting.reject.begin(); reject!=setting.reject.end(); reject++) { i++; printf(" reject[%02d]=('%s','%s','%s')\n", i, reject->file.c_str(), reject->name.c_str(), reject->comment.c_str()); } } } for (it=settings.begin(); it!=settings.end(); it++) { const Settings& setting = it->second; if (it->first != setting.id) { fprintf(stderr, "it->first='%s' setting.id='%s'\n", it->first.c_str(), setting.id.c_str()); err |= 1; } } return err; } static int test_one_pseudo(bool big, const char* expected) { XLIFFFile* xliff = XLIFFFile::Parse("testdata/pseudo.xliff"); if (xliff == NULL) { printf("couldn't read file\n"); return 1; } if (false) { printf("XLIFF was [[%s]]\n", xliff->ToString().c_str()); } pseudolocalize_xliff(xliff, big); string newString = xliff->ToString(); delete xliff; if (false) { printf("XLIFF is [[%s]]\n", newString.c_str()); } if (false && newString != expected) { fprintf(stderr, "xliff didn't translate as expected\n"); fprintf(stderr, "newString=[[%s]]\n", newString.c_str()); fprintf(stderr, "expected=[[%s]]\n", expected); return 1; } return 0; } static int pseudolocalize_test() { int err = 0; err |= test_one_pseudo(false, ""); //err |= test_one_pseudo(true, ""); return err; } int localize_test() { bool all = true; int err = 0; if (all) err |= translated_file_name_test(); if (all) err |= delete_trans_units(); if (all) err |= filter_trans_units(); if (all) err |= settings_test(); if (all) err |= pseudolocalize_test(); return err; }