IRC channel logs
2017-09-19.log
back to list of logs
<ArneBab>benq: I just added a note to the README about installation in /usr/local <benq>arnebab: thanks, interested in a 'realpath' command? <pebftab>daviid , dsmith-work : welp, found out that DUMA was causing trouble. Time to switch to valgrind. <benq>arnebab: perl -MCwd -e 'print Cwd::realpath($ARGV[0])' <ArneBab>benq: is perl guaranteed to exist on OSX? <benq>or with a newline: perl -MCwd -le 'print Cwd::realpath($ARGV[0])' ~/.Xauthority <pebftab>thanks anyway, and may that be a lesson on "if it breaks in testing, perhaps your testing tools are breaking it" <benq>yes, Perl is used for many utilities. That's the reason I still use Perl a lot. <benq>I don't understand why not more people take more advantage of Perl wide distribution. <ArneBab>benq: can I make this fail if the path does not exist? <mwette>ArneBab benq: for portable realpath look at the stackoverflow ref.  It provides a bash function <mwette>    [[ $1 = /* ]] && echo "$1" || echo "$PWD/${1#./}" <ArneBab>mwette: do you mean this one?  2>/dev/null 1>/dev/null <ArneBab>(sorry about the previous, wrong copy buffer) <ArneBab>then that shall be  my fallback-fallback <ft>That's not very realpathy though. :) One could at least take the directory part, cd to that in a reassemble properly. <benq>ArneBab: I think it would be nice to have a customizable delimiter in wisp. I replaced ':' with '$' <ArneBab>benq: You might want to try out the readable project then. Wisp should stay as simple as possible. <benq>Right now I use both .... <ArneBab>benq: in readable they added several useful syntactic structures, but by doing so they lost the simplicity which had drawn me to them <ArneBab>that’s the origin of wisp: trying to make a simpler readable <ArneBab>benq: the reason why I don’t want to add more syntax is that every syntax element I add makes the language more complex and removes one element the programmers can use for their own tools <ArneBab>benq, mwette: thank you for your help in making wisp better! <mwette>I would prefer to see you use /site/. <mwette>The nice thing about wisp is that it could be used by people who don't operate a language sensitive editor.  Scheme has got to be tough if you edit using textedit or some noise like that.  one could potentially have non-sw folks edit in gnumeric <ArneBab_>benq: the deeper reason for preferring : over $ is that : occurs more frequently in normal prose, therefore code written with : looks more familiar to all people who know prose. <ArneBab_>sneek: later tell mwette: 0.9.4 now uses /site/ <ArneBab_>sneek: later tell mwette: editing for non-programmers is something I see as a goal for wisp. However I don’t think that the syntax is actually much easier to edit. What it provides is that it looks less daunting, so people dare to assume that they can understand what it does — and therefore dare to edit. <benq>ArneBab_: I think I once read your entire conversation Arne/David about wisp/readable. What I recall is that he showed great interests in you thoughts I think he even mentions you positively in his SRFI. Thats the important thing: curiosity. In that sense: you see it more from a purely syntactical side, me on the other hand I narrow it down to use the additional sugar for specific uses. <benq>so I use ':' only as infix operator for function application. And to emphasize that point I use a operator symbol that is also used in other languages which is '$' <ArneBab_>benq: yes. I also refer to his SRFI-109 for all the complex stuff. David did great work and wisp wouldn’t be possible without readable, and programming in wisp would be much less convenient without his curly infix (SRFI-105). The difference is essentially aesthetics and purity of language design. <ArneBab_>benq: the actual deep difference is that wisp uses the dot-prefix to denote a line as "not a procedure call". Readable does not have that, so in theory it would need much more vertical space, but that is mitigated by the additional syntax elements. <ArneBab_>benq: how do you use : as infix? do you mean inline? <benq>I thinks there is one big difference and not even sure if that was intentional on your side because it is not discussed in the conversation (as far as i remember). I don't know the proper term, but the thing I'm talking about is how Wisp handles "negative" indentation. <ArneBab_>do you mean a line with less indentation than the previous one? <benq>yes, this is absolutely genius <ArneBab_>I’d love to take that praise, but that’s essentially stolen from Python :) <benq>and the only reason I went through the auto tools pains multiple times. <benq>I once recreated this rules in Perl. It was a painful experience. <ArneBab_>I also fought quite a lot with it ☺ — I have a python implementation which isn’t completely correct, and a scheme implementation which isn’t completely correct, and then a second scheme implementation which finally gets it right :) <ArneBab_>the bootstrapping uses the python-implementation to parse the first scheme implementation which then parses itself and then the second scheme implementation. <ArneBab_>wisp.scm is the first, wisp-scheme.w is the second <benq>good to know. what do you think about curly braces? <ArneBab_>there are some corner cases in string handling which wisp.scm doesn’t get perfectly right. <ArneBab_>benq: I like curly braces a lot. Prefix-math is off-putting to many, and curly braces make that code approachable to them. <benq>any plans to implement it in wisp? <ArneBab_>it’s already included: when you switch to wisp it activates curly braces syntax from SRFI-105 <benq>I've tried it in the past, but it never worked. <ArneBab_>there is one catch compared to readable: curly braces in wisp are always a full expression. If you want to use them as only item on a line, you have to prefix the expression with a dot <ArneBab_>benq: do you have a successfully built wisp folder around? <ArneBab_>if yes: cd $WISP_FOLDER; guile -L . --language=wisp <ArneBab_>(the final period just relieves you from having to hit return thrice) <benq>and which ci tool would you use? <ArneBab_>I run the Guile wisp prompt and edit with Emacs <benq>my system is a mess Wisp wise. So I have to work in the local folder of wisp. Is it wisp-scheme.scm? <benq>Ok , the real works. great! <benq>and now I would like to transpile a file  :-) <ArneBab_>(you can do that to create other wisp projects: it only needs language/wisp/spec.scm and wisp-scheme.scm — but a future release should move wisp-scheme.scm into language/wisp.scm so you’d only need language/ <benq>but wisp.scm not final/good implementation, no? <ArneBab_>this actually works for most lisp syntaxes, including emacs lisp <ArneBab_>benq: it’s the implementation which has at least one known bug in character literal handling in comments <ArneBab_>but it works for almost all wisp files — should work for all files which don’t do something crazy like implementing a wisp parser :) <benq>I get '{ 55 + 88 }' or '({ 55 + 88 })' <ArneBab_>if you use curly infix in the wisp, you will get curly infix in the scheme <ArneBab_>you need to activate its reader directive <benq>Ahh now it get interesting <benq>I love directives .. (not so much) <benq>nope, and  #!curly-infix doesn't do it either <ArneBab_>please create a file with the following content: <benq>I check that, meanwhile examples/fib.w is also interesting. <ArneBab_>benq: ah, that’s from running guile wisp.scm on the file <benq>Ah, sorry, yes then the result is correct <benq>but I would be interested in the transformed code <ArneBab_>(dear powers that be, I hope it’s ok to paste the lines three) <benq>for me it's ok, is there some IRC rule about pasting stuff? <benq>and how to process the file with this 3 lines? <benq>the curly braces are still unprocessed. <ArneBab_>benq: that’s intentional: guile wisp.scm t.w > t.scm; guile t.scm <ArneBab_>curly braces are completely orthogonal to wisp <ArneBab_>in other words: wisp plays well with curly places <ArneBab_>in other words: wisp plays well with curly braces <benq>yes I know that, but still ... (sorry to be annoying) <benq>It would be great if wisp could process/transform the curleys <ArneBab_>if I were to implement curly-braces uncurlying, then wisp would no longer play well with curly braces <ArneBab_>if someone were to add new features to curly braces, wisp would not have them <benq>oh man this goes over my head :-) <ArneBab_>therefore rather use: (write '{55 + 88}) <benq>ok arne: in a few month there is christmas, maybe you can make me a wisp-ben version ... <ArneBab_>wisp is as it is, because that’s the best way I see to do it. There are reasons I did not do it in any other way. <ArneBab_>benq: so, if you want to uncurl curly infix, just use (write '{55 + 88}). the output is (+ 55 88) <benq>wisp-ben version: curly-braces are processed, delimiter is customizable, dot-prefix notation can be disabled (I think you don't like that either, aaand  neoteric expressions! <benq>readable: no "negative" indentation, lot's of additional sugar ('<*', '*>', '\\\\', .. ) I don't like. <benq>so I think my processing pipeline will remain long. <benq>or to put it in other words: I think you took the 'readable' tool and added the pythonic indention rules, which is really great. Then you took a lot of syntax away, a little too much since the dollar-sign and neoteric-expression and curly-infix is great. And then you added dot-prefix which I personally don't like, but I think this comes really down on personal preference. <ArneBab_>but IIRC readable does have something for un-indenting <ArneBab_>you cannot do that in wisp either (or rather: you should not be able to. If you can, that’s a bug in the parser) <benq>I had cases where I've used this <benq>not sure if it was exactly this case, but definitely cases where 'readable' didn't work. <benq>your right this a bad example <benq>and there is a more serious problem with 'readable': it changes the code! So you loose track of the lines. <ArneBab_>this is a non-caught error in wisp.scm. The reader will throw an error here, because it’s too easy to get misled by the different indentation <ArneBab_>benq: that’s true (or at least it was). I took some pains in wisp.scm to preserve lines and comments <benq>And thats REALLY important. I don't know how I forgot that. <benq>indeed; readable erases comments. Cannot use that. <benq>I wait for christmas than. Maybe I'll get my pony. <ArneBab_>and you can make the dollar sign yourself (but I really wouldn’t. It only looks simple to people used to programming languages with $) <ArneBab_>benq: one great part: You found a bug in the reader. I just added a testcase for it. The next release should have consistent transpiling and direct reading <ArneBab_>(direct reading treats intermediate indentation as the lower indentation level, which is the most wrong™ option) <benq>hey you took away my dearest feature :-) <benq>"you already have curly infix there" yes, but only in guile. Am I correct? <wingo>i thought the focus on the weak hash table was probably off-base, but it's an interesting candidate.  i need to collect thoughts more tho <wingo>incidentally it is possible to incrementally mark a large region <wingo>i.e. without making the mark stack overflow <wingo>yes, see comments in gc_mark.h <civodul>how do you tell the GC that an object is partially marked? <wingo>you mark a fixed size, then re-push the to-be-marked large object on the mark stack, remembering where you were <wingo>but i didn't get any improvement when using that strategy to mark stacks <wingo>i think for that reason i didn't commit that test, and then lost the code when i lost my laptop :/ <wingo>i wanted to do some differential profiling at some point... i.e. profile a test file with size N, 2N, 3N, etc, and compare profiles <ArneBab_>benq: yes, only in Guile and other schemes which understand curly infix <ArneBab_>benq: I’m currently unsure whether I’ll throw an error or treat it the same way as the transpiler <sneek>Welcome back thomasd, you have 2 messages. <sneek>thomasd, nee`` says: I moved the system links like you said and reconfigure worked now. Thank you! <sneek>thomasd, nee`` says: in the new parameters file (store (device ...)) is still #f <thomasd>Hi Guilers, is there a guile interface for DBus? <thomasd>thinking about how to listen for dbus/udisk events in a GuixSD service, might not be easy :-/ <thomasd>yes, I found that, too, but I haven't found any other trace <thomasd>Well, if anyone's looking for a project idea... ;-) <civodul>dsmith-work: i think wingo had libdbus bindings a loooong time ago <manumanumanu>ArneBab_: about curly infix... Wouldn't it be neater to make curly bracket partial application? Now, I don't think that would be possible to make as a library, but it would be pretty useful <amz3`>ijp: did you look at my code? <amz3`>ijp: silly, question, do you think it doable to cache some of what is compiled by jslink? <ArneBab_>manumanumanu: if it weren’t for that reasoning, I’d actually be against using up syntax characters for this. <amz3`>“When you have a company idea, you usually want to start right away.” <amz3`>Ah... those startup peoples... <amz3`>Then you end up with dozens of dead projects <amz3`>at the same time it's better than nothing