<< 05-02-2014 >>

00:14:02*Varriount gives a cookie to renesac
00:14:24*Demos should really learn a "scripting" language
00:15:08renesac*chomp* *chomp* humm
00:15:15renesacthanks for the cookie
00:15:59renesacbut I still haven't understood this template thing very well to make a PR for the docs
00:16:25renesacit seems that the last expression in a template definition is the return value, if the return isn't a stmt?
00:16:49EXetoCDemos: learn nimrod then, in a couple of months :>
00:16:58Demoshehe
00:17:40renesacnimrod seems pretty able to do some scripting tasks
00:17:51EXetoCcreate a json bridge!
00:18:09renesacif only it had python's or perl's wealthy of modules
00:19:24renesacfowl, you made some python bindings, but the examples shows only an "eval" thing
00:20:22renesachow hard would it be to really import and use python modules, if I don't care about the overhead of a python interpreter and constant conversions to and from PyObject?
00:21:40EXetoCwithout touching the API? :p
00:21:42fowli didnt make those bindings
00:22:13renesacoh, then who made this: https://github.com/nimrod-code/python
00:22:13renesac?
00:22:18Demoswell one of the goals of learning a scripting language would be to do really quick algos with no reguard to data structures or speed
00:22:37fowlrenesac, says (c) 2010 araq
00:22:49renesacoh, indeed
00:23:28EXetoCI don't think there's a big difference when you have type inference and all
00:23:33fowlrenesac, my guess is its not hard, python is a scripting language, this use is the real intended use for the language
00:24:51renesaccould I just "pyimport: sqlalchemy" on top of my nimrod module, or this is also a pipe dream?
00:24:59renesacXD
00:27:11EXetoCin need of a weekend project? implement that and "nimrod py"!
00:28:38renesacall weekends for the rest of the year?
00:29:13EXetoCI was thinking maybe one or two. is that too optimistic?
00:29:21renesacI have no idea
00:29:53renesacthat was what I was asking for
00:30:07renesacif such a thing is even possible
00:30:57DemosI am bisecting that wierd winlean error
00:33:16Demosthere are a lifetime of weekend projects to do for nimrod
00:34:56EXetoCrly
00:35:06renesacof course
00:35:30renesacI'm doing that benchmark module now, anyway
00:43:18*ddl_smurf quit (Quit: ddl_smurf)
00:43:28renesacI was actually interested in using python's scientific libraries with nimrod
00:44:13renesacso the performance would actually be a point (otherwise, I should just use python)
00:44:46renesacuse nimrod as a better cython, like Araq was saying the other day (not in those words)
00:44:46Demoswell if you are using python from nimrod it will be as slow or slower than python without nimrod
00:45:06renesacnot necessarily
00:45:19renesacif I'm using numpy arrays, many operations can be done in nimrod
00:45:34renesacand then I call some stat function or plotting from python at the end
00:45:36renesacfor example
00:45:52renesaclike you would do using cython to speedup part of your python code
00:46:59renesacthis topic covers it (I don't know what happened after this with julia): https://groups.google.com/forum/#!msg/julia-dev/YftOOEfcwrk/7q3cm2y3Xs4J
00:47:49Demosit is strange that compileing python yields such a speed boost
00:48:07renesacfor every integer addition in python
00:48:23renesacthe compiler must look at the boxed type, do many checks, etc
00:48:28renesacand then make the operation
00:49:34Demoswell nothing is stoping it from just doing the operation!
00:49:56Demosalthough, I suppose....
00:50:17renesac*the interpreter
00:50:27Demoswell cython must be a different language than python. Only a subset of python works right?
00:50:44renesacactually, most of it works
00:50:54renesacit is more like a superset, with type definitions, etc
00:51:04Demosvery strange
00:51:08DemosI should learn python
00:51:08renesacbut if you just compile unmodified python code you don't get much boost
00:51:11Demosor more perl
00:51:19Demosoh, OK I can sleep easy now
00:51:20renesacperl is dying
00:51:26Demosperl is funny
00:52:13renesacit sure is funny: http://stackoverflow.com/questions/11695110/why-is-this-program-valid-i-was-trying-to-create-a-syntax-error
00:52:17renesacXD
00:53:50EXetoC:E
01:00:35DemosVarriount!
01:01:15Demosnever mind
01:57:49*xenagi joined #nimrod
01:59:16*DAddYE quit (Remote host closed the connection)
01:59:50*DAddYE joined #nimrod
02:00:49*DAddYE_ joined #nimrod
02:04:25*DAddYE quit (Ping timeout: 250 seconds)
02:05:11*DAddYE_ quit (Ping timeout: 245 seconds)
02:22:24Demoshm maybe we should have the compiler always pick library files if you have a file of the same name in your tree. Or even better warn... I should look into that
02:26:31*BitPuffi1 quit (Ping timeout: 272 seconds)
02:44:05*DAddYE joined #nimrod
02:51:53brsonwhen's the next nimrod release?
03:19:58Demoswhen it's done
03:49:21*Demos quit (Read error: Connection reset by peer)
03:55:52*BitPuffi1 joined #nimrod
04:01:18*xenagi quit (Read error: Connection reset by peer)
04:05:25*brson quit (Quit: leaving)
04:05:51*Demos joined #nimrod
04:43:25*CarpNet quit (Ping timeout: 272 seconds)
04:53:54*noam joined #nimrod
04:56:43*CarpNet joined #nimrod
05:07:53Demosis https://gist.github.com/e9c41f65f3f677b20b77 valid code?
05:24:29*CarpNet quit (Ping timeout: 272 seconds)
05:31:14*xtagon quit (Ping timeout: 246 seconds)
05:35:46*Demos quit (Quit: ERC Version 5.3 (IRC client for Emacs))
06:23:00*dmac joined #nimrod
06:44:21*CarpNet joined #nimrod
07:03:17*CarpNet quit (Ping timeout: 272 seconds)
07:21:10*CarpNet joined #nimrod
07:56:01*BitPuffi1 quit (Ping timeout: 245 seconds)
08:02:38*BitPuffi1 joined #nimrod
09:17:54*ddl_smurf joined #nimrod
09:23:46*DAddYE quit (Remote host closed the connection)
09:59:46*BitPuffi1 quit (Ping timeout: 245 seconds)
10:20:36*BitPuffi1 joined #nimrod
10:29:15*dmac quit (Ping timeout: 250 seconds)
10:49:44*BitPuffi1 quit (Quit: WeeChat 0.4.2)
10:49:59*BitPuffin joined #nimrod
11:46:09*io2 joined #nimrod
12:09:50*io2 quit (Ping timeout: 264 seconds)
12:52:12*io2 joined #nimrod
13:28:28*[1]Endy joined #nimrod
14:11:53*[2]Endy joined #nimrod
14:15:05*[1]Endy quit (Ping timeout: 265 seconds)
14:40:26*darkf quit (Quit: Leaving)
15:07:55*Mordecai joined #nimrod
15:09:40*Demos joined #nimrod
15:09:41*psquid quit (Ping timeout: 272 seconds)
15:33:24*Demos quit (Ping timeout: 245 seconds)
15:59:29*noam quit (Ping timeout: 246 seconds)
16:28:17Discolodais there a place on freenode i can ask some source liscensing questions?
17:15:14*DAddYE joined #nimrod
17:24:35*BitPuffin quit (Ping timeout: 272 seconds)
17:34:24*BitPuffin joined #nimrod
18:01:53*BitPuffin quit (Ping timeout: 260 seconds)
18:15:47*DAddYE quit (Remote host closed the connection)
18:16:21*DAddYE joined #nimrod
18:21:14*DAddYE quit (Ping timeout: 265 seconds)
18:32:08VarriountMeep. Good morning!
18:34:15VarriountAraq: So, any particular reason we can't easily have arrays whose size is determined at run-time (I mean, we can, with alloc and such, but why can't we do it without alloc?)
18:37:34io2the fact that nimrod made the cover of dr dobbs is pure awesomeness
18:38:07*Varriount is trying to optimize his cartesian product iterator
18:43:53dom96Varriount: I think it's because you can't allocate on the stack at runtime.
18:45:44*DAddYE joined #nimrod
18:47:29renesacdom96, you can with alloca?
18:47:46VarriountOr unsafeNew
18:48:08renesacthe problem is stack overflow
18:48:25EXetoCVarriount: on the stack?
18:48:30*Demos joined #nimrod
18:48:50EXetoCyou get a ref
18:49:21EXetoCDemos: hi. similar functions are annotated with {.compileTime.}. have you tried that?
18:50:07dom96renesac: oh, interesting.
18:50:40dom96Varriount: Doesn't that allocate on the heap?
18:51:55AraqVarriount: what's wrong with using a sequence?
18:52:38EXetoCslower than incrementing the stack pointer?
18:53:03Araq*shrug* so wrap and use alloca ...
18:53:27Araqor wait until the compiler gets smarter and performs an escape analysis
18:54:27*BitPuffin joined #nimrod
18:55:43AraqI prefer the latter
18:57:07renesachum, alloca also prevents function inlining
18:58:22renesacwell, it sholdn't... if the stack can be rolled back while inside a function....
18:59:03renesacI'm not sure if that is possible though...
18:59:55AraqI still think the root cause is the decade old conflation of the control flow stack with the data stack
19:00:25reactormonkdom96, btw, how should babel handle dependencies? Not at all?
19:00:46dom96reactormonk: No, it should handle them. And it does.
19:00:57Araqthe only question is what abstraction models the 2 different stacks appropriately
19:01:07reactormonkdom96, cool. Haven't seen any dependency specs in packages.json yet, that's why I'ma sking
19:01:13*Demos quit (Ping timeout: 252 seconds)
19:01:26dom96reactormonk: It's specified in the .babel files.
19:01:38reactormonkdom96, oh. kk.
19:01:54Araqor maybe there is no abstraction for that and you basically have to use assembler
19:02:08reactormonkdom96, what do you do if two different libs depend on lib A of two different versions?
19:02:39reactormonkAraq, https://github.com/Araq/Nimrod/pull/867 is just a symptom of that?
19:02:42EXetoCit tries to install both
19:02:57renesacAraq, with two stacks and a heap, you can't have them just growing towards each other at oposite directions
19:02:58EXetoCI mean, whichever is needed for said package
19:03:09dom96yes, both are installed.
19:03:27renesacbut with huge address spaces from 64 bit this shouldn't be a problem...
19:04:05Araqrenesac: the control flow stack can easily be fixed size since only return addresses are stored in there
19:05:19reactormonkAraq, can you use return in a macro?
19:05:42reactormonkdom96, how does the nimrod namespace handle the load there?
19:05:47Araqreactormonk: yes
19:06:18reactormonkAraq, http://nimrod-lang.org/tut2.html#statement-macros does that work as intended?
19:06:22dom96reactormonk: You have to build using babel. Babel then passes the paths explicitly to the compiler.
19:06:28renesacAraq, in a template that returns a value, the value of the last statement is returned?
19:06:48reactormonkdom96, for each library in specific?
19:07:07reactormonk... sounds plausible. Cool.
19:07:08Araqrenesac: that's one way to look at it, but it's slightly wrong :P
19:08:03dom96reactormonk: No. For each binary package.
19:08:33reactormonkdom96, what's the difference between binary package and library?
19:09:04dom96Libraries are meant to be imported, binary packages are meant to be compiled.
19:09:16renesacAraq, you should write that documentation then...
19:10:06Araqyou write it, i correct it
19:10:23reactormonkdom96, so in case of [D [C [A_1]] [B [A_2]]], how do you build it?
19:11:47dom96reactormonk: nimrod c --path:~/.babel/pkgs/C-ver --path:~/.babel/pkgs/A_1-ver --path:~/.babel/pkgs/B-ver --path:~/.babel/pkgs/A_2-ver d.nim
19:12:45renesacok... I will try latter
19:12:54*renesac is now known as renesac|away
19:17:38*io2 quit (Ping timeout: 264 seconds)
19:19:06reactormonkdom96, so how will the import in B work to pick up A_2?
19:19:31dom96import A_2/module
19:20:11reactormonkthey're both called A/module, but have two different versions.
19:20:12*brson joined #nimrod
19:20:20reactormonkaka `import A`
19:22:38dom96Ahh, that's not allowed.
19:22:40Araqreactormonk: we have discussed this problem to death already and it's academic until it comes up in practice
19:23:09Araqespecially as long as we have ~50 packages in babel
19:23:48dom96AFAIK there are no easy solutions to this problem.
19:24:17dom96Might be interesting to see what the ruby/python/perl/node.js package managers do in this situation.
19:25:48reactormonkdom96, ruby bails.
19:26:00reactormonkAraq, kk, I'll take your word for it.
19:26:21dom96reactormonk: Really? Does it just give an error?
19:26:30Araqreactormonk: bailing is exactly the wrong solution IME
19:26:46AraqI download myself and try it instead
19:26:54reactormonkdom96, yup
19:26:56dom96I now wonder what you mean by "bails"
19:27:05reactormonkwell, bundle that is.
19:27:09Araqchances are high it works anyway and the version spec was wrong
19:27:26reactormonkfor rubygems, it just installs both and includes both and hopes it works
19:27:28Araqok, in ruby's case chances are high that it doesn't work either way ...
19:27:37reactormonkor actually, the version specified first winds.
19:27:39reactormonk*wins
19:28:01dom96Perhaps we should do that.
19:28:06reactormonkwith bundle, you get an error. Just because ruby has global namespace and it's not possible to separate by version.
19:28:24dom96Maybe i'll just make it a warning.
19:28:26reactormonknimrod has file-local namespace, so with some quirky magic, it should be possible.
19:28:40reactormonkdom96, make it error out for now.
19:28:55dom96That's what it does.
19:29:01reactormonkor a warning when it's just minor versions
19:29:10Araqadd some --force flag
19:29:52Araqwe have static typing, installing and hoping for the best has a chance of either working or producing a compiler error
19:31:20reactormonkwhich doesn't annotate functionality, but yup
19:31:37reactormonkit should be possible to bend around the include paths per file, somehow
19:31:59reactormonkbut then the compiler has to be babel-aware etc.
19:32:03dom96indeed.
19:32:06dom96I suggested that initially.
19:32:13dom96But it would require serious compiler patches.
19:32:36reactormonkAraq, https://github.com/Araq/Nimrod/pull/849 <- could you take a look at that?
19:33:10Araqreactormonk: don't pull, I think I fixed it properly
19:34:07reactormonkAraq, then write back
19:37:28reactormonkbtw, when will you purge the nimrod repo from build/csources*, if at all?
19:47:01Varriountdom96: You could use symlinks to *dump* the appropriate packages into the roots packages directory
19:47:53dom96That would end up conflicting because the two versions have the same names.
19:47:56VarriountSorta like what I do to easily edit and build 1 source tree for both 32 and 64 bit
19:48:14Varriountdom96: Not if the versions are specified in the babel file
19:48:34VarriountIf the babel file specifies the dependancies and their versions
19:48:44Araqsymlinks are evil
19:48:54Varriount^ A conveniant evil
19:49:19dom96oh, I think I just got what you mean.
19:49:24VarriountThey let me easily build 32 and 64 bit versions of the builder, and of nimrod
19:49:39VarriountWithout having to keep 2 separate source trees.
19:50:05dom96I wonder if the compiler could deal with those.
19:50:33Varriountdom96: It should. It already does (The compiler largely ignores symlinks,and just treats them as what they point to
19:51:05dom96That would work but I don't think symlinks are well supported on Windows, are they?
19:51:15VarriountThey are, actually
19:51:38VarriountThe only.. inconsistancy is that on windows, symlnk creation is restricted to admins
19:51:54VarriountAnd in that case, you could just copy the package directories instead
19:51:58dom96Yeah, that's a problem.
19:52:36Varriountdom96: Not if you copy.
19:53:39dom96Not sure if that's a good idea...
19:53:44VarriountWhy not?
19:54:52Araqdom96: the zeta-OS-09 doesn't support symlinks, so that is not a portable solution
20:05:52Araqzielmicha-cloud_: just a friendly reminder: we want your vfork patch
20:06:10VarriountWhat's a v-fork?
20:06:30*io2 joined #nimrod
20:07:42reactormonkAraq, zeta-OS is dead
20:07:49reactormonk... some random internet source
20:08:53Varriountdom96: Currently, how does babel make sure that a package with a dependancy on a specific version of another package, get's built with that other package?
20:09:12reactormonkAraq, and haiku supports symlinks.
20:14:20*xtagon joined #nimrod
20:42:51AraqVarriount: requiring a specific version itself is a bug
20:43:26Araqyou can't reasonably require that, you might as well embed that package then into your code base
20:45:09Araqreactormonk: FAT doesn't support symlinks
20:56:05*bstrie_ is now known as bstrie
20:59:05*[2]Endy quit (Ping timeout: 246 seconds)
21:09:24*Mat3 joined #nimrod
21:09:27Mat3hi all
21:11:30Araqhi Mat3
21:13:01Mat3hi Araq. And finally here it is, the ultimatly 6502 based 64 bit design: https://github.com/fachat/af65k
21:15:56Mat3(the author states: "timing is horrible. Currently ISE says it runs with less than 14MHz" - for me not suprising for accumulator-store design with Z80 like opcode prefixes)
21:16:43Araqmeh that other link was way more impressive
21:17:02Araqthe new general purpose cpu with a call instruction that takes 1 cycle
21:17:16Araqand the splitted instruction stream
21:17:27AraqI want that CPU already :-)
21:17:36Mat3yes, very inspiring
21:22:06Mat3anyhow; I think these english company with its 4096 core processor is also very attractive. Sadly there seem not to sell single CPU's
21:29:28VarriountAraq: Requiring a specific version prevents breakage
21:29:38*io2 quit (Ping timeout: 264 seconds)
21:29:46VarriountOr otherwise developers could never make breaking changes to their libraries
21:30:36Araqok, if you mean something like 2.x to allow for bugfixes, I agree
21:31:08Araqif you mean *exactly* version 2.4 then I argue that's broken
21:31:37VarriountAraq: Depends on what versioning system is used.
21:42:57*Mordecai quit (Ping timeout: 252 seconds)
21:52:36Mat3is the Dr. Dobbs article about nimrod published now ?
21:56:30Araqno
21:56:38Araq11th of february is release
21:56:50Mat3thanks, good to know
21:59:05*Mordecai joined #nimrod
21:59:09*Mordecai quit (Changing host)
21:59:09*Mordecai joined #nimrod
22:01:51Mat3need some sleep, ciao
22:02:02*Mat3 quit (Quit: Verlassend)
23:11:22*filwit joined #nimrod
23:30:19Araqhi filwit
23:30:35filwitAraq: I got the VM to work with my macros now by a) removing the unused check at vmgen:1319, b) removing the assert at vm:~425, and c) changing the assert at vm:82 to the following:
23:30:38NimBotAraq/Nimrod devel 3ff11d2 Araq [+1 ±3 -0]: bugfix: immediate templates are preferred consistently (danger: breaks code)
23:30:38NimBotAraq/Nimrod devel 2b8d7a8 Araq [+1 ±16 -0]: tyTypeDesc and tyRange always have 1 child; this might be tyNone but it is required for skipTypes
23:30:38NimBotAraq/Nimrod devel efcdadf Araq [+0 ±3 -0]: case consistency for -d:useWinAnsi
23:30:38NimBotAraq/Nimrod devel 45379a6 Araq [+0 ±10 -0]: stdlib compiles mostly without warnings again
23:30:38NimBot1 more commits.
23:30:42filwitcase n.kind:
23:30:50filwit of mkMetaNode: return n.sons[0]
23:30:58filwit of mkStmtList: return n
23:31:04filwit else: # fail...
23:31:06Araqwe have skipMeta for that
23:31:20Araqand your fix is wrong, sorry
23:31:27filwiti figured
23:31:44filwiti was just letting you know how it got it to work, still not sure exactly what is going on
23:32:28filwiti'm guessing i'm just adding a safe-guard to a lower-level part of the processing stack instead of fixing the node-tree appropriately early on
23:33:05AraqI still have 4 major building lots ...
23:33:16filwitbuilding lots?
23:33:23AraqVm, closure bugs, gc bugs and exception handling bugs
23:33:53Araqand all of them have a bus factor of 2 ...
23:33:53filwitah, well i'm not really asking you to look at my bug right now. just wanted to share in case you had any insight
23:34:16Araqwell the good news is I know how to fix my vm
23:34:29filwitthat is good news, lol :)
23:35:00filwitor are you talking about doing some major architecture change?
23:35:27Araqnah, I'm patching into hell
23:38:40filwithow are you going to be changing the structure tho?
23:39:41Araqproducing nkRefTy wrappers properly
23:40:23Araqoh filwit I think I fixed your bug properly
23:40:28Araqthe one you made a PR for
23:41:02filwitgreat. what was wrong with my fix?
23:42:24Araqyou only fixed 1 place
23:42:32AraqI fixed it everywhere, I hope
23:43:24filwitah i see, problem with my limited test cases then. glad it wasn't something i wasn't understanding correctly.
23:46:28filwitquick question, why is the body of skipMeta surrounded in () brackets?
23:46:56filwitthe if statement?
23:47:14Araqthere is some issue with the expr/stmt unification in expressions that I didn't look into
23:47:20filwitah, of course, cause you're not using 'return', silly question
23:47:25Araqthe () enforces it's parsed as an expression
23:50:59filwitbtw, have you ever considered (eventually) adding in variant-object param "guards"/"filters"
23:51:31Araqno idea what that is
23:51:36Araqbut yes
23:51:40filwitproc foo(n:PNimrodNode.kind(nkMetaNode))
23:51:47Araqlol, yes
23:51:56Araqin fact
23:51:57*Discoloda quit (Quit: leaving)
23:52:20AraqI planned a blog post about "dispatch tables" and that they are superior to what we have with multi methods
23:52:42Araqand that we should get rid of 'method' as nimrod's meta programming can do even cooler things
23:53:00VarriountAraq: But what about overriding things?
23:53:25filwitVarriount: he said dispatch tables (aka, virtual functions)
23:54:01filwitinteresting, i always thought you believed your method approach was superior to vtables
23:54:11filwitbut then i never really looked into it
23:54:15AraqI'm not talking of vtables
23:54:33EXetoCdoes my PR make sense or is there more to it?
23:54:46Araqand fyi it's well known nimrod's methods are not entirely optimized and perform worse than vtables
23:55:11filwitAraq: yeah i remember you telling me that awhile ago (about the performance).
23:55:22filwitAraq: though at the time you said you thought you could close the gap
23:55:32EXetoC(xml attribute escaping)
23:55:41Araqfilwit: that's still true
23:56:29*ics joined #nimrod
23:56:52filwitAraq: i really like Zahary's generic objects, and I'm interested to know exactly what you come up with as a vtable/method replacement.
23:58:02filwitif objects can eventually be derived from generic types as a way to enforce behavior, that's a real winner
23:58:51Araqyou mean the type classes?
23:59:04filwityes
23:59:15Araqyeah, you've got to love them ... :-)