From 66f0c73f8c1cc7ab3c690193b21613ab27391778 Mon Sep 17 00:00:00 2001 From: Francis De Brabandere Date: Thu, 13 Feb 2020 12:21:49 +0100 Subject: [PATCH 1/5] sbt-dependency-graph 0.10.0-RC1 --- build.sbt | 2 +- .../dependencies/DependenciesDirective.scala | 45 ++++++++++--------- .../ParadoxDependenciesPlugin.scala | 5 ++- .../ParadoxDependenciesPluginKeys.scala | 5 +-- 4 files changed, 30 insertions(+), 27 deletions(-) diff --git a/build.sbt b/build.sbt index 5fa081f..b8418ea 100644 --- a/build.sbt +++ b/build.sbt @@ -14,7 +14,7 @@ organization := "com.lightbend.paradox" name := "sbt-paradox-dependencies" addSbtPlugin("com.lightbend.paradox" % "sbt-paradox" % "0.4.3") -addSbtPlugin("net.virtual-void" % "sbt-dependency-graph" % "0.9.2+10-148ba0ff") +addSbtPlugin("net.virtual-void" % "sbt-dependency-graph" % "0.10.0-RC1") resolvers += Resolver.bintrayIvyRepo("2m", "sbt-plugins") diff --git a/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala b/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala index 9c48853..4bae823 100644 --- a/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala +++ b/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala @@ -17,21 +17,21 @@ package com.lightbend.paradox.dependencies import com.lightbend.paradox.markdown.LeafBlockDirective -import net.virtualvoid.sbt.graph.{ModuleTree, ModuleTreeNode} +import net.virtualvoid.sbt.graph.{Module, ModuleGraph} // .graph.{ModuleTree, ModuleTreeNode} import org.pegdown.Printer import org.pegdown.ast.{DirectiveNode, Visitor} -class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: String => ModuleTree) +class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: String => ModuleGraph) extends LeafBlockDirective("dependencies") { def render(node: DirectiveNode, visitor: Visitor, printer: Printer): Unit = { val projectId = node.attributes.value("projectId") - val tree = projectIdToDependencies(projectId) + val graph = projectIdToDependencies(projectId) printer.println() val classes = Seq("dependencies", node.attributes.classesString).filter(_.nonEmpty) printer.print(s"""
""") - if (tree.roots.flatMap(_.children).nonEmpty) { - renderDirect(node, tree.roots, showLicenses, printer) - renderTree(node, tree.roots, printer) + if (graph.roots.flatMap(m => children(graph, m)).nonEmpty) { + renderDirect(graph, showLicenses, printer) + renderTree(graph, printer) } else { printer.print("
Direct dependencies
This module has no dependencies.
") } @@ -39,7 +39,7 @@ class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: Stri printer.println() } - private def renderDirect(node: DirectiveNode, roots: Seq[ModuleTreeNode], showLicenses: Boolean, p: Printer): Unit = { + private def renderDirect(graph: ModuleGraph, showLicenses: Boolean, p: Printer): Unit = { p.print("
Direct dependencies
") p.indent(2).println() p.print("") @@ -48,10 +48,10 @@ class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: Stri p.print("") p.indent(2) for { - r <- roots - d <- r.children + r <- graph.roots + d <- children(graph, r) } { - val moduleId = d.node.id + val moduleId = d.id val name = moduleId.name p.println() .print("") - if (showLicenses) d.node.license.foreach(l => p.print("")) + if (showLicenses) d.license.foreach(l => p.print("")) p.print("") } p.indent(-2).println() @@ -73,20 +73,20 @@ class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: Stri p.print("
OrganizationArtifactVersion
") @@ -64,7 +64,7 @@ class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: Stri ) .print(moduleId.version) .print("").print(l).print("").print(l).print("
").println() } - private def renderTree(node: DirectiveNode, roots: Seq[ModuleTreeNode], p: Printer): Unit = { + private def renderTree(graph: ModuleGraph, p: Printer): Unit = { p.print("
Dependency tree
")
     for {
-      r <- roots
-      d <- r.children
+      r <- graph.roots
+      d <- children(graph, r)
     } {
-      renderTreeNode(p, d)
+      renderTreeNode(p, graph, d)
     }
     p.print("
").println() } - private def renderTreeNode(p: Printer, n: ModuleTreeNode): Unit = - if (n.node.evictedByVersion.isEmpty) { - val moduleId = n.node.id + private def renderTreeNode(p: Printer, graph: ModuleGraph, n: Module): Unit = + if (n.evictedByVersion.isEmpty) { + val moduleId = n.id val name = moduleId.name p.println() .print(moduleId.organisation) @@ -97,12 +97,15 @@ class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: Stri ) .print(moduleId.version) .print("") - n.node.license.foreach(l => p.print(" ").print(l)) - if (n.children.nonEmpty) { + n.license.foreach(l => p.print(" ").print(l)) + if (children(graph, n).nonEmpty) { p.indent(4) - n.children.foreach(renderTreeNode(p, _)) + children(graph, n).foreach(renderTreeNode(p, graph, _)) p.indent(-4) } } + private def children(graph: ModuleGraph, module: Module) = graph.dependencyMap(module.id) + + } diff --git a/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPlugin.scala b/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPlugin.scala index 515c19b..6d237e2 100644 --- a/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPlugin.scala +++ b/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPlugin.scala @@ -19,7 +19,7 @@ package com.lightbend.paradox.dependencies import com.lightbend.paradox.markdown.Writer import com.lightbend.paradox.sbt.ParadoxPlugin import com.lightbend.paradox.sbt.ParadoxPlugin.autoImport.paradoxDirectives -import net.virtualvoid.sbt.graph.{DependencyGraphKeys, ModuleTree} +import net.virtualvoid.sbt.graph.{DependencyGraphKeys, ModuleGraph} import sbt._ import sbt.Keys._ @@ -47,7 +47,8 @@ object ParadoxDependenciesPlugin extends AutoPlugin { val filter: ScopeFilter = ScopeFilter(projectsToFilter, inConfigurations(Compile)) val projectIdWithTree = Def.task { - (thisProject.value.id, ModuleTree(DependencyGraphKeys.moduleGraphSbt.value)) + val sbtGraph = DependencyGraphKeys.moduleGraphSbt.value + (thisProject.value.id, ModuleGraph.apply(sbtGraph.nodes, sbtGraph.edges)) } projectIdWithTree.all(filter).map(_.toMap) diff --git a/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala b/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala index 39f1783..c234ff7 100644 --- a/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala +++ b/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala @@ -16,13 +16,12 @@ package com.lightbend.paradox.dependencies -import net.virtualvoid.sbt.graph.ModuleTree - +import net.virtualvoid.sbt.graph.{ModuleGraph} import sbt._ trait ParadoxDependenciesPluginKeys { val paradoxDependenciesProjects = settingKey[Seq[ProjectReference]]("Projects to get the dependency information for") val paradoxDependenciesShowLicenses = settingKey[Boolean]("Show the license column (license information is unavailable with sbt 1.3.2)") - val paradoxDependenciesModuleTrees = taskKey[Map[String, ModuleTree]]("Retrieved module trees") + val paradoxDependenciesModuleTrees = taskKey[Map[String, ModuleGraph]]("Retrieved module graph") } From a5017e604aed7f67e79a258ece81c724692fdbf3 Mon Sep 17 00:00:00 2001 From: Francis De Brabandere Date: Thu, 13 Feb 2020 12:25:02 +0100 Subject: [PATCH 2/5] remove bintray repo as we use a version from maven central now --- build.sbt | 2 -- 1 file changed, 2 deletions(-) diff --git a/build.sbt b/build.sbt index b8418ea..a92afcf 100644 --- a/build.sbt +++ b/build.sbt @@ -16,8 +16,6 @@ name := "sbt-paradox-dependencies" addSbtPlugin("com.lightbend.paradox" % "sbt-paradox" % "0.4.3") addSbtPlugin("net.virtual-void" % "sbt-dependency-graph" % "0.10.0-RC1") -resolvers += Resolver.bintrayIvyRepo("2m", "sbt-plugins") - licenses += ("Apache-2.0", url("http://www.apache.org/licenses/LICENSE-2.0")) homepage := Some(url("https://github.com/lightbend/sbt-paradox-dependencies")) scmInfo := Some( From 93178366bd6fd69ec9ac97f898591648f4a878db Mon Sep 17 00:00:00 2001 From: Francis De Brabandere Date: Thu, 13 Feb 2020 13:18:31 +0100 Subject: [PATCH 3/5] fix styling --- .../lightbend/paradox/dependencies/DependenciesDirective.scala | 1 - 1 file changed, 1 deletion(-) diff --git a/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala b/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala index 4bae823..02eb1d3 100644 --- a/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala +++ b/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala @@ -107,5 +107,4 @@ class DependenciesDirective(showLicenses: Boolean)(projectIdToDependencies: Stri private def children(graph: ModuleGraph, module: Module) = graph.dependencyMap(module.id) - } From 748eb55dc0709de1669a2375f26fb692c9036464 Mon Sep 17 00:00:00 2001 From: Francis De Brabandere Date: Thu, 13 Feb 2020 14:55:13 +0100 Subject: [PATCH 4/5] sloppy me Co-Authored-By: Arnout Engelen --- .../lightbend/paradox/dependencies/DependenciesDirective.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala b/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala index 02eb1d3..cf7786a 100644 --- a/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala +++ b/src/main/scala/com/lightbend/paradox/dependencies/DependenciesDirective.scala @@ -17,7 +17,7 @@ package com.lightbend.paradox.dependencies import com.lightbend.paradox.markdown.LeafBlockDirective -import net.virtualvoid.sbt.graph.{Module, ModuleGraph} // .graph.{ModuleTree, ModuleTreeNode} +import net.virtualvoid.sbt.graph.{Module, ModuleGraph} import org.pegdown.Printer import org.pegdown.ast.{DirectiveNode, Visitor} From 8298eeca9827823c7dcee58aabac9b8fd5e13ed3 Mon Sep 17 00:00:00 2001 From: Francis De Brabandere Date: Thu, 13 Feb 2020 14:55:26 +0100 Subject: [PATCH 5/5] clean up import Co-Authored-By: Arnout Engelen --- .../paradox/dependencies/ParadoxDependenciesPluginKeys.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala b/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala index c234ff7..74346c0 100644 --- a/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala +++ b/src/main/scala/com/lightbend/paradox/dependencies/ParadoxDependenciesPluginKeys.scala @@ -16,7 +16,7 @@ package com.lightbend.paradox.dependencies -import net.virtualvoid.sbt.graph.{ModuleGraph} +import net.virtualvoid.sbt.graph.ModuleGraph import sbt._ trait ParadoxDependenciesPluginKeys {