From 6b3fdd2ff004e247d2db259b58b8b6a704efac5d Mon Sep 17 00:00:00 2001 From: Kyle Butt Date: Fri, 9 Aug 2024 01:14:46 -0600 Subject: [PATCH] Include package dbs of source loaded dependencies in unit files Package dbs are one of the few things that need to be transitively included in a unit file. Fix the following case: There are two units A and B, and A depends on B. B depends on an external dependency C. In this case the unit file for A needs to include the package db for C. HLS and GHC will not pick up the package db indirectly through B's unit file. Fix this by passing a set of package-db-only HaskellReplDepInfo when merging. --- haskell/repl.bzl | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/haskell/repl.bzl b/haskell/repl.bzl index e34a3d7c5..ffecef79a 100644 --- a/haskell/repl.bzl +++ b/haskell/repl.bzl @@ -203,7 +203,7 @@ def _merge_HaskellReplLoadInfoMulti(root_info, load_infos): java_deps = depset(transitive = java_deps), ) -def _merge_HaskellReplDepInfo(dep_infos): +def _merge_HaskellReplDepInfo(dep_infos, dep_infos_for_package_dbs = []): package_ids = depset() package_databases = depset() interface_dirs = depset() @@ -219,6 +219,9 @@ def _merge_HaskellReplDepInfo(dep_infos): cc_infos.append(dep_info.cc_info) runfiles.append(dep_info.runfiles) + for dep_info in dep_infos_for_package_dbs: + package_databases = depset(transitive = [package_databases, dep_info.package_databases]) + return HaskellReplDepInfo( direct_package_ids = [], package_ids = package_ids, @@ -409,7 +412,12 @@ def _create_HaskellMultiReplInfo(from_source, from_binary, collect_info): for label in deps_list if label in dep_infos and not sets.contains(local_labels, label) ] - merged_dep_info = _merge_HaskellReplDepInfo(dep_infos_to_merge) + dep_infos_for_package_dbs = [ + dep_infos[label] + for label in deps_list + if label in dep_infos and sets.contains(local_labels, label) + ] + merged_dep_info = _merge_HaskellReplDepInfo(dep_infos_to_merge, dep_infos_for_package_dbs) if dep_info and not load_as_source: dep_info_with_self = _merge_HaskellReplDepInfo([dep_info, merged_dep_info]) else: