Add core unicode functionality.
Add utf-8 processing routines. Change ecma_char_t from char/uint16_t to uint16_t. Apply all utf-8 processing routines. Change char to jerry_api_char in API functions' declarations. JerryScript-DCO-1.0-Signed-off-by: Andrey Shitov a.shitov@samsung.com
This commit is contained in:
@@ -15,7 +15,7 @@
|
||||
|
||||
#include "ecma-helpers.h"
|
||||
#include "lit-literal.h"
|
||||
|
||||
#include "lit-magic-strings.h"
|
||||
#include "test-common.h"
|
||||
|
||||
// Iterations count
|
||||
@@ -28,13 +28,13 @@
|
||||
#define max_characters_in_string 256
|
||||
|
||||
static void
|
||||
generate_string (ecma_char_t *str, ecma_length_t len)
|
||||
generate_string (lit_utf8_byte_t *str, lit_utf8_size_t len)
|
||||
{
|
||||
static const ecma_char_t characters[] = "!@#$%^&*()_+abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ123456789";
|
||||
static const ecma_length_t length = (ecma_length_t) (sizeof (characters) / sizeof (ecma_char_t) - 1);
|
||||
for (ecma_length_t i = 0; i < len; ++i)
|
||||
static const lit_utf8_byte_t bytes[] = "!@#$%^&*()_+abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ123456789";
|
||||
static const lit_utf8_size_t length = (lit_utf8_size_t) (sizeof (bytes) - 1);
|
||||
for (lit_utf8_size_t i = 0; i < len; ++i)
|
||||
{
|
||||
str[i] = characters[(unsigned long) rand () % length];
|
||||
str[i] = bytes[(unsigned long) rand () % length];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -60,10 +60,10 @@ main (int __attr_unused___ argc,
|
||||
{
|
||||
TEST_INIT ();
|
||||
|
||||
const ecma_char_t *ptrs[test_sub_iters];
|
||||
const lit_utf8_byte_t *ptrs[test_sub_iters];
|
||||
ecma_number_t numbers[test_sub_iters];
|
||||
ecma_char_t strings[test_sub_iters][max_characters_in_string + 1];
|
||||
ecma_length_t lengths[test_sub_iters];
|
||||
lit_utf8_byte_t strings[test_sub_iters][max_characters_in_string + 1];
|
||||
lit_utf8_size_t lengths[test_sub_iters];
|
||||
|
||||
mem_init ();
|
||||
lit_init ();
|
||||
@@ -72,17 +72,17 @@ main (int __attr_unused___ argc,
|
||||
for (uint32_t i = 0; i < test_iters; i++)
|
||||
{
|
||||
memset (numbers, 0, sizeof (ecma_number_t) * test_sub_iters);
|
||||
memset (lengths, 0, sizeof (ecma_length_t) * test_sub_iters);
|
||||
memset (ptrs, 0, sizeof (ecma_char_t *) * test_sub_iters);
|
||||
memset (lengths, 0, sizeof (lit_utf8_size_t) * test_sub_iters);
|
||||
memset (ptrs, 0, sizeof (lit_utf8_byte_t *) * test_sub_iters);
|
||||
|
||||
for (uint32_t j = 0; j < test_sub_iters; j++)
|
||||
{
|
||||
int type = rand () % 3;
|
||||
if (type == 0)
|
||||
{
|
||||
lengths[j] = (ecma_length_t) (rand () % max_characters_in_string + 1);
|
||||
lengths[j] = (lit_utf8_size_t) (rand () % max_characters_in_string + 1);
|
||||
generate_string (strings[j], lengths[j]);
|
||||
lit_create_literal_from_charset (strings[j], lengths[j]);
|
||||
lit_create_literal_from_utf8_string (strings[j], lengths[j]);
|
||||
strings[j][lengths[j]] = '\0';
|
||||
ptrs[j] = strings[j];
|
||||
JERRY_ASSERT (ptrs[j]);
|
||||
@@ -90,21 +90,21 @@ main (int __attr_unused___ argc,
|
||||
else if (type == 1)
|
||||
{
|
||||
lit_magic_string_id_t msi = (lit_magic_string_id_t) (rand () % LIT_MAGIC_STRING__COUNT);
|
||||
ptrs[j] = lit_get_magic_string_zt (msi);
|
||||
ptrs[j] = lit_get_magic_string_utf8 (msi);
|
||||
JERRY_ASSERT (ptrs[j]);
|
||||
lengths[j] = (ecma_length_t) ecma_zt_string_length (ptrs[j]);
|
||||
lit_create_literal_from_charset (ptrs[j], lengths[j]);
|
||||
lengths[j] = (lit_utf8_size_t) lit_zt_utf8_string_size (ptrs[j]);
|
||||
lit_create_literal_from_utf8_string (ptrs[j], lengths[j]);
|
||||
}
|
||||
else
|
||||
{
|
||||
ecma_number_t num = generate_number ();
|
||||
lengths[j] = ecma_number_to_zt_string (num, strings[j], max_characters_in_string);
|
||||
lengths[j] = ecma_number_to_utf8_string (num, strings[j], max_characters_in_string);
|
||||
lit_create_literal_from_num (num);
|
||||
}
|
||||
}
|
||||
|
||||
// Add empty string
|
||||
lit_create_literal_from_charset (NULL, 0);
|
||||
lit_create_literal_from_utf8_string (NULL, 0);
|
||||
|
||||
for (uint32_t j = 0; j < test_sub_iters; j++)
|
||||
{
|
||||
@@ -112,10 +112,10 @@ main (int __attr_unused___ argc,
|
||||
literal_t lit2;
|
||||
if (ptrs[j])
|
||||
{
|
||||
lit1 = lit_find_or_create_literal_from_charset (ptrs[j], lengths[j]);
|
||||
lit2 = lit_find_literal_by_charset (ptrs[j], lengths[j]);
|
||||
JERRY_ASSERT (lit_literal_equal_zt (lit1, ptrs[j]));
|
||||
JERRY_ASSERT (lit_literal_equal_type_zt (lit2, ptrs[j]));
|
||||
lit1 = lit_find_or_create_literal_from_utf8_string (ptrs[j], lengths[j]);
|
||||
lit2 = lit_find_literal_by_utf8_string (ptrs[j], lengths[j]);
|
||||
JERRY_ASSERT (lit_literal_equal_utf8 (lit1, ptrs[j], lengths[j]));
|
||||
JERRY_ASSERT (lit_literal_equal_type_utf8 (lit2, ptrs[j], lengths[j]));
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -131,7 +131,7 @@ main (int __attr_unused___ argc,
|
||||
}
|
||||
|
||||
// Check empty string exists
|
||||
JERRY_ASSERT (lit_find_literal_by_charset (NULL, 0));
|
||||
JERRY_ASSERT (lit_find_literal_by_utf8_string (NULL, 0));
|
||||
|
||||
lit_storage.cleanup ();
|
||||
JERRY_ASSERT (lit_storage.get_first () == NULL);
|
||||
|
||||
Reference in New Issue
Block a user