←2009-02-11 2009-02-12 2009-02-13→ ↑2009 ↑all
00:04:30 <ehird> Question:
00:04:39 <ehird> Does "Code" fall under "Documents"? I don't think so.
00:04:45 <ehird> I'm glad we agree.
00:06:01 -!- CakeProphet has joined.
00:11:40 -!- olsner has quit (Remote closed the connection).
00:21:43 -!- GregorR has quit (Read error: 110 (Connection timed out)).
00:44:46 -!- jix has quit ("...").
01:11:50 -!- CakeProphet has quit (Read error: 60 (Operation timed out)).
01:37:20 -!- GreaseMonkey has quit ("Client Excited").
01:38:51 -!- SchrodingersCat has joined.
01:39:08 -!- SchrodingersCat has left (?).
02:09:09 -!- GreaseMonkey has joined.
02:28:27 -!- Corun has quit ("This computer has gone to sleep").
03:21:03 -!- Sgeo has joined.
03:57:35 -!- chuck has joined.
04:45:09 -!- GregorR has joined.
04:45:23 <GregorR> Power outages RULE
04:45:37 <pikhq> Lawlz.
05:05:15 <Sgeo> Bye all
05:06:33 -!- Sgeo has quit (Read error: 104 (Connection reset by peer)).
06:04:13 -!- Dewio has joined.
06:16:59 -!- Dewi has quit (Read error: 101 (Network is unreachable)).
07:40:37 <oklopol> does anyone run unlambda here?
07:47:19 <oklopol> Slereah2: CAN YOU LINK ME TO A PIRRRRRRRRATED TO MOCK A MOCKINGBIRD I KNOW YOU CAN DO IT
07:54:58 <oklopol> looking at it from google, i may have misunderstood the kind of book it is.
07:56:42 <oklopol> oh, two-part book, second part cl, i see i see
07:59:59 -!- clog has quit (ended).
08:00:00 -!- clog has joined.
08:01:21 <MizardX> Closest torrent I find is "To kill a mockingbird", a crime drama movie from 1962.
08:01:45 <oklopol> yeah
08:02:05 <oklopol> closest i found to the book was google's version, which was the part just before combinators
08:02:31 <oklopol> i want to combinator! :<
08:02:55 <oklopol> of course i could probably get the same pleasure from just memorizing the combinator birds
08:03:03 <oklopol> maybe i'll do that this weekend
08:03:14 * oklopol dancessss
08:03:34 <oklopol> anyway U ~>
08:16:48 <MizardX> http://pici.se/363479/
08:23:04 -!- GreaseMonkey has quit ("Client Excited").
08:41:15 -!- Deewiant has quit (Read error: 60 (Operation timed out)).
08:43:13 -!- Deewiant has joined.
09:27:31 -!- Slereah has joined.
09:32:00 -!- ais523 has joined.
09:38:20 -!- Slereah2 has quit (Read error: 110 (Connection timed out)).
10:02:26 <ais523> <Baldrson> The risk adjusted net present value of unicorns is basically 0 because the risk of their not existing is close to 1.
11:45:26 -!- ais523 has quit (Remote closed the connection).
12:10:38 -!- ais523 has joined.
12:54:28 -!- ais523 has quit (Read error: 60 (Operation timed out)).
12:55:38 -!- ais523 has joined.
13:01:52 -!- ais523 has quit (Read error: 104 (Connection reset by peer)).
13:01:54 -!- ais523_ has joined.
13:03:26 -!- ais523_ has changed nick to ais523.
13:05:16 -!- ais523_ has joined.
13:05:22 -!- ais523 has quit (Nick collision from services.).
13:05:28 -!- ais523_ has changed nick to CallForJudgement.
13:23:54 -!- CallForJudgement has quit.
13:24:05 -!- CallForJudgement has joined.
13:24:30 -!- CallForJudgement has changed nick to ais523.
13:33:41 <ehird> hi!
13:34:14 <ehird> [13:32:49] <shortc|laptop> [07:14:53] Hey...I run a site called Rosetta Code, and I was reviewing one of the pages there. There's a strange bit of text in one of the J examples, and I can't tell if it's normal output or vandalism.
13:34:14 <ehird> [13:32:49] <shortc|laptop> [07:15:22] http://rosettacode.org/wiki/Character_code#J
13:34:24 <ehird> [13:32:49] <shortc|laptop> [07:15:57] At the bottom of the second code block, the string "cdefghijklm" looks suspiciously like someone pounding on the home row.
13:34:25 <ehird> [13:32:49] <shortc|laptop> [07:16:37] I'm almost certain it's in error, but I have a hard time reading J to be sure.
13:34:26 <ehird> -- jsoftware
13:35:08 <ais523> hi ehird
13:35:10 <ehird> hi
13:35:39 <ais523> and I love that, just like if someone vandalised TECO probably nobody would ever know
13:35:46 <ais523> unless it was well-commented
13:36:21 <ehird> it wsa actually the correct output :D
13:36:29 <ais523> even better
13:36:31 <ehird> [13:32:49] <olegfink> [07:45:14] shortc|laptop: that's not the home row, that's eleven characters starting with code 99
13:36:32 <ehird> [13:32:49] <shortc|laptop> [07:45:32] doh.
13:36:33 <ehird> [13:32:49] <shortc|laptop> [07:45:40] That's what I get for doing this stuff at 3AM.
13:36:34 <ehird> [13:32:49] <shortc|laptop> [07:45:45] Thanks for the double-check. :-)
13:36:40 <ais523> I noticed it wasn't the home row, too
13:36:45 <ais523> although it's close
13:38:54 <ehird> Uh oh, I crashed Safari...
13:38:58 <ais523> how?
13:39:08 <ehird> Well, it was on Gmail.
13:39:20 <ehird> Probably I triggered some weird JS codepath that made it busy-loop.
13:39:43 <ehird> Gmail saved my draft, anyway/
13:43:50 <ehird> Hmm. I hope Time Machine compresses backups.
13:44:05 <ehird> Even with a 1TB backup drive, I have like 150GB of stuff on here.
13:44:22 <ehird> ais523, btw I realised it wasn't basically a rsync frontend
13:44:29 <ehird> because rsync can't both do --update and also store the old version
13:44:36 <ais523> ah, ok
13:44:38 <ehird> i.e., it can't just store what's changed in a new section
13:44:47 <ehird> (with, I presume, occasional full snapshots)
13:44:53 <ais523> and I'm pretty sure that there's at least one common open source backup program that can, I forget which one
13:45:10 <ehird> yes, almost certainly, it's a rather obvious idea
13:48:17 <ehird> one silly gripe: the 3d dock is inaccurate, from a physics point of view, and it breaks the perspective guidelines (how is the preview two-photos icon standing by a corner of the photo?)
13:48:18 <ehird> http://turbomilk.com/blog/cookbook/criticism/physics_still_matter_even_with_special_effects/
13:48:39 <ehird> to get it right you'd need variations of every icon for (position in dock, length of dock)
13:48:41 <ehird> :D
13:51:41 <ais523> nah, you just need 3D icons
13:51:53 <ais523> then you can project them to the right perspective
13:52:04 <ehird> that too
13:52:10 <ehird> but I think I prefer the infinite pngs
13:52:18 <ehird> maybe run a program with that tuple as the argument
13:52:21 <ehird> and make it output a png
13:54:24 -!- Sgeo has joined.
13:54:45 <ehird> DNS over HTTP over UDP.
13:54:47 <ehird> Dis-CUSS.
13:55:23 <ais523> why the HTTP?
13:55:32 <ais523> come to think of it, that's as stupid as BGP over TCP
13:56:19 <ehird> ais523: because HTTP solves every problem, including finding the IP of a domain to contact it over HTTP.
13:56:47 <ais523> also, who even suggested that? and why?
13:56:56 <ehird> I did. And because my brain is currently in wtf mode.
13:57:08 <ais523> you should look up BGP, some time
13:57:23 <ais523> it's a routing protocol designed to be politically inoffensive rather than good
13:57:57 <ais523> basically, it's designed to make sure traffic gets from one bit of the internet to another despite the various networks en route all disagreeing about which way the packet should go
13:58:34 <ehird> hah
13:58:35 <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$ sudo rm -r scripts
13:58:36 <ehird> rm: cannot remove directory `scripts': Device or resource busy
13:58:38 <ehird> ^ fuck the what
13:58:51 <ehird> (I'm removing bsmnt_bot because I'm too lazy to get it working without reconnecting and meh)
13:58:52 <ais523> ehird: is something cded into that directory?
13:58:58 <ehird> ais523: maybe.
13:59:08 <ais523> daemons are supposed to cd / for that reason
13:59:27 <ehird> not that I can tell though
13:59:32 <ehird> how can I --really-force
13:59:45 <ais523> kill the process that's in that directory
13:59:53 <ehird> i don't know which
13:59:58 <ais523> there's some easy way to find out
14:00:04 <ais523> lsof | grep would work, probably
14:00:04 <ehird> how helpful :P
14:00:07 <ehird> don't have lsof
14:00:14 <ehird> i _could_ install it :P
14:00:18 <ais523> how do you not have lsof?
14:00:28 <ehird> this is a base server install, it doesn't even have man(1)
14:00:44 <ehird> (I'm pretty sure that violates POSIX)
14:00:52 <ais523> ls -l /proc/*/cwd | grep
14:00:54 <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$ lsof | grep scripts
14:00:54 <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$
14:00:54 <ais523> in that case
14:01:33 <ehird> also, you mean cat
14:01:43 <ais523> nope, cwd is a symlink
14:01:51 <ais523> so you have to dereference it somehow
14:02:15 <ais523> you probably don't have readlink due to being on a server, so you either need the cd pwd trick in a loop, or ls
14:02:33 <ehird> ah
14:02:39 <ehird> "Time Machine saves the hourly backups for the past 24 hours, daily backups for the past month, and weekly backups for everything older than a month."
14:02:44 <ehird> hmm, I thought it stored backups forever
14:02:57 <ais523> it does, just not all of them
14:03:05 <ais523> based on that
14:03:18 <ehird> right
14:03:31 <ais523> did the proc/*/cwd trick help?
14:03:36 <ehird> no, I pasted the lsof output
14:03:42 <ehird> [14:00:53] <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$ lsof | grep scripts
14:03:42 <ehird> [14:00:53] <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$
14:03:51 <ais523> oh, you need to sudo it if it's running as a different user
14:03:54 <ehird> oh
14:03:54 <ehird> "Time Machine creates links to any unchanged files, so when you travel back in time you see the entire contents of your Mac on a given day." <- cute trick
14:04:05 <ais523> yep, hardlink backups have been around for ages
14:04:10 <ehird> yeah
14:04:32 <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$ sudo lsof | grep scripts
14:04:32 <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$
14:05:07 <ehird> Backing up to a full disk.
14:05:18 <ehird> One day, no matter how large your backup drive is, it will run out of space. And Time Machine has an action plan. It alerts you that it will start deleting previous backups, oldest first. Before it deletes any backup, Time Machine copies files that might be needed to fully restore your disk for every remaining backup. (Moral of the story: The larger the drive, the farther back in time you can back up.)
14:05:19 <ehird> Non-reality distortion field translation:
14:05:29 <ehird> "We will threaten you with destroying your backups so you quickly buy a new drive."
14:06:01 <ais523> well, it has to do /something/ when you run out of backup space
14:06:17 <ais523> the Windows solution is to delete all but the most recent backup, which is not very encouraging
14:07:08 <ehird> i'd make it pop up going "Your backup drive is full. Delete some backups or get a new drive or something. Meanwhile I'll sit here doing nothing."
14:07:27 <ais523> but then you wouldn't have your backups every hour
14:07:48 <ehird> buy a new harddrive within an hour :P
14:08:11 <ehird> I'm kind of a rabid archivist so I guess it doesn't make sense for others.
14:08:35 <ehird> Still, with a 1TB external drive I think it'd take me rather a while to fill that up...
14:09:04 * ehird reboots rutian to see if the scripts dire
14:09:09 <ehird> ctory will be deletable
14:09:14 <ais523> ctory?
14:09:19 <ehird> see previous line
14:09:22 <ehird> [14:09:04] • ehird reboots rutian to see if the scripts dire
14:09:22 <ehird> [14:09:08] <ehird> ctory will be deletable
14:09:28 <ais523> also, you could always try moving the directory into /tmp
14:09:30 <ais523> then rebooting
14:09:32 <ehird> the scripts folder is rather weird
14:09:33 <ehird> ehird@rutian:/home/bsmnt/python_chroot/bot$ ls -lh
14:09:33 <ehird> total 1.0K
14:09:33 <ehird> drwxrwxrwx 2 1343 root 1.0K Feb 12 13:57 scripts
14:09:37 <ehird> it's also empty
14:09:46 <ehird> mv: cannot move `scripts' to `/tmp/scripts': Device or resource busy
14:09:46 <ais523> even with ls -a?
14:09:58 <ehird> $ ls -lah scripts
14:09:58 <ehird> total 5.0K
14:09:58 <ehird> drwxrwxrwx 2 1343 root 1.0K Feb 12 13:57 .
14:09:58 <ehird> dr-xr-xr-x 3 1001 1001 4.0K Feb 12 13:57 ..
14:10:06 <ais523> ok, that's weird
14:10:15 -!- ehird has quit ("Caught sigterm, terminating...").
14:10:22 <ais523> ...
14:11:03 -!- ehird has joined.
14:11:51 -!- ehird has quit (Client Quit).
14:12:17 <ais523> I wonder what's happening to ehird?
14:13:22 -!- ehird has joined.
14:13:50 <ais523> wb ehird
14:14:02 <ais523> ah, your rebooting messed the bounder?
14:14:04 <ais523> *bouncer?
14:14:04 <ehird> hi
14:14:32 <ehird> huh?
14:14:40 <ehird> the bouncer runs on the server
14:14:41 <ais523> you quitted IRC twice
14:14:46 <ehird> did I?
14:14:47 <ais523> and I thought you were rebooting the eserver
14:14:53 <ehird> hm. who knows
14:15:04 <ais523> <-- ehird has left this server ("Caught sigterm, terminating...").
14:15:12 <ais523> that's the message your bouncer gives when someone sigterms it
14:15:15 <ehird> must have repeated a kill line from the history
14:15:21 <ehird> (ctrl-r by mistake)
14:15:27 <ehird> or it may hvae crashed
14:39:04 <ehird> ... Time Machine will version my .git directories. That will be ... interesting.
14:41:20 <ehird> Gah, I need zsh. Can't take bash any longer.
14:41:31 <ehird> MacPorts or manual compile ... MacPorts.
14:41:37 <ais523> you should be proficient with a range of shells, ideally
14:41:44 <ais523> even csh, in case you're stuck using it
14:42:05 <ehird> I can use bash, I just don't _want_ to
14:42:10 <ehird> Can't use csh though, thank god.
14:42:26 <ais523> the CDE computers here are tcsh by default
14:42:46 <ehird> I wonder how long it took to make the Stacks in the dock fold out line the leaning tower of pisa
14:44:04 <ais523> probably not all that long
14:44:12 <ehird> Too much time :P
14:44:57 <ehird> Can't map the URL 'file://.' to a port description file ("Could not find Portfile in /Users/ehird").
14:44:59 <ehird> vut
14:45:08 <ehird> oh, I need to sync. I think.
14:45:31 <ehird> oh
14:45:34 <ehird> I forgot "zsh"
14:45:34 <ehird> :x
14:45:45 <ehird> MacPorts is written in Tcl./
14:45:47 <ehird> I wonder why.
14:47:10 <ehird> configure: error: C compiler cannot create executables
14:47:15 <ehird> Ah. Methinks I need the developer tools.
14:49:15 <bsmntbombdood> ehird: ur dum lol!
14:49:23 <ehird> very
14:49:24 <bsmntbombdood> run df
14:50:08 <ehird> bsmntbombdood: no, I don't have a C compiler
14:50:09 <ehird> :P
14:50:12 <ehird> is the issue
14:50:22 <bsmntbombdood> i mean for bsmnt bot
14:50:28 <ehird> oh.
14:50:37 <ehird> bit late now
14:50:43 <bsmntbombdood> i was asleeping
14:50:56 <ehird> was scripts mounted?
14:51:00 <ehird> that would explain it
14:51:08 <bsmntbombdood> yeah
14:51:40 <ehird> i knew it was a weird directory :P
14:54:12 <ehird> fuck!
14:54:19 <ehird> this disc doesn't have the developer tools
14:54:25 * ehird trudges off to get it from adc
14:54:38 <ais523> is it a legitimate disk?
14:54:50 <ehird> no, but the problem is that it's disc 1, the install disc
14:55:00 <ehird> instead of disc 2, the Things You Need To Actually Be Able To Use This disc.
14:55:56 <ehird> there we go, downloading
14:56:05 <ehird> holy carp it's 996MB.
14:56:12 <ehird> why isn't this bundled with the os. geez.
14:56:13 <ais523> that won't fit on a CD
14:56:53 <ehird> ais523: OS X install disc = dual-layer DVD
14:56:58 <ais523> ok
14:57:09 <ehird> iirc it's about 7.5 GB used out of 8.5
14:57:12 <ehird> so it would fit
14:57:31 <ehird> http://tunes.org/legalese/bugroff.html <--this is even better than the WTFPL
14:58:38 <ehird> although the "all lawyers suck" sentiment is stupid.
15:07:13 <ehird> ais523: you've used OCaml, right?
15:07:33 <ais523> yes, I'm doing a uni project with it atm
15:12:09 <ehird> ais523: is it as crap as they say
15:12:10 <ehird> ?
15:12:18 <ais523> it has various troubles
15:12:25 <ais523> the most annoying is the lack of any sort of operator overloading
15:12:32 <ais523> or automatic coercion
15:12:43 <ais523> in Perl, you have eq that's different from ==
15:12:48 <ais523> for comparing strings vs. numbers
15:12:54 <ais523> that's fine, you need it as it's weakly typed
15:13:03 <ais523> in C, you have / for int vs. / for float
15:13:08 <ais523> which is also fine, as it's strongly typed
15:13:08 <ehird> ocaml has no typeclasses right?
15:13:15 <ais523> OCaml is strongly typed (without typeclasses)
15:13:15 <ehird> that's why you pay homeage to slashdot all the time
15:13:17 <ehird> (/.)
15:13:24 <ehird> yeah that's really stupid
15:13:25 <ais523> yet it requires a different operator for everything, it seems
15:13:28 <ais523> and normally a cast too
15:13:41 <ehird> also, it's strictly evaluated and non-pure.
15:13:47 <ehird> which is also kinda stupid for a functional language.
15:13:53 <ais523> it's an imperative language too
15:13:59 <ehird> and an OOP language
15:14:02 <ais523> it's specifically designed to be both imperative and functional
15:14:07 <ais523> the OOPness I haven't learnt
15:14:15 <ais523> so although I'm writing OCaml, I'm only really using Caml
15:14:18 -!- KingOfKarlsruhe has joined.
15:15:02 <ehird> ais523: function arguments are evaluated right to left
15:15:07 <ehird> because it's efficient for stack usage
15:15:13 <ehird> that's just awful in an imperative language...
15:15:18 <ais523> I try not to rely on any order of evaluation
15:15:25 <ais523> except the fact that a;b runs a before b
15:15:30 <ais523> it's less confusing that way
15:15:42 <ehird> I'll stick to Common Lisp for my functional/imperative mix.
15:18:16 <ehird> ais523: is ocaml as fast as claimed?
15:18:32 <ais523> it's pretty fast
15:18:40 <ais523> I'm doing all sorts of ridiculous things that should be slow
15:18:52 <ehird> like
15:18:56 <ais523> but they're running so quickly I can't tell how fast they're running
15:19:05 <ais523> and like solving a maze by random walk
15:19:10 <ehird> nice
15:19:11 <ais523> (or the programming equivalent)
15:19:14 <ehird> what's the project?
15:19:22 <ais523> compiling imperative languages into hardware
15:19:34 <ais523> which has basically become compiling functional languages with some weird restrictions into hardware
15:19:43 <ehird> ah right
15:19:58 <ehird> ais523: what lang are you compiling? You've mentioned it, care to show e.g. factorial function?
15:20:18 <ais523> well, it's a functional lang with no recursion
15:20:23 <ais523> there are restrictions to make it turing-incomplete
15:20:33 <ehird> ais523: so presumably you need to do an imperative loop for factorial
15:20:34 <ais523> you have imperative loops instead, which are converted into tail-recursion
15:20:40 <ehird> right
15:20:45 <ehird> so what does factorial look like?
15:20:49 <ais523> also, I'm working mostly on the intermediate representation
15:20:56 <ais523> so I'd have to look up what the syntax for a loop is
15:20:56 <ehird> ok
15:21:01 <ais523> in the original source
15:21:07 <ehird> is it basically just:
15:22:01 <ehird> fun fact(n : integer) : integer; i = 1; loop (n != 0) with (n = n - 1); i *= n; end; end?
15:22:06 <ehird> i.e. nothing special
15:22:13 <ais523> yep, pretty much
15:22:27 <ehird> what computational c lass is it?
15:22:34 <ais523> bounded-storage
15:22:44 <ehird> is that the most powerful sub-TC level?
15:22:48 <ais523> no
15:22:54 <ehird> ah, is such a concept undefined?
15:22:56 <ais523> it's equivalent to finite-state-machine, which is one of the lowest
15:23:11 <ais523> but it means, in practice, "something which would be TC except it doesn't have infinite memory"
15:23:22 <ehird> I'm interested in nearly-TC languages, specifically, total functional programming languages
15:23:33 <ehird> you know how in FP langs, all values are actually (value or _|_)?
15:23:36 <ehird> where _|_ = bottom
15:23:37 <ehird> e.g.
15:23:38 <ehird> x = x
15:23:41 <ehird> that's _|_
15:23:44 <ehird> x = error "nooooo"
15:23:46 <ehird> also _|_
15:23:57 <ehird> func "a value its pattern matching doesnt handle"
15:23:59 <ehird> also _|_
15:24:00 <ais523> I'm not really aware of how fixed-point languages work
15:24:05 <ehird> not FP
15:24:07 <ehird> functional programming
15:24:19 <ais523> ah
15:24:22 <ehird> anyway, a total FP language is one without _|_
15:24:41 <ehird> all pattern matches must be complete, every program halts, and there are no errors apart from with types like (Either Error Result)
15:24:55 <ais523> the one I'm working with is one of those, apart from the every program halts bit
15:25:03 <ehird> I've read a paper which suggests to me that you can actually make such a language useful for most tasks
15:25:09 <ais523> if a program doesn't halt, it's in an infiniloop so there's no way to tell what its return value is
15:25:23 <ehird> what i'm thinking about is making a combinator base like ski
15:25:27 <ehird> except that you can only write total programs in
15:25:28 <ais523> also, I love the way that all the data types are syntactic sugar for multiple booleans
15:25:30 <ais523> apart from functions
15:25:38 <ehird> that is, the machine code for a total FP lang
15:25:40 <ais523> and that would be neat
15:25:51 <ais523> hmm... are total FP langs necessarily reversible?
15:25:53 <ais523> I'd guess no
15:25:55 <ehird> no
15:25:59 <ehird> f n = 0
15:26:05 <ehird> bam, irreversable function
15:26:08 <ais523> ah, ofc
15:26:21 <ehird> although reversibility IS a nice property,
15:26:27 <ehird> I'm not sure total FP + reversability would be useful at all
15:26:34 <ais523> make a functional lang that compiles into BackFlip
15:26:43 <ais523> just for the fun of it
15:26:52 <ehird> can I just gnaw on my toenails instead? that'd be less painful :P
15:27:01 * ehird looks upb ackflip
15:27:05 <ehird> eek
15:27:10 <ehird> something non-2d would be easier :P
15:27:15 <ais523> Unassignable, then
15:27:30 <ais523> which has been proved to be compilable into backflip
15:27:35 <ais523> and which is actually quite fun to write
15:28:03 <ais523> <masklinn> One of the worst parts in XSLT is its verbosity (it's a dysfunctional purely functional language, yet building the structure for a recursive function that takes a single argument and doesn't do anything takes like 8 lines)
15:28:29 <ehird> ok, Unassignable looks pretty usable
15:28:42 <ais523> it's the only reversible guaranteed-termination OO lang I know of
15:28:51 <ehird> Error: Target org.macports.activate returned: Image error: /opt/local/bin/zsh is being used by the active zsh-devel port. Please deactivate this port first, or use the -f flag to force the activation.
15:28:58 <ehird> fuck on earthhhhhhhhhhhh
15:29:03 <ehird> Archive and Install is so crap
15:29:06 <ehird> it doesn't delete everything properly
15:29:09 <ehird> it thinks I have stuff installed
15:29:11 <ais523> ehird: where else would you expect to fuck?
15:29:15 <ehird> space. duh.
15:29:28 <ehird> also, fuck on earth = wtf x 1000
15:29:46 <ehird> bournemouth:~ ehird$ sudo rm -rf /opt
15:29:49 <ehird> that should do it
15:30:39 <ehird> sure is taking a while
15:30:48 <ais523> hmm... I'm not the sort of person who'd do something like that, I don't think
15:31:04 <ais523> I would find it really amusing if rm was in /opt. or sudo was.
15:31:10 <ais523> although that's unlikely
15:31:16 <ehird> ais523: archive and install is meant to move the whole system to /Previous Systems/, then install a clean one
15:31:23 <ehird> unfortunately, it didn't handle macports.
15:31:26 <ehird> or some settings.
15:31:32 <ehird> so it's kind of confused about what it has.
15:33:12 * ehird tells finder to calculate the size of /opt/local
15:33:17 <ehird> it's taking a while to rm...
15:33:24 <ais523> 0, obviously, you're deleting it
15:33:30 <ehird> nope
15:33:34 <ais523> also why not delete /opt/local not /opt?
15:33:34 <ehird> it's in the middle of deleting it
15:33:44 <ehird> because /opt only contains local/
15:33:50 <ehird> ah, 2.4GB left
15:33:50 -!- BeholdMyGlory has joined.
15:34:02 <ehird> a lot of my installed ports are worthless anyway
15:34:08 <ehird> e.g., ruby and python now come with the os
15:34:15 <ehird> 1.7GB left...
15:34:59 <ehird> 500MB...
15:35:16 <ehird> 200MB
15:35:35 <ehird> 10MB
15:35:38 <ehird> bam
15:36:27 <ehird> "Installing this software requires no additional space"
15:36:28 <ehird> erm...
15:37:05 <Slereah> It is exactly 0 byte long.
15:38:23 <ehird> No ports are installed.
15:38:24 <ehird> hooray
15:45:05 -!- MigoMipo has joined.
15:47:25 <ehird> ais523: I'm going to write a factorial program in Unassignable.
15:47:31 <ais523> have fun
15:47:36 <ehird> it is possible, right?
15:47:38 <ais523> yep
15:47:45 <ais523> that binary-to-decimal took me long enough, though
15:47:55 <ehird> I'll just output in unary
15:48:06 <ehird> using your program as the base
15:48:15 <ais523> it's not output that's the problem, I suspect, it's the multiplication
15:48:22 <ehird> err, why is mainloop an integer?
15:48:23 <ais523> trying to reset state afterwards could be fun
15:48:28 <ais523> ehird: it's a loop
15:48:36 <ais523> loops can only exist as methods on integers
15:48:36 <ehird> ah
15:48:39 <ais523> "loop this many times"
15:48:47 <ais523> and you can't change the integer during the loop
15:49:01 <ais523> the general rule is that if you're inside a method of an object, you can't change, or even mention, the object itself
15:49:07 <ais523> because that would be recursion, and that would be wrong
15:49:12 <ehird> (X must be a power of 2).
15:49:15 <ehird> ok, that_is_ an issue
15:49:24 <ais523> you can work around it
15:49:32 <ehird> how?
15:49:35 <ais523> there's a pair of variables in my binary-to-decimal which simulate an x of 10
15:49:45 <ais523> basically, you have two variables, one the power below, one the power above
15:49:47 <ehird> which binary to decimal
15:49:47 <ais523> say 8 and 16
15:49:54 <ais523> ehird: it's the only example program I give
15:49:57 <ais523> a counter which outputs in decimal
15:50:00 <ehird> wrong
15:50:01 <ehird> http://esolangs.org/wiki/Talk:Unassignable
15:50:05 <ehird> http://esolangs.org/wiki/Unassignable#Example
15:50:19 <ais523> ah, the one on the talk page
15:50:24 <ais523> the other one's probably a syntax example
15:50:36 <ehird> its a counter
15:50:37 <ehird> 1
15:50:38 <ehird> 11
15:50:38 <ehird> 111
15:50:39 <ehird> etc
15:50:48 <ehird> ais523: can X be a variable in increment(X)?
15:50:55 <ais523> nope
15:50:58 <ehird> :(
15:51:01 <ais523> it has to be a constant power of 2
15:51:09 <ais523> although increment(1); increment(8); is legal
15:51:13 <ais523> and a trivial way to increment by 9
15:51:17 <ehird> ah, I've figured out how to do it
15:51:24 <ehird> num->increment;
15:51:30 <ehird> then that iterates othernum->increment(1)
15:51:31 <ehird> or whatever
15:51:33 <ais523> yes
15:51:53 <ais523> incidentally, if you need multiple iterators on a single integer, and you normally do
15:52:04 <ais523> get its iterator to call lots of functions, and disable all but the one you need
15:52:20 <ais523> I should make a sugared version of Unassignable some day
15:52:36 <ehird> integer factorial(4294967295)=4294967295;
15:52:43 <ehird> and it calls a special object that just deactivates it
15:52:44 <ehird> in its iterator
15:52:48 <ehird> to break
15:52:54 <ais523> deactivates what?
15:52:59 <ehird> it does
15:53:02 <ehird> factorialkiller->doyourthin
15:53:03 <ehird> g
15:53:05 <ehird> and factorialkiller does
15:53:10 <ehird> factorial->deactivate
15:53:14 <ais523> er... that's recursion
15:53:19 <ehird> dog gammit
15:53:27 <ais523> you can do it
15:53:31 <ais523> but indirectly
15:53:35 <ehird> well, that's okay, n! only iterates n times
15:53:39 <ais523> the iterator, say, is three functions, a, b, and c
15:53:47 <ehird> so just
15:53:59 <ehird> integer factorial(6)=6;
15:53:59 <ehird> integer num(6)=6;
15:53:59 <ehird> integer factorial(6)=6;
15:54:00 <ais523> wait, two will do, a and b
15:54:05 <ehird> to calculate 6!
15:54:07 <ais523> initially, a's active and b's inactive
15:54:11 <ais523> a can break by activating b
15:54:23 <ais523> and b increments a counter that's initially -1, and deactivates a on overflow
15:54:39 <ais523> you can't activate an inactive function, or deactivate an active function, because that breaks reversibility
15:56:09 <ehird> ais523: can any function take non-constant args?
15:56:10 <ehird> e.g.
15:56:10 <ehird> result->multiply(num);
15:56:13 <ehird> if I define num
15:56:24 <ais523> no, all args are constants
15:56:31 <ehird> butts.
15:56:33 <ais523> you can use global variables to pass args
15:56:35 <ehird> yeah
15:56:56 <ais523> due to no-recursion, you don't have scoping problems if you name the args after the functions
15:58:14 <ehird> multiplication is hard :<
15:58:21 <ehird> in unassignable that is :P
15:58:25 <ais523> yes
15:58:29 <ehird> since you can't really loop over two v- except...
15:58:30 <ehird> yes i can
15:58:32 <ais523> even addition is non-trivial
15:58:36 <ais523> a += b is trivial
15:58:50 <ais523> so I suppose you could just do a += b in a loop
15:59:00 <ais523> you probably want to do a -= b in a loop afterwards to reset a
15:59:21 <ehird> a += b is trivial?
15:59:27 <ehird> no it's not
15:59:32 <ais523> loop on b, incrementing a
15:59:41 <ehird> yeah but you can't loop that
15:59:44 <ais523> why not
15:59:44 <ehird> without copying
15:59:47 <ehird> and a = b is also a pain
15:59:52 <ehird> because we're doing multiple iterators
15:59:52 <ais523> a = b is impossible
15:59:54 <ehird> andf sjfhdksfhkdfjhsdkfshfkjdf
15:59:59 <ais523> reversible lang, remember
16:02:01 -!- FireFly has joined.
16:02:45 <ehird> one problem:
16:02:50 <ehird> wait, nevermind
16:02:58 <ais523> it's not an easy language
16:03:20 <ehird> ok, I've got this program working:
16:03:24 <ehird> a *= b;
16:03:27 <ehird> print('1' * a);
16:03:32 <ehird> is there an interp?
16:03:33 <ehird> to test it
16:07:48 <ehird> Copied old '~/.zshrc' to '~/.zshrc.zni'.
16:07:48 <ehird> *** Internal error: bad type for keymap ***
16:07:48 <ehird> --- Type a key in forlorn hope ---
16:08:13 <ais523> ehird: I have a compiler to C++
16:08:19 <ais523> but it doesn't enforce the no-recursion rule
16:08:22 <ehird> to hand?
16:08:34 <ais523> let me try to find it
16:08:38 <ais523> I think I know where it is
16:10:12 <ais523> ok, found it
16:10:27 <ais523> it seems to be in two parts, a .c file which is the compiler in C, and a .h file which is the header for generated files in C++
16:11:00 <ais523> http://filebin.ca/hpckp/una2cpp.tgz
16:11:31 <Sgeo> Post that URL to the wiki?
16:11:52 <ais523> it'll vanish in a few hours
16:11:59 <ehird> no
16:12:02 <ehird> filebin links generally persist
16:12:04 <ais523> it's a temporary pastebin
16:12:05 <ehird> ooh, I have bsd ls(1)
16:12:06 <ehird> yum yum
16:12:19 <ais523> "Files will be kept in a rotating pool of space, and may be removed at any time."
16:12:25 <ehird> ais523: yes, it's not actually true
16:12:28 <ehird> I've never had a filebin link expire
16:12:29 -!- oerjan has joined.
16:12:32 <ais523> so they persist until someone else pastest something big, I guess
16:13:00 <oerjan> beware of what thou pastest
16:13:47 <ehird> /Users/ehird/Code/esolangs/unassignable/una2cpp
16:13:49 <ehird> longest path evar
16:14:00 <ais523> I have longer
16:14:21 <ehird> Integer has invalid maximum.
16:14:24 <ais523> including a complete source tree for all the packages in a uclinux distro which is about 6 directories below my home
16:14:25 <ehird> the max is 4294967295
16:14:28 <ehird> oh, wait
16:14:30 <ehird> needs to be 4294967294
16:14:35 <ehird> err, nope
16:14:37 <ais523> no, the first value is probably correct
16:14:43 <ais523> my guess is I wrote int rather than unsigned
16:14:44 <ehird> then whydit complain
16:14:47 <ais523> in the compiler
16:15:00 <ehird> ;_;
16:15:04 <ais523> it was a quick hack, as you can tell by the state of una2cpp.h
16:15:07 <ehird> if(fscanf(in,"%lu",&templu)!=1)
16:15:07 <ehird> {
16:15:07 <ehird> fprintf(stderr,"Integer maximum is not a number.\n");
16:15:07 <ehird> return EXIT_FAILURE;
16:15:07 <ehird> }
16:15:31 <ais523> ehird: that's not the error you're getting
16:15:36 <ehird> oops
16:15:44 <ais523> and fscanf returns 1 if it inputs 1 input value, so it's a correct check
16:15:52 <ehird> case 4294967295LU: break;
16:15:52 <ehird> default:
16:15:52 <ehird> fprintf(stderr,"Integer has invalid maximum.\n");
16:16:09 <ehird> so it should work...
16:16:09 <ais523> interesting...
16:16:18 <ehird> function main=activated;
16:16:18 <ehird> integer a(4294967295)=5;
16:16:18 <ehird> integer b(5)=5;
16:16:18 <ehird> integer multiply(5)=5;
16:16:22 <ehird> that'sthe whole declaration section
16:16:25 <ehird> ...oh wait
16:16:29 <ehird> 5 isn't allowable
16:16:29 <ehird> is it?
16:16:32 <ais523> it's the 5 that's invalid
16:16:36 <ehird> AAAAAAAAGH
16:16:39 <ais523> that's not 2^n - 1
16:16:50 <ais523> look at tenloop in my Talk:Unassignable program, though
16:16:56 <ais523> that shows how to do an integer with a different maximum
16:17:03 <ais523> basically, to get an int from 0 to 9
16:17:12 <ais523> I had an int from 0 to 8 and an int from 0 to 16
16:17:14 <ehird> wait
16:17:16 <ehird> the maximum can be anything
16:17:19 <ehird> I just set it to 5
16:17:20 <ehird> phew
16:17:28 <ais523> integer b(7)=5; is legal
16:17:33 <ehird> yep
16:17:40 <ehird> b and multiply never change
16:17:46 <ehird> so that's fine
16:18:09 <ehird> erm
16:18:11 <ehird> #define CURCLASS void unatmain::
16:18:11 <ehird> run
16:18:11 <ehird> {
16:18:11 <ehird> multiply->loop;
16:18:12 <ehird> a->loop;
16:18:12 <ehird> }
16:18:18 <ehird> that is not valid C, surely
16:18:19 <ehird> C++
16:18:28 <ais523> look at the other #defines
16:18:36 <ais523> it becomes valid C++ once you apply all of them
16:18:36 <ehird> I think I'll avoid that :P
16:18:39 -!- oerjan has quit ("Reboot").
16:18:46 <ais523> #define loop floop()
16:19:14 <ehird> multiply.cpp:14: warning: this decimal constant is unsigned only in ISO C90
16:19:15 <ehird> lol
16:19:26 <ehird> wtf
16:19:28 <ehird> multiplication doesn't work
16:19:36 <ehird> ais523: does the loop loop for the maximum
16:19:37 <ehird> or the value
16:19:39 <ais523> the value
16:19:44 <ehird> very odd
16:19:49 <ais523> but you mustn't change the value during the loop, or even mention it
16:19:58 <ehird> My program tells me 5 * 5 = 30
16:19:58 <ais523> paste your program, so I can see what's wrong with it?
16:20:08 <FireFly> [17:13:49] <ehird> longest path evar <-- I've seen longer, it's called Windows
16:20:17 <ais523> my guess is you started with 5, then added 5 to it 5 times
16:20:25 <ehird> ais523: http://pastie.org/private/vvvlhnwhslor4idpdepaow
16:20:27 <ais523> whereas you need to start with 0 for that to work
16:20:32 <ehird> ah
16:20:33 <ehird> ofc
16:20:51 <ais523> yep, that was it
16:20:58 <ehird> that makes things a lot more compliated, then
16:21:11 <ais523> the real trouble in unassignable is resetting variables once you're done with them
16:21:20 <ais523> you often have to write large parts of your program in reverse
16:23:10 <ehird> works now
16:23:33 <ehird> calculates 100 * 576 = 57600
16:23:34 <ehird> quickly, too
16:23:36 <ehird> good
16:23:41 <ehird> now I can write factorial
16:23:46 -!- oerjan has joined.
16:23:52 <ehird> for the record:
16:23:52 <ehird> v
16:23:53 <ehird> http://pastie.org/private/e0z6t3a9k0npupa2nk4lbq
16:24:02 <ehird> err
16:24:04 <ehird> it doesn't check limits
16:24:09 <ehird> but whatever
16:24:10 <ehird> you can fix them :P
16:24:28 * ehird just sets all limits to 4294967295
16:25:03 <ais523> as for factorial, note you aren't allowed to iterate on b whilst multiplying by b
16:25:19 <ais523> the easy solution here is just to get the variable you're iterating on to increase a separate loop counter
16:29:14 -!- Hiato has joined.
16:31:26 <ehird> gah, my delete key is ^? but zsh wants %H
16:31:27 <ehird> *^H
16:31:37 <ais523> use stty to fix it?
16:31:47 <ehird> no, you use zsh keybindings
16:32:04 <ehird> factorial.cpp: In member function ‘virtual void unatmain::erun()’:
16:32:04 <ehird> factorial.cpp:38: error: ‘class unatfactorial’ has no member named ‘fcall’
16:32:06 <ehird> vut
16:32:06 <ehird> oh
16:32:08 <ais523> well, it depends on what delete key you want for stdio, I suppose
16:32:28 <ehird> ... 6! = 21, apparently.
16:32:43 <ehird> oh, wait.
16:33:07 <ais523> I should make an unassignable compiler that enforces the restrictions, really
16:33:35 <ehird> wait, why on earth is it = 21...
16:34:39 <Deewiant> ehird: 1+2+3+4+5+6 = 21
16:34:44 <ehird> oh, duh.
16:34:49 <ehird> lol, it's addorial
16:36:57 <ehird> hmm
16:36:58 * oerjan beats ehird with a triangle |>
16:37:03 <ehird> ^H does backwards delete
16:37:06 <ehird> what's forward delete?
16:37:15 <ais523> ^? normally
16:37:36 <ehird> "^H" backward-delete-char
16:37:36 <ehird> "^?" backward-delete-char
16:37:53 <ehird> my terminal sends \033[3~
16:37:56 <ehird> so I guess I'll bind that
16:41:16 <oklopol> what's the commotion that composes this day?
16:41:26 <ais523> oklopol: ehird upgrading his OS
16:41:55 <ehird> I miss my old prompt.
16:41:59 <ehird> Even though it was unreadabl.
16:42:01 <ehird> e
16:42:03 <ais523> you can restore it
16:42:06 <ehird> Indeed.
16:42:12 <oklopol> how is he upgrading it
16:42:16 <oklopol> in an interesting way?
16:42:16 <ais523> anyway, why aren't all your settings saved in dot files in ~?
16:42:18 <ehird> oklopol: past tense
16:42:26 <ehird> ais523: they are, the system was reinstalled
16:42:35 <ehird> archive + install = copy old system to special directory, do clean install
16:42:57 <ehird> /Previous Systems.localized/2009-02-11_1200/Users/ehird % cat .zshrc
16:43:02 <ais523> ah
16:43:11 <ais523> wouldn't it be usual to move your home dir over after doing that
16:43:40 <ehird> yes, but I have so much rubbish in my home directory that I decided to leave it and copy on need
16:44:05 <oklopol> you could always copy on write
16:44:07 <ehird> precmd() { print -Pn "\e]0;%n@%m:%~\a" }
16:44:07 <ehird> export PS1=$(print "%{\e[33m%}")"[%n:%~] %#"$(print "%{\e[0m%}")" "
16:44:09 <ehird> Home once more.
16:44:19 <ehird> Yes, yellow on white is unreadable. I don't care.
16:44:48 <ehird> Prompts are for feel, not usefulness. :P
16:44:53 <oklopol> is that some kinda sh-language?
16:44:58 <ehird> oklopol: zsh
16:45:10 <ehird> PS1&precmd is the hideous baby sublanguage
16:45:14 <ehird> but I use command interpolation there too
16:45:19 <ehird> so i can print out colours
16:45:31 <oklopol> i should learn more languages.
16:46:46 <ehird> I should install SBCL.
16:47:07 <ehird> Where would my system be without a crazy lisp compiler that has tons of hacks to make it portable so you can compile it without a bunch of annoying bootstrapping?
16:47:20 <ehird> And that is really, really fast?
16:47:21 <ehird> Exactly.
16:47:36 <ehird> Ooh ooh, I can get the new Carbon Emacs. Oh wait, I despise emacs.
16:47:45 <ais523> what, I thought you liked it
16:48:04 <ehird> I tolerate it because writing Lisp or Haskell with anything else is painful
16:48:04 <Deewiant> ehird: What does that precmd do?
16:48:16 <ehird> Deewiant: puts "ehird@bournemouth:~/Code" in my titlebar
16:48:19 <Deewiant> ehird: In particular, that print command.
16:48:37 <Deewiant> Where does that print -P go?
16:48:54 * ehird looks for it in zshbuiltins
16:49:14 <ehird> I wrote this in 2007, y'see.
16:49:27 <ehird> -P Perform prompt expansion (see zshmisc(1)).
16:49:37 <ehird> so that's for the %n stuff and suchlike
16:49:43 -!- oklofok has joined.
16:49:51 <Deewiant> Oh, right, I misread
16:49:57 <Deewiant> I was looking at
16:49:57 <Deewiant> -p Print the arguments to the input of the coprocess.
16:50:02 <Deewiant> And was confused
16:50:06 <ehird> I love how the quotes in export PS1=$(print "%{\e[33m%}")"[%n:%~] %#"$(print "%{\e[0m%}")" " start half way through
16:50:15 <ehird> because you can not quote command interpolations, so I didn't
16:50:19 <ehird> can, not
16:50:20 <ehird> not cannot
16:50:27 <ehird> as in you can and you can also opt not to
16:51:49 <ehird> carbbon emacs is from a japanese server and the server is so slooooow
16:52:24 <Deewiant> It's probably fairly fast, it's the wires that're slow :-P
16:53:09 <ehird> fuck wires.
16:53:11 <ehird> I want wireless wires.
16:53:48 <ais523> lasers!
16:54:00 <ehird> yes.
16:54:01 <ehird> lasernet.
16:54:02 -!- oklopol has quit (Read error: 60 (Operation timed out)).
16:54:12 <ehird> not only is it freaking cool, on account of using lasers, it is infinitely fast.
16:54:26 <ehird> because the lasers are actually light. and the computers are -1 miles apart from each other.
16:54:33 <ehird> this is done by bending spacetime.
16:54:34 <ehird> with lasers.
16:56:25 <oklofok> ^ this here sounds very very good.
16:56:56 <Slereah> Lasers aren't infinitely fast, ehird
16:57:04 <ais523> Slereah: they are if they go BACKWARDS!
16:57:06 <ehird> They are if you bend space time, moron.
16:57:17 <Slereah> Still no.
16:57:26 <ehird> They go both backwards _and_ bend space time.
16:57:27 <ehird> NOW WHAT
16:57:41 <Slereah> Still no.
16:57:45 <ehird> Heretic.
16:57:48 <ehird> You're just afraid of new science.
16:57:52 <ehird> Afraid... of WHAT LIES AHEAD.
16:58:05 <oklofok> The Physicist has spoken
16:58:13 <ehird> the physicist is a lameo.
16:58:16 <Slereah> ALL HAIL THE PHYSICIST!
16:58:21 <oklofok> hmm
16:58:21 <Slereah> So is your FACE
16:58:24 <oklofok> what ist should i be
16:58:29 <ehird> we can just bend spacetime so that lasers shoot out lasers that are infinitely fast.
16:58:30 <ehird> trivial
16:58:31 <oklofok> my face is hmm?
16:59:54 <Slereah> It sure is
17:00:33 <ehird> % git init
17:00:33 <ehird> zsh: command not found: git
17:00:36 <ehird> DSHJSDFkJShdfkjsdhfkjsdfhsdf WHAAAAAAT
17:00:37 <ehird> ;_;
17:00:45 <ais523> yay for working package managers
17:00:54 <ehird> my package manager works fine
17:00:57 <ehird> I just haven't installed git
17:01:22 <ehird> i was just assuming this computer was absolutely perfect out of the box
17:01:26 <ehird> because I mean why wouldn't it be
17:03:22 <ehird> emacs is 145mb that's just not right.
17:03:27 <ehird> an editor has no right to be that big :|
17:09:31 <ehird> Too many things depend on other things.
17:10:42 -!- Slereah has left (?).
17:10:52 -!- Slereah has joined.
17:13:27 <ehird> oklofok: will oklotalk handle the euler identity?
17:13:46 <ais523> ehird: Mathematica's probably got a command for solving the euler identity, by the way
17:14:04 <ehird> ais523: I tried doing N[(equation here)] but it just made e and pi into numbers
17:14:05 <ais523> you have to use things like Reduce[] or Solve[] or that sort of thing to manipulate expressions into different forms
17:14:14 <ais523> N is just a numerical approximator
17:14:23 <ehird> right, so it should numerically approximate the euler identity
17:14:24 <ais523> you need a symbolic manipulator to solve that identity
17:14:31 <ehird> ah.
17:14:35 <ehird> mathematica is weird ass
17:14:37 <ais523> because Mathematica operators don't do more than they're designed to do
17:15:40 -!- oerjan has quit ("Noise unbearable").
17:15:50 <ehird> my noise? :<
17:16:07 <oklofok> ehird: dunno. i'm a fairly discrete dude.
17:16:16 <ehird> is discrete your middle name.
17:16:36 <oklofok> oklopol discrete ominovorol
17:16:41 <oklofok> is my full name
17:16:52 <ehird> you lie
17:16:52 <ehird> [17:16:45] oklofok has userhost n=nnscript@a91-153-121-248.elisa-laajakaista.fi and realname Ville Salo
17:17:21 <oklofok> that's my slave name
17:18:03 <ehird> wtffff
17:18:06 <ehird> git relies on gettext
17:18:09 <ehird> whyy
17:18:13 <ehird> I don't care if it's indirect, just ugh
17:18:17 <ais523> internationalisation, obviously
17:18:23 <ehird> git is english only
17:18:28 <ais523> can't be by now
17:18:29 <ais523> surely
17:18:42 <ehird> umm, most version control systems and the like only output in english
17:18:43 <ehird> as far as I know
17:18:46 <ais523> anything let anywhere near a major OSS repo tends to get translated
17:19:04 <oklofok> actually that name is just gibberish i sometimes use to confuse people; you see this one student organization requires real names to be real names, so i made up a finnish-sounding name.
17:19:31 <ehird> ais523: IMO it doesn't make sense to translate a vcs
17:19:41 <ehird> you need to know english to program in most languages
17:19:47 <ehird> yes, you can rote memorize a few keywords as meaningless
17:19:53 <ehird> but you can do that with your VCS's terminology, too
17:20:09 <ehird> e.g. Python's style guide strongly suggests that comments are in english
17:20:11 <ais523> hmm... maybe git depends on gnu coreutils?
17:20:17 <ais523> it's very heavily sh-based
17:20:21 <ais523> it may need specific utils
17:20:30 <ehird> we'll see if macports tries to install gnu coreutils
17:20:37 <ehird> (I hope not, though... I like my BSD userland)
17:20:56 <ais523> LC_ALL=fr_FR.utf8 cp --help outputs in French for me; LC_ALL=fr_FR.utf8 git --help doesn't
17:21:11 <ais523> "Copier la SOURCE vers la DESTINATION, ou de multiples SOURCES vers un RÉPERTOIRE."
17:21:19 <ehird> % LC_ALL=fr_FR.utf8 cp --help
17:21:20 <ehird> cp: illegal option -- -
17:21:20 <ehird> usage: cp [-R [-H | -L | -P]] [-fi | -n] [-pvX] source_file target_file
17:21:20 <ehird> cp [-R [-H | -L | -P]] [-fi | -n] [-pvX] source_file ... target_directory
17:21:47 <ais523> $ LC_ALL=fr_FR.utf8 gcc --help
17:21:49 <ais523> Usage: gcc [options] fichier...
17:22:03 <ehird> % LC_ALL=fr_FR.utf8 gcc --help
17:22:03 <ehird> Usage: i686-apple-darwin9-gcc-4.0.1 [options] file...
17:22:03 <ehird> Options:
17:22:03 <ehird> -pass-exit-codes Exit with highest error code from a phase
17:22:05 <ais523> so gcc, at least, needs gettext, or at least can use it
17:22:10 <ehird> I guess Apple stripped out the translation files
17:22:24 <ais523> I like having multiple languages available
17:22:34 <ais523> you never know when you might want to give a guest account to someone chinese, for instance
17:24:00 <ehird> I beg of you:
17:24:00 <ehird> do not give this email address out
17:24:00 <ehird> do not CC me on any public mailing list with this address
17:24:00 <ehird> do not place this address in cleartext on any web page
17:24:12 <ehird> I am so tempted to type it in here and let clog and Google be the perps, not me...
17:24:19 <ais523> that's giving it out
17:24:34 <ehird> ah, it's already on the interwebs it seems
17:24:36 <Deewiant> Where'd you see that
17:24:42 <ehird> http://www.nightmare.com/~rushing/new_email.html
17:24:43 <oklofok> i don't get the spammophobes, who doesn't like spam
17:24:49 <ehird> As a service to the blind, this address reads:
17:24:52 <ehird> sam@rushing.nightmare.com
17:25:34 <Deewiant> I don't get people who get hundreds of spam messages a day
17:25:38 <Deewiant> How can that happen :-P
17:25:52 <ehird> I get hundreds of spams a day, but I never see them apart from 1 or 2 every once in a while
17:25:54 <ehird> thx gmail
17:25:56 <oklofok> i just get the ones i've requested
17:26:03 <ehird> Deewiant: register for a load of sites willy-nilly
17:26:07 <oklofok> (a seer, and some advertisement)
17:26:09 <ehird> also, post it on the interwebs in plain text regularly
17:26:13 <Deewiant> ehird: I have
17:26:13 <ehird> ----------------------> SPAM
17:26:24 <ehird> well I get more like 30 spams a day
17:26:24 <ehird> still
17:26:25 <Deewiant> I've done both hundreds of times :-P
17:26:29 <ehird> if i was more popular i'd get hundreds
17:26:30 <Deewiant> And I get less than 10 per day
17:26:54 <Deewiant> Maybe my ISP just blocks known spam senders and that's where the bulk comes from
17:27:50 <ehird> gmail has, to my knowledge, never blocked a legitimate mail, and let through less than 50 spams to my inbox since 2006 when I got this account
17:27:57 <ehird> it's one great spamfilter
17:28:00 <Deewiant> gmail has blocked several legitimate mails to my account
17:28:07 <Deewiant> some bugzilla posts and some private mail
17:28:14 <ehird> Deewiant: stop purchasing viagra
17:28:38 <Deewiant> If I purchased viagra wouldn't that mean that it stops blocking viagra, rather than that it blocks something else? :-P
17:28:47 <ehird> "private mail"
17:29:02 <ehird> y'see, I was implying the nature of that private mail. as a bad joke.
17:29:04 <oklofok> Deewiant: umm probably it'd block the viagra
17:29:10 <ehird> thank you oklofok
17:29:13 <Deewiant> ehird: ah, right, didn't get it.
17:29:20 <oklofok> to get is to see
17:30:19 <ehird> man that's one big slipup:
17:30:44 * ehird upload
17:30:48 <Deewiant> Anyhoo, that's one reason why I'd like gmail to /not/ block spam
17:30:58 <ehird> Deewiant: you can tell it not to
17:31:00 <Deewiant> Since now I'm never sure whether it's blocked something it shouldn't have
17:31:07 <Deewiant> ehird: Well, that's new
17:31:11 <ehird> Settings->Filters->Create
17:31:16 <ehird> Has the words: [in:spam ]
17:31:17 <Deewiant> 1, 2, or 3 years ago you couldn't :-P
17:31:18 <ehird> click past the warning
17:31:32 <ehird> i'm sure you can figure it out from there
17:31:42 <FireFly> I've had 6 spam mails the last 3 days, not too bad...
17:32:11 <ehird> meh, it isn't uploading
17:32:14 <Deewiant> ehird: Actually I can't. "[in:spam ]"?
17:32:21 <ehird> Deewiant: [ ... ] = textbox
17:32:31 <ehird> so type in: in:spam
17:32:47 <Deewiant> There are five text boxes
17:32:52 <Deewiant> And besides, it says
17:32:53 <Deewiant> Messages in Spam and Trash will not be searched.
17:33:22 <ehird> [17:31:15] <ehird> Has the words: [in:spam ]
17:33:23 <ehird> Has the words.
17:33:33 <ehird> Also, ignore it.
17:33:43 <Deewiant> You really should consider putting subjects and verbs in your sentences :-P
17:33:51 <ehird> :<
17:33:52 <Deewiant> Is that space relevant
17:33:56 <ehird> no
17:35:06 <Deewiant> Hm, can I forward all my existing spam somehow
17:35:30 <ehird> don't forward
17:35:33 <ehird> ok, i'll be more specific
17:35:45 <ehird> tick never send it to spam, then click "Also apply to ..."
17:35:47 <ehird> create
17:35:49 <ehird> watch spam flood into inbox
17:36:26 <Deewiant> Note: filter will not be applied to old conversations in Spam or Trash
17:36:41 <ais523> why not just read the spam folder/
17:36:48 <Sgeo> Select: All
17:36:57 <ehird> yeah what sgeo said
17:36:59 <ehird> for existing ones
17:37:00 <Deewiant> Besides, I do want it in the Spam folder, I just want to forward it to my 'real' address
17:37:01 <Sgeo> Select all $num conversations in Spam
17:37:05 <ehird> Deewiant: oh
17:37:07 <ehird> then do this:
17:37:15 <ehird> in:spam
17:37:23 <ehird> Forward it to: [... your address ...]
17:37:26 <ehird> [ ] Also apply
17:37:26 <Deewiant> I can select all but I don't see a 'forward' button
17:37:30 <Deewiant> ehird: yes, I did that
17:37:37 <ehird> did it not work?
17:37:38 <ehird> ok, then:
17:37:47 <Deewiant> Also apply filter to 0 conversations below.
17:37:55 <ehird> then your spam is empty
17:38:02 <Deewiant> There are 499 messages there
17:38:14 <ehird> screenshot your filter criteria page
17:38:34 <Deewiant> [in:spam] in "Has the words", all else blank
17:38:42 <ehird> ok, click test search
17:38:46 <ehird> does it show all your spam
17:38:49 <Deewiant>
17:38:49 <Deewiant> No existing messages match your criteria.
17:38:55 <ehird> is this the new gmail
17:38:58 <ehird> or the older one
17:39:00 <Deewiant> Is it so hard to believe "Messages in Spam and Trash will not be searched."
17:39:04 <Deewiant> I don't know
17:39:06 <ehird> yes, because I have a filter with in:spam
17:39:07 <ehird> and it works
17:39:13 <Deewiant> I've used this approximately never
17:39:19 <ehird> Deewiant: do the inbox, starred etc links have a semi-large indent in front of them
17:39:20 <Deewiant> I just get everything over POP
17:39:21 <ehird> if so, it's the new one
17:39:31 <Deewiant> indent as compared to?
17:39:38 <ehird> the labels box
17:39:57 <Deewiant> Yeah, there's about 2 or 3 em there
17:40:11 <ehird> ok, then it's the new one
17:40:13 <ehird> I have this filter:
17:40:15 <ehird> Matches in:spam
17:40:16 <ehird> Mark as read
17:40:17 <ehird> and it works fine
17:40:28 <ehird> so I'm confuzzled
17:40:29 <Deewiant> Right, there's a link to "Older version" at the top
17:40:33 <ehird> yeah
17:40:59 <Deewiant> ehird: that space was relevant
17:41:01 <Deewiant> dammit
17:41:08 <ehird> oh
17:41:11 <ehird> you can't have a space
17:41:13 <ehird> ofc
17:41:15 <ehird> i thought you meant
17:41:16 <Deewiant> erm
17:41:17 <Deewiant> I mean
17:41:18 <ehird> should I put the space in
17:41:19 <Deewiant> the space is necessary
17:41:22 <ehird> WTF
17:41:24 <Deewiant> [in:spam] doesn't work
17:41:27 <Deewiant> [in:spam ] works
17:41:29 <ehird> not [in:spam]
17:41:31 <ehird> in:spam
17:41:38 <Deewiant> gah
17:41:39 <Deewiant> dammit
17:41:41 <ehird> [ ] was just to represent the browser's text box
17:41:43 <ehird> I told you this
17:41:50 <Deewiant> Speak English :-P
17:41:54 <ehird> :D
17:42:15 <Deewiant> hoo, 1200 conversations of spam coming my mway
17:42:19 <Deewiant> s/mw/w/
17:42:40 <ehird> it's like a ROLLERCOASTER of SPAM
17:42:45 <Deewiant> Or then not?
17:43:00 <Deewiant> Either there's a delay or it's not sending them
17:43:01 <ehird> Deewiant: what's your gmail? I'll send you a test spam to see if it's working
17:43:06 <Deewiant> ehird: deewiant@
17:43:43 <ehird> Spam sent
17:43:59 <ehird> note: make sure it's in spam folder in your gmail, as well as being forwarded...
17:44:16 <Deewiant> neither yet
17:46:03 <Deewiant> ehird: Wasn't flagged as spam :-D
17:46:12 <ehird> haha
17:46:16 * ehird gets a real spam from spam folder
17:46:22 <Deewiant> Came into my inbox and thunderbird grabbed it from there
17:46:24 <ehird> viagra spammers should just... write normally
17:46:28 <ehird> they wouldn't be blocked.
17:46:38 <Deewiant> Thunderbird didn't flag it as spam either FWIW
17:46:49 <ehird> spam forwarded
17:48:08 <Deewiant> gmail spam, wasn't forwarded to me though
17:48:23 <ehird> in the filters pane, what does it say?
17:48:59 <Deewiant> The following filters are applied to all incoming mail: Matches: in:spam Do this: Forward to ...
17:49:36 <ehird> :s
17:49:53 <ehird> Deewiant: try also ticking "never mark as spam"
17:49:57 <ehird> in the do this
17:50:31 <Deewiant> Send another then
17:50:37 <ehird> Deewiant: btw if you use imap the spam is sent as a folder
17:50:38 <Deewiant> (Again refused to do anything with the old ones)
17:50:45 <Deewiant> Yeah but I use POP
17:50:49 <ehird> then don't ;D
17:50:56 <ehird> Spam forwarded
17:53:24 <Deewiant> Still not received
17:54:22 <ehird> Switch to IMAP
17:54:23 <ehird> :|
17:54:34 <Deewiant> Wouldn't help for receiving the mail :-P
17:54:55 <ehird> sure it would
17:55:03 <ehird> I meant use IMAP directly on gmail
17:55:04 <ehird> :P
17:55:38 <Deewiant> my gmail got hit with some authentic japanese spam though, and that was forwarded correctly \o/
17:55:46 <ehird> :D
17:55:50 <ehird> still in the spam folder
17:55:50 <ehird> ?
17:55:51 <ehird> if so, great
17:55:56 <Deewiant> No, it's not
17:55:56 <ehird> enjoy your useless ibox
17:55:58 <ehird> inbox
17:56:00 <ehird> Deewiant: o
17:56:07 <Deewiant> Because you told me to set "don't mark as spam" :-P
17:56:18 <ehird> oh well duh
17:56:18 <ehird> :P
17:56:22 <Deewiant> Now it comes to both my gmail and non-gmail inboxes
17:56:25 <Deewiant> That's somewhat suboptimal
17:56:38 <ehird> you can fix that
17:56:44 <Deewiant> Forsooth
17:56:53 <ehird> tick "Delete it"
17:56:55 <ehird> on the action
17:56:58 <ehird> it'll forward it, then delete it
17:57:15 <Deewiant> Rather, I'll not forward it and just grab it from the inbox
17:57:28 <Deewiant> Easier :-P
17:57:38 <ehird> That also doth work
17:57:42 <Deewiant> ehird: Now tell me how I can select all spam and forward it
17:57:56 <Deewiant> Rather, I can do the former, but I don't know how to do the latter
17:57:58 <ehird> Write a script that connects via imap, reads all spams, and forwards them
17:58:00 <ehird> :P
17:58:10 <Deewiant> GMail has no 'forward' button?
17:59:15 <ehird> Sure it does
17:59:18 <ehird> But it's message specific
17:59:28 <Deewiant> POS
17:59:33 <ehird> Deewiant: I know!
17:59:34 <ehird> Select al lof them
17:59:35 <ehird> click not spam
17:59:38 <ehird> hopefully, it'll forward
17:59:40 <Deewiant> Can't do it
17:59:48 <ehird> why not
17:59:48 <Deewiant> The "not spam" button is helpfully disabled after I select all
18:00:02 <ehird> deselect one
18:00:02 <Deewiant> Because I might press it accidentally or something, I guess.
18:00:11 <ehird> then do that one manually
18:00:36 <Deewiant> Deselecting one deselects all pages that I don't see as well
18:00:44 <Deewiant> I'd have to do each page manually
18:00:49 <ehird> wrong
18:00:52 <ehird> hmm
18:00:54 <ehird> right
18:00:56 <ehird> Deewiant: no, you can do it
18:01:00 <ehird> star the top one
18:01:02 <ehird> select: starred
18:01:04 <ehird> err
18:01:05 <ehird> unstarred
18:01:22 <Deewiant> Still selects only the first page
18:01:31 <ehird> Deewiant: do a search for
18:01:33 <ehird> in:spam
18:01:34 <ehird> select all
18:01:37 <ehird> move to inbox
18:01:57 <Deewiant> Ooh, now I got your spam btw :-P
18:04:07 <Deewiant> ehird: Can I search for 'not-in:inbox' with some syntax
18:04:34 <ehird> search options->
18:04:35 <ehird> doesn't have->
18:04:37 <ehird> in:inbox
18:04:43 <Deewiant> Bloody GUIs
18:04:44 <ehird> ->
18:04:46 <ehird> -{in:inbox}
18:04:50 <ehird> so you can just use -{search terms}
18:07:40 * ehird writes gmailbackup.py
18:08:43 <Deewiant> Moving to inbox via the search worked
18:08:49 <ehird> woot
18:09:32 <Deewiant> And thunderbird is moving dozens to "Sent" because from = to = deewiant@ :-P
18:09:48 <Deewiant> And haha, it can only get 252 at a time
18:09:51 <Deewiant> POP limitation I guess
18:10:47 <ehird> lol
18:11:31 <AnMaster> Deewiant, what is this about?
18:11:48 <AnMaster> gmailbackup?
18:11:49 <AnMaster> heh?
18:11:58 <Deewiant> AnMaster: stopping gmail from stopping spam
18:12:05 <AnMaster> Deewiant, oh?
18:12:13 <AnMaster> it stopped non-spam?
18:12:25 <ehird> read the bloody conversation
18:12:29 <ehird> like the rest of us
18:13:20 <AnMaster> well I was just heading to bed anyway, since I have a bad cold, can hardly speak currently...
18:13:22 <Deewiant> Hmm, I think something failed and I only got around 200/500 spam
18:13:24 <AnMaster> so night
18:13:26 <Deewiant> Oh well, whatever
18:13:28 <AnMaster> may read the convo later
18:13:58 <Deewiant> Aha! There is one non-spam message here
18:14:06 <Deewiant> "MSN Groups Service Change"
18:14:12 <ehird> that's spam to me :D
18:14:30 <Deewiant> I like to archive crap like that even if I'm not interested
18:14:48 <Deewiant> Since it's actually authentic mail to me from a provider of a service I use or used
18:14:56 <Deewiant> As opposed to 100% junk.
18:15:03 <ehird> hmm
18:15:10 <ehird> do you think I should back up messages to maildir or mbox
18:15:29 <ehird> maildir seems kinda pointless for what I'm doing and mbox is more supported, but I dislike mbox's one-honking-big-fil
18:15:29 <ehird> e
18:15:52 <Deewiant> Use the Mozilla version of mbox, not supported by pretty much anything right? :-P
18:16:23 <Deewiant> Welp, my junk filter just got 80 messages of training data
18:16:26 <Deewiant> I guess that's good
18:16:30 <Sgeo> Bye for now all
18:16:41 <ehird> I don't really want to invent my own format, see.
18:16:45 <ehird> Since that's not very useful.
18:16:53 -!- Sgeo has quit ("Leaving").
18:17:13 <Deewiant> Haha
18:17:15 <Deewiant> ehird: http://en.wikipedia.org/wiki/Mbox#Limitations
18:17:19 <Deewiant> See the second paragraph
18:17:39 <ehird> er, I knew that? :s
18:17:41 <Deewiant> http://en.wikipedia.org/w/index.php?title=Mbox&diff=267734082&oldid=251122842 :-D
18:17:59 <ehird> that's the third paragraph yo
18:18:05 <Deewiant> no, the second
18:18:14 <Deewiant> Limitations -- title
18:18:19 <Deewiant> mbox stores... -- paragraph one
18:18:23 <ehird> o
18:18:24 <ehird> tru
18:18:25 <Deewiant> The maildir... -- paragraph two
18:19:12 <ehird> mailbox and mbox don't handle folders though
18:19:16 <ehird> err
18:19:16 <ehird> maildir
18:19:20 <ehird> maildir++ does, but it's ugly
18:20:32 <Deewiant> You are currently using 1 MB (0%) of your 7294 MB.
18:20:44 <ehird> You are currently using 751MB (10%) of your 7294MB.
18:20:46 <Deewiant> Hmm, now where's that coming from
18:21:09 <ehird> :<, the only thing Mail.app can import is mbox and various propietary shit, + mozilla
18:21:16 <Deewiant> Aha, there's still something in "All Mail"
18:22:20 <ehird> Mayhaps I will output to both maildir AND mbox
18:22:22 <ehird> configurable
18:22:44 <Deewiant> You are currently using 0 MB (0%) of your 7294 MB.
18:22:44 <Deewiant> Yay
18:28:10 <Deewiant> 939 344 002 bytes of mail here
18:33:58 <ehird> hmm
18:34:10 <ehird> problem with mbox:
18:34:14 <ehird> no folder support :<
18:34:33 <ehird> even folder support isn't that good tbh, since gmail's labels can be all over the place
18:34:56 -!- kwufo has quit ("Leaving.").
18:37:28 <Deewiant> ehird: So what's wrong with maildir++
18:37:47 <ehird> Well, maildir requires me putting hostnames in the generated filenames and really that's just ridiculous
18:37:52 <ehird> also it's not really suited to just dumping
18:37:58 <ehird> I'll probably just dump to multiple mboxes
18:38:01 <ehird> irritating though that is
18:39:50 <ehird> >>> imap.list()
18:40:00 <ehird> ('OK', ['(\\HasNoChildren) "/" "Agora"', '(\\HasNoChildren) "/" "B Nomic"', '(\\HasNoChildren) "/" "INBOX"', '(\\HasNoChildren) "/" "Nomicron"', '(\\Noselect \\HasChildren) "/" "[Google Mail]"', '(\\HasNoChildren) "/" "[Google Mail]/All Mail"', '(\\HasNoChildren) "/" "[Google Mail]/Bin"', '(\\HasNoChildren) "/" "[Google Mail]/Drafts"', '(\\HasNoChildren) "/" "[Google Mail]/Sent Mail"', '(\\HasNoChildren) "/" "[Google Mail]/Spam"', '(\\HasNoChildren) "/" "[Goog
18:40:11 <ehird> imap i s the worst thing evar
18:40:21 <Deewiant> :-P
18:41:23 -!- ais523 has quit (Remote closed the connection).
18:52:13 <ehird> Deewiant: does thunderbird handle maildir?
18:52:40 <Deewiant> "Handle"?
18:52:51 <ehird> can it import it
18:52:51 <ehird> [('1234464706.M732275P80012Q1.bournemouth', <rfc822.Message instance at 0x26a2b0>), ('.DS_Store', <rfc822.Message instance at 0x26a300>)]
18:52:55 -!- Corun has joined.
18:52:57 <ehird> fucking OS X and it's fucking hidden files. :|
18:53:22 <Deewiant> I don't know
18:54:39 <Deewiant> I'm currently in Windows where it tells me it can import mail from "Communicator 4.x", "Eudora", "Outlook", "Outlook Express"
18:54:52 <ehird> but not mbox or maildir? o_O
18:55:25 <fizzie> I've imported mbox format with Windows thunderbird, but I think it was more like "copy the mbox here and hope for the best". Maybe.
18:58:49 <fizzie> This Debian Thunderbird (rebranded Icedove) only has "Communicator 4.x" in the "Tools/Import/Mail" wizzard, but the interweb says that I can just put mbox folders under the "Local Folders" storage-place and they'll appear.
18:59:02 <fizzie> Maildir it probably doesn't do.
18:59:21 -!- kar8nga has joined.
19:00:24 <fizzie> There's a lot of command-line mbox/maildir/pop/imap/stuff-handling tools, though.
19:01:33 <Deewiant> http://yergler.net/projects/one-off/maildir-to-mbox/
19:01:43 <fizzie> GNU mailutils has that "movemail" tool that can do conversions, and "capable of speaking POP3, IMAP, mbox, MH and Maildir". And the Pine people had one, too.
19:05:18 <fizzie> Yes, the "uw-mailutils" package has the "mailutil" tool, which is pretty much a frontend to that c-client library of theirs. It does at least IMAP, POP3 and NNTP on the network side, I don't know what local formats. That mailutil I've used in one migration, anyway.
19:08:12 <fizzie> The driver names are "unix", "mbox", "mmdf", "mbx", "tenex", "mtx", "mh", "news" (it's a local news-spool) and "phile" (single-file thing), so I guess it's pretty comprehensive as far as mailboxy formats go, but not maildirry.
19:12:30 -!- olsner has joined.
19:19:50 <ehird> there should be an mbox variant with a header like
19:19:51 <ehird> Folder: ...
19:19:55 <ehird> >:(
19:20:43 <ehird> (\Noselect \HasChildren) "/" "[Google Mail]"
19:20:47 <ehird> i should totally not have to parse that
19:29:00 <ehird> #!/usr/bin/perl
19:29:00 <ehird> sub c{($_=pop)<0?print substr"/,'\\)(`\n |_.",$_+12,1:c(vec(vec
19:29:00 <ehird> ('<;JK;::::B:::Tshu[FoatcN[LL;DWQ?cJ?=ghTsXqWqwhqgT@CUMGlgTpRd'.
19:29:01 <ehird> 'KhI_wgTp`lpGOYs>quHWthuhUbuhuh[hu@TguhMGWulXsWiiekwhqwhqwxh@q'.
19:29:01 <ehird> 'uXaWGhqqOmqwxhtXiThf:::[:::::Jb?cB_duWI[ZLN[DNqWIObTsPGuUoTDU'.
19:29:03 <ehird> 'oOqWac@sMSUDUMGlWoNp`lXsXeWqc`XquXqW=WqJeW=gpGnWqi[Pu@TgiVeNm'.
19:29:11 <ehird> 'qSQwWwWwWGpSQ]wWonhTTQ]ufeWonhTboEi=::ZQGke`E',$a/6,8)-58>>$a++
19:29:12 <ehird> %6&1?'HGJSTFIXOZ[':'QLRKMUVWYPN',$_,8)-82)}c 10 while$a<1728
19:30:04 <ehird> Perl, Ruby & Python quine:
19:30:11 <ehird> #!/usr/bin/env python
19:30:14 <ehird> print 'Hello, world!\n'
19:30:23 <ehird> err
19:30:26 <ehird> s/quine/polyglot/
19:30:31 <ehird> with perl, it actually executes python :-D
19:30:43 <Deewiant> print "Just another", ((0 and " Ruby ") or ("Pyt" + "hon" or " Perl ")), "hacker.\n",
19:30:46 <Deewiant> ""
19:31:07 <ehird> brilliant
19:31:14 <ehird> but in python it outputs an extraneous space+newline
19:31:48 <Deewiant> Should be no extra newline
19:31:51 <Deewiant> That's what the "" is for
19:32:27 <ehird> try it fo yourself
19:32:34 <ehird> it goes \n, space, \n
19:32:36 <ehird> because of the ""
19:32:58 <Deewiant> I did try and no extra newline :-P
19:33:40 <Deewiant> File generated by running that ends in 0D 0A.
19:33:57 <fizzie> As long as "" is on another line, of course.
19:34:03 <ehird> >>> print "Just another", ((0 and " Ruby ") or ("Pyt" + "hon" or " Perl ")), "hacker.\n",""
19:34:03 <ehird> Just another Python hacker.
19:34:03 <ehird> >>>
19:34:06 <ehird> err
19:34:10 <ehird> >>> print "Just another", ((0 and " Ruby ") or ("Pyt" + "hon" or " Perl ")), "hacker.\n",""
19:34:12 <fizzie> Yes, well, it's two lines.
19:34:13 <ehird> Just another Python hacker.
19:34:14 <ehird> BLANK LINE HERE
19:34:15 <ehird> >>>
19:34:17 <Deewiant> ehird: You fail.
19:34:21 <Deewiant> ehird: "" on another line.
19:34:21 <ehird> Thanks.
19:34:27 <ehird> Yes.
19:34:28 <ehird> And?
19:34:30 <ehird> That's a bug.
19:34:34 <ehird> The others output 1 line.
19:34:46 <fizzie> We mean that in the source you put the "" part on another line.
19:34:51 <fizzie> Then it doesn't print out an extra line.
19:35:05 <fizzie> >>> print "Just another", ((0 and " Ruby ") or ("Pyt" + "hon" or " Perl ")), "hacker.\n",
19:35:09 <fizzie> Just another Python hacker.
19:35:11 <fizzie> >>> ""
19:35:14 <fizzie> ''
19:35:28 <fizzie> And the extra empty string there does not produce any output.
19:35:58 <ehird> oh.
19:36:53 <lament> print "" stops working in python3k
19:37:06 <ehird> that's easily fixable
19:37:08 <ehird> just put parens in
19:38:10 <fizzie> Did they remove the automatic-newline for print() in Python 3k too? I don't remember.
19:38:37 <ehird> dunno
19:38:39 <ehird> hmm
19:39:17 <ehird> I wonder if mbox importers check for sent
19:39:22 <ehird> e.g. folders named Sent
19:39:31 <ehird> and such
19:40:38 <fizzie> Oh, the 3.0 print() function has an extra optional parameter 'end' denoting the ending text.
19:42:36 <ehird> doesn't help for polyglotism
19:45:00 <ehird> http://torvalds-family.blogspot.com/2009/02/25-things-about-me.html
19:45:43 <ehird> written in base 0.04, i assume
19:51:50 <ehird> wtf you can only do one mailbox at a time in imap.
20:13:17 <ehird> grr
20:13:25 <ehird> All Mail is irritating
20:13:52 <ehird> because it's hard to avoid duplicate messages
20:18:06 -!- Hiato has quit ("Leaving.").
20:22:52 <ehird> http://gqwl.wordpress.com/2009/02/12/making-valentines-day-special-with-haskell-and-brainfuck/
20:23:04 <ehird> itt: paintfuck
20:23:21 -!- Metcalf has joined.
20:23:30 <Metcalf> Hi :-)
20:23:42 <ehird> hi
20:24:01 <Metcalf> Hi Ehird, I was wondering where you are
20:24:14 <ehird> oh right, I updated my system
20:24:16 <ehird> so new irc client config
20:24:21 <Metcalf> :-)
20:57:33 -!- MigoMipo has quit (Connection timed out).
21:15:47 -!- Corun has quit ("Leaving").
21:20:40 -!- Metcalf has quit ("mov.i #1,1").
21:49:09 <oklofok> o
21:49:14 <oklofok> ^ o is a letter.
21:49:55 <ehird> Python(80380) malloc: *** mmap(size=2281472) failed (error code=12)
21:49:56 <ehird> *** error: can't allocate region
21:49:56 <ehird> *** set a breakpoint in malloc_error_break to debug
21:49:57 <ehird> WTF
21:50:04 <ehird> thas not rite
21:54:22 <MizardX> Heh. 2.2 gig :P
21:54:34 <ehird> yeah it's downloading an email
21:54:38 <ehird> I don't have any 2.2gig emails
21:57:25 <olsner> um, doesn't that say 2.2 meg?
21:57:40 <olsner> or is it saying 4.8 gig in pages?
21:57:42 <ehird> oh, right
21:57:43 <ehird> 2.2 meg
21:57:44 <MizardX> ... oh
21:57:44 <ehird> yep
21:57:46 <ehird> the email is just 2mb
21:57:48 <ehird> o wtf
21:57:49 <ehird> so wtf
21:57:50 <fizzie> At least the mmap syscall is bytes.
21:57:52 <ehird> i'm streaming it to a file
21:57:56 <ehird> wonder if I could optimize that?
21:58:01 <ehird> i.e., have it not go through a string...
21:58:05 <ehird> (imap yo)
21:58:17 <olsner> optimized transfer of 2MB ... should be a waste of time!
21:59:09 -!- Corun has joined.
21:59:54 <fizzie> And that's a rather small allocation. Although you can get ENOMEM (12) by exceeding the maximum number of mappings, too.
22:00:24 <ehird> Mm.
22:00:27 <ehird> I
22:00:28 -!- GreaseMonkey has joined.
22:00:31 <ehird> 'm not sure why it's doing this.
22:00:44 <ehird> A tiny backtrace snippet from the end:
22:00:44 <ehird> File "/System/Library/Frameworks/Python.framework/Versions/2.5/lib/python2.5/imaplib.py", line 948, in _get_response
22:00:45 <ehird> data = self.read(size)
22:00:45 <ehird> File "/System/Library/Frameworks/Python.framework/Versions/2.5/lib/python2.5/imaplib.py", line 1150, in read
22:00:46 <ehird> data = self.sslobj.read(size-read)
22:00:47 <ehird> MemoryError
22:00:49 <ehird> Odd indeed.
22:02:41 <MizardX> try gc.collect()
22:03:28 <ehird> What, every single mail message? It may balk out at message 10 but I'm downloading tensathousandsa messages here...
22:03:52 <ehird> I'll give it a try though
22:03:55 <ehird> Nope
22:03:56 <ehird> same error
22:07:50 <MizardX> http://mail.python.org/pipermail/python-list/2008-January/474035.html
22:08:20 <ehird> wow, gmail too
22:08:24 <ehird> it's like we're al lthe same <3
22:08:32 <ehird> "In a worst case scenario, you'll need some 13 gigabytes of
22:08:32 <ehird> virtual memory to read a 15 megabyte message..."
22:08:34 <ehird> holy fuck nuggets
22:08:43 <ehird> worst library EVER
22:08:59 <MizardX> http://bugs.python.org/issue1389051
22:09:03 <ehird> yep
22:10:16 <ehird> well, it's been over a year
22:10:18 <ehird> and no fix
22:10:18 <ehird> :(
22:12:44 -!- kar8nga has left (?).
22:13:57 <ehird> O
22:14:00 <ehird> I'll just use libgmail
22:14:00 <ehird> :-)
22:16:53 <ehird> libgmail is prolly really slow though
22:17:06 <ehird> as it screen-scrapes, eww
22:18:08 <fizzie> There were a couple of workaround-attempts in those two bugs (1389051 and 1092502).
22:18:54 <ehird> I don't wanna edit the core socket.py
22:19:59 <MizardX> make a copy of socket.py in your project dir
22:20:25 <ehird> hmm mayb
22:20:25 <ehird> e
22:23:23 -!- KingOfKarlsruhe has quit (Remote closed the connection).
22:34:11 <ehird> libgmail is just too slow
22:35:07 <ehird> # String method conversion by ESR, February 2001.
22:35:08 <ehird> x_x
22:37:41 <MizardX> http://en.wikipedia.org/wiki/ZISC
22:37:51 <ehird> heh
22:45:11 <ehird> "The following are SGI specific, and may be out of touch with the current version of reality.
22:45:11 <ehird> "
22:48:09 -!- Corun has quit ("This computer has gone to sleep").
23:01:04 <ehird> Hooray, backup-gmail version 0.00000001pre-pre-alpha works.
23:03:42 * GregorR doubts highly that ZISCs are TC :P
23:03:54 <ehird> why?
23:04:08 <GregorR> Because non-looping neural networks aren't.
23:04:17 <GregorR> And looping neural networks are generally uncomputable in bounded time.
23:05:11 * lament computes GregorR's brain
23:05:18 <lament> only took me a second!
23:16:05 -!- BeholdMyGlory has quit (Read error: 104 (Connection reset by peer)).
23:26:50 * ehird just stopped 2,000 windows from opening
23:27:11 <FireFly> 2000 windows?
23:27:16 <FireFly> Or Windows 2000?
23:27:19 <FireFly> That's the question
23:27:54 <FireFly> Alright, anyways, how come? Why was 2 000 windows about to open?
23:29:07 <ehird> FireFly: I highlighted 2000 files then double clicked
23:29:14 <FireFly> Ah
←2009-02-11 2009-02-12 2009-02-13→ ↑2009 ↑all