This repository has been archived by the owner on Aug 13, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path10.1.8-1.js
132 lines (109 loc) · 4.41 KB
/
10.1.8-1.js
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
/* The contents of this file are subject to the Netscape Public
* License Version 1.1 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.mozilla.org/NPL/
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
* The Original Code is Mozilla Communicator client code, released March
* 31, 1998.
*
* The Initial Developer of the Original Code is Netscape Communications
* Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All
* Rights Reserved.
*
* Contributor(s):
*
*/
/**
File Name: 10.1.8
ECMA Section: Arguments Object
Description:
When control enters an execution context for declared function code,
anonymous code, or implementation-supplied code, an arguments object is
created and initialized as follows:
The [[Prototype]] of the arguments object is to the original Object
prototype object, the one that is the initial value of Object.prototype
(section 15.2.3.1).
A property is created with name callee and property attributes {DontEnum}.
The initial value of this property is the function object being executed.
This allows anonymous functions to be recursive.
A property is created with name length and property attributes {DontEnum}.
The initial value of this property is the number of actual parameter values
supplied by the caller.
For each non-negative integer, iarg, less than the value of the length
property, a property is created with name ToString(iarg) and property
attributes { DontEnum }. The initial value of this property is the value
of the corresponding actual parameter supplied by the caller. The first
actual parameter value corresponds to iarg = 0, the second to iarg = 1 and
so on. In the case when iarg is less than the number of formal parameters
for the function object, this property shares its value with the
corresponding property of the activation object. This means that changing
this property changes the corresponding property of the activation object
and vice versa. The value sharing mechanism depends on the implementation.
Author: [email protected]
Date: 12 november 1997
*/
var SECTION = "10.1.8";
var VERSION = "ECMA_1";
startTest();
var TITLE = "Arguments Object";
writeHeaderToLog( SECTION + " "+ TITLE);
var testcases = new Array();
var ARG_STRING = "value of the argument property";
testcases[tc++] = new TestCase( SECTION,
"GetCallee()",
GetCallee,
GetCallee() );
var LIMIT = 100;
for ( var i = 0, args = "" ; i < LIMIT; i++ ) {
args += String(i) + ( i+1 < LIMIT ? "," : "" );
}
var LENGTH = eval( "GetLength("+ args +")" );
testcases[tc++] = new TestCase( SECTION,
"GetLength("+args+")",
100,
LENGTH );
var ARGUMENTS = eval( "GetArguments( " +args+")" );
for ( var i = 0; i < 100; i++ ) {
testcases[tc++] = new TestCase( SECTION,
"GetArguments("+args+")["+i+"]",
i,
ARGUMENTS[i] );
}
test();
function TestFunction() {
var arg_proto = arguments.__proto__;
}
function GetCallee() {
var c = arguments.callee;
return c;
}
function GetArguments() {
var a = arguments;
return a;
}
function GetLength() {
var l = arguments.length;
return l;
}
function AnotherTestFunction() {
this.__proto__ = new Prototype();
return this;
}
function test() {
for ( tc=0; tc < testcases.length; tc++ ) {
testcases[tc].passed = writeTestCaseResult(
testcases[tc].expect,
testcases[tc].actual,
testcases[tc].description +" = "+
testcases[tc].actual );
testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
}
stopTest();
return ( testcases );
}