This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2018-03-19
Channels
- # bangalore-clj (2)
- # beginners (217)
- # boot (3)
- # cider (130)
- # cljs-dev (117)
- # cljsrn (11)
- # clojure (99)
- # clojure-china (1)
- # clojure-denver (1)
- # clojure-dev (22)
- # clojure-italy (30)
- # clojure-norway (5)
- # clojure-russia (13)
- # clojure-sanfrancisco (3)
- # clojure-spec (74)
- # clojure-uk (107)
- # clojurescript (40)
- # clr (6)
- # core-async (25)
- # core-logic (4)
- # cursive (1)
- # data-science (1)
- # datomic (62)
- # duct (11)
- # editors (14)
- # figwheel (3)
- # fulcro (12)
- # funcool (1)
- # garden (12)
- # graphql (19)
- # jobs (4)
- # jobs-rus (1)
- # lein-figwheel (1)
- # leiningen (12)
- # luminus (5)
- # off-topic (45)
- # onyx (12)
- # other-languages (1)
- # parinfer (5)
- # programming-beginners (3)
- # re-frame (113)
- # reagent (63)
- # remote-jobs (10)
- # ring-swagger (1)
- # shadow-cljs (31)
- # slack-help (3)
- # spacemacs (27)
- # specter (1)
- # unrepl (44)
- # yada (16)
@hmaurer I remember rebel-readline mentioned a Java lib that is used underneath for this kind of functionality, not sure of the name though...
there's a clojure-cli library somewhere that wraps it, IIRC
I'm using a java library, jackson-jq
, which transforms json strings and leaves me with a list of com.fasterxml.jackson.databind.node.ObjectNode
s. I'd like to get out a list of Clojure maps. Rather that serializing the result to a json-string and then deserializing with eg cheshire.core/parse-string
, I'm thinking I might be able to leverage Cheshire for parsing the Java data structure to a clojure data structure, since Cheshire already wraps Jackson. Is this a sane idea? Any ideas on how to progress?
Please advise the material or book how to correctly interact with the database inside the application and to administer it. I'm new to back-end development. Thank you!
@U9SSRRZ4N please use that luminus channel. Btw. luminus has fairly good documentation: http://www.luminusweb.net/docs and this book is quite good as well: https://pragprog.com/book/dswdcloj2/web-development-with-clojure-second-edition
Thank you! Yes, i agree the official docs. is good. But not enough for me. Thank you for the book, I wanted to buy it last week!
@alexmiller So when I type the 'java -cp <classpath> clojure.main' with <classpath> equal to the output of 'lein classpath' in a DOS command line, I can't even paste the full path, or type past a certain hard limit omitting the last jar file path that gets cut off. So yeah, it's definitely a limit of the command line on Windoze.
$ java -cp lein classpath
clojure.main
bash: /c/Program Files/Java/jdk1.8.0_152/bin/java: Argument list too long
Going to see if the classpath brings my JVM down with the same convulsions on Linux.
@bob592 you’ll probably need to look into excluding some downstream dependencies then - I’m guessing there are deps for many services which are likely all not needed
@alexmiller Yeah I'm sifting through them all now. At present I need mainly S3, but amazonica gives you the kitchen sink and right now my JVM apartment is too crowded for that. 🙂
However knowing there is some hard limit to how many jars can be in my classpath, and how easy it is to blow past that limit just adding a single dependency is... distrubing. I really need s3 integration and may need other AWS services over time.
I wonder if by using some lein megic (assuming you are using lein) you could build a “pathing jar” along the lines of the following s.o. article: https://stackoverflow.com/a/201969/5449431
@alexmiller feel free to shoot this idea down…
well I have no say over Leiningen … :)
yeah, I come from gradle where most aspects of the build process are open to modification, I’m too new to lein to know if this kind of “rip out the guts and replace with something else” thing is easily doable with it
just a though, that would move the long dependency list essentially into a text file and the runtime classpath would be that one jar
back in the deep past when these limits were lower and it was easier to hit them I have written build scripts to do this
as a side note and since I was in an ocd mood, I did a small test where I created the following setup:
* one jar file a.jar with a java class A.class
* another jar file b.jar with a java class B.class using A.class and with a MANIFEST.MF Class-Path entry pointing at the absolute path of a.jar
* executed a java -jar b.jar
(I declared a main class in the b manifest in addition to the Class-Path). This worked which proves that this works for java -jar.
* executed a groovy script using:
~> groovy -cp b.jar -e "println(new A().methodA())"
I am A
i.e. adding b.jar to the classpath, but using a class from a.jar. This worked as well which proves non java -jar
usage.
This is also using absolute paths which means it probably should work for pasting in the lein classpath as is as it normally points at entries under ~/.m2 using absolute paths (only say this as some of the docs talk about relative paths only).I guess technically I can integrate with AWS elsewhere in my stack. I may have to break it up more than I wanted to. I hate having to do this kind of thing because of some stupid hard-coded limit, though. But hey, that's why they call them "micro-services" eh? Can never have enough moving parts... 🙂
fwiw, this is not a common problem in my experience. Amazonica is a particularly bad case.
The stuff in the lazy seq of course needs to be serialized, but that's fine - I could just map str
over it. It's the next step that I'm totally at loss with.
@grav https://docs.oracle.com/javase/7/docs/api/java/io/PipedInputStream.html might be what you are looking for
@alexmiller I'll say! :rolling_on_the_floor_laughing:
If anyone knows of a more modular AWS library for Clojure that is also up to date, I'm all ears... 🙂
@mccraigmccraig I'm also down that path. However, I end up being eager about consuming the sequence:
(let [r (java.io.PipedReader.)]
(with-open [w (java.io.PipedWriter. r)]
(doseq [x (take 20 (repeat 42))]
(do
(println "write!")
(.write w (pr-str x))
(.write w "\n")))
(->> (for [x (line-seq ( r))]
(read-string x))
(take 2))))
If I execute that, I'll get write!
output 20 times, ie the whole sequence is consumed. If I use for
instead of doseq
, nothing happens.
for is lazy so you would need to force its realization. However, when dealing with io stuff like this, it’s usually better to take control over laziness realization using loop/recur or use use something eager like run!
or reduce/transduce
Ok. My goal is to feed something to an external tool via clojure.java.shell/sh
. It surprises me that there isn’t a “recipe” for this kind of thing, like there is with line-seq
the other way around. Maybe I’m just looking for the wrong thing.
@alexmiller Actually the code in amazonica is pretty clean and the relatively few top-level dependencies it includes are not horrible. https://github.com/mcohen01/amazonica/blob/master/project.clj The beast here is aws-java-sdk. Amazon is just freakin' huge and the temptation to write a simple wrapper around all of its SDK reveals just how monstrous and huge Amazon itself has become. It's good to be the Bezos, though.
Seems like it should be possible to use just the aws services I want through plain ol' interop. Looks like the only sane route to go, short of writing a pure Clojure solution, which is not my mission at the moment.
it's also notable that amazonica works if you exclude the dependencies. You just can't require the related namespace.
@dominicm aws-clj-sdk looks promising. Regarding excluding all the dependencies in amazonica, listing them individually would probably double the length of my project.clj. Better that than my classpath, though, I suppose... LOL.
@mbjarland Suggests uber-jarring just the dependencies in a dev build might solve this. Sounds like a good idea for a lein plugin...
@bob592 well my suggestion was actually not for an uber jar but for a “pathing jar”, essentially an empty jar which declares your long dependency list in its MANIFEST.MF file
@bob592 I’m not entirely sure if the manifest file Class-Path
entry is used only when executing a jar via java -jar my.jar
or if it’s used also when just adding the jar to your classpath. The former would invalidate this as an option
that entry was really designed for applets
I think it can work in the java -jar context, but needs appropriate relative or absolute paths which is not something you should ever expect to work in a real environment
@alexmiller true enough. I was thinking more of a dev environment on say windows with potentially limited command line length than a production environment. For completeness it seems that java indeed does use the Class-Path attribute to load local jar files even when not using the java -jar
execution method. Also the jar specification supports this as does the oracle docs on “how classes are found”. Not necessarily saying it’s a good solution, but maybe a possible one in cases where your development is hindered by classpath length.
@mbjarland Ah, right. Yeah either way it's possibly tricky. But worth the effort. Nobody should be stopped by a stupid environment issue like this.
I think Maven creates a dynamic classloader environment and loads things there so there is no classpath transmitted on the cli
so...I have a recollection veiled in the mists of prehistory that I've seen this somewhere but can for the life of me not find any information on how it works...or get it working by experimentation. Care to elaborate on the mechanics of the @
option in calls to java?
I'm aware of (fn [^:double a ^:double b] (+ a b))
to type hiknt that the args are doubles. Is there a way to typehint "this arg is a float-array" ?
it’s just ^double
and you can use ^floats
(note that these will not work on vars where the meta is evaluated, but is fine in the location you are using it)
The Clojure coding convention github repo doesn’t say what to do with code with reader tags. Would it ever be acceptable to have the reader tag on a different line than the form it modifies? I would assume not, although I can see where long reader tags might push the following form so far to the right that it becomes ugly. Maybe it’s a judgement call, defaulting to a single line whenever possible?
Does anybody know if there is a practical reason why Cognitect's blog isn't served over HTTPS?
because it’s a bunch of squarespace garbage
Oh hehe okay 🙂 any plans to make an open source new blog?
do you want more new clojure stuff or a better blog?
I want new clojure stuff on a secure blog
So I can look at the graphics, whatever is hidden here
well, given that our time is far too finite and the options for things to do is far too infinite, I’m going to prioritize moving stuff to a new blog about #813,937 on the list
there is a news feed at https://clojure.org/news and I double-post anything technical or release-oriented over there
That's fair. If you need help I would gladly participate in that endeavour, since I'm still not proficient to contribute with Clojure code but I can create a really nice blog if you need.
Problem is probably migration as you mentioned. Fair enough.
Is anyone here familiar with buddy authentication?
because they all become combinatorial explosion in the IFn interface
https://github.com/clojure/clojure/blob/master/src/jvm/clojure/lang/IFn.java#L97
going to 5 will 800 more lines there :)
sometimes I have stuffed similar prim types in an array to get around that
the other dirty option is to make a deftype which can have primitive fields
and you never learned these dirty tricks from me
I'm writing this computer vision algo in clojure, and the 4-arg limit is limiting my ability to refactor, the deftype to group the arguments sounds really nice though, it's like a typed hashmap
they can be mutable fields too for double extra dirty clojure
but at some point I usually find it’s easier to just write the critical bit in Java
but as @alexmiller suggests, it's usually easier to write some java
I am looking for a way to find date of the nth day of a month. For ex : date of 3rd monday in March for the year 2018. Is there a good way to do this with org.joda.time.DateTime
This is probably in the realm of premature optimization. However, suppose I have:
(deftype Foo [^float x ^float y ^long idx])
x = vector of Foos
Now, standard would x = vector of refs that each point to a 'Foo' object (but not necessarily consecutive in memory)
Is there a way to tell the vector to 'pack' the Foo's one next to the other ?so the closest thing we can do is to 'transpose' the data, so instead of Vector of Foo's, we have triplet of float-array, float-array, long-array ?
This exact usecase is something Brian Goetz brings up for value types. People trading maintainability for performance
I don't really know any of the CS theory behind either, but is core.async closer to CSP or actor model?
http://www.usingcsp.com/cspbook.pdf is probably better link
has anyone looked into using Minimal Value Types with Clojure? https://wiki.openjdk.java.net/display/valhalla/Minimal+Value+Types