On x86 compilers without fastcall, simulate it when invoking traces and un-simulate...
[wine-gecko.git] / js / tests / lc3 / JSBoolean / boolean-002-n.js
blob614051dcfb95e1ae772e97967b97f49b31e8b003
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4  *
5  * The contents of this file are subject to the Mozilla Public License Version
6  * 1.1 (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  * http://www.mozilla.org/MPL/
9  *
10  * Software distributed under the License is distributed on an "AS IS" basis,
11  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12  * for the specific language governing rights and limitations under the
13  * License.
14  *
15  * The Original Code is Mozilla Communicator client code, released
16  * March 31, 1998.
17  *
18  * The Initial Developer of the Original Code is
19  * Netscape Communications Corporation.
20  * Portions created by the Initial Developer are Copyright (C) 1998
21  * the Initial Developer. All Rights Reserved.
22  *
23  * Contributor(s):
24  *
25  * Alternatively, the contents of this file may be used under the terms of
26  * either the GNU General Public License Version 2 or later (the "GPL"), or
27  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
28  * in which case the provisions of the GPL or the LGPL are applicable instead
29  * of those above. If you wish to allow use of your version of this file only
30  * under the terms of either the GPL or the LGPL, and not to allow others to
31  * use your version of this file under the terms of the MPL, indicate your
32  * decision by deleting the provisions above and replace them with the notice
33  * and other provisions required by the GPL or the LGPL. If you do not delete
34  * the provisions above, a recipient may use your version of this file under
35  * the terms of any one of the MPL, the GPL or the LGPL.
36  *
37  * ***** END LICENSE BLOCK ***** */
39 gTestfile = 'boolean-002-n.js';
41 /* -*- Mode: java; tab-width: 8 -*-
42  * Copyright (C) 1997, 1998 Netscape Communications Corporation,
43  * All Rights Reserved.
44  */
46 /**
47  *  JavaScript to Java type conversion.
48  *
49  *  This test passes JavaScript boolean values to several Java methods
50  *  that expect arguments of various types, and verifies that the value is
51  *  converted to the correct value and type.
52  *
53  *  This tests instance methods, and not static methods.
54  *
55  *  Running these tests successfully requires you to have
56  *  com.netscape.javascript.qa.liveconnect.DataTypeClass on your classpath.
57  *
58  *  Specification:  Method Overloading Proposal for Liveconnect 3.0
59  *
60  *  @author: christine@netscape.com
61  *
62  */
63 var SECTION = "boolean conversion";
64 var VERSION = "1_4";
65 var TITLE   = "LiveConnect 3.0 JavaScript to Java Data Type Conversion " +
66   SECTION;
67 startTest();
69 var dt = new DT();
71 var a = new Array();
72 var i = 0;
74 // passing a boolean to a java method that expects a boolean should map
75 // directly to the Java true / false equivalent
78 // passing a boolean to a java method that expects a double
79 // should be an error
81 a[i++] = new TestObject(
82   "dt.setDouble( true )",
83   "dt.PUB_DOUBLE",
84   "dt.getDouble()",
85   "typeof dt.getDouble()",
86   "error",
87   "error" );
89 for ( i = 0; i < a.length; i++ ) {
90   new TestCase(
91     a[i].description +"; "+ a[i].javaFieldName,
92     a[i].jsValue,
93     a[i].javaFieldValue );
95   new TestCase(
96     a[i].description +"; " + a[i].javaMethodName,
97     a[i].jsValue,
98     a[i].javaMethodValue );
100   new TestCase(
101     a[i].javaTypeName,
102     a[i].jsType,
103     a[i].javaTypeValue );
106 test();
108 function TestObject( description, javaField, javaMethod, javaType,
109                      jsValue, jsType )
111   eval (description );
113   this.description = description;
114   this.javaFieldName = javaField;
115   this.javaFieldValue = eval( javaField );
116   this.javaMethodName = javaMethod;
117   this.javaMethodValue = eval( javaMethod );
118   this.javaTypeName = javaType,
119     this.javaTypeValue = eval( javaType );
121   this.jsValue   = jsValue;
122   this.jsType      = jsType;