From 5b99850bf68972855b7a8270072a98e1b6c8ce3c Mon Sep 17 00:00:00 2001 From: James Griffiths Date: Fri, 19 Feb 2021 16:54:31 +0000 Subject: [PATCH] feat: allow custom profiles in vizdeps Currently the only supported profiles in the `vizdeps` command are `:user` and `:dev`. `leiningen` allows arbitrary profiles to be created and to have custom dependencies (and other fields) defined for those profiles. This commit ----------- Adds a `-P | --profiles` parameter, expecting a comma-delimited string of profile names. These profiles will then be used in dependency calculation. The `-d | --dev` flag is removed as its functionality is superseded by `-P | --profiles`. Note that this is a _BREAKING_ change, due to the removal of the `-d` flag. Relates to ---------- walmartlabs/vizdeps/issues/16 --- README.md | 2 +- src/leiningen/vizdeps.clj | 16 +++++++++++----- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index 227db76..07fa378 100644 --- a/README.md +++ b/README.md @@ -59,7 +59,7 @@ On other platforms, Graphviz can be [downloaded](http://www.graphviz.org/Downloa Usage: lein vizdeps [options] Options: - -d, --dev Include :dev dependencies in the graph. + -P, --profiles PROFILE_STR [:user] Comma-delimited list of profiles to use. E.g. -p user,dev -f, --focus ARTIFACT Excludes artifacts whose names do not match a supplied value. Repeatable. -H, --highlight ARTIFACT Highlight the artifact, and any dependencies to it, in blue. Repeatable. -n, --no-view If given, the image will not be opened after creation. diff --git a/src/leiningen/vizdeps.clj b/src/leiningen/vizdeps.clj index 2c48605..fae2ac3 100644 --- a/src/leiningen/vizdeps.clj +++ b/src/leiningen/vizdeps.clj @@ -7,7 +7,8 @@ [leiningen.core.main :as main] [dorothy.core :as d] [leiningen.core.classpath :as classpath] - [leiningen.core.project :as project])) + [leiningen.core.project :as project] + [clojure.string :as str])) (defn ^:private artifact->label [artifact] @@ -215,9 +216,7 @@ Each :dep has keys :artifact-name, :version, :conflict?, and :highlight?." [project options] - (let [profiles (if-not (:dev options) - [:user] - [:user :dev]) + (let [profiles (:profiles options) {:keys [:prune highlight focus]} options project' (project/set-profiles project profiles) root-artifact-name (symbol (-> project :group str) (-> project :name str)) @@ -287,8 +286,15 @@ d/digraph d/dot)) +(defn- parse-profile-str + [profile-str] + (let [profiles (str/split profile-str #",")] + (mapv keyword profiles))) + (def ^:private cli-options - [["-d" "--dev" "Include :dev dependencies in the graph."] + [["-P" "--profiles PROFILE_STR" "Comma-delimited list of profiles to use. E.g. -p user,dev" + :parse-fn parse-profile-str + :default [:user]] ["-f" "--focus ARTIFACT" "Excludes artifacts whose names do not match a supplied value. Repeatable." :assoc-fn common/conj-option] ["-H" "--highlight ARTIFACT" "Highlight the artifact, and any dependencies to it, in blue. Repeatable."