1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/**
File Name: 15.5.4.5.1.js
ECMA Section: 15.5.4.5 String.prototype.charCodeAt(pos)
Description: Returns a number (a nonnegative integer less than 2^16)
representing the Unicode encoding of the character at
position pos in this string. If there is no character
at that position, the number is NaN.
When the charCodeAt method is called with one argument
pos, the following steps are taken:
1. Call ToString, giving it the theis value as its
argument
2. Call ToInteger(pos)
3. Compute the number of characters in result(1).
4. If Result(2) is less than 0 or is not less than
Result(3), return NaN.
5. Return a value of Number type, of positive sign, whose
magnitude is the Unicode encoding of one character
from result 1, namely the characer at position Result
(2), where the first character in Result(1) is
considered to be at position 0.
Note that the charCodeAt function is intentionally
generic; it does not require that its this value be a
String object. Therefore it can be transferred to other
kinds of objects for use as a method.
Author: christine@netscape.com
Date: 2 october 1997
*/
var SECTION = "15.5.4.5-1";
var VERSION = "ECMA_1";
startTest();
var TITLE = "String.prototype.charCodeAt";
writeHeaderToLog( SECTION + " "+ TITLE);
var TEST_STRING = new String( " !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~" );
for ( j = 0, i = 0x0020; i < 0x007e; i++, j++ ) {
new TestCase( SECTION, "TEST_STRING.charCodeAt("+j+")", i, TEST_STRING.charCodeAt( j ) );
}
new TestCase( SECTION, 'TEST_STRING.charCodeAt('+i+')', NaN, TEST_STRING.charCodeAt( i ) );
test();
|