/* Test the Unicode character type functions. Copyright (C) 2007-2009 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include #include "unictype.h" #include #include "macros.h" int main () { /* Test the uc_script function. */ ASSERT (strcmp (uc_script ('A')->name, "Latin") == 0); ASSERT (strcmp (uc_script ('%')->name, "Common") == 0); ASSERT (uc_script (0xE0000) == NULL); /* Test the uc_script_byname function. */ ASSERT (strcmp (uc_script_byname ("Armenian")->name, "Armenian") == 0); ASSERT (uc_script_byname ("Pekinese") == NULL); /* Test the uc_is_script function. */ ASSERT (uc_is_script ('A', uc_script_byname ("Latin"))); ASSERT (!uc_is_script ('A', uc_script_byname ("Common"))); ASSERT (!uc_is_script (0x05DA, uc_script_byname ("Latin"))); ASSERT (uc_is_script (0x05DA, uc_script_byname ("Hebrew"))); { unsigned int c; for (c = 0; c < 0x110000; c++) { const uc_script_t *script = uc_script (c); if (script != NULL) ASSERT (uc_is_script (c, script)); } } /* Test the uc_all_scripts function. */ { const uc_script_t *scripts; size_t nscripts; size_t i; bool found; uc_all_scripts (&scripts, &nscripts); found = false; for (i = 0; i < nscripts; i++) { ASSERT (scripts[i].name != NULL); if (strcmp (scripts[i].name, "Hebrew") == 0) found = true; } ASSERT (found); } return 0; }