This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2022-05-05
Channels
- # announcements (8)
- # babashka (6)
- # beginners (55)
- # biff (8)
- # calva (11)
- # cider (4)
- # clj-kondo (6)
- # cljdoc (23)
- # cljs-dev (22)
- # clojure (89)
- # clojure-brasil (3)
- # clojure-europe (47)
- # clojure-indonesia (1)
- # clojure-nl (1)
- # clojure-spec (3)
- # clojure-uk (5)
- # clojurescript (67)
- # community-development (2)
- # conjure (29)
- # cursive (2)
- # datalog (29)
- # datomic (41)
- # defnpodcast (4)
- # emacs (15)
- # google-cloud (5)
- # holy-lambda (6)
- # hyperfiddle (3)
- # introduce-yourself (8)
- # jobs (1)
- # malli (19)
- # meander (41)
- # nrepl (1)
- # off-topic (30)
- # pathom (22)
- # polylith (30)
- # releases (1)
- # remote-jobs (4)
- # sci (4)
- # shadow-cljs (1)
- # spacemacs (7)
- # specter (3)
- # tools-build (16)
- # tools-deps (2)
I have some kind of user configuration in the form of edn files. They're quite complex and rigorously spec'd, so I want to help the users identify potential problems (e.g. typos, settings that are no longer used etc), to help them manage this complexity.
Assuming that it's not feasible at the moment to simplify the maps and given that spec doesn't support closed maps, what's the best way to do the above? There's a bunch of multi-specs in the specs that seem to break libraries like spell-spec and spec-tools.
Example:
given (s/def ::m (s/keys :req [:foo] :opt [::bar]))
I want to get some warning for (def m {:foo 1 :baar 1})
Reasoning:
In my use case it's more likely that baar is a typo, than a correct key that is used somewhere else.
I have no way of knowing without asking the user, so how can I do that?
I understand that closed maps are an antipattern in Clojure but the use case is real unfortunately. Happy to consider alternatives in any case! Thanks!
Oooh, didn't think of that, thanks! 🙂