Fork me on GitHub
#beginners
<
2022-08-24
>
2FO01:08:45

Howdie, Why am I having trouble calling and referring clojure.set/union from the repl

user=>   (clojure.set/union #{1 2 3 4} #{3 4 5 6})
Execution error (ClassNotFoundException) at java.net.URLClassLoader/findClass (URLClassLoader.java:445).
user=> (refer 'clojure.set)
Execution error at user/eval5899 (REPL:1).
No namespace: clojure.set

phronmophobic01:08:07

use/refer are typically discouraged, but I think you're looking for use rather than refer

🙏 1
2FO01:08:46

Thank you that works but why does it fail when called by its fully qualified name?

(clojure.set/union #{1 2 3 4} #{3 4 5 6})
Execution error (ClassNotFoundException) at java.net.URLClassLoader/findClass (URLClassLoader.java:445)

phronmophobic01:08:56

I'm not sure. It works for me when I use the fully qualified name. Does it fail if you start a new repl from scratch and just use?

seancorfield01:08:19

(require 'clojure.set) first.

🙏 1
seancorfield01:08:37

Some REPLs auto-require more namespaces than others.

👍 1
seancorfield01:08:31

seanc@Sean-win-11-laptop:~/clojure$ clj
Clojure 1.11.1
user=> (clojure.set/union #{1 2 3} #{2 3 4})
Execution error (ClassNotFoundException) at java.net.URLClassLoader/findClass (URLClassLoader.java:445).
clojure.set
user=> (require 'clojure.set)
nil
user=> (clojure.set/union #{1 2 3} #{2 3 4})
#{1 4 3 2}
user=>

seancorfield01:08:16

You should assume everything except clojure.core needs to be require'd before use even if a given REPL experience happens to auto-load something...

🙏 1
👍 1
2FO02:08:42

Got it, I will make a note of this, Thank you

dehli03:08:06

Hi, I'm running into an issue when writing a macro and I can't figure out how to make it work like I'd want. My goal is to write a macro that spits out a map that looks like:

{'get goog.object/get
 'set goog.object/set}
I have the following code, however I can't properly quote the keys so that they're not evaluating (and resulting in an undeclared var issue).
(defmacro my-macro []
  (let [ns-keys
        ['get 'set]

        ns-values
        (mapv #(symbol "goog.object" (str %)) ns-keys)]

    (zipmap ns-keys ns-values)))
Any ideas? Thanks in advance!

jumar03:08:24

Why do you need a macro for this?

dehli03:08:38

ns-keys will be larger and I'd like to ensure that it matches the function naming in goog.object (trying to dry this code up a bit - https://github.com/dehli/nbb/blob/dbb2fde79a0624683fef35178e44963767785edd/src/nbb/core.cljs#L464-L499)

dehli03:08:57

It might be possible to do it w/o a macro. I'm not sure how to dynamically reference the gobj/* functions at runtime though.

jumar04:08:41

It seems you already have a bunch of goog.object symbols. Doesn't that work?

dehli11:08:54

Yeah, the non-macro code I shared does work. I was trying to see if I could use a macro to prevent accidentally doing something like {'foo goog.object/bar} since you always want the symbol on the left to match to the function name in goog.object. Seems like it might be best to just not use a macro to keep it simpler though

dehli11:08:22

Right after saying that I was able to get the macro working 🙂 Needed to do:

(zipmap (map (fn [k] `'~k) ns-keys)
        ns-values)

👍 1
dumrat13:08:25

I saw that there's a new Clojure implementation (with types) for the LLVM. Just wondering, is it wrong to think that because Clojure has reached many eco systems, in the future there will be more demand for it as it can run in a lot of places? Or is this wrong thinking?

delaguardo13:08:24

demand creates supply, not vice versa. For example, Clojure CLR has been there for a long time, but still, I can’t say that there is a huge demand for developers with both .Net and Clojure experience. For sure, I’m in my own information bubble and there is a high chance I don’t see the big picture.

💯 1
ChillPillzKillzBillz14:08:37

Hi all, I have a silly requirement. I have a list/vector ["a" "b" "c" "d"] I want to use the strings in this list/vector to execute (def a (literal-number 'a)) as shown for the first element. For the second element it'll be (def b (literal-number 'b)). How do I go about it? literal-number is a sicmutils library function

👋 1
delaguardo14:08:22

def if a special form. you will need a macro for that. do you know the list at compile time or something produces it in runtime?

ChillPillzKillzBillz15:08:24

I will need both for compile time & runtime... atleast I think I do... depending on the answer I might decide one way or other...

delaguardo15:08:38

(defmacro defify [bindings]
  `(do
     ~@(map (fn [binding]
              `(def ~(symbol binding) (literal-number '~(symbol binding))))
            bindings)))

(macroexpand '(defify ["a" "b" "c" "d"]))
;; => (do
;; (def a (literal-number 'a))
;;  (def b (literal-number 'b))
;;  (def c (literal-number 'c))
;;  (def d (literal-number 'd)))

delaguardo15:08:16

but that macro won’t work if bindings are unknown at compile time.

ChillPillzKillzBillz15:08:33

many thanx, I'll try this and get back if I still have issues... but already looks good! Thanks again!

rolt16:08:26

(doseq [x ["a" "b" "c" "d"]] (intern *ns* (symbol x) (literal-number (symbol x)))
would that work ?

pppaul17:08:30

clojure has a template macro that is for stuff like this https://clojuredocs.org/clojure.template/do-template

ChillPillzKillzBillz19:08:46

thanks for all the help guys!! Appreciate it!

ChillPillzKillzBillz08:08:28

@U04V4KLKC I tried your solution but I am getting an error as shown below. Any suggestions? I can confirm that create-body function works independently.

ChillPillzKillzBillz08:08:23

Is it possible that these solutions are only applicable to clojure and NOT clojurescript?

ChillPillzKillzBillz08:08:19

@U02F0C62TC1 your solution also didn't work for me.

delaguardo08:08:26

macroses exists only in clojure. you can use the result of a macro in clojurescript context thou. https://www.clojurescript.org/about/differences#_macros

👍 1
delaguardo08:08:32

intern also wouldn’t work with cljs because it is not implemented - https://www.clojurescript.org/about/differences#_vars_and_the_global_environment

ChillPillzKillzBillz08:08:51

ok thanks for that!! I'll investigate this further

2FO17:08:46

Good day, How common is it to use data structures other than :keywords as map keys? If it is relatively common in which kind of situations are they used?

phronmophobic17:08:03

keywords are definitely the most common key type, but it's not uncommon to use other data types. • String keys are common when working with data from outside of clojure. • Numbers and uuids are common when used as ids • It's also not uncommon to use vectors/sets/maps as keys. Use cases vary, but I think https://clojuredocs.org/clojure.set/index#example-542692d0c026201cdc326ef1 is an illustrative example.

👍 3
🙏 1
tschady19:08:57

I’ve used coordinate vectors as keys

🙏 1
Joel21:08:17

There is a (evil) global in our system, is there a way to detect when it changes (stack trace preferably)? Most usages do a (binding) to it, fwiw.

hiredman21:08:35

I am usually lazy though and just prn an exception

hiredman21:08:02

(prn (ex-info "" {}))

Joel21:08:30

cool, but where do i add that stack trace? does a var have a function i can override?

Joel21:08:47

it’s a dynamic var

hiredman21:08:49

no, you'll need to to add it to all the functions that touch the var

hiredman21:08:06

or I should say, touch the value of the var

Joel21:08:48

k’ thought that might be the case was hoping to avoid.

didibus03:08:28

Is the watcher feature only work on root value changes and not bindings?

Joel03:08:38

where do you set the watcher?

yrsdi23:08:08

Hi folks, how to debug request coming from http in clojure ? is like var_dump in php or console.log in JS

dpsutton23:08:36

You can do (println request) in your handler function

jumar03:08:23

Or (def my-request request) and inspect it then. tap> is also an option

☝️ 2
ahungry05:08:08

interesting, println is just a prn without readability (of course, that's a good thing here, so you can see 'invisible' characters as their escape seqs):

(defn println
  "Same as print followed by (newline)"
  {:added "1.0"
   :static true}
  [& more]
    (binding [*print-readably* nil]
      (apply prn more)))