test/tools/javac/resolve/tests/PrimitiveBinopOverload.java

Mon, 01 Jul 2013 14:57:03 +0100

author
mcimadamore
date
Mon, 01 Jul 2013 14:57:03 +0100
changeset 1875
f559ef7568ce
parent 0
959103a6100f
permissions
-rw-r--r--

7034798: Ambiguity error for abstract method call is too eager
Summary: Javac should wait and see if ambiguous methods can be reconciled at the end of an overload resolution round
Reviewed-by: jjg, vromero

aoqi@0 1 /*
aoqi@0 2 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
aoqi@0 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
aoqi@0 4 *
aoqi@0 5 * This code is free software; you can redistribute it and/or modify it
aoqi@0 6 * under the terms of the GNU General Public License version 2 only, as
aoqi@0 7 * published by the Free Software Foundation.
aoqi@0 8 *
aoqi@0 9 * This code is distributed in the hope that it will be useful, but WITHOUT
aoqi@0 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
aoqi@0 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
aoqi@0 12 * version 2 for more details (a copy is included in the LICENSE file that
aoqi@0 13 * accompanied this code).
aoqi@0 14 *
aoqi@0 15 * You should have received a copy of the GNU General Public License version
aoqi@0 16 * 2 along with this work; if not, write to the Free Software Foundation,
aoqi@0 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
aoqi@0 18 *
aoqi@0 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
aoqi@0 20 * or visit www.oracle.com if you need additional information or have any
aoqi@0 21 * questions.
aoqi@0 22 */
aoqi@0 23
aoqi@0 24 @TraceResolve
aoqi@0 25 class PrimitiveBinopOverload {
aoqi@0 26
aoqi@0 27 @Candidate(applicable=Phase.BASIC, mostSpecific=true)
aoqi@0 28 int _plus(int x, int y) { return -1; }
aoqi@0 29 @Candidate(applicable=Phase.BASIC)
aoqi@0 30 long _plus(long x, long y) { return -1; }
aoqi@0 31 @Candidate(applicable=Phase.BASIC)
aoqi@0 32 float _plus(float x, float y) { return -1; }
aoqi@0 33 @Candidate(applicable=Phase.BASIC)
aoqi@0 34 double _plus(double x, double y) { return -1; }
aoqi@0 35 //not a candidate
aoqi@0 36 Object _plus(Object x, Object y) { return -1; }
aoqi@0 37
aoqi@0 38 @Candidate(applicable= { Phase.BASIC, Phase.BOX }, mostSpecific=true)
aoqi@0 39 int _minus(int x, int y) { return -1; }
aoqi@0 40 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 41 long _minus(long x, long y) { return -1; }
aoqi@0 42 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 43 float _minus(float x, float y) { return -1; }
aoqi@0 44 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 45 double _minus(double x, double y) { return -1; }
aoqi@0 46
aoqi@0 47 @Candidate(applicable= { Phase.BASIC, Phase.BOX }, mostSpecific=true)
aoqi@0 48 int _mul(int x, int y) { return -1; }
aoqi@0 49 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 50 long _mul(long x, long y) { return -1; }
aoqi@0 51 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 52 float _mul(float x, float y) { return -1; }
aoqi@0 53 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 54 double _mul(double x, double y) { return -1; }
aoqi@0 55
aoqi@0 56 @Candidate(applicable= { Phase.BASIC, Phase.BOX }, mostSpecific=true)
aoqi@0 57 int _div(int x, int y) { return -1; }
aoqi@0 58 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 59 long _div(long x, long y) { return -1; }
aoqi@0 60 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 61 float _div(float x, float y) { return -1; }
aoqi@0 62 @Candidate(applicable= { Phase.BASIC, Phase.BOX })
aoqi@0 63 double _div(double x, double y) { return -1; }
aoqi@0 64
aoqi@0 65 {
aoqi@0 66 int i1 = 1 + 1;
aoqi@0 67 int i2 = 5 - new Integer(3);
aoqi@0 68 int i3 = new Integer(5) * 3;
aoqi@0 69 int i4 = new Integer(6) / new Integer(2);
aoqi@0 70 }
aoqi@0 71 }

mercurial