| Index: runtime/vm/precompiler.cc
|
| diff --git a/runtime/vm/precompiler.cc b/runtime/vm/precompiler.cc
|
| index 16304750a0134f1699f6632778dc8e780b93637c..cc5344a85312cfe932a3eecf294cbafbf8bcdd29 100644
|
| --- a/runtime/vm/precompiler.cc
|
| +++ b/runtime/vm/precompiler.cc
|
| @@ -823,11 +823,13 @@ void Precompiler::CollectCallbackFields() {
|
| // Create arguments descriptor with fixed parameters from
|
| // signature of field_type.
|
| function = Type::Cast(field_type).signature();
|
| + if (function.IsGeneric()) continue;
|
| if (function.HasOptionalParameters()) continue;
|
| if (FLAG_trace_precompiler) {
|
| THR_Print("Found callback field %s\n", field_name.ToCString());
|
| }
|
| - args_desc = ArgumentsDescriptor::New(function.num_fixed_parameters());
|
| + args_desc = ArgumentsDescriptor::New(0, // No type argument vector.
|
| + function.num_fixed_parameters());
|
| cids.Clear();
|
| if (T->cha()->ConcreteSubclasses(cls, &cids)) {
|
| for (intptr_t j = 0; j < cids.length(); ++j) {
|
| @@ -2513,9 +2515,8 @@ void Precompiler::PopulateWithICData(const Function& function,
|
| if (instr->IsInstanceCall()) {
|
| InstanceCallInstr* call = instr->AsInstanceCall();
|
| if (!call->HasICData()) {
|
| - const Array& arguments_descriptor = Array::Handle(
|
| - zone, ArgumentsDescriptor::New(call->ArgumentCount(),
|
| - call->argument_names()));
|
| + const Array& arguments_descriptor =
|
| + Array::Handle(zone, call->GetArgumentsDescriptor());
|
| const ICData& ic_data = ICData::ZoneHandle(
|
| zone, ICData::New(function, call->function_name(),
|
| arguments_descriptor, call->deopt_id(),
|
| @@ -2525,9 +2526,8 @@ void Precompiler::PopulateWithICData(const Function& function,
|
| } else if (instr->IsStaticCall()) {
|
| StaticCallInstr* call = instr->AsStaticCall();
|
| if (!call->HasICData()) {
|
| - const Array& arguments_descriptor = Array::Handle(
|
| - zone, ArgumentsDescriptor::New(call->ArgumentCount(),
|
| - call->argument_names()));
|
| + const Array& arguments_descriptor =
|
| + Array::Handle(zone, call->GetArgumentsDescriptor());
|
| const Function& target = call->function();
|
| MethodRecognizer::Kind recognized_kind =
|
| MethodRecognizer::RecognizeKind(target);
|
|
|