/* * Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package nsk.jdi.Field.equals; import nsk.share.*; import nsk.share.jpda.*; import nsk.share.jdi.*; public class equals001a { public static void main (String argv[]) { ArgumentHandler argHandler = new ArgumentHandler(argv); Log log = new Log(System.err, argHandler); IOPipe pipe = argHandler.createDebugeeIOPipe(log); ClassToCheck check = new ClassToCheck(); log.display("DEBUGEE> debugee started."); pipe.println("ready"); String instruction = pipe.readln(); if (instruction.equals("quit")) { log.display("DEBUGEE> \"quit\" signal recieved."); log.display("DEBUGEE> completed succesfully."); System.exit(95); } log.complain("DEBUGEE FAILURE> unexpected signal " + "(no \"quit\") - " + instruction); log.complain("DEBUGEE FAILURE> TEST FAILED"); System.exit(97); } } class ClassToCheck { // Fields boolean z0, z1[]={z0}, z2[][]={z1}; byte b0, b1[]={b0}, b2[][]={b1}; char c0, c1[]={c0}, c2[][]={c1}; double d0, d1[]={d0}, d2[][]={d1}; float f0, f1[]={f0}, f2[][]={f1}; int i0, i1[]={i0}, i2[][]={i1}; long l0, l1[]={l0}, l2[][]={l1}; static long lS0, lS1[]={lS0}, lS2[][]={lS1}; private long lP0, lP1[]={lP0}, lP2[][]={lP1}; public long lU0, lU1[]={lU0}, lU2[][]={lU1}; protected long lR0, lR1[]={lR0}, lR2[][]={lR1}; transient long lT0, lT1[]={lT0}, lT2[][]={lT1}; volatile long lV0, lV1[]={lV0}, lV2[][]={lV1}; final long lF0 = 999, lF1[]={lF0}, lF2[][]={lF1}; class Class {} Class X0, X1[]={X0}, X2[][]={X1}; Boolean Z0, Z1[]={Z0}, Z2[][]={Z1}; Byte B0, B1[]={B0}, B2[][]={B1}; Character C0, C1[]={C0}, C2[][]={C1}; Double D0, D1[]={D0}, D2[][]={D1}; Float F0, F1[]={F0}, F2[][]={F1}; Integer I0, I1[]={I0}, I2[][]={I1}; Long L0, L1[]={L0}, L2[][]={L1}; String S0, S1[]={S0}, S2[][]={S1}; Object O0, O1[]={O0}, O2[][]={O1}; static Long LS0, LS1[]={LS0}, LS2[][]={LS1}; private Long LP0, LP1[]={LP0}, LP2[][]={LP1}; public Long LU0, LU1[]={LU0}, LU2[][]={LU1}; protected Long LR0, LR1[]={LR0}, LR2[][]={LR1}; transient Long LT0, LT1[]={LT0}, LT2[][]={LT1}; volatile Long LV0, LV1[]={LV0}, LV2[][]={LV1}; final Long LF0 = new Long(999), LF1[]={LF0}, LF2[][]={LF1}; interface Inter {} Inter E0, E1[]={E0}, E2[][]={E1}; static Inter ES0, ES1[]={ES0}, ES2[][]={ES1}; private Inter EP0, EP1[]={EP0}, EP2[][]={EP1}; public Inter EU0, EU1[]={EU0}, EU2[][]={EU1}; protected Inter ER0, ER1[]={ER0}, ER2[][]={ER1}; transient Inter ET0, ET1[]={ET0}, ET2[][]={ET1}; volatile Inter EV0, EV1[]={EV0}, EV2[][]={EV1}; final Inter EF0 = null, EF1[]={EF0}, EF2[][]={EF1}; // Methods void v_m() {} boolean z_m() { return true; } byte b_m() { return (byte)1; } char c_m() { return (char)1; } double d_m() { return (double)1; } float f_m() { return (float)1; } int i_m() { return (int)1; } long l_m() { return (long)1; } }