6.2.11 released! | pugs.blogs.com | pugscode.org | pugs.kwiki.org | paste: sial.org/pbot/perl6 | < audreyt> my fingers juxpatosed
Set by nothingmuch on 24 February 2006.
ayrnieu sigh, I'm lame. 04:21
ayrnieu forgets his feather password.
Khisanth samuel: are you planning on staying or what? 04:33
TimToady putter: it would be relatively easy to make a patch to disable interpolation (except for \\) on regexen. Would that help? 05:43
gaal bsb, lumi: ping 05:53
gaal pizza saturday, my place 05:54
jisom is there currently any intention of allowing inlined pir/pasm in perl 6? 06:09
gaal jisom: eval $pir, :lang<parrot> should work 06:35
$work &
jisom right now I think compiling ghc stalled the computer building ghc...might have to force it to restart....should also say that the memory requirements for building ghc are excessive instead of just "it's slow" 06:36
GeJ morning folks 06:48
draconit_ boker
morning
dduncan I think that effing multiple commit is going to happen again ... 06:57
svnbot6 r9230 | Darren_Duncan++ | r2625@darren-duncans-power-mac-g4: darrenduncan | 2006-02-23 16:48:45 -0800
r9230 | Darren_Duncan++ | ext/Rosetta/ : small changes to resync with new 0.721.0 CPAN release
dduncan yep, there it is
dduncan god, and I don't think that's the only one, either 06:58
svnbot6 r9231 | Darren_Duncan++ | r2646@darren-duncans-power-mac-g4: darrenduncan | 2006-02-24 01:11:26 -0800
r9231 | Darren_Duncan++ | ext/Rosetta/ : incremented main module versions following CPAN release, fixed format bugs in Language.pod
dduncan f*ck
stupid svk 06:59
yet another ...
svnbot6 r9232 | Darren_Duncan++ | r2671@darren-duncans-power-mac-g4: darrenduncan | 2006-02-25 01:39:44 -0800 07:01
r9232 | Darren_Duncan++ | ext/Rosetta/ : added new module Rosetta::Shell, an interactive command shell over Rosetta, to make casual use/try-outs/dev/testing easier
r9233 | Darren_Duncan++ | r2730@darren-duncans-power-mac-g4: darrenduncan | 2006-03-01 22:54:27 -0800
r9233 | Darren_Duncan++ | ext/Rosetta/ : added new file examples/shell.p6, updated Shell.pm and Model.pm
dduncan okay, actually that one was correct 07:02
r9233 is correct, 32 and 31 are dups
and 30 is a dup 07:03
xinming flooding? 07:22
buu So 07:26
buu How are roles different from multiple inheritance? 07:27
audreyt greetings 07:37
<- about to take taxi to German Perl Workshop 07:38
Kattana Hallo o/
audreyt the airline (Austrian/Lufthansa) lost all baggage
they are still trying to 1)find it and 2)send it to hotel
hence I'm without most of my stuff :/
buu: roles are flattened, so you don't ever have to call super()
buu: also, if two roles provides the same methods to a class that mixes them in, that's a compile time error rather than runtime breakage 07:39
buu So what happens if one role provides a method another role does?
heh
audreyt conflict
;)
audreyt okay, bbl in ~30min if the workshop has wireless 07:40
&
ayrnieu irssi: /ignore samuel JOINS PARTS 07:56
gaal audreyt! 07:59
nothingmuch hola 09:01
gaal hey nothingmuch
nothingmuch read the first SYB paper 09:05
how does it replace the threading of inherited/synthesized attrs in AGs?
it's like having just synthesized ones
and while impressive, it's completely orthogonal =) 09:06
azuroth curses UML 09:07
gaal I've no idea--am not familiar with AGs--where did you see it claimed that it did? 09:09
nothingmuch everyone said that SYB is >= AGs 09:10
mooseness 09:24
ayrnieu ?eval { my $bal = 0; sub deposit { $bal += @_[0]; $bal } sub withdraw { if ($bal - @_[0] < 0) { "Sorry, you only have a balance of \\$bal" } else { $bal -= @_[0]; $bal } } } [deposit(250), withdraw(5), withdraw(5), withdraw(100), withdraw(200)] 09:29
evalbot_9233 [undef, undef, undef, undef, sub {...}]
azuroth dare I question that? 09:31
ayrnieu ah, oops.
?eval { my $bal = 0; sub deposit { $bal += @_[0]; $bal } sub withdraw { if ($bal - @_[0] < 0) { "Sorry, you only have a balance of \$bal" } else { $bal -= @_[0]; $bal } } }; [deposit(250), withdraw(5), withdraw(5), withdraw(100), withdraw(200)] 09:32
evalbot_9233 [250, 245, 240, 140, "Sorry, you only have a balance of \$bal"]
ayrnieu oops again :-) azuroth - sure, why not?
azuroth ohh, it was.. trying to subscript the scope..?
for fear of being laughed at ;-) 09:33
ayrnieu if you're already afraid of being laughed at, and in no danger of contracting this fear through trauma... 09:36
would you mind rewriting what I just wrote where $bal is an object with .deposit and .withdraw methods? :-) 09:37
azuroth I can try...
?eval class Account { has $:bal; method deposit(Int $amt) { $:bal += $amt }; method withdraw(Int $amt) { if ($bal - $amt < 0) {"Sorry, $bal"} else {$bal -= $amt} } } 09:39
evalbot_9233 Error: unexpected ":" expecting "$!"
azuroth nah, I've no idea 09:43
ayrnieu ah well, someone who has one will surely come along. 09:46
curiously, though, why did you say Int $amt ?
azuroth good point; s/Int/Num/ 09:47
or did you mean why prototype at all? 09:48
ayrnieu no, just why the Int 09:49
rafl searches for an easy but practical example of rules. 10:02
I'd like to mention them in my Perl 6 talk on GPW, but I think I would need 40 minutes only to explain them. 10:03
Unfortunately the whole talk needs to fit into 40 minutes.
ayrnieu ?eval class Account { has $.bal; method deposit (Num $amt) { $.bal += $amt; $?SELF }; method withdraw (Num $amt) { $.bal < $amt and return "Sorry, you've only \$$.bal"; $.bal -= $amt; $?SELF } }; my $act = ::Account.new.deposit(250); [map { $act.withdraw($_); $act.bal } <5 5 100 200>] 10:14
evalbot_9233 [245.0, 240.0, 140.0, 140.0]
ayrnieu bias towards returning $self^W$?SELF , meet wall. 10:15
?eval class Account { has $.bal; method deposit (Num $amt) { $.bal += $amt }; method withdraw (Num $amt) { $.bal < $amt and return "Sorry, you've only \$$.bal"; $.bal -= $amt } }; my $act = ::Account.new.deposit(250); [map { $act.withdraw($_) } <5 5 100 200>]
evalbot_9233 Error: No such method in class Int: "&withdraw"
ayrnieu ?eval class Account { has $.bal; method deposit (Num $amt) { $.bal += $amt }; method withdraw (Num $amt) { $.bal < $amt and return "Sorry, you've only \$$.bal"; $.bal -= $amt } }; my $act = ::Account.new; $act.deposit(250); [map { $act.withdraw($_) } <5 5 100 200>] # :-( 10:16
evalbot_9233 [245.0, 240.0, 140.0, "Sorry, you\'ve only \$140"]
jp-autark can you defined your own "Num" type, say to be all numbers >= 0? 10:17
define 10:18
ayrnieu doesn't know. 10:19
azuroth I think so - somehow
ayrnieu class Num { has $.bal = 1_000_000 }; 5.bal
?eval class Num { has $.bal = 1_000_000 }; 5.bal
evalbot_9233 Error: unexpected "=" expecting trait, "handles", ";" or "}" 10:20
lypanov hey clkao 10:24
ayrnieu ?eval class Num { has $.bal is rw }; my $n = ::Num.new; [$n, $n.foo = 10, $n.foo, $n.foo = 5, $n.foo] 10:25
evalbot_9233 Error: No such method in class Num: "&foo"
ayrnieu ?eval class Num { has $.foo is rw }; my $n = ::Num.new; [$n, $n.foo = 10, $n.foo, $n.foo = 5, $n.foo]
evalbot_9233 [Num.new(("foo" => 5),), 10, 10, 5, 5]
azuroth ?eval my subset PosNum of Num where {$^x >= 0}; my PosNum $a = 5; 10:28
evalbot_9233 Error: unexpected "P" expecting variable name or "(" 10:29
azuroth ?eval my subset PosNum of Num where {$^x >= 0}; my $a = PosNum.new(5);
evalbot_9233 Error: unexpected "P" expecting variable name or "("
azuroth ?eval my subset PosNum of Num where {$^x >= 0}; my $a = ::PosNum.new(5);
evalbot_9233 Error: unexpected "P" expecting variable name or "("
azuroth ?eval my Num subset PosNum where {$^x >= 0}; my $a = ::PosNum.new(5); 10:30
evalbot_9233 Error: unexpected "s" expecting variable name or "("
azuroth oh well
ayrnieu there are no subtype tests in Pugs, currently. Want to write a test? 10:34
oops, they are in data_types/ 10:36
somehow, my grepping failed me.
actually, Perl6::Bible's S12.pod just seems out of date. The tests indicate that it's called 'subtype', now. 10:37
azuroth hmm. I'd be inclined to go with the synopses rather than the tests? :x 10:38
ayrnieu (still not implemented)
ayrnieu (I mean, the not-implementedness of subtype continues the perceived likely not-implementedness of subset.) 10:40
azuroth true 10:41
ayrnieu but, yes, it looks like I could just use a lexical subtype for ::Account :-) 10:44
where I could make type errors out of <=0 10:45
azuroth interesting indeed 10:47
I'm learning about derivatives of graphs. I really wish I'd done some proper maths 10:48
ayrnieu ?eval multi rev () {}; multi rev (*$a, *@r) { (rev(@r), $a) }; rev 1..5 10:55
evalbot_9233 (\5, \4, \3, \2, \1)
ayrnieu ?eval, (5,4)
evalbot_9233 Error: unexpected "," expecting program
ayrnieu ?eval (5,4) 10:56
evalbot_9233 (5, 4)
svnbot6 r9234 | juerd++ | Committing my Perl 6 Myths talk 11:06
rafl audreyt: Nice talk 11:16
nothingmuch jabbot: seen audreyt? 11:22
jabbot nothingmuch: audreyt was seen 3 hours 41 minutes 51 seconds ago
nothingmuch arf
just missed her then =)
=(
lypanov 01:57 < audreyt> [00:40] okay, bbl in ~30min if the workshop has wireless
now == 04:22 11:23
so at a guess, workshop didn't have wireless
nothingmuch lypanov: Juerd seemed to have access
Juerd Audrey can't get the vpn to work 11:24
nothingmuch i just got retro-spam
spam dated for 2005
oh
Juerd We exchange my lightening talk on a usb stick :) 11:25
nothingmuch מוס! 11:35
nothingmuch Juerd: send my regards to balas if she's at the workshop 11:36
Juerd I haven't seen balas 11:37
svnbot6 r9235 | juerd++ | Audrey's changes: present tense, blank lines, a new slide, a better "Perl 6 is not Perl" slide
lypanov umm 11:38
nothingmuch In that case, please don't try to greet her under any circumstance
lypanov that reminds me. stupid question... but
nothingmuch there's no point in trying to do it if she's not there!
lypanov why did perl6 keep $/%/@ ?
ntgrl lypanov++
Juerd lypanov: Because they're useful. 11:39
nothingmuch lypanov: they help disambiguate things
for example &sub is the value
but sub is a call
this allows us to not need to say sub() all the time
lypanov & understand 11:40
but $ % and @?
nothingmuch it also helps reading
lypanov & makes perfect sense, i'm a ruby oldie and have to agree
nothingmuch they're not *really* necessary
lypanov is it still possible to use a % instead of a $ and make the code just /not work/?
nothingmuch but:a
Juerd lypanov: Of course.
nothingmuch a. it doesn't really fudge
i mean, it's not a hindrance of any sort 11:41
lumi nothingmuch: ping
nothingmuch b. it helps readability
lumi Well, not ping
nothingmuch c. it is perlish
lypanov but it requires you to think about it while you are coding more...
nothingmuch lumi: gnip?
lypanov its the reason i don't use perl...
Juerd lypanov: They're *ugly*, but ugly isn't a reason to have or not have something.
nothingmuch i like having to think while i code
lypanov this is kind of sad :(
Juerd lypanov: They're useful and make many things easier.
nothingmuch ;-)
lypanov nothingmuch: i don't
nothingmuch: my test cases do my thinking
nothingmuch actually i sort of agree
eek
that's not a good enough approahc
thinking is required 11:42
Juerd lypanov: Every feature, every character, everything, in programming, requires thinking. If you are unable to think, or don't like to think, programming is not for you.
nothingmuch at least at some level
lypanov nothingmuch: somedays i'm tired
nothingmuch thinking about *language tax* is not
ntgrl you could also ask why we have % and @, instead of just having all containers as objects in $ vars
nothingmuch but
sigils help when reading
lypanov ntgrl: exactly
nothingmuch lack of sigils help with writing
Juerd ntgrl: You can have that if you want.
ntgrl it's easy to think that functions are special to warrant a sigil
lypanov sigils just confuse...
ntgrl Juerd: yeah, you just have to become world president first to force everyone else to do it too =)
Juerd ntgrl: Forcing people has never been Perlish. 11:43
ntgrl Juerd: okay, how do I write perl code *without* being forced to use sigils? :-P
lypanov okay. lets put it another way
is slice syntax still utterly fucked or does it Just Work these days? 11:44
ntgrl it was utterly fucked? (for something other than hash references...)
lypanov ntgrl: i mean for hash refs
sorry should have said that
nothingmuch perl 6 slicing for hashes is OK now 11:45
i think
lypanov does perl6 still have this weird concept of refs vs non refs?
nothingmuch that's a weird concept?
ntgrl my question is: why separate sigils for hashes and arrays? why not just: my @array is vector; my @array is hash; my @array is btree; ?
lypanov: curiously I wouldn't have said that was weird :-/
nothingmuch ntgrl: again, it's a cultural issue more than anything 11:46
perl programmers are more important to Perl 6's design than ruby programmers
in terms of "feeling at home"
lypanov i can code both, well
ntgrl maybe, but I can understand that you can slice an @ or a %, but you can't slice a $, so there's *two* categories there, not the three
lypanov doesn't remove the fact that it is very difficult to change perl code when compared to changing ruby code 11:47
nothingmuch the main diff is that arrays are ordered, hashes aren't
and that implies that some things make sense with one thing implicitly
but have to be explicit otherwise
ntgrl like?
lypanov umm *thinks*
wolverian refs can't be sliced? 11:48
nothingmuch (iteration, splicing, poping, pushing)
refs can be sliced today
ntgrl we cope with "key", "values" and "each" already
wolverian: well you're slicing the container pointed at by the ref... but I'm needlessly pedantic
nothingmuch ntgrl: it DWIMs in perl 6
lypanov nothingmuch: okay. maybe the main reason for my hate is the difficult with finding a variables type, and added to that the insane syntax that is needed in many cases
nothingmuch $array_ref[...];
lypanov but it sure sounds like the syntax has been fixed 11:49
nothingmuch define finding a variable's type
the value class?
ntgrl but it's still slicing the pointed at thing, not the scalar
nothingmuch or the container implementation?
ntgrl: true, sigils are not as neeeded in perl 6 as they were in perl 5 11:50
due to more "automatic" behavior WRT reference
auto dereferencing
auto enreferencing
ntgrl sure, but that doesn't change what's being sliced!
nothingmuch but we still distinguish between list and scalar context
and listy things are @ish
and @ish things behave in a listy way 11:51
like automatically concatenating
etc
again, this is more of a cultural issue
lypanov i'll have to just try it, its all about feel
if i dislike it i'll try and come up with tests and point out how it can be improved
nothingmuch you can probably hack a weird glue layer over the grammar that makes any term an rvlaue
not just sigiled stuff
sure
that's always welcome
lypanov nothingmuch: i think its stupid so say "this is cultural issue"
s/so/to/ 11:52
nothingmuch but since Perl 5 programmers feel at home with this, i doubt it's going to change a lot
lypanov nothingmuch: you can surely make it less of a cultural issue and improve it for others
nothingmuch well, show me how it isn't
most of Perl 6's target audience irrationally thinks that sigils are important
lypanov print Dumper in perl5 doesn't work generically
nor does ref(blah) always work
nothingmuch (just read all the crap P6 has been getting for changing -> to .
the first should be fixable in perl 6 11:53
the second will not
because not everything is a ref
lypanov there is thusly in some (read, many) cases when its simply impossible to find out how you are meant to use a methods returned value
without good documentation (*cough*)
or reading the entire damn source
nothingmuch okay
lypanov this is fixed somehow?
nothingmuch you mean returning an array ref instead of a list for "performance" reasons?
lypanov for example, yes
nothingmuch okay
that behaves better now 11:54
because things coerce more nicely
but frankly, i couldn't care less
this is a low level issue
the reason I want Perl 6 is because of high level things
for example, all the idiots that diss python for using significant whitespace are just white noise to me
it's just syntax 11:55
if the semantics are good enough, than who cares
(i like haskell, and it parses almost like python, but i wasn't very impressed with python... guess why?)
ntgrl lack of overriding the whitespace convention?
nothingmuch ? 11:56
Perl 6's approach to this is: here's a default, the underlyingg API lets you change that
ntgrl you can do: do { f; g } in haskell, so whitespace convention is entirely optional
nothingmuch if you want 'use Syntax::Ruby' i don't think it'll mind
not just for do
also for where
and let
they have significant whitespace
azuroth why weren't you impressed though, nm? 11:57
nothingmuch and nobody uses do { f; g }, that's ugly ;-)
because python has this sort of uninspiredness about it
ntgrl sure, that's because it's defined as a single way to convert {;} <-> whitespace
nothingmuch it is as simple as it can ever be, and getting simpler
read: dumber
azuroth hmm. I think I feel the same way about PHP
a similar way, at least
nothingmuch there is lots of stuff to sto pthe user from being inspired
php is an attrocity
the only think i liked about php was that open returns a file handle, instead of accepting an uninitialized one as a param 11:58
but now we have lexically scoped handles in perl 5 so it doesn't matter
anyway, this discussion is really going nowhere 11:59
bottom line is:
sigils won't go
it's not my fault
lypanov not saying it is 12:00
gaal I am! of course it's nothingmuch's fault
lypanov just feel its very short sighted to not attempt to address these issues while "you" still can
its audreyt's fault. as always ;)
lypanov no longer likes the direction ruby is heading in
lypanov is most impressed by perl6 and pypy
lypanov hates python
so what is my option? ;) 12:01
"fix" perl6...
nothingmuch why don't you like it?
lypanov perl6 or the direction of ruby?
nothingmuch (ruby)
lypanov ah
there are a number of syntax changes that i dislike heavily, feel they are huge regressions
nothingmuch like?
lypanov nothingmuch: can't think of specifics, its a feeling 12:02
nothingmuch syntax can be anything as long as it isn't taxing
Perl 5's syntax for OO and FP is hard
lypanov syntax effects me a lot, if it doesn't look pretty then i really don't want to work with it :)
nothingmuch because it's easier to misbehave than to do the right thing
okay
let's try a few things in ext
lypanov and python made me just want to cry
nothingmuch i feel that most of the code i've written in Perl 6 is very beauutiful compared to what I can dish out in Perl 5
lypanov (first time i had an indentation related bug i ran screaming) 12:03
nothingmuch svn.openfoundry.org/pugs/ext/
lypanov most of the code i've written in perl6 is cute
s/writ/seen &/
nothingmuch write some then =)
lypanov waiting on the arrival of a new machine
nothingmuch something that really made me happy was Class::Event 12:04
and another thing that was very fun was Getopt::Process
Perl 5 really lacked the umph to make these feel dense and meaningful
wolverian Class::Event? 12:05
nothingmuch oh! collect_arguments should be lexical to parse_arguments
wolverian: yes
it's not in ext
wolverian ah. 12:06
nothingmuch because it makes very very heavy use of roles and mmds
wolverian is the module name in Getopt::Process a typo btw?
(module Getopt::Proccesor)
wolverian imagines it could be a namespace clash too
nothingmuch yes, i think it is ;-)
Migo wanted to rename it anyway
to Getopt::Engine
svnbot6 r9236 | gaal++ | r9257@sike: roo | 2006-03-02 14:01:55 +0200 12:07
r9236 | gaal++ | Minor edits to Peek talk. Online version updated.
nothingmuch svn.openfoundry.org/pugs/ext/
sorry
damn clipboard
svn.openfoundry.org/pugs/misc/Class.../Events.pm
wolverian those are long lines 12:09
anatoly ugh, I don't know :(
looks too javaish to my taste
nothingmuch anatoly: interfaces?
gaal yo tolymoose
anatoly interfaces and the general verbosity
method get_subscriptions (Class::Events::Publisher $publisher, Class::Publisher::Event $event) 12:10
this is not a line I will enjoy writing out
perl5 almost never has lines I don't enjoy writing out
yo gaal
gaal: what time at your place saturday?
lumi Yo gaal
nothingmuch anatoly: err, you don't need to =)
get_subscriptions( $thing, $event );
but that's internal, isn't it? 12:11
and interfaces suck
roles are nice because they can actually contain behavior
anatoly nothingmuch: what do you mean I don't need to? When I use the role? Sure, not the point though.
nothingmuch oh, yhou mean how iwrote it? 12:12
you can shorten the class names
and you can not annotate the types if you don't want to
but i have the über power of completion on my side
anatoly by the way, if I'm in A::B::C::D, why do I have to write A::B::C::E and not some kind of ::..E or whatever?
nothingmuch yes, there's something like that
i just don't remember how to write that
anatoly ah, ok :)
nothingmuch also, please look at the code within 12:13
lumi Package names are globally scoped, right?
nothingmuch the idea of Class::Event's numerous roles is that you can milk performance but also get flexibility
lumi Like Java and not like Python
nothingmuch lumi: not necessarily
you can have lexical ones too
they default to global though
gaal anatoly: not sure about time yet 12:14
there may be a jazz gig i want to go to afterwards :)
nothingmuch gaal: which one? 12:15
gaal Third World Love
anatoly gaal: well moose me or something, I'm in Rishon over weekend. 12:16
gaal great, will do
nothingmuch when is it?
gaal trying to check 12:17
hmm, 21:30 but it's w/o daniel friedman who I really like 12:18
nothingmuch what date? 12:19
saturday?
gaal yeah. next thu, 9/3, he will be there.
www.hagada.org.il/hagada/html/modul...&pid=7
nothingmuch whatever happenned to luqui =( 12:23
sisi what else is new? :) 12:50
sisi . o O 12:53
Arathorn everything old is new again. 13:00
elmex is stitting on the GPW 13:07
Juerd ntgrl: Write your own grammar, that is sigilless. 13:10
nothingmuch no, just derive a grammar 13:11
== less repeating yourself
integral except that sigils are stored in the pads, so I have to magic them out of somewhere... 13:11
Juerd ntgrl: This is a matter of changing the syntax for "my", and alike declaration keywords, and having them install lvalue subs.
nothingmuch: Same difference.
nothingmuch integral: what ntgrl wants is to have just scalars
sisi Ah..."everything changed"
Juerd sisi: No
integral nothingmuch: sort of, More like bound values like in haskell really 13:12
but maybe not *sigh*
sisi Juerd: oh? :)
integral ntgrl ::= integral
Juerd integral: Hey, don't fool us into thinking you're some kind of newbie ;)
elmex is there a syntax freeze in perl6 ? 13:14
Juerd No
sisi "No means no"?
Juerd sees audreyt read and edit a talk. Impressive, that speed of reading and typing. 13:15
elmex when is a syntax freeze going to happen? when is the final perl6 interpreter going to be written?
Juerd elmex: Probably not even then. Why do you ask?
nothingmuch elmex: christmas
Juerd elmex: Do you want a freeze?
lypanov Juerd: have to admit i'd love to be there just to see that :)
Juerd Someone's whistling here. Very annoying during a talk.
lypanov: Why? Don't you think that if something isn't perfect, and someone has something *better*, we should use the better thing? 13:16
lypanov: Don't you think that if ambiguous cases are found, clashing syntax is found, we should be able to fix the problem?
I think a syntax freeze before the release is a bad idea.
Eh, s/before/long before/
rafl: Don't forget to diff the usb stick against your local old copy. 13:17
elmex ok, then, when will there be a release of the final perl6 compiler (which targets parrot)?
lypanov Juerd: sorry. "Juerd sees audreyt read and edit a talk. Impressive, that speed of reading and typing."
Juerd elmex: Christmas
lypanov: Ahhh, okay.
lypanov: Sorry for my misinterpretation.
lypanov i don't believe there is ever any such thing as a "final interpreter"
and nor do i believe in syntax freezes
;)
rafl Juerd: I won't. 13:18
Juerd elmex: Perl 5 has known a syntax freeze for very long; it hasn't benefitted from that.
elmex: In fact, it pushed innovations like // far, far away.
We still don't have it, while the feature itself has been wished for for over a decade.
(Originally it was written "??", hookhook.)
lypanov rationals or comments?
oh. i have no idea then? :) 13:19
i like the ?? !! syntax btw
Juerd So do I.
elmex ah, ok, so there will be finally the real perl6 interpreter.... why took it so long? :)
lypanov elmex: its Hard (tm)
Juerd elmex: It's hard to create something that hasn't existed ever before.
fglock audreyt: re packing iterator_engine to CPAN: how about "Perl6::Grammar", and reuse Parse::RecDescent API? 13:20
elmex yes, it is, i agree. but that doesn't explain why the interpreter hasn't been started earlier
Juerd elmex: There is no programming language that has all these new features
elmex Juerd: perl5 has at least a part of it
Juerd elmex: Yes, but we're not trying to re-create Perl 5. Perl 5 already exists, it doesn't need to be created. 13:21
lypanov and its not possible to easily add to perl5 13:22
Juerd elmex: Perl 5 has many neat features, but Perl 6 has more. They cannot be integrated into Perl 5, because Perl 5 is very hard to maintain because (lack of) its internal structure.
elmex yes... Perl6 isn't Perl anymore
rgs and backward compatibility constraints
Juerd Also, for a better Perl, we need *fundamental* changes in syntax. 13:23
lypanov perl sucks. yay for perl6! :P
elmex yes, maybe
Juerd elmex: It depends on your definition of Perl. It still looks and feels like Perl.
elmex: Do you think that Larry Wall's view on the definition of Perl isn't authoritive?
elmex Juerd: yes, but it is not the successor of Perl5
rgs some would say it even smells like perl.
Juerd He thinks the definition *includes* Perl 6.
elmex Juerd: no, i don't think that larrys view is the end of all wisdom
Juerd rgs: Mind if I quote you on that in my lightening talk? :)
rgs heh
nothingmuch elmex: look at my compiling perl 6 ttalk 13:24
Juerd elmex: But he created both Perl 5 and 6.
rgs and the previous ones too.
lypanov and patch!
elmex Juerd: Perl6 was created by the comunity
lypanov elmex: perl6 was defined by larry
nothingmuch nothingmuch.woobling.org/perl6_comp...start.html
note that images willl load very slowly
lypanov and implemented / refined by the community
nothingmuch and only then will S5 kick in
Juerd elmex: Nah, the community will *write* it :)
elmex lypanov: there were RFC's
Juerd elmex: Larry is this ship's captain
elmex Juerd: the ship is traveling very long now.... 13:25
svnbot6 r9237 | fglock++ | iterator_engine - added a talk sketch
nothingmuch elmex: don't take it as "larry is not open to suggestions"
Juerd elmex: Indeed.
nothingmuch in fact, i wasted about 4-5 hours of larry's time just in the OSDC/Hackathon
he is a very good listener 13:26
lypanov elmex: /win 5
elmex thats great
Juerd elmex: However, I think it's good to wait and get something that resembles perfection, instead of rushing things and getting something as horrible as the unreadable as Perl 5's source.
lypanov doh
lypanov kicks irssi
elmex: sorry. ignore that :)
Juerd: i disagree for what its worth
Juerd elmex: It has taken years, and perhaps it will take a few more.
nothingmuch lypanov: you can use esc/meta 13:27
sisi thinks: marriages don't break up on account of infidelity. *^.^*
Juerd elmex: In the meantime, we have Perl 5.
lypanov: Elaborate
lypanov nothingmuch: oh. esc-1 etc is a wonderful idea
elmex Juerd: i've been waiting since 2002, and there is no real spec yet. the synopsis are imho very incomplete and many things are only documented on the mailing list
lypanov nothingmuch: thanks :)
lypanov elmex: the spec == the test cases 13:27
elmex Juerd: yes, but Perl6 does block improvements in Perl5 imho
Juerd elmex: Audrey et all are working on that. Don't expect things to change extremely quickly.
nothingmuch elmex: well, we're not going to scrap it 13:28
elmex lypanov: great, so i have to crawl through thousand lines of test-code to learn perl6 ?
nothingmuch this is a volunteer thing
Juerd elmex: Different people work on Pelr 5.
nothingmuch nobody tells anyone to work on this and not that
or vice versa
lypanov elmex: you learn from a spec?!
Juerd elmex: Perl 6 doesn't block Perl 5 development, it actually improves it at times.
rgs right !
Juerd Perl 5 learns from Perl 6, and gets some of its features.
rgs like //, switch, ~~, say
elmex lypanov: yes, partially. i learn mainly from having an interpreter and then i look at the spec and try out
lypanov elmex: pugs runs now
nothingmuch // is lovely 13:29
elmex ok
lypanov ?eval 5
evalbot_9236 5
lypanov elmex: ^^ see? :P
elmex perl -e 'print 5' 13:30
# 5
lypanov: see? :)
lypanov no... not really
elmex lypanov: yes, me too
lypanov elmex: pugs (one impl of perl6), runs now
elmex: and there is a partial constantly updating spec. and testcases
i also have to admit i'd like a more compact version of the spec 13:31
is one available?
nothingmuch test cases, interpreter, and spec are all complements to each other
none can be good without the other
lypanov the current stuff is verrrry verbose
lypanov doesn't really like reading
nothingmuch lypanov: there's a quick ref
lypanov nothingmuch: ah. neat. uri?
azuroth am I horribly mistaken in thinking fixity is somehow a synonym for associativity?
lypanov or in docs/ ?
nothingmuch lypanov: in docs or something
lypanov nothingmuch: thx. shall check it out 13:32
nothingmuch azuroth: fixity is how manny, where
like, postfix is 'after'
it's always after "one thing"
as with prefix
azuroth ahh, right
nothingmuch circumfix is around any number
infix is between two things
postcircumfix is after, and then around some more stuff
lypanov fixity == arity + associativity?
azuroth damn. is there a short word for assoc?
nothingmuch like [ ] is after @array and around the slice
lypanov: you could say that, yes 13:33
lypanov azuroth: assoc? :P
nothingmuch ass
azuroth uglyyy :-P
lypanov hehe
ummmm ass
elmex it's just scary that Perl5 grow from a evolutionary process out of perl1 to perl4 and was mainly done by Larry. Perl6 seems to throw away most things from Perl5 and introduce very many new untested concepts in a very short time and throws away the old codebase 13:35
rgs nope, it doesn't 13:36
Juerd rgs: How does one pronounce your name?
lypanov elmex: its not a bad thing go occasionally throw away the codebase...
rgs translators will happen !
Juerd: I don't know. Spanishish ?
Arathorn elmex: sounds exciting rather than scary to me :) 13:37
Juerd rgs: I can't guess the last part, Suarez
rgs Juerd: "aar - gee - ess" ?
Juerd Does that sound like swahres?
rgs Juerd: soo a ress
Juerd Ah, thank you
rgs yes
azuroth spanishish... sounds an interesting - oil of spaniards? 13:38
Juerd elmex: What do you mean "untested"? 13:38
rgs even *I* pronounce my name differently depending on contexts
elmex imho the perl5 people should improve the old perl5 interpreter a little bit more and just bump the version to perl6
Juerd elmex: Larry *is* actively improving (refactoring) Perl 5!
elmex: Nicholas Clark will integrate his changes back into the main Perl 5.
elmex: This all helps migration to Perl 6. 13:39
elmex Juerd: many concepts were invented before there was Pugs and some concepts aren't implemented yet
Juerd elmex: Indeed.
elmex: Your point, please?
elmex Juerd: good question
Juerd Also, isn't every invention at first untested?
rgs aren't the specs written before the implementation ? :)
lypanov Juerd: i think the point is depth vs breadth wise implementation
Juerd Like, ehm, pseudohashes? Restricted hashes? Formats? All those other things we don't use, but are implemented in Perl 5? 13:40
lypanov Juerd: and afaic there is slightly too much depth in perl6
s/ic/ics/
elmex yes, but wouldn't it be better if all these new concepts were integrated in perl5 from the beginning? then they could've been tested when they came up
Juerd elmex: It's hard for me to understand what you want. A few moments ago, you complained that there was no complete specification, but now you say things should be tested first.
rgs no, because perl 5 needs to be mostly backwards compatible
Juerd elmex: Can you explain how these go together?
lypanov elmex: perl5 is very difficult to extend 13:41
Juerd lypanov: There might be. The Plan is to do it Right.
lypanov elmex: if what you did was the case, it would take /even longer/
s/did/said/
Juerd (See how the uppercase words make things really cute in English, while they just don't even look weird in German? :))
lypanov Juerd: hehe
elmex lypanov: i don't think it would have taken 6 years to have // in perl5 or a 'class' keyword... 13:42
lypanov elmex: the perl6 spec is a lot more than jusrt that
s/rt/t/
rgs // is in perl 5 right now
Juerd Because they capitalize every Noun, you cannot use uppercase Letters to indicate something that is cutely official.
elmex lypanov: yes, the perl6 spec is a big blob
Juerd elmex: You don't NEED those in Perl 5.
elmex rgs: yes, after 6 years 13:43
lypanov when did pugs start?
lypanov is sure it wasn't six years ago
rgs one year ago
Juerd elmex: Why write "class Foo { }" instead of "{ package Foo; }" if they mean exactly the same thing?
The point is that it does something *different* in Perl 6.
lypanov doesn't really care about parrot all that much as he deems it doomed
Juerd lypanov: One year and one month ago.
lypanov right
its come very far 13:44
rgs jumps off the troll train
lypanov good idea
bbl
elmex maybe the only thing that bugs me is that Perl6 is not Perl5+1
lypanov everyone hates change, but its pretty much inevitable 13:45
lypanov personally hates lack of change
azuroth parrot is doomed?
lypanov azuroth: yeah
elmex i don't hate change. perl6 has many great features.
nothingmuch parrot has had lots of management issues
and I think parrot has been prematurely optimized in ways that are not generally useful enough
azuroth hmm, ok
nothingmuch but that doesn't mean it's doomed
people are still participating and helping 13:46
nothingmuch is not so quick to mark it off as a dead thing
rgs it's merely resting !!
lypanov nothingmuch: its slow. and pretty much pointless
azuroth :-)
nothingmuch rgs: when *I* made that joke i was beaten up 13:47
rgs runs and hides 13:47
lypanov ;)
nothingmuch rgs: you're supposed to give lypanov a voucher for your brother's fish store instead
and instead of running off and hiding, running off to become a lumberjack 13:48
lumi Pet store, surely?
nothingmuch i thiink it was more specialized but can't remember.... googling 13:48
lypanov que? :P
lumi His brother's pet store in Bolton
nothingmuch ah 13:49
lypanov: www.mtholyoke.edu/~ebarnes/python/d...parrot.htm
lypanov ummm
lypanov sucks at quotes
gaal lypanov: I wouldn't say it's slow:
# www.nntp.perl.org/group/perl.perl6....nals/32958
lypanov lumi: second you said "bolton" i knew something was going on ;)
gaal: ackermans makes no difference in the real world 13:50
gaal: real world optimisations == high level things such as malloc coaslescing
gaal: sorry but parrot is just bullshit
i agree entirely with nothingmuch in "in ways that are not generally useful enough" 13:51
and yes. its true, i can not spell coacleslssing
Juerd Hm, would it be safe to mention that I put my talk in the Pugs repository? ;)
lypanov flames Juerd
Juerd (It might be construed as "If you really don't like my talk, go ahead, and change it")
nothingmuch lypanov: did yyou see the perl 6 compilation talk?
Juerd Ah well. We'll see.
nothingmuch i'm very very concerned with Perl 6 being fast 13:52
and most of the ways I want to make sure it's fast have nothing to do with parrot
lypanov nothingmuch: no. any urls?
nothingmuch nothingmuch.woobling.org/perl6_comp...start.html
images will load slowly
lypanov reads
nothingmuch but when they're done S5 will kick in
lypanov k
ummmfunkycheese 13:53
elmex yaho, audrey is having her talk now
Juerd Visual Basic Rocks. 13:54
elmex yes
azuroth for real?
Juerd gwbasic++
:)
lypanov lol
Juerd # Audrey
# Larry
# me
rafl # me 13:55
Juerd gwbasic++ then
elmex elmex--
Juerd # toothpaste
lypanov Juerd: how come? ;)
anatoly gwbasic doesn't really ++
lypanov s5 kicked in! yay!
anatoly but audrey's talk is cute
elmex VB was one of my first languages too 13:56
nothingmuch anatoly: but it seems that vb 9 *does* rock ;-)
anatoly nothingmuch: in a funny way, yes 13:57
Arathorn wonders if audrey's trying to get hired by M$ ;)
anatoly vb is one of those languages which either "no one uses" or "everyone uses" depending on your perspective 13:58
Juerd She already is
;)
Arathorn ah, that makes more sense, then :)
Juerd Not really
But there is another Audrey Tang who is.
anatoly but then again, so is perl, so we shouldn't be snobbish about vb, I guess.
Juerd pugs.blogs.com/audrey/2005/12/the_o...audre.html 13:59
lypanov umm
nothingmuch: s5 is lame
nothingmuch lypanov: i can generate plain spork
i just like working with it better since it's one file instead of N per slide
ughhhhhhhhhhhhhhhhhhhhh 14:00
Juerd audreyt++ # Good speaker
nothingmuch there's a "python rocks, perl sucks, you shouldn't make perl 6 it hurts perl 5" thread on the OSDC list
why do people go that way so easily? 14:01
what point are they fucking trying to prove?
it's so pathetic
webmind nothingmuch, url? :)
nothingmuch webmind: for what?
webmind of the archive?
nothingmuch ah
err
it's not worth it
elmex elmex--
nothingmuch you can google if you like
webmind ok
nothingmuch osdc-discuss is the list
lumi elmex: Keep that up, there'll be nothing left of you
nothingmuch the thread is a subthread of "feedbacks from the conference" 14:02
webmind ok, thanks :)
anatoly nothingmuch: i can't believe you put ninjas and pirates in your talk
nothingmuch starting with a reply by Roman Yakovenko to Dov Levenglick
anatoly: =D
webmind something to fight the boredom ;)
anatoly nothingmuch: you're a psycho! but ++ :)
lypanov nothingmuch: anything but this. is it xul or something? 14:03
svnbot6 r9238 | juerd++ | Some more slides
nothingmuch lypanov: javascript + css
i'll make it plain html 14:04
lypanov nothingmuch: either firefox or s5 is damn lame
nothingmuch: it keeps on reverting to unstyled when i open a new tab
nothingmuch uh
odd
complain to eric s. raymond, he wrote the damn thing
lypanov lol
i just pressed a link
anatoly haha
nothingmuch i must admit i don't optimize for portability when doing that stuff
lypanov and ... dum dum dum. firefox crashed
anatoly that explains a few things
what's the thing that audreyt uses for her talks? use that :) it's also one file 14:05
gaal anatoly: nothingmuch is a DrMcNinja really
lypanov anatoly: only works on firefox. also lame
nothingmuch anatoly: takahashi xul
anatoly lypanov: is not lame
lypanov anatoly: if it runs only on firefox its lame 14:06
nothingmuch: yeah... i could really do with the html version
nothingmuch: ff just died again
anatoly lypanov: anything that lets you write the talk as one text file so easily and fast rocks. bah about firefox, it's for displaying at the conference, who cares.
lypanov anatoly: then don't public the damn things on a public site...
nothingmuch haha
lypanov and why not use powerpoint? 14:07
its /more/ accesible than this shit
nothingmuch i don't have ppt
lypanov sorry. but meh
nothingmuch and s5 is accessible for *me*
anatoly lypanov: because powerpoint blows
nothingmuch again, i was not optimizing for portability
but i *can*
give me 2 mins
anatoly lypanov: powerpoint eats your brain
lypanov nothingmuch: was just bitching at anatoly not you, sorry
anatoly: then buy a mac and use keynote :) 14:08
anatoly lypanov: you have ff already. it crashes at nm's spork but won't at audreyt's takahashi, so what's your problem? :)
lypanov anatoly: i don't have ff on my osx box
nothingmuch lypanov: actually, not spork
s5
spork is just kwid -> slides
and it defaults to plain html
well, kwiki
but we use spork::formatter::kwid nowadays 14:09
lypanov so many funny cute names!
nothingmuch okay
yeah, that's ingy for you
nothingmuch.woobling.org/perl6_comp/slides/
reload that
it's in hotpink
because that's the default
;-)
lypanov yay hot pink!
nothingmuch gaal has a nice scheme for plain spork, but i don't know it 14:10
gaal quite simple really
nothingmuch also, wrt ff/s5 borkedage - it's known
that's why my darcs talk sucked
because i had to use ff unexpectedly
but it didn't crash, it was just very slow
lypanov same thing :)
when i can read 10x faster than my computer can display. i begin to worry ;) 14:11
nothingmuch the old html is in s5.html
gaal for reference:
nothingmuch hehe
gaal banner_bgcolor: lightblue
nothingmuch i use it in safari and it works very well
lypanov okay
nothingmuch so there
=)
lypanov *opens his mac up*
nothingmuch no need
s5 is no longer the default for that URL
lypanov i just got s5 again, maybe cached 14:12
nothingmuch think i'll delete index.html
there is start.html which is plain spork
and s5.html which is s5
lypanov nothingmuch: thx. works absolutely perfectly in safari
nothingmuch =) 14:13
again, i'm optimizing for my comfort as I give the talk
and write it
lypanov nods
azuroth nothingmuch++ # like the slides
nothingmuch if we could have Spork::Keynote i'd be even happier
because Keynote has mad-presenter-skill-toolz
like a timer, and the next slide, and whatnot
but i don't work well with graphical tools for this stuff
just for real graphics 14:14
fglock can I use 'return' inside a BEGIN block? 14:17
nothingmuch fglock: you should be able to, yes
when a begin block is used in rvalue context then it's return value is serialized and reused as a constant 14:18
e.g. 'print BEGIN { localtime }'
although, wait
return might not work
because BEGIN isn't a sub
but i guess that ought to be fixed?
fglock nothingmuch: I read it is a sub
nothingmuch since there is no other possible use for return at begin time, not in a macro?
fglock nothingmuch: I need to eval a string that has a BEGIN block, and I don't want BEGIN to be executed twice 14:19
nothingmuch oh wait, is this perl 5 or perl 6?
fglock it's p6 compiled to p5, so it's p5 14:20
nothingmuch ah 14:20
fglock I need to evaluate a BEGIN block during parse, and then again when executing
nothingmuch in that case I don't think that's specccced
fglock nothingmuch: it works: 14:22
perl -e ' BEGIN { print "begin\n"; return; print "not\n"; } '
nothingmuch yay!
Juerd just had his lightening talk 14:23
And I invited people to come here (just in case there's a big stampede... ;)) 14:24
nothingmuch yay
we need to have a lightning talk about TTH btw
welcome back, Draconit 14:25
Juerd What exactly is TTH?
integral that'd be why it needs a lightning talk :-P
Juerd :)
So what is it? 14:26
Heh, rafl just asked me "What's TTH" :)
So now two people want to know :)
nothingmuch Test::TAP::Harness 14:27
Juerd Ah
nothingmuch basically say:
hi, i'm X
Juerd Different from T::H?
nothingmuch at pugs we have many many unit tests
sorry
Test::TAP::HTMLMatrix
Juerd Ahh
nothingmuch i always confuse the name
find t/
find t/ | wc -l
Juerd Right.
nothingmuch then say:
so we wrote an HTML visualizer
show the lovely output
Juerd I actually did a count yesterday, 35000+ (see my lightening talk, p6myths2.html) 14:28
nothingmuch and have another 2 mins about how to actually run it
Juerd Right
Juerd Get over here, and have it :) 14:28
gaal nothingmuch: I think TimToady just mentioned BEGIN was, in fact, a sub on p6-l just the other day 14:33
or here, or somewhere
Draconit הי לא חשבתי שמישהו בכלל הבחין שנכנסתי לפה 14:34
nothingmuch yay 14:35
Draconit sorry dont know how to say that in english
nothingmuch Draconit: well, we are very sensitive people
and we get a little line saying 'Draconit ..... has joined #perl6' whenever you joined
gaal Juerd: there are another 8-odd k in ext/
Draconit yes, and clorfall too!
sorry for my spelling.. 14:36
kolibrie I did not see TimToady in AUTHORS. Who is he? 14:46
integral you've never met him on perlmonks? 14:47
gaal he's someone who puts moose in his talks. gotta love him!
kolibrie has never been to perlmonks
azuroth I've heard he can write an IRC client in less than ten characters 14:48
gaal kolibrie: look at all his replies here: perlmonks.org/?node=perl+oddities&a...ton=Search
GeJ cat /dev/urandom | perl <-- more than 10 characters 14:49
gaal useless use of cat! 14:50
Juerd rafl: Hm 14:51
GeJ yes... realized that just after typing <Enter>
kolibrie gaal: I still haven't solved the riddle 14:53
Arathorn blames CPM 14:54
where you had to TYPE FOO.DOC | MORE to paginate it
iirc
hence not useless abuse of s/cat/type/
Arathorn mumbles
kolibrie: if you want the riddle spoilt: pugs.blogs.com/pugs/2006/02/hackathonil_12_.html 14:55
kolibrie gaal: by the way, I got a little 'hello world' parsec parser working, but don't think I quite understand the AST definition syntax
Arathorn: thanks 14:56
kolibrie almost wanted to guess that, but knowledge generally serves me better than my guesses 14:57
gaal kolibrie: ooh I need to thank you again BTW because a lot of what we talked about made it into my talk
kolibrie gaal: you're welcome - it was mutually beneficial 14:58
kolibrie gaal: do you have time a little later today to help me comprehend a little more? 14:59
gaal ignoring what AST means for a moment, look at: perlcabal.org/~gaal/peek/slide17b.html#end
how about now? :)
and perlcabal.org/~gaal/peek/slide19.html
kolibrie gaal: have a half hour meeting starting seconds ago 15:00
but after that is fine
gaal ok
Draconit_ i hate gaim 15:03
it is evil
when u r not a geek
anatoly don't use gaim for irc 15:04
it's ok for im i think
azuroth I don't particularly mind it for IRC..
lypanov colloquy!!!!
Draconit_ it has mood swings
lumi Sadly, there's no Colloquy or Adium for [wl]in 15:05
Draconit_ whats colloquy?
azuroth not for win or lin? what is it on, then? 15:06
lumi Mac OS X
Which is a BSD, of course
azuroth oh, heh, whoops
integral irssi is pretty standard for *nix
lypanov admits to being in irssi right now
lumi aol 15:07
integral gaal: you've got a missing return on slide23a before the Syn 15:08
gaal integral: nope, look at the soource 15:09
oh wait no 15:10
you're right
nice catch :)
integral np
gaal that's what I get for rhetorical simplifications (it uses a trivial helper retSyn in the real source) 15:11
integral I wish the source wouldn't use things like retSyn sometimes. With return $ Syn, everybody knows what return does 15:12
gaal it is kind of a trivial function, yes
anyone know what might start making vim look for X all the time? it used to work fine, but now I always need to vim -X to avoid sloooow loads 15:14
fixed
svnbot6 r9239 | gaal++ | r9261@sike: roo | 2006-03-02 17:11:16 +0200 15:15
r9239 | gaal++ | * fix a missing `return`. Reported by integral++.
Juerd rafl: jitcrunch.cafepress.com/jitcrunch.a...bnQvZ2xvYm
gaal yikes
Juerd ;)
xrl.us/j9rm
rafl Juerd: It incomplete 15:16
Juerd Your sentence also incomplete, it verbless.
(Hi, Leo :P) 15:27
:) 15:28
LeTo *g*
Juerd rafl: gather { ...; take $something; ... } 15:30
Where $something is in list context
azuroth gee. he does seem to have broken english. I'd never really noticed, or it's just worse than usual
Juerd @foo = gather { for @numbers { take $_ + rand() } }; 15:31
azuroth: Who be he?
azuroth err, doesn't matter :-)
Juerd I'm sure it doesn't, but I want to know ;) 15:32
azuroth when you said "hi, leo" up there I thought you were referring to leopold, so I backlogged #parrot and noticed he was talking noticably foreign-english 15:34
svnbot6 r9240 | bsmith++ | Factored out the localisation of the environment from ruleBlockBody.
Odin- Juerd: You want to end like the cat?
Juerd Odin-: ...cat? :) 15:36
azuroth: I see :)
Odin- Juerd: Yeah, the one that got killed by curiousity. :) 15:37
rafl Juerd: That was caused by the us_intl layout. 15:37
Juerd Odin-: I'm not curious, I just want to know everything.
rafl: You and your silly umlauts
Sorry, *U*mlauts.
Odin- Juerd: I think one is the definition of the other... :p
Juerd Odin-: Nahhh
Odin- ümläüts! :p
Juerd ?ml??ts? 15:38
rafl Juerd: They are nice to have in german presentations.
Juerd ümläs
Hm
rafl: Disagreed.
kolibrie gaal: so, the 'data' block is very concise. Can we go over that line-by-line
integral argh, why does the pod parser need to call ruleStatementList?! 15:39
Juerd Why is anything that has to do with perl called xxxxXxxxxxxxxXxxxx? 15:40
kolibrie Juerd++
gaal kolibrie: sure 15:41
kolibrie listens 15:42
gaal look at both those slides... Exp is the name for the entire data type, each variant is one of the possible types in an actual box
it's a *little* like inheritance, but not really 15:43
kolibrie so the AST Syn 'if' matches the line: Syntax String [Exp]
gaal when you're talking in general, an AST is a tree of Exps
but each Exp needs to be of a particular variant 15:44
you can have functions that demand one variant, or you can have functions that are more general
the slide with the long names is just for pedagogical purposes :) 15:45
kolibrie wants to see how the data definition yields a tree, but does not see it
gaal the real code defines Syn String [Exp] as one variant
and "Syn" is called a "constructor" because it's one of the various ways to construct an Exp 15:46
:t Syn
Syn :: String -> [Exp] -> Exp
this means, that in your code you can have Syn "for" [body]
and that returns an Exp (that is of the Syn variant), whose String element is "for" 15:47
kolibrie what are :: and -> ?
gaal that's haskell typing syntax
:: reads "has the type" 15:48
kolibrie so Syn has the type String
gaal the type String -> [Exp] -> Exp
Juerd Does that mean it turns a string into a list of exp, and that into an exp?
gaal which means that if you give it a String and an array of Exp, you get an Exp 15:49
Juerd Oh, almost
kolibrie why do they both use an -> then?
gaal when coming from a non-functional point of view, read type signatures this way:
a -> b -> c -> d -> e
function taking a b c d and yielding e 15:50
but of course there's a trick:
Juerd Hm
Multiple arguments?
gaal if you call this function with fewer args than it "needs", it doesn't blow up
Juerd Why not a, b, c, d -> e or something like that? 15:51
gaal it returns a function waiting on the rest of the arguments!
this is called autocurrying
so for example:
(+) 1 5
"add 1 and five"
(+) :: Int -> Int -> Int
lumi Read it: a -> (b -> (c -> (d -> e)))
gaal but if I say 15:52
(+) 1
I get back a function
azuroth is impressed. looks like I have a parser that supports variable associativity and precedence in 40 lines
gaal its type is Int -> Int
and I can apply that function to an int, and get.. another int, one higher.
(+) 1 is "the function that adds one to its argument" 15:53
kolibrie so any number you pass it will have one added to it and be returned
gaal this is also known as partial application, or sometimes, a section.
you can give this function a name, too:
let inc = (+) 1
you can also write this
let inc = (+1)
lumi gaal: section is the name for the (+ 1) syntax, I think 15:54
kolibrie do all haskell functions autocurry?
gaal lumi: I think you're right.
gaal kolibrie: yes. 15:54
kolibrie ok
gaal in fact, all functions in haskell only take one arguemnt!
so when you see "f 1 2 3 4"
azuroth and sections can let you curry the second arg, instead of the first
gaal it's like saying 15:55
((((f 1) 2) 3) 4)
(well, they all take one argument except for those that take one.) 15:56
lumi Like (** 2) is raise-to-the-power-of-two, and (2 **) is raise-two-to-the-nth-power
gaal so how is Exp a tree? look at the slide with the graphic again
kolibrie looks
gaal the node for Syn, for example, had a name to it, and also an array of Exps
so for example the "if" node has two or three children 15:57
Syn "if" [condition, truecase, elsecase]
kolibrie ok
gaal The node for function application is defined as 15:58
gaal App Exp (Maybe Exp) [Exp] 15:58
that means it has (1) an Exp representing the function to be called
kolibrie so condition = 42, truecase = { say "hello" }, elsecase = { say "oh no!" } 15:59
gaal (2) an optional invocant, defined only in method calls
(3) an argument list
exactly
more precisely, condition == Val (VInt 42)
because the condition must be an Exp also, not a haskell native type 16:00
you can see that in the graphic:
under the if there's an extra Val box, not immediately 42
and note that Val is one of the variants of Exp
kolibrie and so the condition, being an Int, uses line: Value Val
gaal yeah. of course, it could have been a much more complex condition 16:01
for example, an equality test
42 == 42
which in Perl really means &infix:<==>(42, 42)
that is, a function application 16:02
in that case, the condition would be replaced by a subtree which was a little more complex:
App (Val (VStr "&infix:<==>")) Nothing [Val (VInt 42), Val (VInt 42)] 16:03
see if you can mentally parse that
kolibrie concentrates really hard
gaal you know that App A B C 16:04
start by distinguishing A, B, and C 16:05
kolibrie A = (Val (VStr "&infix:<==>"))
B = Nothing
C = [Val (VInt 42), Val (VInt 42)]
gaal exactly
kolibrie but I forgot what A B and C are 16:06
B is invocant?
gaal then look at the data definition again
oh, in terms of what they mean
yes
that can use a little commenting :-)
A == Exp evaluating to whatever function we're invocing 16:07
B == invocant, maybe
C == argument list 16:08
*invoking
now, it may be the case that the expression resulting in the condition is even more complex
kolibrie wait 16:09
gaal if 42 == get_answer() { say "..." }
kolibrie so for that line, the function we call is (Val (VStr "&infix:<==>"))
there is no invocant
gaal yes
right
kolibrie and we have been given two arguments
or a list with two elements as our argument 16:10
gaal yeah. it's somebody else's job to check that == really wants two args.
yes
kolibrie ok, /me is ready to continue
gaal cool. have a pugs handy? 16:11
kolibrie yes
gaal run it with nothing on the command line
kolibrie ready
gaal and write ":d 42 == 42"
then ":D 42 == 42"
the first one is a little abbreviated 16:12
the second is actual runnable haskell code
kolibrie nifty
gaal (which also contains annotations, like in the slide after the graphic we've been looking at)
kolibrie so, I see the stuff we were just talking about at the end of the second one 16:13
but a lot of stuff at the front I don't understand
gaal there are other representations for this AST, I think we saw the YAML one together last time we talked, no?
kolibrie yes 16:14
gaal yeah, that stuff is Ann nodes, which add more info about parts of the tree
mainly position
so that if there's an error message, it knows to tell the user where the error was
MkPos "<interactive>" 1 2 1 8
that means "in the interactive pugs, from line 1 col 2 to line 1 column 8" 16:15
kolibrie ok
gaal it also happens to be parsed as a bunch of statements, and there's a spurious Noop in there, but you can ignore that 16:16
kolibrie on some of those lines in the data definition, there a more pieces, and some have less
gaal yes; but haskell doesn't get confused because for each type there is a precise number of pieces. 16:17
kolibrie and those types are all defined somewhere else
gaal yes, learning to find them quickly takes a bit of getting used to 16:18
if you know the general data type name (like Exp), you can grep around for /^data Exp/
kolibrie and before this parser is run, strings have already been converted into tokens by something else 16:19
gaal but if you didn't know that Syn belonged to Exp, you may have had a little harder time finding that
I don't have a great solution to that
but when you see this kind of thing, start from the beginning
in this case, you see Stmts Noop (...) 16:20
we happen to know that Stmts is a constructor in Exp
Stmts :: Exp -> Exp -> Exp
that is:
it takes Noop and another (long!) Exp, and together they are one Exp of variant Stmts 16:21
if you have a Perl block with some stuff:
{ A; B; C; }
then the statements inside the block can be arranged to look like Stmts A (Stmts B (Stmts C Noop)) 16:22
kolibrie Stmts has the type Exp -> Exp -> Exp (or, it takes two Exps and returns an Exp)
gaal yes.
integral do I need to do anything to add a new .hs file to the build? 16:23
gaal this isn't really important, except that it provides us with a way to talk aobut a bunch of statements together.
integral: add it to Pugs.cabal.in
integral ah!
gaal and to the clean directive in Makefile.PL
the second bit may not be needed 16:24
integral ack! why? Makefile.PL already uses glob to *search* for .hs files automatically
gaal integral: why what, why can't this only be defined in one place? I don't know the good answer to it, but I do see why cabal wants to know about files 16:25
integral well it's actually wanted to know module names, so I guess it's slightly different :-/ 16:26
*wanting
gaal we can probably engineer things so as this is more automatic, but that'd add some more complexity to our glorious build system
commits welcome, in other words :) 16:27
integral I hope that "glorious" was sarcastic ;-)
gaal kolibrie: so, have things started to sink in?
integral: sarcastic? well, we do use Haskell during build... 16:28
kolibrie gaal: somewhat. I'm going to paste an example 16:29
pasteling "kolibrie" at 66.239.158.2 pasted "gaal: this tokenizes, but how do I define what a sentence must contain" (47 lines, 1K) at sial.org/pbot/16114 16:30
kolibrie I got that from an example, and don't really understand parseToken 16:31
mauke do you know choice? 16:33
gaal let me rewrite it in hopefully more readable form
kolibrie choice is like alternation, I think 16:34
mauke yeah, choice [a, b, c] is a <|> b <|> c 16:34
do you know >>=?
kolibrie no
mauke ah, that's the problem 16:35
azuroth not quite related, but how does <- work? it seems like magic
integral mauke: no, it's mzero <|> a <|> b <|> c, it foldls with mzero, not foldl1
mauke d'oh
azuroth: you mean in do blocks? 16:36
azuroth yeah
mauke m >>= \x -> y is the same as do { x <- m; y }
<- is syntactic sugar for >>=
kolibrie ok, that almost makes sense 16:37
kolibrie let's it sink in
azuroth ohh! I thought the ; was, for some reason
mauke (>>=) :: (Monad m) => m a -> (a -> m b) -> m b 16:38
gaal don't worry about that monadic stuff yet :)
kolibrie hmm, don't know => either 16:39
mauke => is special syntax in type declarations
the things before it are class constraints 16:40
in this case it says m must be an instance of class Monad
in our example it's like (>>=) :: Parser a -> (a -> Parser b) -> Parser b 16:41
gaal that's probably a mouthful right now
kolibrie so it could also read: (>>=) :: m a -> (a -> m b) -> m b
mauke p >>= f runs the parser p, calls f with the result, then runs the resulting parser
gaal consider parseToken to mean something like 16:42
parseToken = choice [ A, B, C, D, E ]
gaal where the return value of each of these is what's on the right of the >> or >>= 16:42
this example is a little golfy. 16:43
kolibrie so parseToken defines which subparsers to run on the input
and each subparser tokenizes what it can
gaal kolibrie: they are tried in order, and the parses backtracks when one fails
in Pugs style, that would have been
parseToken = choice [ ruleSpaces, ruleEnding, ruleName, ruleWord, ruleChar ] 16:44
mauke huhu, fmap ((: []) . TokenEnding) ending
azuroth what does { e <- getInt; f <- getInt; return (e - f)} monadify to? {getInt >>= \e -> (getInt >>= \f -> return (e - f))} or something similarly crazy?
mauke azuroth: no { }
gaal and ruleSpaces woudl be
azuroth and no return? 16:45
mauke return stays, it's just a function
gaal ruleSpaces = do
many1 space
return []
mauke getInt >>= \e -> getInt >>= \f -> return (e - f) -- works
gaal ruleEnding = do
s <- ending
return [TokenEnding s]
ruleComma = do 16:46
char ','
return [TokenComma]
that's hopefully clearer
take ruleComma
the line char ',' is a sort of an assertion 16:47
if it fails, so does ruleComma
that behaves like throwing an exception
azuroth cool, thanks mauke! it makes much more sense now
kolibrie gaal: so I could replace me parseToken with those definitions
gaal yes 16:48
svnbot6 r9241 | bsmith++ | Factored out inline documentation from Pugs.Parser to Pugs.Parser.Doc.
r9241 | bsmith++ | Had to leave ruleDocBlock in Pugs.Parser for the moment.
gaal ooh integral++
mauke a >> b = a >>= \_ -> b
integral gaal: that was the easy part, now to figure out ruleDocBlock and why it needs to parse statement lists :)
kolibrie and then to make the parser fail if a sentence is not correct, do I change the definition of the new parseToken? 16:49
gaal kolibrie: what does a parser do now if a sentence is incorrect? 16:51
integral *argh* I see why it's so annoying. it's the silly recursive way ruleStatementList works :-/
kolibrie gaal: right now it tokenizes anything that matches a subparser 16:52
I want it to fail if no ending punctuation, for instance
gaal oops, I have a "ride" home 16:53
kolibrie: add assertions
in this case, it looks like you want choice [ ruleEndOfInput, ruleEndOfSentence ] 16:54
but i gotta go :)
kolibrie gaal: thanks so much!
gaal integral: worst case pass ruleStatement as an implicit param.
or an explicit one :) 16:55
&
integral best case: rewrite ruleStatementList to use these higher-order functions we keep talking about :-P
svnbot6 r9242 | fglock++ | - iterator_engine_p6grammar.pl - precompiled Prelude! 16:56
r9242 | fglock++ | loads in less than 1 second
integral *sigh* it's so nice how emptyExp and Noop are the same thing, but it can be confusing to read 16:59
svnbot6 r9243 | fglock++ | - iterator_engine_p6prelude.p6 - this is the Prelude file 17:02
azuroth night, all 17:03
fglock iterator_engine now has dynamic grammar - iterator_engine_p6prelude.p6 defines pod, and then immediately uses pod for documentation 17:04
svnbot6 r9244 | fglock++ | iterator_engine - cosmetic fix
r9245 | fglock++ | - iterator_engine_p6grammar.pl promoted to p6compiler.pl 17:07
Juerd rafl: When could you re-enable the automatic installation of Pugs on feather? 17:14
rafl: beep
rafl Juerd: Will do so. 17:22
svnbot6 r9246 | fglock++ | - iterator_engine - p6compiler can be invoked with: 17:37
r9246 | fglock++ | perl iterator_engine_p6compiler.pl iterator_engine_p6sample.p6
putter audreyt, gaal: so is it time, and still the plan, to move functionality from Prim.hs to Prelude.pm, now that its compile-duration issues have been fixed? 17:43
fglock: ping?
putter TimToady: re would a patch help, I don't think so. I'm at this moment trying to work out the design constraint space - more in a bit. 17:46
gaal putter: we can definitely start, but there's a small matter of packaging to perform before pulling the switch 17:54
precompilation works but is not engineered yet 17:55
that is to say, it has a good design but that isn't implemented yet
wolverian typo on peek slide37, missing } 17:59
in case that's still relevant :)
gaal sure, thanks :)
putter: right now, pugs looks only at src/Pugs/PreludePC.yml and ./Test.pm.yml[.gz] 18:01
we need the per-user cache folder
integral does Test.pm.yml get created at the same time as PreludePC by the build?
gaal integral: no, only on "make smoke" or "make test"
gaal this means incidentally that "make install" suckifies ./pugs :) 18:02
If I'm lucky I'll fix it over the weekend, but possibly not as there's some pizza and a family dinner both waiting to happen 18:03
fglock putter: pong
gaal fixed. 18:06
err, I mean the slides. :)
svnbot6 r9247 | gaal++ | r9268@sike: roo | 2006-03-02 20:02:42 +0200 18:07
r9247 | gaal++ | * fix missing closing brace. Reported by wolverian++.
gaal nothingmuch: ping 18:11
svnbot6 r9248 | gaal++ | r9275@sike: roo | 2006-03-02 20:08:53 +0200 18:13
r9248 | gaal++ | * perl6.vim: hilight `rule` the same way as `method`
fglock is there a way to set the filename/line in an eval(), for warnings to behave properly ? 18:17
meeting & 18:21
gaal fglock: #line? 18:29
?eval eval "say 'mmm'; \n#line 44324\nwarn 42" 18:30
evalbot_9248 OUTPUT[mmm ] undef
gaal ?eval eval "say 'mmm'; \n#line 44324\nsay Carp::longmess"
evalbot_9248 OUTPUT[mmm ] undef
gaal oof unsafe
gaal but that oughta work 18:33
i have to go now... &
axs221 I've been trying to decide on learning either perl or python. With Perl6 coming out, will learning Perl5 still be useful, or will 6 be too different so that I'd have to relearn most of what I would learn? 18:51
mauke learn all three of them 18:52
axs221 eventually i might, but i'm wanting to just learn by book right now, i bought a python book 18:53
i'm thinking about taking the python book back and getting a perl book, mostly because of the greater demand in the market for Perl, atleast in job search sites, although from what I know Python sounds easier to learn for someone relatively new to programming like me 18:56
mauke yes, probably 18:58
putter gaal: I don't quite understand. are you saying src/Prelude.pm still has constraints on size (maybe on install??), and thus shouldnt be non-trivially enlarged at the moment? or that it can be? 19:24
fglock: #line N "filename" which I think the next line is considered N, but I'm not sure. 19:25
yes, now sure. ;)
(used in the "I really should put a copy in common" somewhat cleaned up spike backtracking regexp engine thing - makes syntax errors in evals much clearer. ) 19:26
svnbot6 r9249 | bsmith++ | * Rewrote the looping logic in ruleStatementList so that the recursion is 19:27
r9249 | bsmith++ | factored out into a higher-order function.
r9249 | bsmith++ | * The above allows ruleDocBlock to be moved from Pugs.Parser to its proper
r9249 | bsmith++ | place in Pugs.Parser.Doc.
putter axs221: if you dont have experience coding in other languages, learning python is more likely to start you off with good habits than learning perl. 19:28
integral *sigh* only 50 lines smaller though
putter ;) 19:29
were expecting a greater code shrinkage? 19:30
integral just wishing that it'd suddenly turn into one when I commited ;-)
putter lol
nothingmuch hola 19:31
putter hola, como estas?
nothingmuch estas beseder
putter goes to google language tools...
nothingmuch a friend of mine always asks me como estas
she knows some spanish/portugise phrases from TV soaps 19:32
i always try to spoil her fun
putter :) google translates to "to beseder". had to check OneLook to make sure that was a googlism, and not a nifty word which is similar in both spanish and english :) 19:33
hmm, so I still dont know what it means. 19:34
nothingmuch beseder is hebrew for "OK"
i don't know what "estas" means
she would always laugh at me and say "enough nonsense" or something of the sort
nothingmuch anyway, my sister's birthday party was a big success 19:34
and now I'm off to visit a friend 19:35
putter aaahhh. como=how estas=are you esta=i am etc
fglock nothingmuch: I speak portuguese in case you need :)
nothingmuch i hope i'll survive, i haven't seen her in weeks and she is touch about that kind of stuff =)'
putter yay. was surprise?
nothingmuch fglock: ah, good thing
putter: yes
we made her a Moomin cake house
putter win
nothingmuch thanks to elaine ashton
and we bought her an ipod
and she is delighted 19:36
putter Moomin... putter goes back to google... later...
nothingmuch en.wikipedia.org/wiki/Moomins
fglock hi putter - bye putter
putter ah, it's great when a plan comes together :)
nothingmuch www.axis-of-aevil.net/archives/2005...omins.html
putter hi fglock, bye? fglock
fglock quick question
ping? 19:37
fglock pong
putter are you doing any <expr> expression/operator parsing stuff?
fglock (I said bye because you said later...)
putter oooohh.
putter goes to look at moomins :) 19:38
fglock mm - yes, more or less
nothingmuch putter: it's a series of children's books for adults
fglock I didn't implement operator precedence yet, but it does espressions
s/expressions/
see: iterator_engine_p6sample.p6 19:39
putter ah, en.wikipedia.org/wiki/Moomins
nothingmuch ciao guys 19:39
putter: yes, just like i linked you =) 19:40
fglock putter: it compiles: '1' infix:<*> '1' infix:<+> '1';
putter oh, duh. saw the first link, explored, ... 19:41
fglock if you try 'print' on that it might work
putter which there was more description of... content? perspective? ie, not cast and geography, but what they do/believe/etc. 19:42
fglock: err, so where is precedence handled? 19:45
fglock putter: there is no precedence yet - first come, first compiled. 19:47
putter got it.
fglock first priority was bootstrapping, which is mostly done
now there are many possibilities - adding precedence is one of them 19:48
I'm not sure what to do next - would like to hear some opinions
performance is quite good
there is the object system work, 19:49
completing the rule syntax,
putter ok, so is a correct one-liner "interator is like the regexp/parser spike, but bootstrapped to self hosting, and using p6 rather than p5 syntax regexps"? other key differences?
fglock packaging to CPAN,
the whole syntax is defined in p6 19:50
see: iterator_engine_p6prelude.p6
I could move the compiler to p6 now :) 19:51
putter right. parser_spike.pl cheats a bit to get parser_spike_target.p6 working. 19:52
:)
hmm... what to do next... 19:53
fglock there is some cheating going on in making { return } blocks work before bootstrapping - but after boorstrapping it can go away - it uses a source filter 19:54
putter I'm afraid I haven't even looked yet at the new -CParser-YAML (or somesuch) output. is it something you could derive from your parse tree, so there is a cross check? maybe a cross check. the trees may be too tied to parsing strategy to compare easily. 19:55
fglock I could generate YAML if I knew the nodes, but I'm afraid it is too complex for now - it can be left for later 19:56
being able to read YAML would be nice, you could reuse compiled things from pugs to i_e
i_e nneds a name, maybe a directory :) 19:57
s/nneds/needs/
putter you could start pouring Parser.hs into p6 rules... 19:58
start working through the sanity tests, eyeballing for reasonable parses...
misc/IteratorEngine ? ;) 19:59
easy enough to rename. svn++ 20:00
fglock Puggie - Pugs little brother/syster
putter *shudder*
:)
PerlParserPrototypingPlatform 20:02
fglock I'd like to have more opinions on the subproject, before working too hard on it
putter lol
fglock it was very successful as an experiment 20:03
putter ooo, PerlParserPrototypingPlatformProject
fglock that's java-ish
putter makes sense. audreyt said something about attempting a pass over the t/ and ext/ code using... something. a new parser? implementing the "sandwich" parser concept to proof it? 20:05
re very successful, indeed. congrats. :)
putter I seem to have backburnered my backtracking engine (still mostly p5 syntax - next step was to be an operator parser), when the spec for one of my "solid places to stand touchstones", Match, started fluxing. Think I may fork a Natch class, that I can keep stable and do whatever the engine needs for now, without worrying about spec. 20:08
Hmm, and perhaps more importantly, the operator precedence parsing turned out to be a messier proposition than I anticipated. 20:11
In retrospect, I should have / should now hack something, to get back to a parser running, and some semblance of p6, so we could have two implementations chasing each other. maybe. or maybe that would simply be a waste. 20:12
fglock putter: operator precedence is easy - it just take a while to optimize (if needed) 20:13
:) not a waste, but we could have a common API such that we can interchange engines
putter not in the presence of pre-, post-, and especially circum- fix.
re simple.
fglock putter: that's a grammar problem (solved) - all we need is to present options to the grammar in the proper order. it should be about 50 lines of code 20:14
putter I hypothesize pge is not quite doing the right thing re close tokens on cirumfix ops. and there are assorted "make for extra work" bits like operators having a "no whitespace allowed before me" flag. assorted cruft. 20:15
fglock bbiab 20:17
putter so your parser, given ... * ,,, with * rule defined early, looks ahead through the input to match *, with two unprocessed strings ... and ,,, , and then recurses on them? 20:19
Regarding using an alternate regexp engine in perl5, I did a design space grovel - it would take something like four pages to write up - isn't going to happen unless someone _rteally_ wants it. 20:21
Most important point is most of the difficulties lie in trying to swap engines in a way which is _transparent_ for _humans_ coding _perl5_. 20:23
for p6 _on_ p5, rather than _in_ p5, with a compiler emitting arbitrary p5 code, the only(?) residual issue is exporting qr//'s to native modules. 20:24
So in a p6 context, I don't think the exercise is worth the pain. Questions about "what pain?" entirely welcome. :) 20:25
My key uncertainties/questions are:
fglock re: ... * ,,, - yes, and it backtracks if fail
re: "no whitespace allowed before me" 20:26
it can be specified in the grammar, I believe
fglock re: qr// - I could write an emitter for that, so we can choose between rule or regex (besides, we can use regex instead of rule when possible, which is faster) 20:28
putter Can XS somehow set $1 to a non-string (an object)? Is there some way to create an arbitrary variable which gets scoped just like $1 does? Regards reentrancy - is it strictly capture which is broken? does everything not dependent on captures still work? I think those are my big fuzzies.
fglock re: $1 - it's good to have TimToady around :) 20:29
putter :) and japhy.
and bsb
and ... :)
fglock bbiab 20:33
putter Oh, and the tech for playing with regexp's that I know about is, well, source filters of course, bsb's "regexp which calls matcher, gets capture offsets, and correctly sets up capture vars", the use re 'debug'-ish regcompp and regexecp hooks, and... I dont know of any other tools to get leverage around here, short of playing with opcodes (p5, and regex) or patch p5. 20:34
If anyone knows of any other candidates, I would be most interested.
buu Um, Regexp::Parser? 20:36
putter I should mention the hooks are basically providing a way to fake up regexp struct's, both as an api into the perl matchvar machinery, and as a way to do qr// which _is_ reentrant (the hooks are reentrant, its just the engine which isnt - thus the one downside of bsb's device). 20:37
buu: Yes, a good thing to mention. Thanks. (and there is a copy with some bug fixes in misc/pX/Common/Regexp-Parser, also with some additional tests, some failing...) 20:39
PerlJam I know it's been a while since I've paid attention to pugs when I look at #perl6 and I haven't the foggiest idea what's being discussed :-) 20:41
putter This is the p5p perl5-porters sidebar on #perl6. ;) 20:42
PerlJam Oh. I haven't read p5p in *years*, so that makes sense.
fglock PerlJam: we are porting p6 to p5 (kind of) 20:43
buu Yay!
PerlJam fglock: good luck! I'm of the uninformed opinion that it's Too Hard :-)
fglock PerlJam: no it's not :) 20:44
putter Somewhat off topic. You dont need it for pugs. Nor for a pugs backend running on p5. Nor for a completely independent p6 parse-compile-emit implementation on p5. You only need these silly time-absorbing games if you attempt to give human p5 programmers p6-ish regexs they can use transparently on p5. eh.
fglock it's just that there are _too_ many ways to do it
putter: right 20:45
putter though to be fair, some of the stuff turned up could end up being useful for the p6 on p5 stuff interoperating with native p5 modules.
PerlJam putter: twould be easyish if PGE were a library you could embed. 20:46
fglock putter: I'll translate i_e to p6 anyway
putter I'm basically puttering. Could be working on moving Prim.hs to Prelude.pm, but it's not clear it time for that. Could getting the somewhat cleaned up bactracking stuff at least checked in, or continue work on operator parsing, but with fglock making progress, the presure is off, and it's just not -Ofun. So I've spent 10-ish hours being random. 20:48
fglock: re _too_ many ways, no. the number of possible tools certainly makes analysis harder. but I believe the real problem, at least for a full bore "use EverythingRegexyNowLooksLikeP6; ...", is that you simply cant do it. 20:51
fglock goes read Prim.hs 20:53
putter PerlJam: re PGE, the engine is actually the easy part :). sort of. or at least the part we've sort of kind of already done. the long-term as-yet-unresolved puzzle is the pragmatics of integrating it with unpatched perl.
fglock putter: OT - do you know of an example of using '&' in a rule? (conjunction) 20:54
PerlJam Hmm. unpatched perl? How incestuous must the engine be?
putter though there are some low hanging fruit, like a reentrant p5 regexp engine with rules. that one could do now as an XS module for cpan. but that's a bit off-perl6-topic.
fglock: an example? any example? 20:55
abc&\w**{3} ;)
fglock putter: what is it useful for?
putter ooooohh
PerlJam fglock: Are you asking what & is generally useful for? 20:56
putter one sec
fglock PerlJam: in the context of p6 rules 20:57
PerlJam The things I can think of all involve increased specificity.
putter PerlJam: the regexp engine and the perl compiler/runtime unfortunately know each other quite well.
And p5's extensibility has never extended to permitting the user to, for example, create a Qr class which emulates qr//, overloading =~. 20:58
And there are no hooks, even at the C level, for creating the $1,etc suite. 20:59
PerlJam putter: sounds like the goal should be to get those patches in before the next release of perl5 :-)
putter One of the key values of the hooks, and their ability to create "struct regexp"'s, is you finally have a way to twiddle some of those internals. But I'm afraid it may not go as far as "please, can my $1 be an SV?". :( 21:01
PerlJam: doing p5 guts modifications to better support p6-like stuff... is something which could be added to perltodo. ;) volunteers welcome. making the regexp engine reentrant is listed there. in the "hard" section (though I'm not clear on why it's hard exactly. but I dont see perlguts hacking in my future). 21:04
Oh my, scary last words.
man perltodo (i only discovered it the other day:) 21:05
fglock: re conjunction,
fglock putter: other option - help me doing the i_e thing :P 21:06
putter you know how you sometimes use lookahead to assert some property on the following characters, in addition to the regex which actually matches them? the one gotcha is you cant assure the lookahead matches exactly... (well, you can, but it takes, oh wait, I'm not sure you can) anyway, that it matches exactly what you intended. 21:08
<hiaku>&[<line>+] 21:10
hmm, the grouping [] was unnecessary
fglock putter: thanks 21:11
putter [<mail_header>&.*?^^From: (\N+).*] $<body>:=(.*) 21:12
PerlJam: what's an increased specificity example? both of mine were assert-spec&unpack pairs. 21:16
fglock putter: .* would make it fail, isn't it? 21:18
putter you mean the .* after the (\N+) ? 21:19
fglock yes
PerlJam putter: yes, mine are similar, just that the "unpack" part isn't necessary: [<mail_header>&^^<'From:'>] && do_something_only_with_from_lines; 21:20
putter I don't believe so. I would expect the & to force the * to backtrack.
PerlJam putter: btw, beware the cut-colon! :-) (unless I'm mistaken that you meant for the : to be matched)
putter lol
right
god, both my p5 and p6 are going to be so buggy. colons and brackets and sigh, oh my. 21:21
when writing p5 regex's i now do a double-take each time I use {, "wait, that's... no, it's p5, that's ok". ;) 21:22
PerlJam The conceptual and syntactic overlap is annoying if you have to do both. 21:24
(ergo, I've sworn off writing perl6 for a while)
putter I don't think that last & example actually works... 21:25
ah
<mail_header> would have to match exactly the 5 chars "From:". 21:27
putter wonders what the big-picture status and critical path of pugs currently are. 21:28
putter goes to check audreyt's blog ;)
PerlJam putter: Are you *sure* it would have to be that way? Must they both match the exact same characters completely? Granted, if it didn't I have no idea what state it would leave the current byte/char position pointer in. 21:36
fglock PerlJam: it must match exactly the same substring
putter has anyone groveled over Parser.hs and created a p6 grammar? either a direct translation, or one using <statement> and <expr> modifying constructs like statement_control:<if> and infix:<+>, etc? 21:37
PerlJam Seems like you'd have to worry about end points then rather than just "matches at this position"
"foobar" ~~ /<'foo'>&<'foobar'>/ # What happens? Does the match fail? 21:38
putter PerlJam: just doing zero-length lookahead assertions (?=...) and <before ...> satisfies the "they both start here, and I dont care where they end" need. & exists entirely to provide the "i do care where they end". 21:39
yes, that match fails
PerlJam putter: that seems entirely reasonable.
fglock putter: re: grammar - I'll start doing that soon
PerlJam (Well, that seems reasonable as along as it's adequately documented :-) 21:40
putter translation or self-modifying (what's a better name for that?)
:)
fglock putter: I can write a grammar to parse Haskell, and use it as-is 21:41
putter "foobar" ~~ /<before <'foobar'>><'foo'>/ succeeds
any ideas on what to call a grammar which uses non-local definition of <statement> and <expr> ? 21:42
fglock putter: non-local?
putter ok, that was either you suggesting "non-local" was an ok name, or you being confused about what i meant by "non-local", thus eliminating as an option. i'm not sure which... 21:43
:) 21:44
fglock what do you mean by non-local?
putter ah, eliminated as an option. meant
something which, instead of an explicit rule statement { subrule1 | subrule2 | ... }, 21:45
PerlJam putter: a fully qualified rule name? 21:46
fglock putter: that's <@subrule> in i_e
putter one uses multi statement_control:<if> (...){...} multi statement_control:<while> (...){...} etc to fill it in. 21:47
fglock putter: you mean, statement_control is represented by an array? (or namespace thing)
putter fglock: yeah, but there are some issues... like how do (pause) 21:48
PerlJam must not have been enough svk talk here ;-) 21:49
fglock putter: please not that it is an array of rule - it is very flexible
putter statement_control is a grammatical category. it defines one of the <statement> subrules.
(my yeah, was directed at <@subrule>, not represented by an array ;) 21:50
fglock: yes but. when writing a grammar, in a first match wins engine (like | is), you carefully craft the order of the subrule list. when subrules get added by statement_control defs, someone other than the human has to do the crafting. either the statement_control infrastructure assures the @array has a nice order, or <statement> can't use <@array>. 21:53
fglock putter: you can opt to use longest-match instead of ordered-match 21:54
putter yes
fglock that would be <%statement_control> 21:55
putter and the real parser can play games like trying to massage the @array into a trie, so it doesnt have to repeatedly reparse the same stuff the same way.
fglock putter: it is cached 21:56
putter re statement_control, dev.perl.org/perl6/doc/design/syn/S04.html has a little bit in Statement parsing. 21:58
fglock putter: nice 21:59
Limbic_Region is there a known problem with Feather and https ATM? 22:01
fglock why is 'if' a macro? (S04)
putter re hash, "An interpolated hash matches the longest possible key of the hash as a literal, or fails if no key matches.", which doesnt help you distinguish between /if <expr> <block> [else <block>]?/ and /if <expr> <block> [else <block>]? [wrap_around_both_branches <mumble>]?/. comparing "if" and "if" isnt going to help. 22:04
pmurias Does any one think that useing Smart::Comments in iterator_engine.pl would be a good idea? 22:05
fglock pmurias: I like Smart::Comments, but I'd like to keep it simple (that is, no unnecessary dependencies) 22:06
putter (there shouldn't have been a ? on the <mumble> clause)
pmurias It would be a dependency only for debugging :)
And casual users don't do that often :)
at least they shouldn't have to :) 22:07
fglock pmurias: I'll check that (you mean, disable 'use Smart::Comments' when not in use?)
pmurias the use line should be comment out by default 22:08
fglock putter: re /if.../ - I don't understand the mumble part, what would it be?
pmurias and if the debuging messages are needed you just delete the #
putter re if macro, well, you need to add a regex to <statement> so you can parse it. and we can currently hang regexs off of, well, rule, and macros macro statement_control:<if> (...) is parsed(/heres the regex/) {...} 22:09
pmurias i'll commit it tommorow if youd don't mind
fglock pmurias: sounds good - I'll check the pod again
pmurias i have to sleep now, will be back tomorrow, bye
fglock putter: ok. so the macro is just a simplification of the rule thing I'm using 22:12
putter re mumble, oh, maybe a block/closure which is handed the block/closure which if would normally execute itself, but it gets to do some stuff, then maybe call it, then do other stuff. but it was just a strawman to point out that with random cruft being added to the parser, some of which will conflict with existing rules, an alt-like parse is insuffient.
putter goes to look again at what fglock is using... and then has to remember to search.cpan Smart::Comments... 22:13
fglock putter: I think there must exist just one 'if' - if you need something more complex, you define it inside the if-macro or define it with a rule, which gives you full flexibility. but there is only one entry in the statement tabl 22:14
putter: re using: only rules, no macros 22:15
s/tabl/table/
unlike multis, which are defined in another category 22:16
putter yes - the push'es, and on to what, are implied by the grammatical category stuff. statement_control, infix, term, etc. 22:17
fglock putter: yes - that would be handled by macros, if we had them
fglock thinks about adding macros - it goes to the TODO list 22:18
putter well, the whole issue of what's a macro/rule/method/sub is still a bit unspeced (or such is my recollection)
putter perhaps in this case, a macro (would have to be a string macro, yes?) could match and rewrite the input. a rule statement_control:<if> {...} could do whatever ruleish things the rest of the p6 grammar rules are doing, perhaps to build an ast. (caveat, I'm not sure I've seen a spec example of a "rule statement_control"). 22:26
svnbot6 r9250 | fglock++ | iterator_engine - updated TODO list - putter++ 22:28
fglock putter: a macro is just like a source filter; macro statement_control:<if> {...} is probably setting an element in the hash %statement_control in the p6 compiler namespace 22:31
%statement_control:<if> actually 22:32
it will look like: %statement_control:<if> = rule { ... } 22:33
putter it has to be a is_parsed and string-returning (not code-returning) macro, yes? 22:34
fglock in i_e, it is supposed to return AST. but a macro can return either string or AST (no code) 22:35
macros that return string will be more portable - I don't think there will be an official AST for all compilers 22:37
so AST is for internal use only
putter ah. have to go. enjoy. 22:40
&
fglock &
svnbot6 r9251 | fglock++ | iterator_engine - pasted some comments 22:42
nothingmuch moose 23:04
audreyt: ping
beppu stupid question perhaps, but will perl6 allow us to use chars like '!' and '?' in subroutine names? 23:11
mauke probably yes, because perl5 does it 23:14
integral yes, but perl5 allows "\0" in subroutine names. 23:16
beppu mauke, how does perl5 allow it? I didn't think it did. 23:31
can you post an example?
mauke *{"!"} = sub {"y helo thar"}; 23:32
beppu how do you call it afterwards?
mauke *{"!"}->()
beppu I see... what I really wanted to be able to do was say things like: if ($block->is_filled?) { ... } 23:33
with the ? being part of the method name./
I didn't want to have to use typeglobs for this. 23:34
mauke heh, scheme style
beppu yeah. :)
mauke wouldn't that clash with operators? 23:35
beppu I think it would, but I figured it wouldn't hurt to ask.
mauke hmm, it shouldn't be too hard to write a lisp skin for perl 6 23:37
or perl 5, for that matter
beppu no source filters for me. 23:39
avar integral: perl is pretty liberal about the names of everything 23:39
${'Woo, variable with spaces!'} = 5; 23:40
beppu but you have to turn strict refs off, right? 23:43
avar no 23:45
mauke yes
er, wait
avar bleh, yes
beppu ;) 23:48
we should steal back from ruby and allow '?' and '!' at the end of method names. 23:49
PS: has anyone noticed the similarity between `perl -h` and `ruby -h`. I think that's cool. 23:50
obra beppu: or just go hardcore and use _p (predicate) instead of ? 23:53
beppu that's not as cool. ;) 23:54
perl and sigils belong together.
avar I like ! a lot 23:57
.chomp! str
eh
str.chomp!
what does ? do again? 23:58
mauke returns a bool
avar perl 6 has that
if (?foo) ..
IIRC
along with ~ for a scalar cast.. 23:59