# HG changeset patch # User acorn # Date 1383149464 25200 # Node ID fdd464c8d62ee3a48c697e061164fe57aa2f2cb7 # Parent 1a04de1aaedb6e64182a75b1803d117fe5289893 8027304: Lambda: inheriting abstract + 1 default -> default, not ICCE Reviewed-by: hseigel, zgu diff -r 1a04de1aaedb -r fdd464c8d62e src/share/vm/classfile/defaultMethods.cpp --- a/src/share/vm/classfile/defaultMethods.cpp Mon Oct 28 21:41:48 2013 +0400 +++ b/src/share/vm/classfile/defaultMethods.cpp Wed Oct 30 09:11:04 2013 -0700 @@ -392,10 +392,16 @@ } GrowableArray qualified_methods; + int num_defaults = 0; + int default_index = -1; for (int i = 0; i < _members.length(); ++i) { Pair entry = _members.at(i); if (entry.second == QUALIFIED) { qualified_methods.append(entry.first); + default_index++; + if (entry.first->is_default_method()) { + num_defaults++; + } } } @@ -408,6 +414,9 @@ if (!method->is_abstract()) { _selected_target = qualified_methods.at(0); } + // If only one qualified method is default, select that + } else if (num_defaults == 1) { + _selected_target = qualified_methods.at(default_index); } else { _exception_message = generate_conflicts_message(&qualified_methods,CHECK); _exception_name = vmSymbols::java_lang_IncompatibleClassChangeError();