2005-08-19 Florian Gross <flgr@ccan.de>
[mono.git] / mcs / class / Microsoft.JScript / Test / Mozilla / ecma / ExecutionContexts / 10.1.8-2.js
index e0d6291b641abeae1e4867a5d555e5eefba8b1f0..db3f89785674c5bef000f641710b93a7c4cbc70e 100644 (file)
-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */\r
-/* ***** BEGIN LICENSE BLOCK *****\r
- * Version: MPL 1.1/GPL 2.0/LGPL 2.1\r
- *\r
- * The contents of this file are subject to the Mozilla Public License Version\r
- * 1.1 (the "License"); you may not use this file except in compliance with\r
- * the License. You may obtain a copy of the License at\r
- * http://www.mozilla.org/MPL/\r
- *\r
- * Software distributed under the License is distributed on an "AS IS" basis,\r
- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License\r
- * for the specific language governing rights and limitations under the\r
- * License.\r
- *\r
- * The Original Code is Mozilla Communicator client code, released\r
- * March 31, 1998.\r
- *\r
- * The Initial Developer of the Original Code is\r
- * Netscape Communications Corporation.\r
- * Portions created by the Initial Developer are Copyright (C) 1998\r
- * the Initial Developer. All Rights Reserved.\r
- *\r
- * Contributor(s):\r
- *\r
- * Alternatively, the contents of this file may be used under the terms of\r
- * either the GNU General Public License Version 2 or later (the "GPL"), or\r
- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),\r
- * in which case the provisions of the GPL or the LGPL are applicable instead\r
- * of those above. If you wish to allow use of your version of this file only\r
- * under the terms of either the GPL or the LGPL, and not to allow others to\r
- * use your version of this file under the terms of the MPL, indicate your\r
- * decision by deleting the provisions above and replace them with the notice\r
- * and other provisions required by the GPL or the LGPL. If you do not delete\r
- * the provisions above, a recipient may use your version of this file under\r
- * the terms of any one of the MPL, the GPL or the LGPL.\r
- *\r
- * ***** END LICENSE BLOCK ***** */\r
-\r
-/**\r
-   File Name:          10.1.8-2\r
-   ECMA Section:       Arguments Object\r
-   Description:\r
-\r
-   When control enters an execution context for declared function code,\r
-   anonymous code, or implementation-supplied code, an arguments object is\r
-   created and initialized as follows:\r
-\r
-   The [[Prototype]] of the arguments object is to the original Object\r
-   prototype object, the one that is the initial value of Object.prototype\r
-   (section 15.2.3.1).\r
-\r
-   A property is created with name callee and property attributes {DontEnum}.\r
-   The initial value of this property is the function object being executed.\r
-   This allows anonymous functions to be recursive.\r
-\r
-   A property is created with name length and property attributes {DontEnum}.\r
-   The initial value of this property is the number of actual parameter values\r
-   supplied by the caller.\r
-\r
-   For each non-negative integer, iarg, less than the value of the length\r
-   property, a property is created with name ToString(iarg) and property\r
-   attributes { DontEnum }. The initial value of this property is the value\r
-   of the corresponding actual parameter supplied by the caller. The first\r
-   actual parameter value corresponds to iarg = 0, the second to iarg = 1 and\r
-   so on. In the case when iarg is less than the number of formal parameters\r
-   for the function object, this property shares its value with the\r
-   corresponding property of the activation object. This means that changing\r
-   this property changes the corresponding property of the activation object\r
-   and vice versa. The value sharing mechanism depends on the implementation.\r
-\r
-   Author:             christine@netscape.com\r
-   Date:               12 november 1997\r
-*/\r
-\r
-var SECTION = "10.1.8-2";\r
-var VERSION = "ECMA_1";\r
-startTest();\r
-var TITLE   = "Arguments Object";\r
-\r
-writeHeaderToLog( SECTION + " "+ TITLE);\r
-\r
-//  Tests for anonymous functions\r
-\r
-var GetCallee       = new Function( "var c = arguments.callee; return c" );\r
-var GetArguments    = new Function( "var a = arguments; return a" );\r
-var GetLength       = new Function( "var l = arguments.length; return l" );\r
-\r
-var ARG_STRING = "value of the argument property";\r
-\r
-new TestCase( SECTION,\r
-             "GetCallee()",\r
-             GetCallee,\r
-             GetCallee() );\r
-\r
-var LIMIT = 100;\r
-\r
-for ( var i = 0, args = "" ; i < LIMIT; i++ ) {\r
-  args += String(i) + ( i+1 < LIMIT ? "," : "" );\r
-\r
-}\r
-\r
-var LENGTH = eval( "GetLength("+ args +")" );\r
-\r
-new TestCase( SECTION,\r
-             "GetLength("+args+")",\r
-             100,\r
-             LENGTH );\r
-\r
-var ARGUMENTS = eval( "GetArguments( " +args+")" );\r
-\r
-for ( var i = 0; i < 100; i++ ) {\r
-  new TestCase( SECTION,\r
-               "GetArguments("+args+")["+i+"]",\r
-               i,\r
-               ARGUMENTS[i] );\r
-}\r
-\r
-test();\r
+/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* ***** BEGIN LICENSE BLOCK *****
+ * Version: MPL 1.1/GPL 2.0/LGPL 2.1
+ *
+ * The contents of this file are subject to the Mozilla 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/MPL/
+ *
+ * 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 the Initial Developer are Copyright (C) 1998
+ * the Initial Developer. All Rights Reserved.
+ *
+ * Contributor(s):
+ *
+ * Alternatively, the contents of this file may be used under the terms of
+ * either the GNU General Public License Version 2 or later (the "GPL"), or
+ * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
+ * in which case the provisions of the GPL or the LGPL are applicable instead
+ * of those above. If you wish to allow use of your version of this file only
+ * under the terms of either the GPL or the LGPL, and not to allow others to
+ * use your version of this file under the terms of the MPL, indicate your
+ * decision by deleting the provisions above and replace them with the notice
+ * and other provisions required by the GPL or the LGPL. If you do not delete
+ * the provisions above, a recipient may use your version of this file under
+ * the terms of any one of the MPL, the GPL or the LGPL.
+ *
+ * ***** END LICENSE BLOCK ***** */
+
+/**
+   File Name:          10.1.8-2
+   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:             christine@netscape.com
+   Date:               12 november 1997
+*/
+
+var SECTION = "10.1.8-2";
+var VERSION = "ECMA_1";
+startTest();
+var TITLE   = "Arguments Object";
+
+writeHeaderToLog( SECTION + " "+ TITLE);
+
+//  Tests for anonymous functions
+
+var GetCallee       = new Function( "var c = arguments.callee; return c" );
+var GetArguments    = new Function( "var a = arguments; return a" );
+var GetLength       = new Function( "var l = arguments.length; return l" );
+
+var ARG_STRING = "value of the argument property";
+
+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 +")" );
+
+new TestCase( SECTION,
+             "GetLength("+args+")",
+             100,
+             LENGTH );
+
+var ARGUMENTS = eval( "GetArguments( " +args+")" );
+
+for ( var i = 0; i < 100; i++ ) {
+  new TestCase( SECTION,
+               "GetArguments("+args+")["+i+"]",
+               i,
+               ARGUMENTS[i] );
+}
+
+test();