diff --git a/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/Ast.scala b/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/Ast.scala index d16a6fdaca60..5de2edf77665 100644 --- a/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/Ast.scala +++ b/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/Ast.scala @@ -712,7 +712,12 @@ object Ast { observers: E, // Observers of the contract. key: Option[GenTemplateKey[E]], implements: Map[TypeConName, GenTemplateImplements[E]], - ) + ) { + lazy val inheritedChoices: Map[ChoiceName, TypeConName] = + implements.flatMap { case (iface, impl) => + impl.inheritedChoices.view.map(chName => (chName, iface)) + } + } final class GenTemplateCompanion[E] private[Ast] { diff --git a/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/PackageInterface.scala b/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/PackageInterface.scala index a1bd9d38ca7d..0fb1dbf503f9 100644 --- a/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/PackageInterface.scala +++ b/daml-lf/language/src/main/scala/com/digitalasset/daml/lf/language/PackageInterface.scala @@ -6,7 +6,6 @@ package language import com.daml.lf.data.Ref._ import com.daml.lf.language.Ast._ -import scalaz._, std.list._, std.either._, syntax.traverse._ private[lf] class PackageInterface(signatures: PartialFunction[PackageId, PackageSignature]) { @@ -202,14 +201,15 @@ private[lf] class PackageInterface(signatures: PartialFunction[PackageId, Packag template.choices.get(chName) match { case Some(choice) => Right(choice) case None => - // TODO https://github.com/digital-asset/daml/issues/10810 - // Improve lookup for fixed choices - for { - ifaces <- template.implements.keys.toList.traverse(lookupInterface(_, context)) - choices = ifaces.flatMap(_.fixedChoices.get(chName).toList) - choice <- - choices.headOption.toRight(LookupError(Reference.Choice(tmpName, chName), context)) - } yield choice + template.inheritedChoices.get(chName) match { + case None => Left(LookupError(Reference.Choice(tmpName, chName), context)) + case Some(ifaceName) => + lookupInterface(ifaceName, context).flatMap(iface => + iface.fixedChoices + .get(chName) + .toRight(LookupError(Reference.Choice(ifaceName, chName), context)) + ) + } } )