Skip to content

Commit c4c0437

Browse files
committed
String.prototype.trim() fixes and tests.
JerryScript-DCO-1.0-Signed-off-by: Laszlo Vidacs [email protected]
1 parent 127ac2b commit c4c0437

File tree

2 files changed

+106
-30
lines changed

2 files changed

+106
-30
lines changed

jerry-core/ecma/builtin-objects/ecma-builtin-string-prototype.cpp

Lines changed: 37 additions & 30 deletions
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,6 @@
1414
* limitations under the License.
1515
*/
1616

17-
#include <ctype.h>
1817
#include "ecma-alloc.h"
1918
#include "ecma-builtins.h"
2019
#include "ecma-conversion.h"
@@ -26,6 +25,7 @@
2625
#include "ecma-string-object.h"
2726
#include "ecma-try-catch-macro.h"
2827
#include "jrt.h"
28+
#include "jrt-libc-includes.h"
2929

3030
#ifndef CONFIG_ECMA_COMPACT_PROFILE_DISABLE_STRING_BUILTIN
3131

@@ -567,45 +567,52 @@ ecma_builtin_string_prototype_object_trim (ecma_value_t this_arg) /**< this argu
567567
ecma_op_to_string (this_arg),
568568
ret_value);
569569

570-
ecma_string_t *original_string_p = ecma_get_string_from_value (to_string_val);
571-
JERRY_ASSERT (ecma_string_get_length (original_string_p) >= 0);
570+
if (ecma_is_completion_value_empty (ret_value))
571+
{
572+
ecma_string_t *original_string_p = ecma_get_string_from_value (to_string_val);
573+
JERRY_ASSERT (ecma_string_get_length (original_string_p) >= 0);
572574

573-
/* 3 */
574-
const uint32_t len = (uint32_t) ecma_string_get_length (original_string_p);
575+
/* 3 */
576+
const uint32_t len = (uint32_t) ecma_string_get_length (original_string_p);
575577

576-
uint32_t prefix = 0, postfix = 0;
577-
uint32_t new_len = 0;
578+
/* Workaround: avoid repeated call of ecma_string_get_char_at_pos() because its overhead */
579+
uint32_t zt_str_size = (uint32_t) sizeof (ecma_char_t) * (len + 1);
580+
ecma_char_t *original_zt_str_p = (ecma_char_t*) mem_heap_alloc_block (zt_str_size,
581+
MEM_HEAP_ALLOC_SHORT_TERM);
582+
ecma_string_to_zt_string (original_string_p, original_zt_str_p, (ssize_t) zt_str_size);
578583

579-
while (prefix < len &&
580-
ecma_is_completion_value_empty (ret_value) &&
581-
isspace (ecma_string_get_char_at_pos (original_string_p, prefix)))
582-
{
583-
prefix++;
584-
}
584+
uint32_t prefix = 0, postfix = 0;
585+
uint32_t new_len = 0;
585586

586-
while (postfix < len &&
587-
ecma_is_completion_value_empty (ret_value) &&
588-
isspace (ecma_string_get_char_at_pos (original_string_p, len-postfix-1)))
589-
{
590-
postfix++;
591-
}
587+
while (prefix < len && isspace (original_zt_str_p[prefix]))
588+
{
589+
prefix++;
590+
}
591+
592+
while (postfix < len - prefix && isspace (original_zt_str_p[len-postfix-1]))
593+
{
594+
postfix++;
595+
}
592596

593-
new_len = len - prefix - postfix;
597+
new_len = prefix < len ? len - prefix - postfix : 0;
594598

595-
MEM_DEFINE_LOCAL_ARRAY (new_str_buffer, new_len + 1, ecma_char_t);
599+
MEM_DEFINE_LOCAL_ARRAY (new_str_buffer, new_len + 1, ecma_char_t);
596600

597-
for (uint32_t idx = 0; idx < new_len; ++idx)
598-
{
599-
new_str_buffer[idx] = ecma_string_get_char_at_pos (original_string_p, idx + prefix);
600-
}
601+
for (uint32_t idx = 0; idx < new_len; ++idx)
602+
{
603+
new_str_buffer[idx] = original_zt_str_p[idx + prefix];
604+
}
601605

602-
new_str_buffer[new_len] = '\0';
603-
ecma_string_t *new_str_p = ecma_new_ecma_string ((ecma_char_t *) new_str_buffer);
606+
new_str_buffer[new_len] = '\0';
607+
ecma_string_t *new_str_p = ecma_new_ecma_string ((ecma_char_t *) new_str_buffer);
604608

605-
/* 4 */
606-
ret_value = ecma_make_normal_completion_value (ecma_make_string_value (new_str_p));
609+
/* 4 */
610+
ret_value = ecma_make_normal_completion_value (ecma_make_string_value (new_str_p));
607611

608-
MEM_FINALIZE_LOCAL_ARRAY (new_str_buffer);
612+
MEM_FINALIZE_LOCAL_ARRAY (new_str_buffer);
613+
614+
mem_heap_free_block (original_zt_str_p);
615+
}
609616

610617
ECMA_FINALIZE (to_string_val);
611618
ECMA_FINALIZE (check_coercible_val);

tests/jerry/string-prototype-trim.js

Lines changed: 69 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,69 @@
1+
// Copyright 2015 Samsung Electronics Co., Ltd.
2+
// Copyright 2015 University of Szeged.
3+
//
4+
// Licensed under the Apache License, Version 2.0 (the "License");
5+
// you may not use this file except in compliance with the License.
6+
// You may obtain a copy of the License at
7+
//
8+
// http://www.apache.org/licenses/LICENSE-2.0
9+
//
10+
// Unless required by applicable law or agreed to in writing, software
11+
// distributed under the License is distributed on an "AS IS" BASIS
12+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
// See the License for the specific language governing permissions and
14+
// limitations under the License.
15+
16+
// check properties
17+
assert(Object.getOwnPropertyDescriptor(String.prototype.trim, 'length').configurable === false);
18+
19+
assert(Object.getOwnPropertyDescriptor(String.prototype.trim, 'length').enumerable === false);
20+
21+
assert(Object.getOwnPropertyDescriptor(String.prototype.trim, 'length').writable === false);
22+
23+
assert(String.prototype.trim.length === 0);
24+
25+
// check this value
26+
assert(String.prototype.trim.call(new String()) === "");
27+
28+
assert(String.prototype.trim.call({}) === "[object Object]");
29+
30+
// check undefined
31+
try {
32+
String.prototype.trim.call(undefined);
33+
assert(false);
34+
} catch(e) {
35+
assert(e instanceof TypeError);
36+
}
37+
38+
// check null
39+
try {
40+
String.prototype.trim.call(null);
41+
assert(false);
42+
} catch(e) {
43+
assert(e instanceof TypeError);
44+
}
45+
46+
// simple checks
47+
assert(" hello world".trim() === "hello world");
48+
49+
assert("hello world ".trim() === "hello world");
50+
51+
assert(" hello world ".trim() === "hello world");
52+
53+
assert("\t hello world\n".trim() === "hello world");
54+
55+
assert("\t\n hello world\t \n ".trim() === "hello world");
56+
57+
assert("hello world\n \t\t".trim() === "hello world");
58+
59+
assert(" hello world \\ ".trim() === "hello world \\");
60+
61+
assert("**hello world**".trim() === "**hello world**");
62+
63+
assert(" \t \n".trim() === "");
64+
65+
assert(" ".trim() === "");
66+
67+
assert("".trim() === "");
68+
69+
// FIXME: add unicode tests when unicode support available

0 commit comments

Comments
 (0)