samcv so guys i'm thinking about adding an op to let you get the columns and rows of the termina 01:12
Geth rakudo: MasterDuke17++ created pull request #1171:
In slurp, don't call nqp::join if not needed
01:57
MasterDuke noticed ^^^ while working on MVM_string_join 01:58
japhb MasterDuke: Does that reduce the max memory usage of your tests? 02:02
From your numbers before, it looked like you were getting at least x8 memory blowup for loading a large file containing at least one >127 codepoint. 02:03
s/loading/slurping/
MasterDuke not the maxresident that /usr/bin/time reports
but less is allocated and then garbage collected
japhb MasterDuke: So fewer GC runs? Or just smaller ones? 02:04
I guess by smaller I mean nursery-only
MasterDuke heh, didn't measure those. i was using heaptrack for the memory measurements 02:05
just ran some profiles. slurp took 200ms before, 3ms after. no GCs 02:10
japhb WOAH
MasterDuke but there wouldn't be any difference if the file had "\r\n" as the line separator 02:13
japhb I'm OK with having that be slower. Just wish we didn't have to scan for it in the first place. 02:15
AlexDaniel MasterDuke: why does it need to split at all? 02:16
japhb AlexDaniel: Logical newline. It's looking to see if it needs to do \r\n => \n conversion 02:17
And if you have to scan at all, might as well track the locations in a split (since I believe the difference need not be large in MoarVM, due to immutable strings) 02:18
AlexDaniel so why not nqp::replace ? 02:19
oops, not replace
ah-ha, ok… 02:20
well, that's exactly how we transpose: github.com/rakudo/rakudo/blob/6646...#L295-L297 02:22
thing is, “\r\n” is already one grapheme 02:23
it could've been so great if we just replaced it in-place somehow 02:24
/o\ why do we even have this code there 02:31
japhb: by the way, have you seen this? 02:33
docs.perl6.org/language/traps#Spli...Into_Lines
japhb AlexDaniel: No, thanks for the pointer 02:34
AlexDaniel maybe I don't understand something, but how come that code is even there
japhb What code? The code in the traps doc? 02:35
AlexDaniel no, “\r\n” substitution
it's so meaningless that it drives me insane :-/ 02:36
spurt ‘deleteme’, “foo\rbar”
dd slurp ‘deleteme’ # "foo\nbar"
oops
dd slurp ‘deleteme’ # "foo\rbar" # here's the right output
well, “right”, it's kinda wrong 02:37
ah, so it's a double-trap 02:39
not only .lines splits by whatever it wants to, but if you do .split(“\n”) you will get garbage anyway. 02:40
pff
MasterDuke doesn't the comment explain why the "\r\n" substitution happens? it's read in binary mode cause that's faster than reading in streaming mode, but that then require "\r\n" to be converted to "\n" explicitly
AlexDaniel MasterDuke: what about \r 02:41
I can maybe understand .lines splitting by whatever is considered a newline, sure 02:42
but .slurp mangling your data silently… that's just garbage
MasterDuke so .slurp with :bin, then it won't 02:43
AlexDaniel MasterDuke: ok, maybe. How do I .split a buf? 02:48
oh, I know. you slurp it with :bin, then you decode it 02:50
and then split it properly
to avoid this built-in data mangling 02:51
that's not right
MasterDuke i'm kind of ok with that if you're using \r as a line separator 02:52
AlexDaniel you have to do it if you use \n as a separator 02:53
because otherwise \r\n will be converted into \n, and then you're splitting where you don't want to
which is fine for Str.lines, it's a human thing to do
but slurp(:!bin, …).split(“\n”) should do exactly what it says, without half-assed data mangling 02:54
ok, RT #132154 03:07
synopsebot6 Link: rt.perl.org/rt3/Public/Bug/Display...?id=132154
AlexDaniel MasterDuke: fwiw, have you tried doing index($l, "\r\n") first, and then calling .split.join? In worst case it will make one unnecessary pass through the data, but I wonder if most of the time the speedup will be worth it. 03:31
this assuming that .split itself is slow, maybe that's not the case 03:32
MasterDuke hm, haven't tried that. but now that we have a fast index, could be worth trying
might not be worth it though. after my change, the .slurp of the 50mb, 1million line file only took 5ms. decode took 850ms, append took 715ms, and read-internal took 25ms 03:37
AlexDaniel append? 03:39
MasterDuke src/core/Buf.pm:565 03:40
AlexDaniel MasterDuke: ok. Am I understanding it correctly that join-ing one element takes so much time? 03:43
I mean before your change vs after your change
MasterDuke joining one large element is slow. after my change, it just doesn't do a join if there's only one element 03:44
AlexDaniel what about making nqp::join return the same string if there's only one element? :) 03:46
MasterDuke join returns a new string 03:47
(i did that, and the savings was the same, but that's not what's supposed to happen) 03:48
m: my $a = "a" x 2**29; my $t = now; my $b = join(",", $a); say now - $t; say $a eq $b; say $a.WHERE == $b.WHERE 03:49
camelia MoarVM panic: Memory allocation failed; could not allocate 2147483648 bytes
MasterDuke m: my $a = "a" x 2**28; my $t = now; my $b = join(",", $a); say now - $t; say $a eq $b; say $a.WHERE == $b.WHERE
camelia 0.8793568
True
False
MasterDuke on my machine that's 5s for 2**29 and 20s for 2**30 03:50
AlexDaniel MasterDuke: why is it not supposed to happen? 03:51
I may not know something, but isn't it the whole point of having immutable strings? 03:52
MasterDuke github.com/perl6/nqp/blob/master/d...kdown#join
AlexDaniel doesn't really explain why it can't return the same string if it makes sense 03:53
maybe it can't, I dunno
MasterDuke .ask jnthn instead of github.com/rakudo/rakudo/pull/1171, could nqp::join return the input string if there was only one? 03:55
yoleaux MasterDuke: I'll pass your message to jnthn.
MasterDuke .ask timotimo instead of github.com/rakudo/rakudo/pull/1171, could nqp::join return the input string if there was only one?
yoleaux MasterDuke: I'll pass your message to timotimo.
MasterDuke AlexDaniel: btw, what's some combining graphemes? 03:56
*what're
AlexDaniel u: COMBINING 03:57
unicodable6 AlexDaniel, U+0301 COMBINING ACUTE ACCENT [Mn] ( ́)
AlexDaniel, U+0300 COMBINING GRAVE ACCENT [Mn] ( ̀)
AlexDaniel, 445 characters in total: gist.github.com/fe71497199952fc975...7a2718092d
AlexDaniel u: { .uniprop-bool(‘Prepend’) }
unicodable6 AlexDaniel, U+0001 <control-0001> [Cc] (control character)
AlexDaniel, U+0000 <control-0000> [Cc] (control character)
AlexDaniel, Cowardly refusing to gist more than 5000 lines
AlexDaniel hmmm what… 03:58
u: { .uniprop(‘GCB’) eq ‘Prepend’ }
unicodable6 AlexDaniel, U+0600 ARABIC NUMBER SIGN [Cf] (؀ ) 03:59
AlexDaniel, U+0601 ARABIC SIGN SANAH [Cf] (؁ )
AlexDaniel, 19 characters in total: gist.github.com/131f7975630ddcad96...1211ae4b4a
AlexDaniel u: { .uniprop(‘GCB’) eq ‘Extend’ }
unicodable6 AlexDaniel, U+0301 COMBINING ACUTE ACCENT [Mn] ( ́)
AlexDaniel, U+0300 COMBINING GRAVE ACCENT [Mn] ( ̀)
AlexDaniel, 1901 characters in total: gist.github.com/39c0a9c995ea99700d...4edd84fb76
AlexDaniel MasterDuke: so Prepend+some character, some character+Extend, and everything here: unicode.org/emoji/charts/emoji-zwj-...ences.html 04:00
MasterDuke: does that answer your question? :)
MasterDuke i think so, thanks
[Tux] This is Rakudo version 2017.09-80-gcf95ce81c built on MoarVM version 2017.09.1-36-gfbd89898 09:01
csv-ip5xs 1.357 - 1.363
test 9.821 - 9.944
test-t 3.402 - 3.427
csv-parser 12.188 - 12.446
This is Rakudo version 2017.09-82-g0b15f6728 built on MoarVM version 2017.09.1-36-gfbd89898
csv-ip5xs 1.363 - 1.369
test 9.854 - 10.008 09:02
test-t 3.422 - 3.445
csv-parser 12.128 - 12.365
lizmat Files=1229, Tests=75177, 306 wallclock secs (14.94 usr 5.40 sys + 2098.97 cusr 212.79 csys = 2332.10 CPU) 09:51
Geth rakudo/nom: 1d63dfd2a8 | skids++ | src/Perl6/Grammar.nqp
Restrict dynamic lookup metasyntax in rx EVAL (security RT#131079)
11:11
rakudo/nom: b02da4d1ac | lizmat++ (committed using GitHub Web editor) | src/Perl6/Grammar.nqp
Merge pull request #1168 from skids/rt131079

Restrict dynamic lookup metasyntax in rx EVAL (security RT#131079)
synopsebot6 Link: rt.perl.org/rt3/Public/Bug/Display...?id=131079
synopsebot6 Link: rt.perl.org/rt3/Public/Bug/Display...?id=131079
rakudo/nom: ebd6440c27 | (Elizabeth Mattijsen)++ | 2 files
Make task[2] always contain the full attribute name

To make the first 3 values of the task in the BUILDALLPLAN always the same: 0 = type of action, 1 = object type, 2 = full attribute name.
This makes refactoring the BUILDPLAN logic easier.
11:33
timotimo MasterDuke: since nqp::join uses str instead of Str and that can't be mixed into or anything (i believe) it should be fine to return the same object in that case 11:40
MasterDuke timotimo: huh. think i should add that to my MoarVM PR instead? 12:20
timotimo that's the PR that also makes join use strands sometimes? 12:37
MasterDuke yeah 12:50
timotimo i think we could have that, yeah 13:02
MasterDuke i'll add another commit that does that 13:03
timotimo: i pretty much am just copying github.com/MoarVM/MoarVM/blob/mast...1658-L1668 up to github.com/MoarVM/MoarVM/blob/mast...ps.c#L1632 and changing the continues to returns 13:09
oops. changing the `piece =` to return. but do i need to worry about those `if (...) continue`? 13:10
timotimo hm, there can potentially be null strings 13:14
MasterDuke it just passed a spectest, but how can i explicitly test those cases? joining a Nil? type object? 13:19
timotimo m: use nqp; nqp::join(nqp::null_s()) 13:20
camelia ===SORRY!===
Arg count 1 doesn't equal required operand count 3 for op 'join'
timotimo er, obviously
m: use nqp; nqp::join([nqp::null_s()], "")
camelia This type cannot unbox to a native string: P6opaque, Array
in block <unit> at <tmp> line 1
timotimo m: use nqp; nqp::join(nqp::list_s(nqp::null_s()), "")
camelia This representation (VMArray) cannot unbox to a native string (for type BOOTStrArray)
in block <unit> at <tmp> line 1
timotimo m: use nqp; nqp::join("", nqp::list_s(nqp::null_s()))
camelia ( no output )
timotimo you can check if this covers that branch
m: use nqp; nqp::join("", nqp::list_s(nqp::null())) 13:21
camelia Cannot unbox a type object (VMNull) to a str.
in block <unit> at <tmp> line 1
timotimo but perhaps we don't have a way to put null pointers in string lists any more
so perhaps has to be a non-string list
m: use nqp; nqp::join("", nqp::list(nqp::null()))
camelia ( no output )
timotimo so maybe this would trigger that code
MasterDuke ah. `use nqp; nqp::join("", nqp::list(nqp::null()))` now gives `Cannot unbox a type object (VMNull) to a str.` with my change 13:22
instead of no output
timotimo hm, but that if only checks if the pointer value is true, not MVM_is_null(tc, thepointer) 13:23
that would be necessary to weed out VMNull objects 13:24
MasterDuke think i should put in the same exact checks? or change the existing ones and then use those? 13:30
timotimo i'm not sure :( 13:38
that code is 3 years old, but i think we already had VMNull at that point
MasterDuke i'll use the same for now, changing both could be another commit later 13:40
stmuk has the idea of shipping 6.d next month been abandoned? 15:14
Zoffix Yup
Months ago
Zoffix points to the FAQ entry
stmuk no weeks ago and I just changed that entry 15:15
Zoffix points to the log where Zoffix said not committing to a date will make people just wait it all out
stmuk I've no idea what that means 15:16
Zoffix People oposed my wanting to release on Diwalli and wanted the date to be fluid instead. And I said if we do that, we'll just do nothing until later time. And that happened. 15:17
Well, at least I did nothing :) Don't know about anyone else :)
Without the date, there's no pressure.
stmuk Yeah I know time based releases seem unpopular after Dec 2015 :) 15:18
Zoffix Yeah 15:19
Biggest thing is reviewing roast. Once that's done, the rest is cake. 15:20
Gonna switch to 6.d-release mode: when some free time turns up, do release-affecting stuff only... instead of stuff like $*USAGE 15:21
Second biggest thing: making roast pass on Windows: github.com/perl6/6.d-prep/tree/mas...sing-tests 15:23
The plan to make docs site mark 6.d vs. 6.c feels like something to be done pre 6.d-release, but thinking more of it, it might suffice to just do manual markers (same as we've done so far for Rakudo release versions) and implement it properly when the docs site is swapped to Bootstrap and (possibly) Pod::To::SQL and dynamic backend. Simply 'cause doing it right now and then re-doing it for BS seems like 15:25
more work and I think a dynamic backend would make it easier to implement properly too
properly => being able to easily see (or even show/hide)_features that are for a specific language version only
& easy for devs to add new features (even as stubs, for documentation later) 15:26
s/features/docs for new features/;
Zoffix &
dogbert11 wonders if jnthn is still sampling food truck dishes 15:31
gfldex i'm optimising JSON::Fast right now and wish we had a fast .trans implementation 17:06
quoting string to output them as json takes most of the time 17:07
timotimo does .trans do anything different from .split with :v? 17:10
MasterDuke knows that Unicode is The Right Thing To Do™, but is still somewhat nostalgic for the days when 8-bits was good enough for everybody 17:11
MasterDuke really wishes that Unicode had been universal a long time ago, so everybody already had time to optimize it 17:14
timotimo optimize it or optimize for it? 17:20
MasterDuke optimize all the things
timotimo: find out anything more about that possibly missing $?CLASS lookup optimization? 17:24
timotimo i find the optimization (in general, not sure about $?CLASS in particular) still fires a bunch 17:25
MasterDuke huh. so no certain leads into the MVM_string_equal business?
timotimo nothing certain so far 17:26
i don't have good tools to cross-reference the calls to getlexperinvspec with what speshed code was in effect at what time 17:27
bbiab 17:29
MasterDuke timotimo: btw, updated github.com/MoarVM/MoarVM/pull/705 with those checks 18:04
timotimo so, what should it do if it falls through these returns? 18:09
i.e. (piece) or (item && IS_CONCRETE(item)) not being true?
do we perhaps want to return The Empty String™ instead? 18:10
MasterDuke well, it just does whatever happened before 18:53
timotimo fair enough 19:05
MasterDuke i'm not saying what it does now is the best possible option, so we could consider changing that also 19:16
gfldex timotimo: I got to-json in JSON::Fast 6.1x faster 20:00
timotimo *nice* 20:05
AlexDaniel :ooo
timotimo though the from-json was much nearer and dearer to my heart. since i didn't write a line of to-json ;)
gfldex there slight changes in output bit jq is parsing it propery it and it roundtrips fine 20:06
i got a 11MiB json file I have to read, update and write
the biggest win comes from checking if there is anything to escape and if not just to return the unmodified Str 20:07
timotimo ah! 20:10
i do something similar in parsing
gfldex travis is happy, PR incomming 20:15
lizmat ok, so I'm working on a prototype to flatten BUILDALL into a method per class (rather than on in Mu going over the BUILDALLPLAN) 20:19
gfldex timotimo: I didn't bump version
MasterDuke afk for a while, but clickbaiting github.com/rakudo/rakudo/pull/1171 and github.com/MoarVM/MoarVM/pull/705 in case anybody has opinions and hasn't seen them yet 20:20
lizmat preliminary results: 30% improvement for a class with a single not-required public attribute without default
to 50% improvement for 4 required public attributes
the prototype uses EVAL to create the BUILDALL method for the class 20:21
now I need to move that to a version that builds AST's and uses the MOP directly
and I'm sorta stuck, so would appreciate pointers to get me started on that part 20:22
timotimo have you looked at parts of the code that generate code for our accessor methods? 20:29
lizmat yeah looking at generate_accessor now 20:30
timotimo i'd imagine it'd be much like that 20:31
lizmat timotimo: so you're saying I should create a "generate_buildall" method inside CompilerServices?
timotimo aye 20:32
hold on a bit
lizmat I would pass the BUILDALLPLAN to it
timotimo check out the generate_buildallplan_3 branch
it's old, but it has a tiny start
maybe you can steal the bits around the compilation and just rewrite what exactly it compiles
lizmat aye, yeah, that's a good start :-) 20:34
.ask nine wrt to calling BUILDALL with positionals: could we create another name for that, like BUILDALL_WITH_POSITIONALS() ? 20:38
yoleaux lizmat: I'll pass your message to nine.
lizmat .tell nine BUILDALL could then be an only method, instead of a multi 20:39
yoleaux lizmat: I'll pass your message to nine.
lizmat timotimo: in your branch, why are there two Qast::Var.new( ) for :name<init> ? 21:53
*QASR
*QAST grrr
Geth roast: mryan++ created pull request #332:
Add tests for type byte
22:16
timo lizmat: please feel free to consider any and all parts of my old code for this to be potentially broken. the code never worked as i had it, it caused mysterious breakage during core setting compilation at the earliest, or loading the core setting at the latest; fuzzy on the details 23:52
yoleaux 17 Sep 2017 09:43Z <lizmat> timo: good catch with 1ca81432af51b842ca0f0 That was really a typo