From 7d120c3c00a704c7be8a729617fdf4d9bcb755b2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mois=C3=A9s=20Ackerman?= <6054733+akrmn@users.noreply.github.com> Date: Fri, 15 Oct 2021 14:59:57 +0200 Subject: [PATCH] Extract UtilLF module from daml-lf-conversion to its own library changelog_begin changelog_end --- compiler/damlc/daml-compiler/BUILD.bazel | 1 + .../src/DA/Daml/Compiler/Repl.hs | 2 +- compiler/damlc/daml-ide-core/BUILD.bazel | 1 + .../src/Development/IDE/Core/Rules/Daml.hs | 2 +- compiler/damlc/daml-ide/BUILD.bazel | 2 +- .../src/DA/Daml/LanguageServer/CodeLens.hs | 2 +- compiler/damlc/daml-lf-conversion/BUILD.bazel | 1 + .../src/DA/Daml/LFConversion.hs | 2 +- .../src/DA/Daml/LFConversion/Primitives.hs | 2 +- compiler/damlc/daml-lf-util/BUILD.bazel | 27 +++++++++++++++++++ .../src/DA/Daml}/UtilLF.hs | 4 +-- compiler/damlc/stable-packages/BUILD.bazel | 2 +- .../lib/DA/Daml/StablePackages.hs | 2 +- compiler/damlc/tests/BUILD.bazel | 2 +- .../tests/src/DA/Test/DamlcIntegration.hs | 2 +- 15 files changed, 42 insertions(+), 12 deletions(-) create mode 100644 compiler/damlc/daml-lf-util/BUILD.bazel rename compiler/damlc/{daml-lf-conversion/src/DA/Daml/LFConversion => daml-lf-util/src/DA/Daml}/UtilLF.hs (98%) diff --git a/compiler/damlc/daml-compiler/BUILD.bazel b/compiler/damlc/daml-compiler/BUILD.bazel index 1ae03d841317..047a0dd607fc 100644 --- a/compiler/damlc/daml-compiler/BUILD.bazel +++ b/compiler/damlc/daml-compiler/BUILD.bazel @@ -53,6 +53,7 @@ da_haskell_library( "//compiler/damlc/daml-doctest", "//compiler/damlc/daml-ide-core", "//compiler/damlc/daml-lf-conversion", + "//compiler/damlc/daml-lf-util", "//compiler/damlc/daml-opts", "//compiler/damlc/daml-opts:daml-opts-types", "//compiler/damlc/daml-package-config", diff --git a/compiler/damlc/daml-compiler/src/DA/Daml/Compiler/Repl.hs b/compiler/damlc/daml-compiler/src/DA/Daml/Compiler/Repl.hs index 217a14d4014c..d494f43e84a3 100644 --- a/compiler/damlc/daml-compiler/src/DA/Daml/Compiler/Repl.hs +++ b/compiler/damlc/daml-compiler/src/DA/Daml/Compiler/Repl.hs @@ -33,10 +33,10 @@ import qualified DA.Daml.LF.TypeChecker as LF import DA.Daml.LF.Ast.Optics (packageRefs) import qualified DA.Daml.LF.ReplClient as ReplClient import DA.Daml.LFConversion (convertModule) -import DA.Daml.LFConversion.UtilLF (buildPackage) import DA.Daml.LFConversion.UtilGHC import DA.Daml.Options.Types import qualified DA.Daml.Preprocessor.Records as Preprocessor +import DA.Daml.UtilLF (buildPackage) import Data.Bifunctor (first) import Data.Functor.Alt import Data.Functor.Bind diff --git a/compiler/damlc/daml-ide-core/BUILD.bazel b/compiler/damlc/daml-ide-core/BUILD.bazel index c14e89e20616..52a79a6f82a5 100644 --- a/compiler/damlc/daml-ide-core/BUILD.bazel +++ b/compiler/damlc/daml-ide-core/BUILD.bazel @@ -58,6 +58,7 @@ da_haskell_library( "//compiler/daml-lf-tools", "//compiler/damlc/daml-doctest", "//compiler/damlc/daml-lf-conversion", + "//compiler/damlc/daml-lf-util", "//compiler/damlc/daml-opts", "//compiler/damlc/daml-opts:daml-opts-types", "//compiler/damlc/daml-rule-types", diff --git a/compiler/damlc/daml-ide-core/src/Development/IDE/Core/Rules/Daml.hs b/compiler/damlc/daml-ide-core/src/Development/IDE/Core/Rules/Daml.hs index 6edf4db1446e..4ad901fa9dca 100644 --- a/compiler/damlc/daml-ide-core/src/Development/IDE/Core/Rules/Daml.hs +++ b/compiler/damlc/daml-ide-core/src/Development/IDE/Core/Rules/Daml.hs @@ -91,7 +91,6 @@ import Development.IDE.Core.RuleTypes.Daml import DA.Bazel.Runfiles import DA.Daml.DocTest import DA.Daml.LFConversion (convertModule) -import DA.Daml.LFConversion.UtilLF import qualified DA.Daml.LF.Ast as LF import qualified DA.Daml.LF.InferSerializability as Serializability import qualified DA.Daml.LF.PrettyScenario as LF @@ -99,6 +98,7 @@ import qualified DA.Daml.LF.Proto3.Archive as Archive import qualified DA.Daml.LF.ScenarioServiceClient as SS import qualified DA.Daml.LF.Simplifier as LF import qualified DA.Daml.LF.TypeChecker as LF +import DA.Daml.UtilLF import qualified DA.Pretty as Pretty import SdkVersion (damlStdlib) diff --git a/compiler/damlc/daml-ide/BUILD.bazel b/compiler/damlc/daml-ide/BUILD.bazel index d0800a63ac8e..94ecd844cef5 100644 --- a/compiler/damlc/daml-ide/BUILD.bazel +++ b/compiler/damlc/daml-ide/BUILD.bazel @@ -36,7 +36,7 @@ da_haskell_library( deps = [ "//compiler/daml-lf-ast", "//compiler/damlc/daml-ide-core", - "//compiler/damlc/daml-lf-conversion", + "//compiler/damlc/daml-lf-util", "//compiler/damlc/daml-rule-types", "//compiler/damlc/daml-visual", "//libs-haskell/da-hs-base", diff --git a/compiler/damlc/daml-ide/src/DA/Daml/LanguageServer/CodeLens.hs b/compiler/damlc/daml-ide/src/DA/Daml/LanguageServer/CodeLens.hs index cc54a7362ded..915a6f55666e 100644 --- a/compiler/damlc/daml-ide/src/DA/Daml/LanguageServer/CodeLens.hs +++ b/compiler/damlc/daml-ide/src/DA/Daml/LanguageServer/CodeLens.hs @@ -8,8 +8,8 @@ module DA.Daml.LanguageServer.CodeLens ) where import Control.Monad.IO.Class -import DA.Daml.LFConversion.UtilLF (sourceLocToRange) import qualified DA.Daml.LF.Ast as LF +import DA.Daml.UtilLF (sourceLocToRange) import qualified Data.Aeson as Aeson import Development.IDE.Core.Service.Daml import Data.Foldable diff --git a/compiler/damlc/daml-lf-conversion/BUILD.bazel b/compiler/damlc/daml-lf-conversion/BUILD.bazel index de4ad331edbd..2acdb2d59027 100644 --- a/compiler/damlc/daml-lf-conversion/BUILD.bazel +++ b/compiler/damlc/daml-lf-conversion/BUILD.bazel @@ -38,6 +38,7 @@ da_haskell_library( "//compiler/daml-lf-ast", "//compiler/daml-lf-proto", "//compiler/daml-lf-tools", + "//compiler/damlc/daml-lf-util", "//libs-haskell/da-hs-base", ], ) diff --git a/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion.hs b/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion.hs index 48cf0607ed25..07d37207b647 100644 --- a/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion.hs +++ b/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion.hs @@ -83,8 +83,8 @@ module DA.Daml.LFConversion import DA.Daml.LFConversion.Primitives import DA.Daml.LFConversion.UtilGHC -import DA.Daml.LFConversion.UtilLF import DA.Daml.LFConversion.MetadataEncoding +import DA.Daml.UtilLF import Development.IDE.Types.Diagnostics import Development.IDE.Types.Location diff --git a/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion/Primitives.hs b/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion/Primitives.hs index 2409cd3afb44..860fb254125d 100644 --- a/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion/Primitives.hs +++ b/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion/Primitives.hs @@ -8,7 +8,7 @@ -- | The DAML-LF primitives, matched with their type, and using 'primitive' on the libraries side. module DA.Daml.LFConversion.Primitives(convertPrim) where -import DA.Daml.LFConversion.UtilLF +import DA.Daml.UtilLF import DA.Daml.LF.Ast import DA.Pretty (renderPretty) import qualified Data.Text as T diff --git a/compiler/damlc/daml-lf-util/BUILD.bazel b/compiler/damlc/daml-lf-util/BUILD.bazel new file mode 100644 index 000000000000..7200c335e376 --- /dev/null +++ b/compiler/damlc/daml-lf-util/BUILD.bazel @@ -0,0 +1,27 @@ +# Copyright (c) 2021 Digital Asset (Switzerland) GmbH and/or its affiliates. All rights reserved. +# SPDX-License-Identifier: Apache-2.0 + +load( + "//bazel_tools:haskell.bzl", + "da_haskell_library", +) + +da_haskell_library( + name = "daml-lf-util", + srcs = glob(["src/**/*.hs"]), + hackage_deps = [ + "base", + "bytestring", + "lsp-types", + "ghc-lib-parser", + "text", + ], + repl_ghci_args = ["-hide-package=ghc"], + src_strip_prefix = "src", + visibility = ["//visibility:public"], + deps = [ + "//compiler/daml-lf-ast", + "//compiler/daml-lf-proto", + "//libs-haskell/da-hs-base", + ], +) diff --git a/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion/UtilLF.hs b/compiler/damlc/daml-lf-util/src/DA/Daml/UtilLF.hs similarity index 98% rename from compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion/UtilLF.hs rename to compiler/damlc/daml-lf-util/src/DA/Daml/UtilLF.hs index f2f2d41a8321..b382d43ecd53 100644 --- a/compiler/damlc/daml-lf-conversion/src/DA/Daml/LFConversion/UtilLF.hs +++ b/compiler/damlc/daml-lf-util/src/DA/Daml/UtilLF.hs @@ -4,8 +4,8 @@ {-# OPTIONS_GHC -Wno-orphans #-} -- | DAML-LF utility functions, may move to the LF utility if they are generally useful -module DA.Daml.LFConversion.UtilLF( - module DA.Daml.LFConversion.UtilLF +module DA.Daml.UtilLF ( + module DA.Daml.UtilLF ) where import DA.Daml.LF.Ast diff --git a/compiler/damlc/stable-packages/BUILD.bazel b/compiler/damlc/stable-packages/BUILD.bazel index 5d3427a30417..dd4edd5eb1ef 100644 --- a/compiler/damlc/stable-packages/BUILD.bazel +++ b/compiler/damlc/stable-packages/BUILD.bazel @@ -16,7 +16,7 @@ da_haskell_library( deps = [ "//compiler/daml-lf-ast", "//compiler/daml-lf-proto", - "//compiler/damlc/daml-lf-conversion", + "//compiler/damlc/daml-lf-util", "//libs-haskell/da-hs-base", ], ) diff --git a/compiler/damlc/stable-packages/lib/DA/Daml/StablePackages.hs b/compiler/damlc/stable-packages/lib/DA/Daml/StablePackages.hs index f2e982911ab5..150598de5358 100644 --- a/compiler/damlc/stable-packages/lib/DA/Daml/StablePackages.hs +++ b/compiler/damlc/stable-packages/lib/DA/Daml/StablePackages.hs @@ -15,7 +15,7 @@ import qualified Data.Text as T import DA.Daml.LF.Ast import DA.Daml.LF.Proto3.Archive -import DA.Daml.LFConversion.UtilLF +import DA.Daml.UtilLF allStablePackages :: [Package] allStablePackages = diff --git a/compiler/damlc/tests/BUILD.bazel b/compiler/damlc/tests/BUILD.bazel index 04ecbd2cd323..8159bdbe1d50 100644 --- a/compiler/damlc/tests/BUILD.bazel +++ b/compiler/damlc/tests/BUILD.bazel @@ -171,7 +171,7 @@ da_haskell_library( "//compiler/daml-lf-proto", "//compiler/damlc/daml-compiler", "//compiler/damlc/daml-ide-core", - "//compiler/damlc/daml-lf-conversion", + "//compiler/damlc/daml-lf-util", "//compiler/damlc/daml-opts", "//compiler/damlc/daml-opts:daml-opts-types", "//compiler/scenario-service/client", diff --git a/compiler/damlc/tests/src/DA/Test/DamlcIntegration.hs b/compiler/damlc/tests/src/DA/Test/DamlcIntegration.hs index a62de269238e..365ed4b71395 100644 --- a/compiler/damlc/tests/src/DA/Test/DamlcIntegration.hs +++ b/compiler/damlc/tests/src/DA/Test/DamlcIntegration.hs @@ -11,7 +11,7 @@ module DA.Test.DamlcIntegration import DA.Bazel.Runfiles import DA.Daml.Options import DA.Daml.Options.Types -import DA.Daml.LFConversion.UtilLF +import DA.Daml.UtilLF import DA.Test.Util (standardizeQuotes) import DA.Daml.LF.Ast as LF hiding (IsTest)