»ö« Welcome to Perl 6! | perl6.org/ | evalbot usage: 'p6: say 3;' or rakudo:, std:, or /msg camelia p6: ... | irclog: irc.perl6.org | UTF-8 is our friend! Set by masak on 12 May 2015. |
|||
TimToady | well, the exact semantics might change a bit, to more like, returns the first defined value, or Empty | 00:01 | |
dha | Oh. Ok, Will not patch. :-) | 00:05 | |
00:06
japhb left,
japhb joined
00:10
Akagi201 left
00:13
Akagi201 joined
00:17
dha left,
Akagi201 left
00:21
vendethiel left
00:22
khw joined
00:25
ShimmerFairy left
00:26
vendethiel joined
00:27
gfldex left
00:37
ShimmerFairy joined
|
|||
ugexe | finally got this installing modules on windows. but for how long... | 00:43 | |
00:45
laouji joined
00:48
vendethiel left
|
|||
ugexe | installs panda to a further stage than panda itself, but it stills fail testing | 00:49 | |
00:56
dayangkun joined
01:11
rmgk left
01:13
rmgk joined
01:18
BenGoldberg joined,
araujo left
01:21
araujo joined
01:26
yqt left
01:38
skids joined,
AlexDani` left
01:42
tinyblak joined
01:44
yeahnoob joined
01:45
ilbot3 left
01:47
ilbot3 joined
02:13
nys left
02:19
aborazmeh joined,
aborazmeh left,
aborazmeh joined
02:20
raiph left
02:22
jack_rabbit joined
02:28
vendethiel joined
02:29
jack_rabbit left
02:36
Akagi201 joined
02:37
Dee22 joined
02:40
VinceDee left
02:44
Akagi201_ joined
02:47
Akagi201 left
|
|||
dalek | kudo/nom: 63de9a1 | TimToady++ | src/Perl6/Grammar.nqp: catch obvious misuse of ^100.method |
02:52 | |
02:53
noganex joined
02:55
noganex_ left
02:56
aborazmeh left
03:11
kaare_ joined
|
|||
TimToady | m: say ^100.pick | 03:19 | |
camelia | rakudo-moar a32c1d: OUTPUT«0..^100» | ||
03:19
vendethiel left
|
|||
TimToady | m: say ^100.pick | 03:21 | |
camelia | rakudo-moar 63de9a: OUTPUT«Potential difficulties: Precedence of ^ is looser than method; please parenthesize at /tmp/db2BxGAzgx:1 ------> 3say ^1007⏏5.pickUse of Nil in numeric context in block <unit> at /tmp/db2BxGAzgx:10..^0» | ||
03:28
vendethiel joined
|
|||
dalek | kudo/nom: 852340f | TimToady++ | src/Perl6/Grammar.nqp: oops, warning shouldn't move cursor position |
03:34 | |
lizmat | good *, #perl6! | 03:45 | |
03:50
vendethiel left
|
|||
kanl | m: my %a = a => *; my %b = %a.invert; %b.say; | 03:50 | |
camelia | rakudo-moar 63de9a: OUTPUT«Whatever<140359990650704> => a» | ||
kanl | m: my %a = a => *, b => *; my %b; %b.push: %a.invert; %b.say; | 03:51 | |
lizmat | kanl: this is unexpected why ? | ||
camelia | rakudo-moar 63de9a: OUTPUT«» | ||
lizmat | ah... hmmm... | 03:52 | |
kanl | m: my %a = a => <1>, b => <1 2>; my %b; %b.push: %a.invert; %b.say; | ||
camelia | rakudo-moar 852340: OUTPUT«1 => a b, 2 => b» | ||
kanl | lizmat: so i was expecting Whatever => a b | 03:53 | |
03:56
vendethiel joined
|
|||
lizmat | to really get Whatever as the key value, you should use a typed hash, aka 'my %b{Any}' | 03:57 | |
otherwise you'll get a stringification of Whatever as the key | |||
however, that doesn't solve the problem | |||
brb | |||
m: my %h{Any}; %h{Whatever} = "a"; say %h.perl # golfed down problem | 04:04 | ||
camelia | rakudo-moar 852340: OUTPUT«Hash[Any,Any].new()» | ||
lizmat | m: my %h = a => 42, b => 666; %h{*} = 43,667; say %h.perl # {*} means all keys in the hash | 04:08 | |
camelia | rakudo-moar 852340: OUTPUT«{:a(43), :b(667)}<>» | ||
lizmat | now, since the order of the keys is random, assignment as such would be rather roulette like | 04:09 | |
kanl: so I'm afraid this is a case of DIHWIDT | 04:11 | ||
since the roulette nature of assigning to {*}, one could wonder whether this should be allowed at all or not | 04:12 | ||
kanl | lizmat: thanks! so i should not be considered a bug then? though i'd still prefer it does what i meant :p | 04:16 | |
^it | |||
lizmat | well, but that's just it: it currently *is* doing what is meant | 04:17 | |
04:17
gfldex joined
|
|||
lizmat | it's just not doing what *you* meant :-) | 04:17 | |
m: my %h = a => 42, b => 666; say %h{*} # slice all keys | 04:18 | ||
camelia | rakudo-moar 852340: OUTPUT«42 666» | ||
lizmat | m: my %h = a => 42, b => 666; say %h{*} = pi; say %h | 04:19 | |
camelia | rakudo-moar 852340: OUTPUT«3.14159265358979 (Any)a => 3.14159265358979, b => (Any)» | ||
dalek | kudo/nom: bccd76d | lizmat++ | src/core/hash_slice.pm: Don't allow assignment to %h{*} Since the order of the keys as given by {*} is non-deterministic, it is rather roulette-like trying to use them as a list to assign to. To avoid confusion, it is probably better to not allow this at all. Or perhaps a warning should be in order instead. |
04:22 | |
kanl | fair enough, i'll try and digest it. lizmat++ | 04:23 | |
lizmat | kanl: why are you using Whatever as a value anyway? | ||
m: my %a = a => <*>, b => <*>; my %b; %b.push: %a.invert; %b.say; # perhaps confusing, perhaps what you need ? | 04:24 | ||
camelia | rakudo-moar 852340: OUTPUT«* => a b» | ||
lizmat | aka, use the string '*' instead of the type * | 04:25 | |
kanl | lizmat: it would work for me, only if the * means Whatever when used as a hash key. | 04:26 | |
i'll try it | |||
lizmat | no, it won't mean Whatever in that case | 04:27 | |
it will just look like Whatever | |||
kanl | close enough, i can just check it as a special case, i guess :) | ||
lizmat | still feels like an X Y issue here, though | 04:29 | |
what are you trying to achieve with Whatever as a key value ? | |||
kanl | getting all the keys in an hash from time to time. i'm trying to write a system monitoring too with functions like FALLBACK( $name, *%index ), with name being DF, IOSTAT, etc. and %index being Capacity => </ /foo /bar>, Iuse => *, etc. etc. long story :) | 04:31 | |
i can gist you the code if you'd like, but it probably just adds too much noise :p | 04:32 | ||
lizmat | m: my %h = a => 42, b => 666; say %h{}' | ||
camelia | rakudo-moar 852340: OUTPUT«5===SORRY!5=== Error while compiling /tmp/VOjTXlGIw8Strange text after block (missing semicolon or comma?)at /tmp/VOjTXlGIw8:1------> 3my %h = a => 42, b => 666; say %h{}7⏏5' expecting any of: infix infix stoppe…» | ||
lizmat | m: my %h = a => 42, b => 666; say %h{} | ||
camelia | rakudo-moar 852340: OUTPUT«a => 42, b => 666» | ||
lizmat | m: my %h = a => 42, b => 666; say %h{%h.keys} | ||
camelia | rakudo-moar 852340: OUTPUT«42 666» | ||
lizmat | m: my %h = a => 42, b => 666; say %h{}:k | ||
camelia | rakudo-moar 852340: OUTPUT«a b» | ||
lizmat | m: my %h = a => 42, b => 666; say %h{}:v | 04:33 | |
camelia | rakudo-moar 852340: OUTPUT«Unexpected named parameter 'v' passed in block <unit> at /tmp/ZODGmkMsyH:1» | ||
lizmat | hmmm... that is surprising | ||
kanl | but yeah, for now <*> would work for me, and i'd just check for it as a special case :) | ||
lizmat | okidoki | ||
04:34
Akagi201_ left
|
|||
kanl | i'm sure this is one of those dumb yahoo + not enough doc problem :) | 04:34 | |
lizmat | well, actually, you pointed out a glitch in the matrix, afaiac | 04:37 | |
for typed hashes, what does %h{*} mean? | |||
does it indicate all of the keys, or does it just take Whatever as its key? | |||
04:41
vendethiel left
04:42
laouji left,
laouji joined
|
|||
kanl | m: say 'FOO' if < 1 1 30 1 1 1 3 1 1 -1 0 1 0 1 25 2 1 1 >.none > 20; | 04:47 | |
camelia | ( no output ) | ||
04:47
laouji left
|
|||
lizmat | those are strings, not numbers | 04:52 | |
kanl | right. and it looks right, i think. | 04:53 | |
lizmat | m: say < 1 1 30 1 1 1 3 1 1 -1 0 1 0 1 25 2 1 1 >.none.Int > 20 | 04:54 | |
camelia | rakudo-moar bccd76: OUTPUT«none(False, False, True, False, False, False, False, False, False, False, False, False, False, False, True, False, False, False)» | ||
lizmat | m: say "FOO" if < 1 1 30 1 1 1 3 1 1 -1 0 1 0 1 25 2 1 1 >.none.Int > 20 | 04:55 | |
camelia | ( no output ) | ||
kanl | was just trying to see if it typecasts to Int or not | ||
lizmat | it doesn't, you need to do that yourself | ||
kanl | oh.. | ||
but i'm getting the expected behavior, no? ( no output ) | 04:56 | ||
lizmat | ah, I see where you're getting at now | 04:57 | |
kanl | apologies for any confusion i might've caused :p | 04:59 | |
lizmat | nonono, you're teaching me something :-) | ||
I guess using the > on the junction, automatically does force the string to be numerically interpreted | |||
so indeed, you don't need to do the .Int yourself | 05:00 | ||
TimToady | yes, it does | ||
m: say ^100.pick | 05:01 | ||
camelia | rakudo-moar bccd76: OUTPUT«Potential difficulties: Precedence of ^ is looser than method call; please parenthesize at /tmp/XqFgxBcxPR:1 ------> 3say ^1007⏏5.pick0..^100» | ||
05:03
khw left
05:05
BenGoldberg left
|
|||
dalek | kudo/nom: 2904f3a | lizmat++ | src/core/hash_slice.pm: Add :v candidates for %h{*} and %h{} Not sure why they were missing before |
05:10 | |
lizmat | m: say ^100.Int | 05:16 | |
camelia | rakudo-moar bccd76: OUTPUT«Potential difficulties: Precedence of ^ is looser than method call; please parenthesize at /tmp/K92pr9lSrV:1 ------> 3say ^1007⏏5.Int0..^100» | ||
05:17
laouji joined
|
|||
lizmat | m: say ^"100".Int | 05:17 | |
camelia | rakudo-moar bccd76: OUTPUT«0..^100» | ||
TimToady | it's only trying to recognize the most common case; it doesn't even look for ^$foo.method, since .method might well be a normal way to produce an integer on whatever $foo contains | 05:20 | |
skids | m: sub f (::T $a) { my T $b; { T.WHICH.say; $b.WHICH.say } }; f(1); | 05:22 | |
camelia | rakudo-moar bccd76: OUTPUT«IntInt» | ||
skids | m: sub f (::T $a) { { my T $b; T.WHICH.say; $b.WHICH.say } }; f(1); | ||
camelia | rakudo-moar bccd76: OUTPUT«IntMethod 'WHICH' not found for invocant of class 'T' in sub f at /tmp/BRvz9zBD_p:1 in block <unit> at /tmp/BRvz9zBD_p:1» | ||
skids | This underlying bug caused the elide-type code to break: | ||
m: :(::T $a, T $b).perl.say | |||
camelia | rakudo-moar bccd76: OUTPUT«Method 'WHICH' not found for invocant of class 'T' in block <unit> at /tmp/WOh7wT2yZO:1» | ||
05:23
coffee` left
|
|||
skids tries to find an RT | 05:23 | ||
lizmat catches some more sleep | 05:28 | ||
05:33
vendethiel joined
05:35
Akagi201 joined
05:37
coffee` joined
05:40
telex left
05:42
telex joined,
Akagi201 left
05:46
Psyche^ joined,
Akagi201 joined
05:48
skids1 joined
05:50
Psyche^_ left,
skids left
05:52
g4 joined,
g4 left,
g4 joined
05:54
Gruber joined
|
|||
skids1 submits RT#125537 | 05:55 | ||
05:57
_mg_ joined
05:58
_mg_ left
05:59
_mg_ joined
|
|||
kanl | my $s = '[foo:bar]'; $s.= subst: /'[' (\w+) ':' (\w+) ']'/, "baz.$0-$1"; ( $/, $0, $1, $s )>>.say; | 06:02 | |
06:03
diana_olhovik_ joined
|
|||
skids1 | m: my $s = '[foo:bar]'; $s.= subst: /'[' (\w+) ':' (\w+) ']'/, "baz.$0-$1"; ( $/, $0, $1, $s )>>.say; | 06:04 | |
camelia | rakudo-moar 2904f3: OUTPUT«Use of Nil in string context in block <unit> at /tmp/D9SoMUZWyc:1Use of Nil in string context in block <unit> at /tmp/D9SoMUZWyc:1baz.-「foo」「bar」「[foo:bar]」 0 => 「foo」 1 => 「bar」» | ||
kanl | skids: thanks. | 06:07 | |
m: my $s = '[foo:bar]'; $s.= subst: /'[' (\w+) ':' (\w+) ']'/, "baz.$0-$1"; $s.say; | |||
camelia | rakudo-moar 2904f3: OUTPUT«Use of Nil in string context in block <unit> at /tmp/eLzq5gebaI:1Use of Nil in string context in block <unit> at /tmp/eLzq5gebaI:1baz.-» | ||
kanl | hmm.. not getting why it's not replacing. | 06:09 | |
skids1 | m: my $s = "[foo:bar]"; $s .= subst: /"[" (\w+) ":" (\w+) "]"/, { "baz." ~ $_[0] ~ "-" ~ $_[1] }; ( $/, $0, $1, $s )>>.say; | 06:13 | |
camelia | rakudo-moar 2904f3: OUTPUT«baz.foo-bar「foo」「bar」「[foo:bar]」 0 => 「foo」 1 => 「bar」» | ||
skids1 | The match is passed to the second argument as an argument, not put in $/. | ||
(not totally sure it should not be in $/ as well) | 06:14 | ||
kanl | skids1: thank you. | 06:17 | |
[Tux] | I know, I know, work in prgress, but today I see additionall slowdown. just FYI | ||
test 50000 44.229 44.140 | |||
test-t 50000 42.542 42.454 | |||
06:28
RabidGravy joined
06:31
[Sno] left
|
|||
RabidGravy | morning! | 06:44 | |
06:53
domidumont joined
06:57
domidumont left,
kanl left
06:58
domidumont joined
06:59
rurban joined
07:03
kanl joined
|
|||
kanl | m: sub foo( *%h ) { %h.say }; foo( a => 1 ); foo( 'a%' => 1 ); | 07:06 | |
camelia | rakudo-moar 2904f3: OUTPUT«a => 1Too many positionals passed; expected 0 arguments but got 1 in sub foo at /tmp/Nr_YC7kyJj:1 in block <unit> at /tmp/Nr_YC7kyJj:1» | ||
kanl | m: sub foo( *%h ) { %h.say }; foo( a => 1 ); foo( | hash 'a%' => 1 ); | 07:08 | |
camelia | rakudo-moar 2904f3: OUTPUT«a => 1a% => 1» | ||
kanl pulls hair | |||
moritz | m: sub foo( *%h ) { %h.say }; foo( a => 1 ); foo( |{'a%' => 1} ); | 07:09 | |
camelia | rakudo-moar 2904f3: OUTPUT«a => 1a% => 1» | ||
07:10
Woodi joined,
cdc_ joined,
dams_ joined
|
|||
kanl | why wouldn't "naked" 'a%' => 1 work like a => 1? | 07:10 | |
07:10
garu_ joined,
rvchangue_ joined
07:11
cdc left,
dams left,
rmgk left,
salv0 left,
rvchangue_ is now known as rvchangue,
salv00 joined,
rmgk joined
07:12
pRiVi joined
|
|||
moritz | kanl: because pairs with quoted LHS don't count as named arguments | 07:12 | |
kanl | to an unsophiscated user like me, the intuitive thing is, either both work, or both fail. | ||
moritz | m: sub f(*@pos, *%named) { say "pos: @pos.perl(); named: %named.perl()" }; f a => 1; f 'a' => 1; | 07:13 | |
camelia | rakudo-moar 2904f3: OUTPUT«pos: []<>; named: {:a(1)}<>pos: [:a(1)]<>; named: {}<>» | ||
07:15
Akagi201 left
07:16
rurban left
|
|||
kanl | i can appreciate the explanation, but (to rant) do not love the subtle differences in various things. | 07:16 | |
07:18
[Sno] joined
07:20
darutoko joined
07:21
rurban joined
|
|||
moritz | kanl: how would you all passing of literal Pairs to named parameters? | 07:23 | |
s/all/allow/ | |||
07:28
phdphil left
07:30
amurf left
07:31
rurban1 joined
07:33
rurban left
07:35
zakharyas joined
07:36
Woodi left,
Woodi joined
07:48
laouji left
07:51
fxbrain joined,
laouji joined
07:53
laouji left,
laouji joined
07:56
skids1 left,
rindolf joined
08:10
yeahnoob left
08:22
laouji left,
rurban joined
|
|||
masak | morning, #perl6 | 08:22 | |
or, um, antenoon. | 08:23 | ||
BooK | sssh, don't wake the americans | ||
08:24
laouji joined
|
|||
ShimmerFairy | masak: I've got a truly horrendous script that counts the partitions in the 2D version of hexslide, I'll put it up in a little bit :) | 08:24 | |
masak | ShimmerFairy: I played around with some ideas yesterday too. it looked promising, but nothing conclusive. | ||
ShimmerFairy | masak: The most annoying thing about hexslide I've found is that I don't have the mathematical knowledge to formally prove the conjectures I have, so nothing is 100% certain for me. | 08:25 | |
masak | ShimmerFairy: we could discuss it over privmsg if you want. | ||
ShimmerFairy | Perhaps :) | 08:26 | |
BooK | doc.perl6.org/routine.html # how is this generated? I'd be willing to add html anchors so one could link to a specific routine directly (at least the ones with an alphabetical name) | 08:29 | |
masak | BooK: think it's this one: github.com/perl6/doc/blob/master/htmlify.p6 | 08:35 | |
BooK | masak: cool, will have a look | 08:37 | |
I'm also recording my travel into the perl 6 realm | |||
08:37
rurban1 left
|
|||
masak | \o/ | 08:38 | |
BooK | can any unicode character be used to define operators? | 08:41 | |
DrForr | Nope. | 08:42 | |
ShimmerFairy | masak: here is the horrid code: github.com/lue/hexslide | ||
DrForr | The first exception is any combining character, which IMO is a real bummer, and sort of contravenes Unicode Tech Note #25. | ||
08:43
Akagi201 joined
|
|||
DrForr | They're treated as part of the identifier, not as a standalone character. Which is fine for most cases, such as umlauts, cedilla and diaresis. | 08:44 | |
masak | ShimmerFairy: kudos on the README | ||
DrForr | But IMO anything with an IsMath property shouldnt' appear in an identifier. | ||
BooK | DrForr: is the charactestics of what can be used documented somewhere? | ||
masak | ShimmerFairy: "It's recommended that you keep all row/column names unique" -- no, it's necessary to keep all row/column names unique :) don't make the problem harder than it already is :) | 08:45 | |
08:45
darutoko- joined
|
|||
DrForr | Not to my knowledge, but I haven't investigated the relevant docs. | 08:45 | |
ShimmerFairy | masak: considering how the regex works, you _could_ get away with non-unique names, but you really, _really_ shouldn't :) (it matches characters from the name specification part, so as long as the second through last characters of a piece contain one unique name, the regex could maybe figure out what you were going for) | 08:46 | |
masak: Also, just noticed an error in the conjecture in the README, in case you spot it too (fixed it) | 08:48 | ||
08:48
darutoko left
|
|||
RabidGravy | in a case where I want to do something like "method do-something { ... start { self.do-something-else } }" is it best to get the self as an argument instead? | 08:51 | |
masak | ShimmerFairy: in fact, I would be even more boring than you currently are in your format. | 08:52 | |
RabidGravy | i.e "method do-something(Thing $self:) { ... start { $self.do-something-else } }" ? | ||
masak | ShimmerFairy: I'd specify rows and columns like this: "ABCD\n123\n" | ||
BooK | still experimenting. | ||
masak | ShimmerFairy: or maybe even leave that out, and have the program assign those names. | 08:53 | |
BooK | find / | perl6 -e 'run( <rev>, :out, :!chomp ).out.lines.say' # why does this only give me the first 100 lines and '...' at the end? | ||
ShimmerFairy | masak: yeah, the reason why I did it visually was so I didn't have to spend so much time trying to visualize rows and columns mentally :) | ||
masak: and letting you specify your own names somehow seemed the easier route to me :) | 08:54 | ||
masak | ShimmerFairy: your conjecture at the bottom is trivially true. but it's an "if", not an "if and only if", so it's not that interesting. | ||
ShimmerFairy: it's not the easier route. if you want to have a board to look at, allow `#` comments in the format instead. :) | 08:55 | ||
BooK | find / | perl6 -e '.say for run( <rev>, :out ).out.lines' # DWIM, i.e. prints all lines, without hanging | ||
ShimmerFairy | masak: well, my current idea of dividers are that they are spots that will always be taken by a piece, so there's no way to clear them. I'd be interested in getting a counterexample | ||
08:56
espadrine joined
|
|||
masak | oh, I see. | 08:56 | |
RabidGravy | BooK, I think it's something to do with the .gist on the List | ||
masak | that seems tricky to define somehow. but maybe it can be done. | ||
RabidGravy | you can also do .... list>>.say | ||
ShimmerFairy | (also, the ease in specifying names was in not having to spend time figuring out One True Naming System for things in general) | 08:57 | |
RabidGravy | lines rather | ||
.. lines>>.say | |||
ShimmerFairy | masak: my code recursively finds dividers (starting with fake dividers surrounding the board) from all the pieces until no new dividers show up. It basically moves pieces to the extremes they can go to, and takes the overlap as dividers. | 08:58 | |
masak | I think I just figured out why I don't like the .say method form most of the time. | ||
because it puts the important thing too far to the right in the statement. it should be up front, at the left. | |||
which I guess is why I'm fine with `.say;` in loops and stuff | |||
so it's not so much the .say method as a method I don't like, it's syntactically mis-balancing the statement. | 08:59 | ||
ShimmerFairy | masak: with a special case before that recursive search for "intra-groove" dividers (caused by things like <>.<> creating vertical groove dividers .X.X. ) | ||
BooK | RabidGravy: yup, my first use of » | ||
ShimmerFairy | I usually use .say when I'm typing the line and I realize I forgot to put "say" in front :P | ||
BooK | now how do I silence the standard error | ||
RabidGravy | grooviness, special bonus points and stuff if you use » | ||
BooK | meh, the error I see is not from rev, it's from find | 09:00 | |
so perl can't do anything about it | |||
RabidGravy | Boo! bad find bad! bad! | ||
masak | ShimmerFairy: that doesn't sound like a way to end up with a readable program. | 09:01 | |
ShimmerFairy | masak: check my script, and you'll see that's so far true :P | ||
masak | (doing something because you forgot something) | ||
RabidGravy | » is one of the few unicode operators I use as I can remember how to type it | 09:02 | |
ShimmerFairy | oh, talking about .say :) | ||
masak: Usually for one-liners, as in perl6 -e '... @a.sort.grep({stuff}). .oO(oh hey I forgot to put a say in front, I'll just tack it on the end instead of cursoring back to the beginning) .say' | 09:03 | ||
masak | ok, fair enough. it's a question of scale. script vs application. | 09:04 | |
still, I have little sympathy for that line of reasoning, because *I don't forget to put `say` at the beginning*. :P | |||
I don't really see how that would happen. :) | |||
dalek | ok: d3296e5 | PerlJam++ | src/preface.pod: Update section on obtaining Rakudo |
09:05 | |
ok: fa18755 | PerlJam++ | src/regexes.pod: Add a little more explanatory text |
|||
masak | (cue someone digging up a place in the backlog where masak feeds camelia something without a `say` at the beginning...) | ||
dalek | ok: ad5d765 | PerlJam++ | src/regexes.pod: a few other minor edits |
||
ok: 54fc3fa | PerlJam++ | src/basics.pod: Some wording updates |
|||
BooK | I need to find a way to ignore dalek highlighting me | ||
ShimmerFairy | masak: it happens :) I have a hard time dealing with 2D arrays even! (So when I rewrite the script I shared to make it readable, it'll _definitely_ feature enough code where I don't constantly have to make sure I got the rows and columns right) | ||
masak | I don't really see what's so hard about 2D arrays. | 09:06 | |
BooK | fooling around with infinite streams, I get "Malformed UTF-8" errors | ||
masak | m: my @board = [1, 2], [3, 4]; say @board[1][0] | ||
camelia | rakudo-moar 2904f3: OUTPUT«3» | ||
masak | voilà, 2D array | ||
BooK | I'm surprised :bin does not help | ||
masak | BooK: me too. | 09:07 | |
BooK | oooh I need to set :enc | ||
masak | even for :bin ? | ||
BooK | looks like | ||
ShimmerFairy | masak: the problem is my brain doesn't automatically know how to interpret @board[1][0] ; not in the same way I automatically know what @board[2] means. | 09:08 | |
BooK | doc.perl6.org/type/IO%3A%3AHandle#E...ng_options # reading this, it feels like :bin and :enc are mutually exclusive | 09:09 | |
ShimmerFairy | It's just something weird about my brain, not too big a deal. It just means I'd ideally label which one is the row number and which one is the column number :) | ||
masak | ShimmerFairy: seems more like a mental barrier (fixable with conditioning) than a language problem :) | ||
ShimmerFairy: write a sub so that you can pos(@board, :$row, :$column) :) | 09:10 | ||
ShimmerFairy | BooK: well, considerings encodings are about text files, not binary ones... | ||
masak | ShimmerFairy: then it's hard to go wrong :) | ||
RabidGravy | BooK, well if you supply :bin it totally ignores any :enc so yes | ||
ShimmerFairy | masak: of course, I'm not blaming the language at all, it's definitely a conceptual issue of some kind :) (the reason why I fought through it with the listparse.p6 script, instead of defining convenience functions, was in an interest to get something working as fast as possible) | 09:11 | |
jnthn | Make sure to use .read/.write with a binary file | ||
BooK | find / -type f | xargs cat | perl6 -e 'run( <cut -b 1-8>, :out, :bin ).out.lines».say' # then why does this die with Malformed UTF-8 in block <unit> ? | ||
jnthn: ooh, say expects text ? | |||
jnthn | BooK: More immediately, .lines returns a List of Str | 09:12 | |
BooK | i see | ||
jnthn | Str being at Unicode grapheme level. .read/.write work in terms of Buf, which is the byte level thing. | ||
BooK | "A file opened with :bin may still be processed line-by-line, but IO will be in terms of Buf rather than Str types." | 09:13 | |
ShimmerFairy | masak: it's also precisely why I have a visual name specifier for the boards. I think I did consider supporting comments, but I didn't want to go through the trouble of adding that in for a "simple text file" :) | 09:14 | |
BooK | so how do I iterate on the Buf? | ||
masak | ShimmerFairy: don't make the problem more difficult to solve than it already is. there's essential complexity, and then there's complexity you add on top of that. | 09:15 | |
jnthn | BooK: Just put it in list context somehow | 09:16 | |
m: for @('abc'.encode('utf-8')) { .say } | |||
camelia | rakudo-moar 2904f3: OUTPUT«979899» | ||
ShimmerFairy | masak: for sure, the script as it stands is the result of going for whatever seemed faster to do at the moment (whether or not it actually was). I'll get to reworking it soon for readability and general sanity :) | 09:17 | |
09:18
amurf joined
|
|||
BooK | jnthn: I have run( <cut -b 1-8>, :out, :bin ).out | 09:19 | |
so I guess I need to .read($bytes) from it | |||
jnthn | BooK: I guess so; I'm a bit behind on the latest IO bits, I'm afraid.. | 09:20 | |
BooK | can't yet figure out a way to get a stream of Buf of size $bytes from that | 09:21 | |
which I'll then be able to ».write($*OUT) I guess | |||
jnthn | gather { while $handle.read(256) -> $buf { take $buf } } # or so | 09:22 | |
09:23
amurf left
|
|||
kanl | moritz: i don't know. while i appreciate named parameters, i do miss being able to 'slurp' in k => v pairs via @_, without caring whether the lhs is quoted or not, like in p5. e.g. my %named = @_; | 09:25 | |
RabidGravy | I'm guessing that it's the content of "binary" files that is shagging it up | 09:26 | |
e.g. find . -type f -name '*.pm' | xargs cat | perl6 -e 'run( <cut -b 1-8>, :out ).out.lines».say' works fine | 09:27 | ||
BooK | RabidGravy: yes it is | ||
09:31
TEttinger left
|
|||
RabidGravy | On a completely unrelated note regarding tutorials etc has anyone mentioned www.livecoding.tv/ ? | 09:31 | |
BooK | can't find the doc for gather/take in doc.perl6.org | 09:32 | |
kanl | moritz: but thanks for the demonstration. i guess i can just easily do { %named.push: @pos } | 09:33 | |
RabidGravy | BooK, I think take is only documented in docs.perl6.org/routine/take | 09:35 | |
gather nowhere as far as I can tell, this probably should be remedied | 09:36 | ||
BooK | although I have a hard time getting this oneliner running, I really like that Perl6 does not let you get away with the ambiguity of a chunk of bytes being used as a string and the other way around | 09:38 | |
this is annoying, but I'm sure this prevents a lot of bugs that are more annoying | 09:39 | ||
RabidGravy | yeah, it definitely stops you from getting shagged up multibyte characters being rendered as ascii | 09:40 | |
09:44
bin_005 joined
09:53
brrt joined
10:00
ggoebel2 left
10:10
wolf_work joined
10:13
domidumont left
10:14
domidumont joined
10:15
rurban1 joined
10:17
fxbrain left,
Woodi left
10:21
rurban1 left,
darutoko joined,
bjz joined
10:23
darutoko- left
10:24
Woodi joined
10:27
aborazmeh joined,
aborazmeh left,
aborazmeh joined
10:32
Akagi201 left
10:34
kanl left
10:40
RabidGravy left,
virtualsue joined
10:54
Dee22 left
10:56
yqt joined
11:01
aborazmeh left
11:04
bin_005 left
11:06
rurban1 joined
11:08
amurf joined
11:12
amurf left
|
|||
BooK | ok, so I only have annoting questions | 11:17 | |
annoying | |||
11:17
cognominal joined,
cschwenz joined
|
|||
masak | shoot | 11:18 | |
BooK | like, how do I portably set the locale+encoding for a program I'll call with run() | ||
moritz | locale through %*ENV, I guess | 11:20 | |
and encoding with :enc | |||
masak | moritz++ beat me to it :) | ||
moritz | portable? locales aren't portable | 11:21 | |
masak .oO( you can't just pick France up and carry it to Egypt! ) | |||
BooK | they aren't ? | ||
moritz | I don't think so | ||
BooK | indeed the key word was "portably" | ||
like, does windows respect it? | 11:22 | ||
moritz | I'm not aware of a windows locale mechanism, except system (or maybe user)-wide | 11:23 | |
I don't see how Perl 6 could change that for existing windows programs | |||
BooK | oh well, I guess I have to know how to tell the program I'm run()ing which encodibg to expect from me, and which I expect from it | ||
I was somehow hoping some combination of LC_ALL to magically fix the issue for me :-) | 11:24 | ||
obviously, I'm a dreaming optimistic | |||
11:24
laouji left
11:32
rurban1 left
|
|||
lizmat | re irclog.perlgeek.de/perl6/2015-07-03#i_10843541 : I would like to reiterate my stance that we should disambiguate :a(42) and a => 42 notation | 11:32 | |
11:33
Akagi201 joined
|
|||
lizmat | into :a(42) *always* being a named parameter, and a => 42 *always* being a Pair constructor | 11:33 | |
foo( :a(42) ) would this always be a named parameter | |||
foo( a => 42 ) would always be a positional Pair | 11:34 | ||
</rant> | |||
sjn | in what way are those two different? (I'd assume that a named parameter _is_ a pair) | 11:35 | |
jnthn | They're the same today | 11:36 | |
The discontinuity is in "a" => 42 | |||
Where the LHS is not an auto-quoted literal | |||
One immediate reason is that efficient compilation of named parameters comes a lot more difficult when you don't know the names at compile time. | |||
11:37
Akagi201 left
|
|||
masak | I think we can shove the discontinuity around, but there will always be one, and it will always chafe a bit. | 11:38 | |
the reward of putting the discontinuity in a better place should be weighed against the breakage to the ecosystem the move will inevitably cause. | 11:39 | ||
ShimmerFairy | It would be nice if there were a clearer distinction between Pairs and named arguments, methinks | ||
moritz | there is. | ||
masak | what moritz said. | ||
moritz | oh, "clear*er*" | ||
sjn wonders about the circumstances around not knowing names at compile-time | |||
jnthn | sjn: |($key => $value) works | ||
And looks like more effort, and probably costs at least 10 times as much | 11:40 | ||
ShimmerFairy | masak: I guess I'm misunderstanding the problem then. Isn't the issue that a => 42 is treated the same as :a(42) | ||
jnthn | ShimmerFairy: I don't consider that an issue | ||
sjn | jnthn: right. | ||
jnthn | Anyway, I think I'm just going to shoot this down with "no, too late" | ||
I'm not interested in revisiting such fundemental things now. | 11:41 | ||
ShimmerFairy | or "please try again in 6.1" :P | ||
11:41
brrt left
|
|||
jnthn | And I don't particularly dislike the way it is now anyway. | 11:41 | |
11:41
dayangkun left
|
|||
jnthn | I think foo => ... looks nicer than :foo(...) in a lot of cases too | 11:41 | |
masak | I agree with "too late". | 11:42 | |
timotimo | you can still slang it | ||
masak | I use both forms, and I never encounter any bugs due to confusion. it's a matter of learning the (simple) rules. | ||
timotimo: yes, and that. thanks. | |||
11:42
laouji joined
|
|||
timotimo | :) | 11:42 | |
nine | lizmat: FWIW I'd miss => for named arguments because it makes lining up vertically easy. Also because I'm just so used to it from Perl 5 :) However I do think that the difference between a => 42 and 'a' => 42 is one of the few warts that got added with Perl 6. | 11:43 | |
ShimmerFairy | The only named parameter issue I run into is implict *%_ :) | 11:44 | |
*implicit | |||
timotimo | hehe | ||
jnthn | The implicit *%_ is one thing I'd like to see addressed pre-6.0, yes | ||
lizmat | I think it is a wart on the same scale as sigil variance in Perl 5 is | ||
timotimo | oh wow | ||
that's a harsh wart | 11:45 | ||
lizmat | like, a hell to teach newbies | ||
masak | then you write a slang where that wart is gone. | ||
and you promote it at conferences, telling people why. | |||
lizmat | but, having had a "too late" from both jnthn and masak, I will not bring this up again | ||
I will reserve the right to say "I told you so" in the future :-) | 11:46 | ||
nine | It's absolutely surprising and non-obvious | ||
masak | lizmat: I do that a lot :P | ||
ShimmerFairy | I do want to point that, for me at least, :a(42) and a => 42 seem like different things, at least to me (one is "when I want to give a named parameter", one is "when I want a pair"), so I can see possible issues with Perl 6 not holding the same views | ||
masak | has someone said harsh words about the use of parens, too? like (a => 42)? | 11:47 | |
timotimo | i value being able to use :a(42)and a => 42 interchangably for named parameters | ||
masak | m: sub foo(*@poses, *%nameds) { say +@poses, "; ", +@nameds }; foo( a => 42 ); foo( (a => 42) ) | 11:48 | |
camelia | rakudo-moar 2904f3: OUTPUT«5===SORRY!5=== Error while compiling /tmp/t_OJ32oBBqVariable '@nameds' is not declared. Did you mean '%nameds'?at /tmp/t_OJ32oBBq:1------> 3@poses, *%nameds) { say +@poses, "; ", +7⏏5@nameds }; foo( a => 42 ); foo( (a => 42» | ||
masak | m: sub foo(*@poses, *%nameds) { say +@poses, "; ", +%nameds }; foo( a => 42 ); foo( (a => 42) ) | ||
camelia | rakudo-moar 2904f3: OUTPUT«0; 11; 0» | ||
masak | I think I was a little upset first time I saw that. | ||
ShimmerFairy | timotimo: I don't disagree, I'm simply stating that they _feel_ like different things; => looks Pair-like and :() looks parameter-like | ||
masak | because Perl also believes that "parentheses are only for grouping" | ||
timotimo | masak: the pair gets to be its own group :) | 11:49 | |
masak | ShimmerFairy: but... named parameters are implemented as pairs, and that implementation is exposed/sold pretty heavily to the user. (through slurpies and flattening, etc) | ||
ShimmerFairy: saying that they look like one another is missing that it's a feature, not a bug. | |||
ShimmerFairy | masak: I understand that (and it's pretty nice, I think), but I can't pretend that I don't see the two syntaxes in a lightly different way from each other. | 11:50 | |
masak | ShimmerFairy: ...aaaand again the problem that needs fixing is inside your mind, not outside it ;) | ||
ShimmerFairy | masak: basically, even though %h = :a(1), :b(2) is perfectly fine, it looks really weird to me (but foo(a => 1) doesn't really look weird. Huh.) | 11:52 | |
masak .oO( Perl 6: "it's easy to use if you just learn this simple rule" -- ShimmerFairy: "but it doesn't work when I use this different rule!" ) | |||
11:53
yqt left
|
|||
masak | I'm one of your "get off my lawn" types, even though I joined somewhere around 2005. I remember a time before we had the :a(42) syntax. | 11:53 | |
so your only choice was a => 42 | |||
so I guess I always think of the former as convenient sugar for the latter | 11:54 | ||
and *boy* is it convenient! | |||
not only :$a, but also things like :$^a and :$!a | |||
ShimmerFairy | And :42a is even more convenient! :) | ||
masak | ShimmerFairy-- # you deserve that one :) | ||
I don't take away karma lightly :> | 11:55 | ||
ShimmerFairy | aw :< | ||
masak | :42a syntax has *exactly* one use, in my world: :2nd et al | ||
jnthn | m: :100ways-to-annoy-masak | ||
camelia | ( no output ) | ||
jnthn | :) | ||
lizmat | ShimmerFairy++ # need to compensate | 11:56 | |
masak | jnthn-- # don't get to do this often :) | ||
the colon syntax for named args is so convenient that it has affected the way I name variables before a call. | |||
jnthn | :D | ||
lizmat | masak: my only argument is that it should be used for named args exclusively | 11:57 | |
masak | I'm more likely to name a callee argument variable after a parameter, because of the colon syntax. | ||
lizmat: I guess what I'm saying is I don't see it that way, because I was present when it was introduced as sugar. | |||
lizmat: to me, a => 42 is the "real" way to write a named arg | |||
lizmat: and I'm lucky enough to *also* get to write it as :a(42) or :$a or :$.a because Perl 6 is awesome | 11:58 | ||
some day I might cook up a slang that allows me to write :$<a>, by the way :) | |||
ShimmerFairy | m: say DateTime.new(:1year); # tell me this doesn't look cool, masak :P | ||
camelia | rakudo-moar 2904f3: OUTPUT«0001-01-01T00:00:00Z» | ||
masak | ShimmerFairy: you... have a point. | ||
ok! two uses! but that's *it*! :P | 11:59 | ||
ShimmerFairy | (too bad you can't do :2years , since there's no :$years) | ||
11:59
rindolf left
|
|||
ShimmerFairy | .oO(use Slang::PluralNamedArgsSometimes;) |
11:59 | |
12:00
jantore joined
|
|||
masak | ShimmerFairy: in fact, the .later and .earlier methods on Date/DateTime do support :years | 12:01 | |
12:01
rindolf joined
|
|||
ShimmerFairy | Interestingly: | 12:01 | |
m: say DateTime.new(:1month); | |||
camelia | rakudo-moar 2904f3: OUTPUT«Must provide arguments to DateTime.new() in block <unit> at /tmp/7IgHuCh4M1:1» | ||
ShimmerFairy | DateTime's constructor complains if you don't have :year , but the error message doesn't tell you that at all. | ||
masak | ShimmerFairy: nice find. please submit a rakudobug and/or make a patch :) | 12:02 | |
ShimmerFairy++ ++ShimmerFairy | |||
ShimmerFairy | Looks like a simple fix (just have to change the error message; should I spectest a change regardless, in the interest of paranoia?) | 12:06 | |
moritz | yes please | ||
paranoia++ | |||
ShimmerFairy | That's what I thought. "It's just a simple string!" (but you never know...) :) | 12:07 | |
I'm assuming TEST_JOBS is the only parallelization feature? | 12:12 | ||
timotimo | yeah | ||
er ... for what exactly? | |||
ShimmerFairy will be doing a before and after spectest, just so she's absolutely sure | |||
moritz | and you can build with 'make -j' or 'make -j4' | ||
ShimmerFairy | timotimo: for testing a change I'll be making | 12:13 | |
moritz: Ah, forgot to specify I was talking about testing parallelization | |||
timotimo | building with -j* sadly doesn't help very much | 12:14 | |
ShimmerFairy | not for rakudo, at least :( | ||
masak | does someone want to reply to Tom's latest p6u email? | 12:15 | |
moritz | it does do the 'git pull' in roast in parallel with the build | ||
which helps on slow networks | |||
masak | looks pretty easy -- he doesn't seem aware that 0 boolifies to False. | ||
moritz | aye | 12:16 | |
masak: seems like you want to answer :-) | |||
masak | I can do that. | ||
ShimmerFairy | Heh, my network incidentally is being slow atm, thanks to ~certain people~. | ||
masak | main reason I was checking is that there's some lag on p6u so many people tend to give the same answer | ||
lizmat | masak: maybe also mention .starts-with("#") | ||
12:18
cschwenz left
12:19
raiph joined
|
|||
masak | lizmat: oops, sent without seeing the above. | 12:20 | |
lizmat: feel free to add that in a separate reply ;) | 12:21 | ||
lizmat | will do | ||
masak | (my email was about everything else) | ||
BooK | I like using :a for a => True | 12:27 | |
timotimo | me, too | ||
and of course the :$foo form is a very nice thing indeed | |||
ShimmerFairy | masak: good thing "0" doesn't boolify to False anymore, though :) (...right?) | 12:28 | |
lizmat | mail sent | ||
timotimo | right, ShimmerFairy | 12:29 | |
moritz | m: say ?'0' | ||
camelia | rakudo-moar 2904f3: OUTPUT«True» | ||
lizmat | m: say +'0' | ||
camelia | rakudo-moar 2904f3: OUTPUT«0» | ||
lizmat | m: say +?'0' | ||
camelia | rakudo-moar 2904f3: OUTPUT«1» | ||
lizmat | :-) | ||
jnthn | m: say ?+'0' | ||
camelia | rakudo-moar 2904f3: OUTPUT«False» | ||
timotimo | m: say say ?+~?'0' | ||
camelia | rakudo-moar 2904f3: OUTPUT«FalseTrue» | ||
timotimo | er | 12:30 | |
%) | |||
m: say ?~?'0' | |||
camelia | rakudo-moar 2904f3: OUTPUT«True» | ||
lizmat | .oO( stop stop stop! this is getting way too silly! ) |
||
ShimmerFairy | m: my @a = 1,2,3; say +^@a; # always a weird typo to leave unnoticed | ||
camelia | rakudo-moar 2904f3: OUTPUT«-4» | ||
12:31
Akagi201 joined
|
|||
timotimo | ouch, that's mean :) | 12:31 | |
12:31
Akagi201_ joined
|
|||
ShimmerFairy | In case it's not obvious, it's supposed to be ^+@a . There have been a couple of times where I wondered why there was this unwanted negative number for an index inside a for +^@a { ... } | 12:32 | |
timotimo | took me a few seconds | 12:33 | |
i don't do bitwise ops often in p6 | 12:34 | ||
ShimmerFairy | Yeah, I think prefix:<+^> is particularly uncommon, at least in my experience. | ||
12:35
shlomif joined,
rindolf left,
shlomif is now known as rindolf
|
|||
ShimmerFairy | By the way, what about the bitwise string ops? Do they no longer work on Stringy types, because S03 itself says it indicates a design error? :) | 12:35 | |
12:35
Akagi201 left
|
|||
timotimo | welllll~ | 12:36 | |
stringy things are NFG now .. | |||
so how does that work :D | |||
oh, obviously we also need stringy set ops that go grapheme-wise and act on combining characters | |||
ShimmerFairy | "hello" ~& "world" :carefully | 12:37 | |
12:37
rurban1 joined
|
|||
jnthn |  | 12:37 | |
BooK | timotimo: is :$foo an indirection? | ||
ShimmerFairy | timotimo: I'm of the opinion that the bitwise string ops should have never been defined for anything more than buffers. (Have you see that S32::Stringy I wrote a looong time ago and have shared a few times recently, by any chance?) | 12:38 | |
timotimo | BooK: no, it's short for foo => $foo | ||
jnthn | The hell did I just paste... | ||
timotimo | ShimmerFairy: i think i saw it | ||
jnthn: it's a small image, possibly an icon? | |||
BooK | oh, nice | ||
ShimmerFairy | jnthn: Base64 data of an image. Because. | ||
jnthn | epic fail | ||
BooK | depends on an image of what it is... | ||
jnthn | It was supposed to be a meme :P | 12:39 | |
ShimmerFairy | could be worse; could've been a moderately-sized image :P (or, your client wouldn't've cut off the data) | ||
jnthn | Apparently instead of giving me a link to an image, it gave me a data: protocol URL with the whole image :P | ||
BooK | so undecidably safe for work | ||
jnthn | Not at all, it was one about bitwise ops :P | 12:40 | |
timotimo | i'm not entirely sure if that's the picture you pasted or my browser telling me the data is broken | ||
because it looks like an icon for a broken image %) | |||
jnthn | heh | ||
jnthn goes back to writing code :) | |||
ShimmerFairy | timotimo: the pasted stuff looks suspiciously like it ends at the cutoff length for IRC messages | ||
BooK | jnthn: I just realized we've known each other for about ten years... | 12:41 | |
timotimo | ah, of course | ||
ShimmerFairy | By the way, what kind of Uniform Resource Locator doesn't locate the resource, but just gives it to you instead? :P | ||
timotimo | the one for content-addressed storage :) | 12:42 | |
BooK | chartreuse and fishnet, what a welcome in the perl community ;-) | ||
jnthn | BooK: Yes, YAPC::EU 2005 was my first YAPC and second Perl event :) | 12:43 | |
And what fun it was :) | |||
BooK++ # one of the folks who made me feel very welcome in the Perl community | 12:44 | ||
ShimmerFairy | fail "Must provide arguments to DateTime.new()"; <-- should "DateTime" be instead "{self.^name}", or is that thinking ahead too much? (Derived classes and so on) :P | ||
12:45
woolfy joined
|
|||
lizmat welcomes woolfy | 12:47 | ||
jnthn | woolfy! \o/ | 12:48 | |
masak | ShimmerFairy: "0" ? why would "0" boolify to false? that's insane. that'd be like the strings "nul", "zero" and "zilch" also boolifying to false :P | ||
woolfy | hey jnthn | ||
masak | woolfy! \o/ | 12:49 | |
ShimmerFairy | m: say ?"The Earth is flat."; # this is clearly a bug, masak | ||
camelia | rakudo-moar 2904f3: OUTPUT«True» | ||
masak | ShimmerFairy: well, I certainly welcome you submitting a patch to fix that one! | 12:50 | |
ShimmerFairy: don't just solve special cases, though. you have to come up with a general solution. | 12:51 | ||
jnthn | Just implement it by delegating to Rule 1... | ||
ShimmerFairy | sub prefix:<?>(Str:D $a) { Wikipedia::query($a) || StackOverflow::query($a) || ... } | 12:52 | |
woolfy | hey masak | ||
(just passing by, showing #perl6 to a friend)(byebye) | 12:53 | ||
12:53
woolfy left
|
|||
dalek | p/multidim: b296e1b | jnthn++ | src/vm/moar/QAST/QASTOperationsMAST.nqp: Map multi-dim array ops on MoarVM. |
12:54 | |
p/multidim: 8deb3b8 | jnthn++ | t/moar/02-multidim.t: Tests for VMArray supporting new multi-dim ops. Only run on MoarVM for now. This checks that existing dynamic arrays will play nice with the new multi-dim access APIs, which may ease some code-gen (but mostly checks the ops are basically functional). |
|||
p/multidim: 287814e | jnthn++ | docs/6model/repr-compose-protocol.markdown: Extend REPR array compose protocol for dimensions. |
13:00 | ||
13:00
lucasb joined
|
|||
lucasb | good friday to everyone | 13:01 | |
jnthn | .oO( he said crossly ) |
||
japhb | Just had to share this, as it cracked me up ... got a cold email from a recruiter today that begins "We’ve analyzed your open source contributions in Github, and we identified you as a potential good fit for a position as Software Developer at Booking.com." You mean, I wrote some Perl? | 13:04 | |
timotimo | %) | 13:05 | |
ShimmerFairy | japhb: got that too, seemed spammy | ||
lizmat didn't get that :-( :-) | 13:07 | ||
japhb | lizmat: Clearly you're nto qualified to work at Booking! ;-) | 13:08 | |
ShimmerFairy tries to imagine what :-( ... :-) would mean :P | |||
lizmat | yeah, not enough commits on github :-) | ||
japhb | ShimmerFairy: The :-( was tongue in cheeck, methinks | ||
Man, my connection from brain to fingers is a little broken today | 13:09 | ||
ShimmerFairy | japhb: I meant as a language construct :P (see how it's a matching pair?) | ||
rurban1 | we get a lot of excellent and qualified devs with no single github commit | ||
lizmat | that would qualify me :-) | ||
japhb | ShimmerFairy: I would think :-( and )-: would be the matching pair ... or (-: and :-) for the more positive | 13:10 | |
masak | what's the idiomatic way to call a MAIN multi from another? | 13:11 | |
ShimmerFairy | The only change I got in the spectest was a different Wstat for t/spec/S17-lowlevel/lock.rakudo.moar , but I imagine that's not surprising | ||
japhb | Emotion markers! "This is sad code ... and this is happy code!" | ||
masak: nextsame? | |||
lizmat | masak: samewith(...) | ||
tadzik | samwich() | ||
japhb goes to look in bench, I'm pretty sure I did that | |||
ShimmerFairy | masak: shell("$*PROGRAM-NAME ...") ? :P | 13:12 | |
japhb | Oh interesting, I just directly call MAIN with the appropriate args. | ||
masak tries samewith | |||
japhb wonders if that was once a backwards compat hack or something ... I've forgotten why I did it that way now. | 13:13 | ||
masak | ooh, interesting. that fails, with "Could not find 'self'"! | ||
lizmat | ah, of course | ||
masak | of course? | ||
lizmat | samewith is for methods... | ||
masak | m: multi MAIN() { samewith('foo') }; multi MAIN('foo') { "foo'd you!" } | ||
camelia | rakudo-moar 2904f3: OUTPUT«Could not find 'self' in sub MAIN at /tmp/b9x1yueixg:1 in block <unit> at /tmp/b9x1yueixg:1» | ||
masak | how is samewith for methods? | 13:14 | |
13:14
brrt joined
|
|||
japhb | m: multi MAIN() { nextwith('foo') }; multi MAIN('foo') { "foo'd you!" } | 13:14 | |
camelia | ( no output ) | ||
ShimmerFairy | Wouldn't it be nextwith/callwith ? | ||
japhb | m: multi MAIN() { nextwith('foo') }; multi MAIN('foo') { say "foo'd you!" } | ||
camelia | ( no output ) | ||
japhb | What ...? | ||
masak | japhb: I think `nextwith` uses the original list of candidates... | 13:15 | |
japhb | m: multi MAIN() { callwith('foo') }; multi MAIN('foo') { say "foo'd you!" } | ||
camelia | ( no output ) | ||
japhb | OK, that explains why I did it the old fashioned way, then. | ||
dalek | kudo/nom: 7b9145f | ShimmerFairy++ | src/core/Temporal.pm: Improved error message for missing :year in DateTime.new() |
||
13:17
xfix joined,
xfix left,
xfix joined
13:18
_mg_ left
|
|||
masak | jnthn: are we just unlucky with nextwith/samewith/callwith above, or is something broken, or have we misunderstood their purpose altogether? | 13:23 | |
does &?ROUTINE refer to a single candidate, or to all of them? | |||
jnthn | masak: nextwith/callwith iterate the existing candidate list | 13:24 | |
masak: If you supply incompatible arguments, that's your problem | |||
samewith...I don't know, I think lizmat++ added that and I think it re-dispatches | 13:25 | ||
But I don't see why it coudln't handle subs too | |||
I mean, callwith etc does | |||
masak | right. I was surprised about "only for methods". | ||
oh, well. | |||
lizmat | fwiw, it was one of my first implementations | ||
jnthn | I don't immediately see why we can't liberalize it to all routines | ||
lizmat | and I actually eradicated it from the core itself because of the overhead involved | ||
masak | it's not like MAIN is going to be refactored to have another name :) might as well write `MAIN` :) | ||
lizmat: mind if I submit a rakudobug for it not working with subs? | 13:26 | ||
lizmat | I don't :-) | ||
masak submits rakudobug | |||
obviously, `samesame` is missing from the set we currently spec/implement ;) | 13:34 | ||
timotimo | m: samesame | 13:35 | |
camelia | rakudo-moar 2904f3: OUTPUT«5===SORRY!5=== Error while compiling /tmp/bl347FUvYdUndeclared routine: samesame used at line 1. Did you mean 'callsame', 'samecase'?» | ||
masak | jnthn: S12:954 | 13:36 | |
synbot6 | Link: design.perl6.org/S12.html#line_954 | ||
masak | nextwith(1,2,3); # redispatch with a new set of arguments (no return) | ||
samewith(1,2,3); # same dispatcher with new arguments (no return) | |||
jnthn | masak: Uhh... | ||
masak | jnthn: makes it sound like it's `nextsame` the gets a new candidate list and `samewith` that keeps l'old one | ||
jnthn | Whoa | ||
When did that happen? | |||
masak | nextwith* | 13:37 | |
so in that case, I'd expect `nextwith` to have worked with MAIN... | |||
jnthn | I think next is the right name though; I mean, you're doing "next" on the candidate list... | ||
I think S12 is out of line. | |||
masak | no idea | ||
just reporting a discrepancy | |||
I find that redispatching on the *same* candidate list as the first time is almost never what I want to do anyway. | |||
in fact, I find I don't think naturally in terms of candidate lists when I code. I just think in terms of subs/methods with the same name but different signatures. | 13:38 | ||
jnthn | Remember that delegating to a base class is the most common use of these. | ||
masak | that is true. | ||
13:38
RabidGravy joined
|
|||
masak | yeah, I can see that use case making sense. | 13:39 | |
and that doesn't translate well to my MAIN case. | |||
answer from question before: &?ROUTINE refers to a single multi, not to all the multis. | |||
(as one might expect) | 13:40 | ||
jnthn | Oh, I expect it to refer to the leixcally enclosing routine | ||
masak | right. | ||
jnthn | &?ROUTINE.dispatcher # gets you the proto | ||
13:40
_mg_ joined
|
|||
masak | I'd rather write `MAIN` :P | 13:40 | |
gtodd | withnext withsame :) | ||
jnthn | Me too :P | ||
13:42
mr-foobar left
13:43
mr-foobar joined
13:45
telex left
13:46
telex joined
|
|||
hoelzro | morning #perl6 | 13:58 | |
13:58
abraxxa left
|
|||
hoelzro | I found some behavior using heredocs, and I'm not really sure what the right thing to do is | 14:00 | |
gist.github.com/hoelzro/3b1ff9951908c9ce5aa4 | |||
it's concerning how leading whitespace removal is handled when one has an embedded newline via \n in a heredoc | |||
14:02
g4 left
|
|||
timotimo | oh, interesting | 14:03 | |
i hadn't considered newlines that are escaped inside heredocs like that when i wrote the new dedenting code | |||
hoelzro | timotimo: I hadn't considered it either until I was converting code that used a single non-heredoc line and came across that =/ | 14:06 | |
I would file a ticket, but I don't even know if that's a bug. I don't even know what I expect it should do! | |||
timotimo | the latter part is the hard part | 14:07 | |
hoelzro | indeed | 14:08 | |
lucasb | Is there a way to dedent the heredoc literal text before expanding newline escape sequences? | 14:09 | |
hoelzro | TimToady may have to weigh in | ||
timotimo | at the point the dedent code gets a hold of it, the information of literal \n and escaped \n is no longer available ;( | 14:11 | |
masak | I'm... not sure I feel that's a bug... | ||
timotimo | in theory, the heredoc parser could emit the "required" number of spaces before a \n when it sees one | ||
that would get rid of the warning | |||
hoelzro | masak: "not sure" is the thing with me too =/ | ||
masak | what I see is a string with a newline with no spaces after it, which is fewer than the four spaces required. | 14:12 | |
that would normally qualify for the warning we see. | |||
I can understand the argument that this \n newline is not part of the heredoc's actual newlines, but... | |||
timotimo | hehe | ||
masak | ...I'm also not ready to tear up compiler internals just to fix this one. | 14:13 | |
but let's see if TimToady has some nice insight about it. | |||
colomon | why would you want to embed a \n in a heredoc? | 14:14 | |
masak | it's kind of related to (but not the same as) strangelyconsistent.org/blog/here-be-heredocs under the heading "Indentation, revisited" | ||
colomon: that's a good, but separate question :) | |||
we're exploring "what happens when you do?" | |||
I don't believe it should be illegal. | |||
hoelzro | colomon, masak: there's no good reason, I just found it interesting | ||
masak | it is interesting. | 14:15 | |
hoelzro | I was converting a long single double quoted string with multiple embedded newlines into a heredoc while refactoring a program | ||
masak | I mean, from the user's point of view, a \n in a heredoc isn't the same as a hard newline in a heredoc. | ||
hoelzro | right | ||
14:15
laouji left
|
|||
colomon | what happens if you embed a string with a newline in it? I actually do that quite a bit in my (mostly p5) scripts | 14:16 | |
masak | and the "Indentation, revisited" section chronicles when we decided (sort or) that only hard newlines should be indented (not newlines in interpolated strings) | ||
colomon: read the blog post I linked. | |||
colomon: there was a debate at some point. | |||
hoelzro | colomon: *that* is a really good question | ||
RabidGravy | hoelzro, you're interested in tutorial stuff have you seen www.livecoding.tv/ ? | ||
masak | hoelzro: yes, but it's been *resolved*. | ||
hoelzro: read the post :) | |||
hoelzro | masak: working on it =) | 14:17 | |
jnthn | I seem to remember I did it one way in the original herdocs impl in Rakudo, and something was off and got changed (probably what masak++ is referencing) | ||
masak | yes. | ||
hoelzro | RabidGravy: I did, but I don't know if I'm brave enough to do it live =S | ||
jnthn | I think I spliced in all the bits and then de-dented or something | ||
timotimo | that's right | ||
masak | yes. | ||
hoelzro | what's on YT is the result of lots of preperation, re-takes, and edits | ||
masak | which was surprising to users. | ||
timotimo | hoelzro: how long did it take you for just the recording phase? | 14:18 | |
masak | timotimo++ implemented the less surprising behavior for indentation. | ||
hoelzro | timotimo: I just had to do two takes, so I think 20-30m? | ||
jnthn | *nod* | ||
Yeah, the examples were pretty convincing. | |||
hoelzro | the live RT fixing took me a lot more takes, about 1h, iirc | ||
timotimo | <3 | 14:19 | |
masak | jnthn: not at first... it's one of the few times when I as a user supplied what I felt was a clear bug, and you as a compiler implementor gave a response equivalent to "orka!" :P | ||
jnthn: but that's all Yeti under the bridge. it works as expected now. :) | |||
14:21
khw joined
|
|||
dalek | kudo/nom: 9efa091 | lizmat++ | src/core/Backtrace.pm: Fix error in Backtrace generation, skids++ |
14:22 | |
kudo/nom: add2827 | lizmat++ | src/core/array_slice.pm: Make [*]:v and []:v slices slightly faster |
|||
jnthn | masak: Yes, well, being a compiler writer is one of those tasks where most interactions you have with users are when something doesn't work, 'cus when it does work they've little reason to come to you. And I can be pretty darn human about that sometimes. :) | 14:24 | |
masak | jnthn: nod. completely understandable. | ||
jnthn | VM writer is even more like that, 'cus mostly folks only get concious of the VM when it says SIGSEGV or panics :P | ||
(And yes, I do enjoy working on these things; it's just the nature of working on any infrastructural thing. You're building the stuff that people use to build the exciting shiny stuff, largely. :)) | 14:25 | ||
colomon | masak: believe it or not, indented heredocs was one of my main “must have p6 now!!!!” features back in 2004. | 14:26 | |
my $work scripts that generate C++ code use heredocs A LOT. | 14:27 | ||
and the fact that they cannot be indented has very serious effects on the readability of said code. | |||
hoelzro | colomon: hah, that's *exactly* what I was working on | ||
colomon | (err, the perl part, not the c++ part) | 14:28 | |
hoelzro | C++ generating code | ||
colomon | yes, generating C++ with Perl is one of my main tricks of my $work code | 14:29 | |
gtodd | colomon: hehe | 14:31 | |
timotimo | i had python code that generated c++ code some time ago | 14:32 | |
masak | jnthn: also worth pointing out that the "torment the implementor" counter-argument is always worth hearing out, even in the cases where we eventually decides to go ahead and make the implementation difficult | ||
colomon: as seen in that blog post, I was a latecomer to being enthusiastic in that way. but I'm all on board now. | 14:33 | ||
RabidGravy | I think for any given pairwise combination of languages I know I've written code in one to generate code in the other | 14:34 | |
colomon | masak: April of this year? Yeah, you were a decade behind me. :) | ||
hoelzro | masak: nice post | 14:36 | |
gtodd | colomon: so you have a large installed base of commercial production code written in written in perl6 | 14:37 | |
14:37
tinyblak_ joined
|
|||
gtodd | colomon: written in (written in perl6) | 14:38 | |
colomon | gtodd: no | ||
well, guess it depends on what you mean. | |||
gtodd | :-D I'm trying to be irrational here | ||
colomon | I ship C++ source code. My customers never seen the Perl frame that makes much of it. | ||
hoelzro | it's 4th of July weekend here in the US, so I'll probably not be online much for the rest of the weekend. later #perl6! | 14:39 | |
DrForr | Have fun, frighten the wits out of some dogs for me! | ||
colomon | gtodd: also, I’m a pretty conservative coder, so generally the p5 is only changed to p6 when I need to make significant changes in a script. | 14:40 | |
gtodd: so probably 75% of it is still p5, even though it would be vastly better in p6. | |||
14:41
tinyblak left
14:42
_mg_ left
|
|||
colomon | life’s too short to change working code unnecessarily. | 14:43 | |
lucasb | I think heredoc whitespace handling should happen very early in the compilation, before things like "\n\n\n $interpolvar { some-huge-text() } etc." gets evaluated. As a user, I think that is what I would expect. | 14:44 | |
But I understand it must be very hard to hook this things into the lexer/parser. There is that rule of knowing at which language one is at a time, so idk if it is possible to process the heredoc before other things. | |||
14:45
gtodd left
14:46
amurf joined
14:50
amurf left
|
|||
lizmat | I just found some inconsistencies in the use of Whatever slices: | 14:51 | |
m: my @a = ^10; my $b = Whatever; say @a[*]; say @a[$b] | |||
camelia | rakudo-moar 7b9145: OUTPUT«0 1 2 3 4 5 6 7 8 9Indexing requires an instance, tried to do: @a[ (Whatever) ] in block <unit> at /tmp/p3vLdfQCe2:1» | ||
lizmat | m: my %a = ^10; my $b = Whatever; say %a{*}; say %a{$b} | ||
camelia | rakudo-moar 7b9145: OUTPUT«9 7 5 1 39 7 5 1 3» | ||
14:52
noganex left
|
|||
lizmat | so I wonder whether the Whatever slice should be a syntax feature | 14:52 | |
aka, only allowing a literal * to trigger it | |||
or whether a Whatever slice should be value driven (as it is now in the hash case) | |||
jnthn | m: say (*).perl | 14:53 | |
camelia | rakudo-moar add282: OUTPUT«WhateverCode.new» | ||
lizmat | in any case, I think the behaviour should be independent of whether it is on an array or on a hash | ||
jnthn | aww | ||
m: my $a = *; say $a.perl | |||
camelia | rakudo-moar add282: OUTPUT«*» | ||
jnthn | lizmat: Note that * is an instance of Whatever, not just Whatever the type object. | ||
lizmat | m: my $a = *; say $a.defined | 14:54 | |
camelia | rakudo-moar add282: OUTPUT«True» | ||
jnthn | m: my @a = ^10; my $b = Whatever.new; say @a[*]; say @a[$b] | ||
camelia | rakudo-moar add282: OUTPUT«0 1 2 3 4 5 6 7 8 90 1 2 3 4 5 6 7 8 9» | ||
lizmat | jnthn: good point | 14:55 | |
ugexe | m: say [*] | ||
camelia | rakudo-moar add282: OUTPUT«1» | ||
14:55
AlexDani` joined
|
|||
timotimo | m: say [Whatever] | 14:55 | |
camelia | rakudo-moar add282: OUTPUT«(Whatever)» | ||
14:56
noganex joined
|
|||
ugexe | m: say [*, 2] | 14:56 | |
camelia | rakudo-moar add282: OUTPUT«* 2» | ||
dalek | p/multidim: e719094 | jnthn++ | t/moar/02-multidim.t: Tests for setting up MultiDimArray REPR. |
14:59 | |
14:59
[Sno] left
15:02
skids joined
15:03
vendethiel left
|
|||
ugexe | Version needs some Whatever love too it looks like | 15:03 | |
m: say Version.new(*); say Version.new('*') | |||
camelia | rakudo-moar add282: OUTPUT«vWhatever.140438490100392v*» | ||
lizmat | m: say Version.new(i) # eek | 15:05 | |
camelia | rakudo-moar add282: OUTPUT«v0.1.i» | ||
timotimo | m: say Version.new("a", "b", "c") | 15:06 | |
camelia | rakudo-moar add282: OUTPUT«Default constructor for 'Version' only takes named arguments in block <unit> at /tmp/Ua3ZhRrmE_:1» | ||
timotimo | m: say Version.new("abc") | ||
camelia | rakudo-moar add282: OUTPUT«vabc» | ||
timotimo | tee hee | ||
15:07
diana_olhovik_ left,
RabidGravy left
|
|||
ugexe | m: say Version.new('0.01') cmp Version.new('0.1'); # there is also stuff like this, but with the way versions are i would probably blame the author of the changing version scheme | 15:09 | |
camelia | rakudo-moar add282: OUTPUT«Same» | ||
15:09
vendethiel joined
|
|||
skids | masak: actually :34x :45y :3width works really well in SVG code. FWIW. | 15:09 | |
ugexe | i implemented a better ACCEPTS for Version but its sloppy string chopping | 15:10 | |
15:12
domidumont left
|
|||
timotimo | m: say (:4.5m) | 15:13 | |
camelia | rakudo-moar add282: OUTPUT«5===SORRY!5=== Error while compiling /tmp/JLOuU19_qZMalformed radix numberat /tmp/JLOuU19_qZ:1------> 3say (:47⏏5.5m) expecting any of: number in radix notation» | ||
timotimo | do we want that to work? :P | ||
.o( masak says NNNNNOOOOOOoooooo! ) | |||
15:17
rurban1 left
15:19
rurban left
15:20
RabidGravy joined
15:24
SmokeMachine_ joined,
rurban joined
15:26
Sqirrel left
15:28
Sqirrel joined
15:31
vendethiel left
15:33
berekuk joined
15:34
vendethiel joined
15:37
jack_rabbit joined
15:42
zakharyas left
|
|||
lucasb | To me, Whatever is just a special value like Nil. Why is it needed more than one instance of it? Why is it needed instances of it at all, since you can treat a typeobject as a value, just like Nil? | 15:43 | |
If Nil === Nil.new, so why not have Whatever === Whatever.new === * === $var-holding-whatever? This way, constructs that work if one kind, would work with all 4 representations the same way. | |||
15:49
jack_rabbit left
|
|||
lucasb | m: say (* + 2)(3) | 15:49 | |
camelia | rakudo-moar add282: OUTPUT«5» | ||
lucasb | m: say { $^a + 2 }(3) | ||
camelia | rakudo-moar add282: OUTPUT«5» | ||
lucasb | What are the differences between these two? After a WhateverCode is constructed, it as special as a normal subroutine/block with arguments, right? Why differentiate then? | ||
masak | colomon: heh, I got convinced quite some time ago :) | 15:50 | |
skids: no, that still qualifies as a "bad use" to me. "34 x" and "3 width" don't sound good when read out loud. "2nd" and "2 years" do. | |||
skids | masak: I try never to read anything XMLish out load though. :-) | 15:51 | |
masak: When "reading out load" X,Y coordinates, like longitude, latitude, the number is often read first. | 15:58 | ||
16:01
Akagi201_ left
|
|||
dalek | p/multidim: 42bece2 | jnthn++ | t/moar/02-multidim.t: Test set/introspect dimensions of multi-dim array. |
16:07 | |
masak | skids: well, not liking how :3x looks is subjective. but I don't like how it looks. | 16:14 | |
skids | :-) it is a bit of a weird feature | ||
timotimo | :3x looks like a cat with a bow tie | 16:15 | |
so of course i like how it looks :) | |||
TimToady | :3D <- happy cow | 16:16 | |
masak .oO( "in 2015, we realized where the language was heading, and just renamed it LOLCAT 6..." ) | |||
or LOLCOW 6 | 16:17 | ||
timotimo | COWCODE | ||
jnthn | .oO( "the top type was also renamed to Moo" ) |
16:18 | |
skids wishes someone with too much time on their hands would leverage locales for humorous purposes. | |||
timotimo | LC_MESSAGES="angry" | ||
skids | LC_MESSAGE="pirate" | 16:19 | |
16:19
berekuk left
|
|||
skids | or lolcat, or comicbookguyfromthesimpsons | 16:20 | |
geekosaur | github.com/crawl/crawl/blob/master...ng-fake.cc :p | ||
TimToady | but you have to specify which kind of pirate, fr.pirate, es.pirate, en.pirate... | 16:21 | |
geekosaur | although less so than it used to be, since it's filters now instead of pretending to be actual languages | ||
16:21
uncleyear left
16:23
uncleyear joined,
tinyblak_ left
|
|||
skids | .oO(is t/spec/S24-testing/line-numbers.t failing for anyone else or is that my new code) |
16:24 | |
16:24
_mg_ joined
|
|||
geekosaur | I'll be spectesting a just-finished pull-and-build in a couple minutes... | 16:25 | |
16:26
VinceDee joined
|
|||
geekosaur | (and then see if I can figure out a prototype for that \sigil warning from list discussion) | 16:29 | |
skids | \sigil warning? | 16:30 | |
(which list?) | 16:31 | ||
geekosaur | p6u but I don't see it in the archive yet. subject "Passing a hash to a subroutine: best method?" | 16:32 | |
oh, archive direct page lands in june, whoops :) | 16:33 | ||
16:33
_mg_ left
|
|||
geekosaur | www.nntp.perl.org/group/perl.perl6....g2148.html | 16:33 | |
16:34
amurf joined
|
|||
skids | Ah. | 16:35 | |
16:39
amurf left,
brrt left
16:41
vendethiel left
16:42
tinyblak joined
|
|||
geekosaur | t/spec/S24-testing/line-numbers.t (Wstat: 65280 Tests: 0 Failed: 0) | 16:42 | |
think that'd be a "yes" :) | |||
skids | That is probably also what is breaking panda install Inline::Perl5 | 16:43 | |
nine | skids: that's broken? | 16:44 | |
skids | Maybe the new run() stuff. | ||
nine: via a submodule | |||
erm, dependency | 16:45 | ||
16:48
rurban left
|
|||
masak | geekosaur: I don't think %() is the opposite of \ | 16:51 | |
timotimo | t.h8.lv/early_deaths_percentage.html - i'd be interested to learn if anybody makes sense of the "early deaths" numbers that can be found where the Allocations are | ||
geekosaur | no, it's not | ||
timotimo | jnthn: also for you -^ | ||
skids | nine: File::Directory::Tree fails its test suite in much the same way as t/spec/S24-testing/line-numbers.t | ||
geekosaur | but if you're an experienced perl5 programmer, it *looks* like \%foo / %$foo | 16:52 | |
(the former making a ref and the latter dereferencing it) | |||
(and the generalized form of the latter being %{expr} | |||
) | 16:53 | ||
16:53
vendethiel joined
|
|||
timotimo | 90.5% early deaths for Scalar objects seems good | 16:53 | |
jnthn | The IntAttrRef survival rate is...curious | 16:54 | |
timotimo | "109.73% early deaths" ... that's curious :S | ||
i must be dividing by the wrong value | 16:55 | ||
DrForr | It done kilt 'em *good*. | ||
skids | I think I might be ready to unleash the new .assuming I've been working on. Needs github.com/rakudo/rakudo/pull/454 first though. | ||
timotimo | what are all those numbers %) | ||
skids | .oO(zombie scalars oh noes) |
16:56 | |
timotimo | i don't get it :) | 17:01 | |
17:02
diana_olhovik_ joined,
Akagi201 joined
|
|||
DrForr | I for one welcome our new weakly typed overlords. | 17:03 | |
dalek | p/multidim: 4219437 | jnthn++ | t/moar/02-multidim.t: Tests for atposnd/bindposnd for multi-dim array. |
||
jnthn | I don't always program in 30C+, but when I do I write lots of tests... | 17:04 | |
timotimo | i've apparently forgotten to build another hash to accumulate some data differently | ||
jnthn | dinner & | ||
timotimo | damn, i misinterpreted ... i think | 17:06 | |
the html app for the profiler is kinda hard to grok | 17:08 | ||
i have a need for a nap, i think | |||
17:09
xfix left
17:13
Akagi201 left
17:28
domidumont joined
|
|||
lucasb | so, there was some change recently about run external programs? | 17:37 | |
maybe that's why S24-testing/line-numbers.t is failing | |||
skids | FROGGS++ did some IO related stuff. | ||
lucasb | It tries to match qqx[$cmd] ~~ /.../ | ||
but since qqx failed, well, it dies. or so I think | 17:38 | ||
geekosaur | hm, so on the assumption that most intended captures are \(...) I added a warning to the other case; I should figure out how to only warn about it once, though. | 17:41 | |
...and guess I need to be more specific, since \key won't be a p5-ism (but *is* in the setting) | 17:44 | ||
TimToady | and please be sure to include the recommendation to parenthesize if you really mean it | 17:46 | |
ugexe | lucasb: it fails because it tries to use a non-existant directory | 17:48 | |
lucasb | ugexe: if we are talking about the same dir, it exists here on my end | ||
I added a "...; true" to the line $cmd = "$*EXECUTABLE $full-path 2>&1; true"; | 17:49 | ||
17:49
yqt joined
|
|||
lucasb | so that the command always returns success | 17:49 | |
17:49
spider-mario joined
|
|||
lucasb | What is a cleaner way of running a program you expect to fail, but just want the output? My work-around is silly, but it worked :) | 17:49 | |
ugexe | ah so it works, its just the wrong exit code? | ||
geekosaur | yes, I will add that (esp. since I was looking at one such to make sure I was doing the right thing :) | ||
ugexe | btw, "true" is an exitcode of 0 | 17:50 | |
geekosaur | right now I'm testing with the first cut, just to get some idea of whether it's a sane text | ||
*test | |||
lucasb | yeah, exitcode of 0 is success, right? :) | 17:51 | |
geekosaur | you hope :) | ||
TimToady | .tell pmichaud I'm going to assume that, if you're prototyping the new efficient underpinnings as a module, I can safely work on removing most flatteners from the API, so we have more time to work out the programmer-visible gotchas (or in other words, Break All The Things sooner rather than later) | 17:52 | |
yoleaux | TimToady: I'll pass your message to pmichaud. | ||
17:53
yqt left
|
|||
ugexe | QX inherits stderr already | 17:54 | |
lucasb | does it joins stdout and stderr in the same output? idk, I was just taking a look at why the code was failing | 17:55 | |
s/join/merge/ | 17:56 | ||
ugexe | its supposed to i think. or give you 2 streams | ||
but right now that doesnt work | |||
geekosaur | heh, I think this might be my first submission since I derailed the original smartmatching in 2007 or thenabouts :) (still spectesting to validate it) | 17:57 | |
ugexe | there is also a bug where if you try to call .status before you .close on the stderr/stdout, then it will give a bad exitcode even though the command will have executed successfully | ||
seems that whatever reads the pipe buffer fails to close the stream for some reason and waits forever | |||
you are right though. its busted. | 18:00 | ||
18:02
espadrine left
18:05
nys joined
|
|||
TimToady | re \n in heredocs, the dedent should be happening before \n interpolation, just as it happens before $I-contain-a-newline interpolation | 18:07 | |
so re irclog.perlgeek.de/perl6/2015-07-03#i_10845432 I'd call it a bug | 18:09 | ||
18:10
yqt joined
18:11
Akagi201 joined
|
|||
TimToady | recall that dedent is only for the purposes of establishing a false margin on the literal text, so from the user's perspective it really needs to happen before any kind of string processing | 18:14 | |
I can think of several ways to fix it | 18:16 | ||
one is to treat \n interpolation more like $newline interpolation | 18:17 | ||
18:17
Akagi201 left,
nowan left
|
|||
TimToady | another is to substitute a sentinel character for \n inside heredoc parsing, and only dedent after the sentinel (and replace the sentinel with a real \n) | 18:17 | |
geekosaur got one unexpected fail, checking if that's because spectest is now ahead of his source or if it's related to his change | 18:20 | ||
TimToady | if it's t/spec/S24-testing/line-numbers.t, that's been failing for a while | 18:21 | |
geekosaur | no, that one was why I said "unexpected fail" :) | ||
18:21
[Sno] joined
18:22
bjz_ joined,
Sqirrel left,
Sqirrel joined
|
|||
TimToady | well, there are still some flappers | 18:23 | |
18:23
bjz left
|
|||
geekosaur | looks like it was a flap indeed, no error this time around | 18:28 | |
18:30
zakharyas joined
18:32
_mg_ joined
18:36
tinyblak left,
zakharyas left
|
|||
AlexDani` | Hm, I remember there was a way to group some of the regexes in a grammar, so that using <thatgroupname> will result in using one of the regexes of that group, OR SOMETHING, I don't really remember what was that thing. Maybe there was no such thing at all and I made it up. Does anybody know what I'm talking about? | 18:36 | |
jnthn | protoregexes? | 18:39 | |
ugexe | proto token scheme {*}; token scheme:sym<http> { <sym> }; token scheme:sym<https> { <sym> } | ||
18:40
noganex left
|
|||
AlexDani` | yea! | 18:41 | |
thanks | |||
18:41
tinyblak joined,
noganex joined
18:46
noganex_ joined,
noganex left
|
|||
AlexDani` | Is it possible to negate a regex? Like match a thing that is NOT something. Or 'after' and 'before' are the only ways to do that? | 18:52 | |
masak | AlexDani`: !~~ | ||
AlexDani` | masak: um, but in a grammar? | 18:53 | |
geekosaur | I should redo my repo as a github fork so I can pull-request... | ||
jnthn | Note that for <before <foo>> and <!before <foo>> can be expressed as <?foo> and <!foo> respectively | ||
AlexDani` | oh, so it is just <!foo> | 18:54 | |
jnthn | Yeah. Note that it's still a zero-width assertion | ||
AlexDani` | oh | ||
jnthn | If you have a rule that matches a single char then you can use it as if it was a char class | ||
masak submits TimToady-approved heredoc n de-indentation rakudobug | |||
jnthn | <-foo> | ||
AlexDani` | jnthn: this actually makes sense. Thanks | 18:55 | |
jnthn | So <-alpha> means nything non-alphabetic. | ||
darn my any key isn't working... | |||
18:56
tinyblak left
|
|||
AlexDani` | jnthn: although I wonder why that single char limitation exists. Theoretically it can work with any fixed-width regex, no? | 18:56 | |
jnthn | AlexDani`: Yeah but...how do we know the width? :) | 18:57 | |
You can always write <!foo> .**4 if it were 4 wide, for example | 18:58 | ||
AlexDani` | jnthn: I don't know, but I remember seeing something like that in perl5 | ||
skids | m: my multi bar ($) { }; my sub foo () { my $q := bar($q); }; foo(); | ||
camelia | rakudo-moar add282: OUTPUT«(signal SEGV)» | ||
AlexDani` | like "sorry, this regex is not fixed-width, I cannot do lookaround with this+ | ||
" | |||
19:00
VinceDee left
|
|||
skids | ah, RT#125371 maybe | 19:01 | |
synbot6 | Link: rt.perl.org/rt3/Public/Bug/Display...?id=125371 | ||
19:02
nowan joined
|
|||
skids | I'll tack it on there as a potentially-related. | 19:02 | |
timotimo answerized Tom on p6u | 19:03 | ||
dalek | p/early_death_percentage: 3268d38 | timotimo++ | src/vm/moar/profiler/template.html: profiler template changes for "early death percentage" currently sometimes displays values above 100% |
19:06 | |
19:07
bin_005 joined,
nowan left
|
|||
lucasb | Would you agree if I said these contextualizers @(...), %(...) play *two* roles? They serve both to "dereference" an itemized aggregate and also as an aggregate constructor. I think I don't like they having both roles. | 19:16 | |
masak | in timotimo++'s recent posting to p6u, is there something *theoretically* standing in the way of the typechecker going "hm, I have this constant `[1, 2, 3]` which will never work against the constraint `Int @bar`, but it *would* if I instantiated the array as an Array[Int]... so let's quietly do that behind the scenes" ...? | 19:21 | |
(I suspect it's possible but a bad idea, just like a lot of silent "fixing up" of failure conditions are a bad idea) | 19:22 | ||
timotimo | if you do it for constants only, you'll confuse the user when they extract that constant into a variable, i suppose | 19:23 | |
19:23
Begi joined
|
|||
masak | ...yeah. | 19:24 | |
timotimo | i could see "here's a unified patch to fix that problem", though :P :P | ||
masak | right, it's like putting a patch on a leak, only to discover that the user is now dismayed by a bunch of leaks further out. | ||
such a unified patch would need to do a lot of code flow analysis. | |||
if I'm understanding you correctly, that is | 19:25 | ||
jnthn | I'm not sure "let's quietly do this O(n) operation on a potentially infinite thing BEHIND THE SCENES" is a great idea. ;) | 19:27 | |
19:27
nowan joined
|
|||
TimToady | lucasb: yes, but with the GLR we're de-emphasizing itemization to the point where it will be less of an issue | 19:28 | |
jnthn | More generally, though, I don't get why people choose to opt in to stricter typing, then complain when they have to make some effort to follow the very rules they chose for themselves. | ||
timotimo | :) | ||
Begi | Jonathan, I'd like tell you THANKS for your talks ! | 19:29 | |
jnthn | Begi: Welcome. I'm looking forward to the next round this summer :) | 19:30 | |
TimToady | we might have some sugar on the caller end that says "please coerce the rest of this list to the nominal type we bind to" | ||
lucasb | TimToady: thanks! | 19:31 | |
19:31
nowan left
|
|||
TimToady | also, @() and %() are coercers, not obligate constructors | 19:32 | |
masak | nice long de-indentation bug summary here: rt.perl.org/Ticket/Display.html?id=125543 | ||
TimToady | whereas [] and {} are obligate constructors/composers | ||
but your question does relate to a fundamental issue we have to nail down with the GLR, which is detangle the two meanings of .list, which has the same 2-function problem | 19:33 | ||
lucasb | If @() and %() don't get an itemized aggregate of the right type as their first and only argument, they work (more or less) like constructors: @(1,2,3), %{a=>1,b=>2} | ||
jnthn | lucasb: @(1,2,3) is just syntax sugar for (1,2,3).list, and % for .hash | 19:34 | |
And 1,2,3 in Perl 6 is a first-class thing that can be coerced | |||
TimToady | I consider .list to be the real amibiguity, because we use it to iterate things, as well as to coerce to list | 19:35 | |
and those are really two different things | |||
19:36
domidumont left
|
|||
lucasb | After the GLR, the [] vs []<> and {} vs {}<> will still exist? | 19:37 | |
TimToady | no | ||
[] and {} will no longer itemize | |||
nor will [] flatten inside | |||
19:38
VinceDee joined
|
|||
TimToady | we might or might not need a p5flat primitive to flatten the () without flattening []/{} | 19:39 | |
but we don't know if anyone will really want that distinction, post-GLR, other than making it work more like p5 | |||
or some more general .tree-like method that can choose what to flatten and what not to | 19:40 | ||
lucasb | I may have not understood: post-GLR, my @a = [1,2],[3,4] will be [1,2,3,4] ? | ||
TimToady | no | ||
lucasb | Oh, good :) | ||
TimToady | the outer comma causes you to have two top-level elemens | ||
basically one of those spots where we say, just take the top node and iterate it | 19:41 | ||
so my @a = [1,2] iterates teh top Array, while my @a = [1,2],[3,4] iterates the top List | |||
much like for does currently | 19:42 | ||
m: for (1,2) { .say } | |||
camelia | rakudo-moar add282: OUTPUT«12» | ||
TimToady | m: for (1,2),(3,4) { .say } | ||
camelia | rakudo-moar add282: OUTPUT«1 23 4» | ||
TimToady | [] will work the same after we de-itemize it | ||
m: for (1,2), { .say } | 19:43 | ||
camelia | rakudo-moar add282: OUTPUT«5===SORRY!5===Expression needs parens to avoid gobbling blockat /tmp/4hPVQnKJPu:1------> 3for (1,2), { .say }7⏏5<EOL>Missing block (apparently taken by expression)at /tmp/4hPVQnKJPu:1------> 3for (1,2), { .say }7⏏5<EOL>» | ||
TimToady | m: for (1,2),Empty { .say } | ||
camelia | rakudo-moar add282: OUTPUT«1 2» | ||
TimToady | m: for ((1,2),) { .say } | ||
camelia | rakudo-moar add282: OUTPUT«1 2» | ||
TimToady | m: for $(1,2) { .say } | 19:44 | |
camelia | rakudo-moar add282: OUTPUT«1 2» | ||
TimToady | three workarounds if you don't want the outer parens to be ignored | ||
lucasb | It made things clear, thanks | 19:48 | |
19:48
nnms left,
domidumont joined
|
|||
dalek | p/multidim: caee034 | jnthn++ | t/moar/02-multidim.t: Test for 3D native packed int array. |
19:49 | |
masak | the THIRD DIMENSION | 19:52 | |
19:56
nowan joined,
mr-foobar left,
darutoko left
19:59
raiph left,
Akagi201 joined
20:04
domidumont left
20:06
Akagi201 left
|
|||
ugexe | pr sent to allow setting cwd of proc::async proccess via await $proc.start(CWD => "/some/other/path"); instead of always using $*CWD | 20:06 | |
RabidGravy | works for me | 20:07 | |
ugexe | keeps one from having to do the chdir shuffle if you have to send relative file paths as an argument to whatever you want to run | 20:08 | |
20:11
_mg_ left,
amurf joined
|
|||
dalek | kudo/nom: d67674b | (Nick Logan)++ | src/core/Proc/Async.pm: allow Proc to be started in any directory Allows the use of relative file path arguments to `$!path` to work. This allows avoiding CWD related boilerplate like: my $cwd-bak = $*CWD; chdir("/home/foo"); # execute some process that expects CWD to be /home/foo chdir($cwd-bak); |
20:12 | |
kudo/nom: c28ad62 | lizmat++ | src/core/Proc/Async.pm: Merge pull request #459 from ugexe/patch-7 allow Proc::Async to be started in any directory |
|||
jnthn wonders a little about the uppercase parameter name... | 20:15 | ||
geekosaur | probably shouldn't be, although I can see why | ||
ugexe | its used in IO that way which is why. not a good reason i admit, but i didnt really think about it :) | 20:16 | |
20:16
amurf left
|
|||
lizmat | m: my $q := $q.foo | 20:18 | |
camelia | rakudo-moar add282: OUTPUT«Cannot call method 'foo' on a null object in block <unit> at /tmp/VohBd_wlEv:1» | ||
lizmat | I wonder whether we should allow binding a new variable to itself, whether that id directly or not | 20:19 | |
m: my $q := $q | |||
camelia | ( no output ) | ||
lizmat | m: my $q is default(42) := $q | ||
camelia | ( no output ) | ||
lizmat | m: my $q is default(42) := $q; say $q | ||
camelia | rakudo-moar add282: OUTPUT«(signal SEGV)» | ||
lizmat | m: my $q := $q; say $q | ||
camelia | rakudo-moar add282: OUTPUT«(signal SEGV)» | ||
geekosaur | somehow I had a feeling that was going to happen | ||
lizmat | I know it's a matter of DIHWIDT | 20:20 | |
TimToady | no, it's a matter of nobody's implemented stringifying recursive structures yet | ||
jnthn | That one is because we optimize such lexicals into locals, and there's some mishandling of nullness there | 20:21 | |
I've known the issue for a while, but it didn't reach top of the list yet, not least 'cus it's always a NULL it hits rather than an exploitable... | |||
Will make srue to deal with it ahead of the .birthday release. | 20:22 | ||
TimToady | m: my $q := $q; say $q.DEFINITE | ||
camelia | rakudo-moar add282: OUTPUT«False» | ||
TimToady | m: my $q := $q; say $q.WHAT | 20:23 | |
camelia | rakudo-moar add282: OUTPUT«(signal SEGV)» | ||
lizmat | m: my $q := $q; $q.gist # don't think the SEGV is because of the stringification | 20:24 | |
camelia | rakudo-moar add282: OUTPUT«Cannot call method 'gist' on a null object in block <unit> at /tmp/DHb7uZHQak:1» | ||
TimToady | nod | 20:25 | |
dalek | kudo/nom: 1d82c95 | usev6++ | src/core/Mu.pm: Prevent calling .clone with new attributes affect the original fixes RT #118559 |
||
synbot6 | Link: rt.perl.org/rt3/Public/Bug/Display...?id=118559 | ||
dalek | kudo/nom: 362c456 | lizmat++ | src/core/Mu.pm: Merge pull request #448 from usev6/rt118559 Prevent calling .clone with new attributes affect the original |
||
20:28
Begi left
|
|||
dalek | p/multidim: d3dbc81 | jnthn++ | t/moar/02-multidim.t: Test we can't do dimension-changing ops. |
20:31 | |
p/multidim: 37bf89d | jnthn++ | t/moar/02-multidim.t: Fix thinkos in tests. |
|||
p/multidim: 1092020 | jnthn++ | t/moar/02-multidim.t: Tests for atpos/bindpos ops on MultiDimArray. |
|||
ugexe | it seems a similar cwd parameter will work for Proc.pm's new spawn/shell/run commands. time for more tests | ||
20:33
espadrine joined,
mr-foobar joined
|
|||
ugexe | if i were to submit a similar pr for that, should i use 'cwd' or 'CWD'? | 20:42 | |
TimToady | cwd seems fine to me | 20:46 | |
dalek | p/multidim: 4b77efd | jnthn++ | t/moar/02-multidim.t: Another few thinko fixes. |
20:47 | |
p/multidim: fac0b5c | jnthn++ | t/moar/02-multidim.t: Test elems/setelems ops on MultiDimArray REPR. |
|||
ugexe | i see the light now. with a sig of ($CWD = $*CWD), it never saves the user anything as calling func(:$*CWD) is redundant. But in IO:: modules its binding to attributes and whatnot | 20:51 | |
20:57
diana_olhovik_ left
20:58
lucasb left
|
|||
moritz | m: sub f(Int() @a) { say @a.join }; f [1, 2, 3] | 21:03 | |
camelia | rakudo-moar 362c45: OUTPUT«Type check failed in binding @a; expected 'Positional[Any]' but got 'Array' in sub f at /tmp/VU1E0y65N3:1 in block <unit> at /tmp/VU1E0y65N3:1» | ||
moritz | m: sub f(Int(Mu) @a) { say @a.join }; f [1, 2, 3] | ||
camelia | rakudo-moar 362c45: OUTPUT«Type check failed in binding @a; expected 'Positional[Mu]' but got 'Array' in sub f at /tmp/YnUpt5_ljK:1 in block <unit> at /tmp/YnUpt5_ljK:1» | ||
21:03
bin_005 left
|
|||
moritz | m: my Int @a = 1, 2, 3; say @a | 21:05 | |
camelia | rakudo-moar 362c45: OUTPUT«1 2 3» | ||
dalek | ast: d466fc7 | usev6++ | S32-array/push.t: Add test for RT #112660 |
21:06 | |
synbot6 | Link: rt.perl.org/rt3/Public/Bug/Display...?id=112660 | ||
21:07
TimToady left
21:09
TimToady joined
|
|||
timotimo | moritz: that'd just parameterize the "wanted" type with a coercive type, not coerce on assignment. but cute idea anyway | 21:11 | |
dalek | ast: e84a51c | usev6++ | S32-array/push.t: Adjust test to make description clearer |
21:13 | |
moritz just wrote a longish rant to p6u about typed arrays | 21:15 | ||
21:16
TEttinger joined
|
|||
timotimo | uh oh | 21:16 | |
21:20
Sqirrel left
21:21
nowan left,
bin_005 joined
|
|||
masak | moritz++ # good rant :) | 21:22 | |
moritz++ # "yours ranting" | |||
geekosaur | rantiloquent | 21:23 | |
21:24
nowan joined
|
|||
skids | m: gist.github.com/skids/d1552470ba7c4ca6d3 | 21:25 | |
camelia | rakudo-moar 362c45: OUTPUT«gist not found» | ||
21:29
rindolf left
|
|||
skids | (That gist is what I found irksome about Cursor) | 21:30 | |
21:41
VinceDee left
21:48
Akagi201 joined
21:50
rurban joined
|
|||
timotimo | it's a 404, though | 21:51 | |
21:54
Akagi201 left
|
|||
skids | Oh, I thought camelia was just not doing gists still. What did I... oh gist.github.com/skids/d1552470ba7c4ca6d318 selection fail. | 21:55 | |
21:58
awwaiid left
|
|||
jnthn | 'night, #perl6 | 21:58 | |
timotimo | gnite jnthn | 21:59 | |
21:59
kaare_ left
|
|||
RabidGravy | erp | 21:59 | |
timotimo | and plane well tomorrow :) | ||
jnthn | Thanks! :) | ||
o/ | |||
22:01
awwaiid joined,
amurf joined
|
|||
timotimo | it won't be terribly hot on the plane at least :) | 22:01 | |
22:06
amurf left
22:16
spider-mario left,
telex left
|
|||
masak | 'night, #perl6 | 22:17 | |
22:18
telex joined
22:28
espadrine left
22:34
Akagi201 joined
22:39
colomon left
|
|||
dalek | kudo/nom: 0c88527 | lizmat++ | src/core/Mu.pm: Fix .clone issues a bit better |
22:42 | |
22:43
vendethiel left
|
|||
dalek | ast: fa49fa9 | lizmat++ | S12-attributes/ (2 files): Unfudge now passing .clone test, fixes #118559 |
22:44 | |
synbot6 | Link: rt.perl.org/rt3/Public/Bug/Display...?id=118559 | ||
lizmat calls it a day as well | 22:46 | ||
so good night, #perl6! | |||
skids | o/ | 22:47 | |
22:48
vendethiel joined
22:50
rurban left
|
|||
skids | github.com/skids/rakudo/tree/assuming_alpha buildable snapshot of my current .assuming work if anyone wants to play with it. Everything of consequence is in src/core/Block.pm | 23:02 | |
23:13
BenGoldberg joined,
newbie joined,
yqt left,
newbie left
|
|||
dalek | Iish/pg-config: 7e5eff5 | lembark++ | .gitignore: ignore editor cruft |
23:14 | |
Iish/pg-config: 9b7f194 | lembark++ | t/ (4 files): use PG environment variables to configure connection; update POD to avoid user having to pre-create hardwired database and user |
|||
23:14
dj_goku joined
23:16
RabidGravy left
|
|||
japhb | skids: What are you changing about .assuming? | 23:17 | |
skids | japhb: github.com/skids/rakudo/commit/975...8856e2e240 | 23:18 | |
And it all started by trying to fix one simple RT :-) | 23:20 | ||
23:23
bin_005 left,
bin_005_j joined
23:30
rvchangue left,
rvchangue joined
23:31
avalenn left,
steve_mc left
|
|||
japhb | skids: Ah, interesting! | 23:31 | |
23:32
avalenn joined,
Ben_Goldberg joined
23:33
BenGoldberg left
|
|||
skids | Eventually will have to figure out whether macros or some sort of MOP are the best approach to ridding it of EVAL. | 23:33 | |
23:34
steve_mc joined
23:45
virtualsue left,
virtualsue joined
23:50
amurf joined
23:54
amurf left
|