8008723: Graph Inference: bad graph calculation leads to assertion error

Dependencies are not propagated correctly through merged nodes during inference graph initialization

Reviewed-by: jjg
This commit is contained in:
Maurizio Cimadamore 2013-02-28 14:00:52 +00:00
parent 9f2721bfb1
commit 9c01455eb6
2 changed files with 62 additions and 3 deletions

View File

@ -1216,7 +1216,7 @@ public class Infer {
* created, effectively replacing the original cyclic nodes. * created, effectively replacing the original cyclic nodes.
*/ */
void initNodes() { void initNodes() {
ArrayList<Node> nodes = new ArrayList<Node>(); nodes = new ArrayList<Node>();
for (Type t : inferenceContext.restvars()) { for (Type t : inferenceContext.restvars()) {
nodes.add(new Node(t)); nodes.add(new Node(t));
} }
@ -1235,7 +1235,7 @@ public class Infer {
} }
} }
} }
this.nodes = new ArrayList<Node>(); ArrayList<Node> acyclicNodes = new ArrayList<Node>();
for (List<? extends Node> conSubGraph : GraphUtils.tarjan(nodes)) { for (List<? extends Node> conSubGraph : GraphUtils.tarjan(nodes)) {
if (conSubGraph.length() > 1) { if (conSubGraph.length() > 1) {
Node root = conSubGraph.head; Node root = conSubGraph.head;
@ -1244,8 +1244,9 @@ public class Infer {
notifyUpdate(n, root); notifyUpdate(n, root);
} }
} }
this.nodes.add(conSubGraph.head); acyclicNodes.add(conSubGraph.head);
} }
nodes = acyclicNodes;
} }
/** /**

View File

@ -0,0 +1,58 @@
/*
* Copyright (c) 2013, 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.
*/
/*
* @test
* @bug 8008723
* @summary Graph Inference: bad graph calculation leads to assertion error
* @compile TargetType65.java
*/
class TargetType65 {
interface Predicate<X> {
boolean accepts(X x);
}
static class Optional<T> {
public boolean isPresent() { return false; }
public static<E> Optional<E> empty() { return null; }
}
interface Supplier<X> {
X make();
}
static class Sink<O, T> { }
static class SubSink<R> extends Sink<R, Optional<R>> { }
static class Tester<T, O> {
public static <F> Tester<F, Optional<F>> makeRef() {
return new Tester<>(Optional.empty(), Optional::isPresent, SubSink::new);
}
private Tester(O emptyValue,
Predicate<O> presentPredicate,
Supplier<Sink<T, O>> sinkSupplier) {
}
}
}