agentzh | hi guys, as discussed originally in #perl6, i'd like to propose a "is ref" trait for class attribute declarations like has @.foo is ref; | 00:17 | |
so that the default new() method will pass arrays or hash tables by ref by default instead of the current full value copying behavior. | 00:24 | ||
is that a good idea? | |||
Zoffix | agentzh: for module space, sure. | 00:41 | |
agentzh | what do you mean by "module space"? | 00:42 | |
Zoffix | agentzh: write a module. Release it to modules.perl6.org | ||
agentzh | so it cannot go into the core? | 00:43 | |
Zoffix | Why does it need to be in core? | 00:44 | |
agentzh | it would be very hard for the perl 6 compiler to take advantage of this hint for optimizations if it's not in the core language. | ||
very hard, if not impossible. | |||
Zoffix | huh | 00:45 | |
agentzh | and the extra overhead in the external module may outweigh any benefit from saving the container copying. | ||
i find it very useful for class writers. | |||
Zoffix | Well, then don't copy it. Use scalar attribute. | ||
agentzh | otherwise we'll have to stick with $.foo for everything to avoid copying on @.foo and %.foo. | 00:46 | |
that's ugly. | |||
defeating the purpose of sigils in the first place. | |||
(to some extend, at least) | |||
Zoffix | No, it's not. I see no reason to be adding to core traits that modify well-defined container semantics. Especially since you're not even willing to make a module for this first. That just shows how un-needed the feature really is. | 00:48 | |
agentzh | well, it only affects the default new() method. | 00:49 | |
making it pass those selective containers by ref instead of by value. | |||
if you know perl 6 supports another easy way to achieve the same result, please let me know. | |||
llfourn | agentzh: I can easily see a module that made the default constructor bind attributes to the arguments. That is all the compiler needs to make "optimizations". | ||
Zoffix | agentzh: I already told you the easy way to achieve that. Use $.foo | 00:50 | |
agentzh | Zoffix: and i've already said $.foo is ugly and defeating the purpose of sigils in the first place :) | ||
llfourn: i don't see how it's possible without using MOP if not using macros. | 00:51 | ||
llfourn: and MOP is definitely some extra overhead that the compiler may not optimize away completely. | |||
samcv | agentzh, sigil is a container. if you want to pass container. use $ | ||
agentzh | samcv: it does not carry as much info as @. since $ can be anything. | 00:52 | |
the same applies to %. | |||
Zoffix | agentzh: which is nonsensical argumentation. What YOU'RE proposing is defeating the purpose of sigils. If you don't want the benefits the %.foo and @.foo offer you, then don't use them. | 00:53 | |
llfourn | agentzh: All you are doing is adding a custom constructor and a .new which will pass the list arguments raw and bind them to your @!foo attribute for example. | ||
Zoffix | agentzh: @. and %. can have anything you want too. | ||
llfourn | agentzh: there is no "MOP" overhead | ||
agentzh | llfourn: the problem is that i have 46 classes in a single project, adding special new to each class is too much a burden to me ;) | ||
llfourn | agentzh: yeah so write a module that does it automatically... | ||
class Foo { @!foo is raw; } # :) | 00:56 | ||
ugexe | no suggestions for Proxy? | 00:59 | |
agentzh | alas, it is sad that it would require a nonstandard external module using MOP and open classes for such simple things. | 01:01 | |
but anyway, thank you all for the feedback. | |||
i think we'll just implement the `is ref` trait in our own perl 6 dialect compiler anyway. | 01:02 | ||
Zoffix | ugexe: you can just bind. Less typing. | ||
samcv | m: gist.githubusercontent.com/samcv/6...tfile1.txt | ||
camelia | 5===SORRY!5=== Error while compiling <tmp> Confused at <tmp>:1 ------> 3https:7⏏5//gist.githubusercontent.com/samcv/69141 expecting any of: colon pair |
||
Zoffix | m: class Foo {has @.bar; submethod BUILD (:@bar) { @!bar := @bar }; method alter { @.bar[2] = 42 } }; my @bar = 42; my $x = Foo.new: :@bar; @bar[0] = 100; say $x.bar; $x.alter; say @bar; | ||
camelia | [100] [100 (Any) 42] |
||
samcv | evalable6, gist.githubusercontent.com/samcv/6...tfile1.txt | 01:03 | |
evalable6 | samcv, Successfully fetched the code from the provided URL. | ||
[1 2 3] [2 3] |
|||
agentzh | Zoffix: but you still need to define BUILD yourself, no? | ||
samcv | that seemed to copy the reference agentzh | ||
i mean it changes when i change the object it was created from | |||
Zoffix | m: class Foo {has @.bar; submethod TWEAK (:@bar) { @!bar := @bar }; method alter { @.bar[2] = 42 } }; my @bar = 42; my $x = Foo.new: :@bar; @bar[0] = 100; say $x.bar; $x.alter; say @bar; | ||
camelia | [100] [100 (Any) 42] |
||
Zoffix | Can use TWEAK too | ||
agentzh | p6: my @lst = <foo bar baz>; class A { has @.b is rw }; my $o = A.new(b => @lst); pop @lst; say $o; | 01:04 | |
camelia | A.new(b => ["foo", "bar", "baz"]) | ||
agentzh | my example is like this. | ||
i just want to avoid array copying in @lst easily. | |||
Zoffix shakes head. | |||
agentzh | Zoffix: as i've said, i have 46 classes. | ||
samcv | i didn't get copying in my gist agentzh | 01:05 | |
Zoffix | p6: my @lst = <foo bar baz>; class A { has $.b }; my $o = A.new(b => @lst); pop @lst; say $o; | ||
agentzh | i'd rather add is ref trait to attributes instead of adding special BUILD or TWEAK. | ||
camelia | A.new(b => $["foo", "bar"]) | ||
samcv | maybe you're doing something different | ||
llfourn | agentzh: Just make a module and then once everyone feels they need it maybe it will get into core? | ||
there's no chance otherwise. | 01:06 | ||
agentzh | and some of those classes may already have TWEAK or BUILD. | ||
llfourn | agentzh: maybe you can figure out a way to do it without clobbering pre-existing TWEAKs and BUILD from your module :) | 01:07 | |
agentzh | llfourn: thanks for the suggestion, but i'm sorry that i don't have a time to write such a module for rakudo. since we are not really interested in rakudo except using it to compare our own perl 6 dialect implementation. | ||
*have the time | |||
llfourn | agentzh: fair enough :) | ||
agentzh | anyway, thank you all for your time and suggestions. | 01:08 | |
Zoffix | We should really draft up a protocol for feature addition to core, with some rules to follow. It's tiring to constantly discuss something the proposers don't really care about. | 01:13 | |
Several times a week. | |||
Last week I was baffled that a PR to add a feature wasn't even working. The submitter didn't even bother to ensure the feature they want to add was working. | 01:14 | ||
Not with some edge case, but *at all*. | |||
llfourn | +1 on that, python community seems to be happy with their PEP system (www.python.org/dev/peps/) | 01:15 | |
Zoffix | And this comment, I think, is very elucidating as to why people want to add stuff to core but are very hesitant to make a module instead: irclog.perlgeek.de/perl6/2017-03-27#i_14327502 | 01:16 | |
"I give ideas. Someone else has to take care of the code" | |||
Zoffix reads a few PEPs | 01:18 | ||
That may be an overkill, at the moment. | |||
Some of these proposals are 25+ pages long. | 01:19 | ||
llfourn | Yep. Python 3's inbuilt event loop asyncio was a PEP so some of them are serious business. | 01:20 | |
agentzh | hopefully i won't have to write a 10+ page proposal for future ideas :) | 01:21 | |
Zoffix | :) | ||
llfourn | I think we can cut off 9 or so pages if you write a module that does it :P | ||
agentzh | llfourn: then i'd rather stick with our own perl 6 dialect language :) | 01:22 | |
llfourn | agentzh: to each their own :) | ||
agentzh: btw have you considered "is raw" rather than "is ref" because that's the trait we use on routine parameters when we want to pass them "raw". | 01:23 | ||
agentzh | for unrelated issue, so now perl 6's language design is now determined by the test suite instead of the synopses? | ||
llfourn: interesting. looking into is raw now. | 01:24 | ||
was not aware of it. | |||
llfourn: where is it documented? failed to find is raw in docs.perl6.org. | |||
llfourn | It's not searchable on docs.perl6.org :< | ||
agentzh | oh | 01:25 | |
llfourn | hmm | ||
agentzh | what do you mean by passing them "raw"? | ||
it is a new term for me. | |||
does it mean the same thing as "is ref"? | |||
llfourn | agentzh: basically, it means passing the raw container I think. | ||
agentzh | okay, then mostly the same thing. | 01:26 | |
that's very close! | |||
looks like a good chance for is raw going into class attributes as well? *grin* | |||
Zoffix | agentzh: yes, the roast (test suite) is the computer version of the spec and the docs are meant to be explanatory for humans. Basically, trying to keep the speculations up to date and accurate is too much work. | ||
llfourn | m: say {;}.gist | ||
camelia | -> ;; $_? is raw { #`(Block|52980376) ... } | ||
llfourn | agentzh: as you can see blocks by default are is raw | ||
agentzh | Zoffix: good to know, thanks for the info. | 01:27 | |
llfourn: nice | |||
okay, i'll play with is raw in our own compiler. | |||
llfourn: thanks for the info! | |||
llfourn | agentzh: good luck :) | 01:28 | |
agentzh | thanks | ||
we're trying to build a more "practical" version of perl 6 compiler for commercial use. | |||
by "more practical", i mean much faster. | |||
hopefully much faster than even perl 5. | |||
llfourn | agentzh: is it going to be open source? | ||
agentzh | llfourn: maybe at some point. not right now. | ||
llfourn | agentzh: ok I would love to look it it :D | 01:29 | |
agentzh | we'll give a free personal license for our perl 6 dialect compiler to official perl 6 team members :) | ||
llfourn | agentzh: it's compiling into lua bytecode or something I think I saw? | ||
agentzh | if you guys are interested. | 01:30 | |
it's compiling into OpenResty/Lua code, so eventually LuaJIT bytecode. | |||
the compiler is called fanlang. | |||
llfourn | ah cool so it compiles into lua first | ||
agentzh | the compiler itself is written in perl 5 atm, but will soon get boostrapped by fanlang itself. | ||
llfourn: yes. since the LuaJIT bytecode is a moving target. | 01:31 | ||
there's constantly new changes made into the LuaJIT VM bytecode. | |||
llfourn | ooo, can I ask why you didn't start writing the compiler in rakudo? speed? | ||
agentzh | for new perofmrance features. | ||
yes, speed. | |||
and also simplicity. | |||
we only employ a common subset of perl 6, though this subset is getting larger and larger according to our own engineering needs. | 01:32 | ||
llfourn | I am writing a perl6-dialect that compiles itno shell scripts :) | ||
github.com/spitsh/spitsh | |||
agentzh | and we take performance very seriously when considering what perl 6 features to implement. | ||
from the very beginning. | |||
llfourn: huh, that's fun. | |||
llfourn | I would find it very hard to have written it in p5. | ||
agentzh | llfourn: our fanlang compiler will also target browser JS too soon. | ||
it's on our company's plan. | 01:33 | ||
maybe the shell language is too limited for us. | |||
it's fun stuff though. | |||
llfourn | heh no yep it's for fun + config management | ||
I was just saying that it would be hard for me to parse the language in p5. | 01:34 | ||
perl6 grammars make it so much easier | |||
agentzh | llfourn: i tried to use rakudo/p6 to implement one of our DSL compilers. | ||
but the compiling time was too much for us to bear. | |||
every single edit requires at minimum 6 sec to compile. | 01:35 | ||
llfourn | oh you mean to precompile your perl6 code? | ||
agentzh | so i eventually gave up. | ||
llfourn | or was that before precomp? | ||
agentzh | llfourn: yep, i tried everything suggested here and on #perl6. | ||
including concatenating every .pm6 files into a single giant p6 script. | |||
that gives the best result: 6 sec | 01:36 | ||
still too long for development. | |||
our p6 project contains 8000 LOC. | |||
relatively large project. | |||
llfourn | ah ok. that's pretty big. | ||
agentzh | our perl 6 dialect compiler is much bigger. | ||
llfourn | I think spitsh is like 6k LOC. | ||
agentzh | 23K+ LOC. | 01:37 | |
llfourn | wow! | ||
agentzh | i told you it's a perl 6 dialect, large p6 subset. | ||
OO, smartmatching, a lot of common things. | |||
most of the statements | |||
a simplified grammar engine | |||
big enough to bootstrap itself i think :) | 01:38 | ||
llfourn | Very excited to see it when it's released in whatever form :) | ||
agentzh | llfourn: glad you'd look at it. | 01:39 | |
will let you guys know. | |||
we are still busy polishing it. | 01:40 | ||
and using it to write real world DSL compilers for commercial products. | |||
llfourn | agentzh: I think using Perl 6 syntax as a base to design a new langauge is a great idea. | ||
agentzh | llfourn: agreed! | 01:50 | |
[TuxCM] | This is Rakudo version 2017.03-49-gfa9aa4765 built on MoarVM version 2017.03-25-ga8448142 | 05:30 | |
csv-ip5xs 3.085 | |||
test 12.661 | |||
test-t 4.970 - 4.982 | |||
csv-parser 13.236 | |||
samcv | this seems fine right? | 05:38 | |
not ok 352 - retired metachars (\Q...\E)# TODO error messages | |||
# got: Unsupported use of \Q as quotemeta; in Perl 6 please use quotes or literal variable match at line 2, | |||
i think it's showing the proper error message right? | |||
also don't know what this is: `expected: <Unrecognized>` | 05:39 | ||
j: 'st'.fc.say | 06:13 | ||
camelia | st | ||
samcv | nqp: my $match := 'st' ~~ /st/; say($match); | 06:50 | |
camelia | Substring length (-3) cannot be negative at gen/moar/stage2/QRegex.nqp:2032 (/home/camelia/rakudo-m-inst-1/share/nqp/lib/QRegex.moarvm:Str) from gen/moar/stage2/NQPCORE.setting:713 (/home/camelia/rakudo-m-inst-1/share/nqp/lib/NQPCORE.setting.moarvm:joi… |
||
samcv | nqp-j: my $match := 'st' ~~ /st/; say($match); | 06:51 | |
nqp-jvm: my $match := 'st' ~~ /st/; say($match); | |||
camelia | Error occurred during initialization of VM Could not allocate metaspace: 1073741824 bytes |
||
lizmat | Files=1181, Tests=55992, 196 wallclock secs (11.68 usr 4.45 sys + 1163.77 cusr 111.90 csys = 1291.80 CPU) | 09:49 | |
yoleaux2 | 09:27Z <jnthn> lizmat: p6firstflag has no thread-related handling, though for the sake of hyper/race we should only really be setting it in one thread anyway, I'd think | ||
dogbert17_ | m: say 1122333.split(/<!same>/, :skip-empty) | 09:53 | |
camelia | (11 22 333) | ||
dogbert17_ wonders what other secrets might be hiding in the regex engine | |||
jnthn | That's cute :) | 09:55 | |
dogbert17_ | one of TimToady's secrets which he divulged yesterday. There are no spectests though ... | 09:57 | |
m: say 123456789.split(/<?at(4)>/) # experiment | 10:00 | ||
camelia | (1234 56789) | ||
jnthn | .oO( In today's episode of "accidentally O(n)..." ) |
10:01 | |
dogbert17_ | jnthn: care to look at a gist? | 11:40 | |
wrt RT #131003 | 11:41 | ||
synopsebot6 | Link: rt.perl.org/rt3/Public/Bug/Display...?id=131003 | ||
dogbert17_ | dunno if it contains any useful information but you never know: gist.github.com/dogbert17/ea5855ab...86c2f24f62 | 11:45 | |
jnthn | Hmm, interesting | 11:55 | |
dogbert17_ | if it contains anything useful; I'll ask AlexDaniel to add it to the original report | 11:56 | |
jnthn | Yeah, it gives something to explore at least | 11:57 | |
Could you try it with the GC debug stuff turned on also? | |||
dogbert17_ | will do | ||
jnthn: sry, was held up by a meeting. Here's a new gist: gist.github.com/dogbert17/3eb15ea5...1d4966f7b2 | 13:03 | ||
Zoffix | . | 13:16 | |
yoleaux2 | 09:26Z <brrt> Zoffix: that the usual way is to look at the JIT log and find the 'bail' entry corresponding to the JIT log of that frame | ||
Zoffix | hm. I'm wondering if yoleaux2 is not delivering messages or if I'm missing the deliveries | 13:17 | |
Zoffix │ .ask jnthn what are your thoughts on removing $*SPEC and all the IO::Spec* in v6.d? We'd treat all the OSes as mostly-same rather than mostly-differn. e.g. we'd use "/" as path separator on all OS's | |||
jnthn | Zoffix: It did deliver it | 13:19 | |
Zoffix | Ah, cool. | ||
jnthn | Zoffix: But needs more thought | ||
Zoffix | Sure. | ||
jnthn | (delivered it in #moarvm since that's where I spoke first today) | ||
I can't say I've ever personally used it, but that doesn't mean others aren't | |||
Zoffix | Oh, now I see it :) | 13:20 | |
I've seen some people use it, but personally, I think they're misusing it. | |||
Instead of catpaths/splitdirs, you're meant to use .child/.parent, and the proposed in IO Plan, .cat-with methods on IO::Path | |||
Geth | nqp/master: 6 commits pushed by (Pawel Murias)++ | 13:26 | |
Zoffix | My worry's more about trying to treat Windows/Linux as the same. Is there some edge case that will blow up in our face? | 13:28 | |
lizmat++ believes that ditching $*SPEC will give us a lot of performance boost, and I can see it happening: dynamic lookup is high in the profile and not having to call a method just to figure out what the "curdir" is can be beneficial too. | 13:29 | ||
jnthn | Well, there's drive letter thing | ||
At the very least | |||
I guess also network paths maybe? | |||
Zoffix | From what I understand, that's to be handled as paths with "volumes" and on Linux the volume is simply an empty string. | 13:30 | |
jnthn | Maybe another way to ask it is: how can I reliably ask if "/foo" is a relative path from a POSIX perspective should I wish to do that, even if I'm running on Windows, and vice versa? | 13:31 | |
I think that question is the kinda thing IO::Spec could answer | |||
And if we remove it, then we're saying that such questions belong to module space | 13:32 | ||
Zoffix | Currently it says it's absolute on Windows too tho | ||
C:\Users\zoffi>perl6 -e "'/foo'.IO.is-absolute.say" | |||
True | |||
jnthn | heh, "interesting" :) | ||
Zoffix | :D | ||
I think this idea should be done as a module first... | 13:35 | ||
jnthn | What do you think the impact of its removal would be? | ||
(on the ecosystem) | |||
Zoffix | Looks big. So removing entirely in 6.d might not a good idea; maybe just deprecating. | 13:37 | |
157 instances of $*SPEC in all modules | |||
But a lot of them is stuff like my $class-path = $*SPEC.catfile( $class-dir, 'Metadata.pm' ); Which is what I thought originally, that people just aren't using IO::Path the way it was meant to be used | 13:38 | ||
ugexe | fwiw getting zef to work well on windows between the various adapters was a huge PITA because of these windows things | 13:50 | |
for instance: most code using `.dirname` probably meant `.parent` but may be using .dirname because its method name seems more natural | 13:52 | ||
pmurias | agentzh: is fanlang implying that it's a fan language (in the way fanfiction does) intentional? | 13:53 | |
yoleaux2 | 25 Mar 2017 05:14Z <Zoffix> pmurias: if you're interested, IO Action Plan is ready for review. The review period will end April 1st: irclog.perlgeek.de/perl6-dev/2017-...i_14321373 | ||
ugexe | of course if you are using run/shell you also get to deal with trying to get scripts to deal with uris that don't start with . or / (use relative URIs for everything and pass in the vol to run/shell's :cwd) | 13:54 | |
Zoffix | pmurias: no, in Chinese Fan means... translator... I think | ||
pmurias | hmm, roast/S03-operators/div.t fails because it assumes int is 64bit while rakudo.js has a 32bit int | 14:01 | |
Zoffix: regarding the IO proposal having the method that does a file test assertion be called 'chdir' doesn't seem good | 14:05 | ||
I don't have a good name replacement name for it :( | 14:06 | ||
Zoffix | ? | ||
Zoffix doesn't follow | |||
pmurias | my $*TMPDIR = '/tmp'.IO.chdir | 14:07 | |
Zoffix | I don't see that in the action plan... | 14:08 | |
pmurias | tmpdir is being removed, and it's replacement is supposed to be setting $*TMPDIR and calling .chdir, right? | 14:10 | |
Zoffix | No, just setting it, period | 14:11 | |
You can ask .chdir to test the directory it's chdiring to, so alternatively, you could also do $*TMPDIR .= chdir: :r:x:w, "/whatever" | |||
pmurias | the .chdir does do any chdiring | 14:12 | |
* doesn't do | |||
Zoffix | It changes the path and does tests on it..... Which is exactly what you'd want to do when you want to change $*TMPDIR and do tests on it | 14:15 | |
pmurias | no it doesn't | 14:21 | |
m: say $*CWD.chdir('/tmp');say $*CWD | 14:22 | ||
camelia | "/tmp".IO "/home/camelia".IO |
||
Zoffix | It clearly does. | 14:23 | |
pmurias | Zoffix: the .chdir method just performs the test it doesn't change the dir | ||
Zoffix | It DOES! Your own code just showed it returned a new path!! | ||
Zoffix leaves | 14:24 | ||
pmurias: IO::Path.chdir returns a new path; if you give it a relative fragment it'll be relative to the invocant. It does tests too. &chdir() does the same thing but with $*CWD, and sets $*CWD to the new path. And &*chdir does the process chdir | 14:29 | ||
dogbert17_ | m: $*CWD.chdir('/tmp');say $*CWD | 14:30 | |
camelia | "/home/camelia".IO | ||
Zoffix | So $*TMPDIR .= chdir: :r:x:w, "whatever"; will create a new path, possibly relative to old $*TMPDIR, do tests on it and since .= operator is used, will assign the new path to $*TMPDIR | ||
dogbert17_ | .seen TimToady | 14:32 | |
yoleaux2 | I saw TimToady 25 Mar 2017 17:41Z in #perl6-dev: <TimToady> it's probably a shibboleth to include the definite article :) | ||
Geth | nqp/master: 4 commits pushed by skids++, (Zoffix Znet)++
|
14:52 | |
nqp: 7bd72e5c8b | (Zoffix Znet)++ | tools/build/MOAR_REVISION Bump MoarVM Brings these commits: github.com/MoarVM/MoarVM/compare/2...1-g8f9325b 8f9325b chr: For cp < 0x300 short circuit a unicode property test f2acad4 MVM_string_chr: Only allocate and normalize for cp's that require it ad44958 Merge pull request #557 from MasterDuke17/fix_overflow_to_negative_boundary_detection_in_mp_get_int64 c5eb7d5 Split into mp_get_int64 and mp_get_uint64 65f35b2 Rename `sign` to `is_signed` 84a730f Correctly detect+handle overflow in mp_get_int64 |
14:58 | ||
¦ nqp: version bump brought these changes: github.com/MoarVM/MoarVM/compare/2...1-g8f9325b | |||
roast: 1ca4ce00ae | (Zoffix Znet)++ | S02-types/native.t Change TODO fudge into SKIP Tests now throw instead of just giving incorrect results |
15:10 | ||
rakudo/nom: 666ce35dd7 | (Zoffix Znet)++ | tools/build/NQP_REVISION Bump NQP Brings these commits github.com/perl6/nqp/compare/2017....2-g7bd72e5 7bd72e5 Bump MoarVM 885d2c8 Merge pull request #349 from skids/FOREIGN_LANG c360266 Test dividing big negative numbers ... (27 more lines) |
15:12 | ||
rakudo/nom: version bump brought these changes: github.com/perl6/nqp/compare/2017....2-g7bd72e5 ffeb896daa | skids++ | src/Perl6/Grammar.nqp |
|||
rakudo/nom: fb1beef844 | (Zoffix Znet)++ | src/Perl6/Grammar.nqp Merge pull request #1047 from skids/FOREIGN_LANG Fix SEGV in FOREIGN_LANG after nqp fixes in nqp PR#349 |
|||
Zoffix | ZOFVM: Files=1230, Tests=132967, 122 wallclock secs (20.96 usr 3.44 sys + 2352.90 cusr 262.37 csys = 2639.67 CPU) | 15:25 | |
and a few passing todos; tried to unfudge but can't figure it out. | 15:26 | ||
nine | Zoffix: the confusion about chdir is that it doesn't change the current working directory but people expect it to | 15:27 | |
ilmari | what _does_ it do if not _ch_ange _dir_ectory? | 15:28 | |
timotimo | it sets an internal "current working directory" that other stuff relies on | 15:29 | |
Zoffix | nine: but it does just that, as far as Perl 6 is concerned. | 15:32 | |
m: ".".IO.absolute.say; chdir "/tmp"; ".".IO.absolute.say | |||
ilmari | to avoid the thread-racy nature of the process-global working directory? | ||
camelia | /home/camelia /tmp |
||
Zoffix | ilmari: that and also two threads doing different things; if one thread changes chdir, we don't want code in other thread to all of sudden doing things in the wrong dir. | 15:34 | |
Though we do provide &*chdir that changes the process-global working dir. | |||
ilmari | that's what I meant | 15:35 | |
Zoffix | nine: or do you mean the IO::Path.chdir that just changes it for the invocant? | ||
ilmari | unix "solved" it with the *at() family of syscalls | ||
Zoffix | IO::Path.chdir is basically [ IO::Path.new (if argument is an absolute path) | IO::Path.concat-with (if arg is relative ] + .d + (.e)? + (.r)? + (.w)? | 15:38 | |
m: dd "/foo".IO.chdir: "/bar/" | |||
camelia | Failure.new(exception => X::IO::Chdir.new(path => "/bar/", os-error => "does not exist"), backtrace => Backtrace.new) | ||
Zoffix | m: dd "/foo".IO.chdir: "/tmp/" | ||
camelia | "/tmp/".IO(:SPEC(IO::Spec::Unix)) | ||
Zoffix | This is kinda iffy since original had the file in it and now it's just a dir. | 15:39 | |
So deprecate IO::Path.chdir? | 15:40 | ||
Another way to reword it: $foo.chdir($arg) is basically IO::Path.new($arg, :CWD($foo)) + .d + (.e)? + (.r)? + (.w)? | 15:41 | ||
pmurias | ilmari: the method form _ch_ecks_the_dir_ectory | ||
Zoffix | pmurias: all forms check the directory :/ | ||
pmurias | the sub form both checks the directory and sets $*CWD | 15:43 | |
Zoffix | and method form both checks the directory and returns the new paths set to it... | 15:44 | |
pmurias | yes | ||
Geth | rakudo/nom: 5ca924df26 | (Zoffix Znet)++ | docs/2017-IO-Grant--Action-Plan.md Add removal of IO::Path.chdir to list |
15:47 | |
TimToady notes that there are 36 different Chinese characters that are pronounced "fan" | 16:13 | ||
yoleaux2 | 26 Mar 2017 18:24Z <Zoffix> TimToady: what are your thoughts on removing $*SPEC and all the IO::Spec* in v6.d? We'd treat all the OSes as mostly-same rather than mostly-differn. e.g. we'd use "/" as path separator on all OS's | ||
TimToady doesn't even know what $*SPEC does... | 16:14 | ||
Zoffix | My current thought on that ^ is implement it as a module first and see if it's (a) works right enough; and (b) offers good perf improvement | ||
Oh, heh. OK then nevermind :) | |||
$*SPEC is set to an IO::Spec::* instance based on the OS running, which provides catpath/splitdir etc; So for example IO::Spec::Win32 has method dir-sep that returns \ but IO::Spec::UNix returns / instead and those are used to join a dir | 16:17 | ||
And the idea is to toss all that. So that when you need to join a path, you just use '/' instead of having to do a dynamic var lookup and call its dirsep or whatever | 16:18 | ||
TimToady | how do you represent D: and such? | ||
it's all very well to have an abstraction layer above, as browsers use, but there'd better be a complete mapping in that case | 16:19 | ||
Zoffix | Without $*SPEC? From what I understand, all paths have a "volume" which on Linux is just an empty string | ||
TimToady | and maybe access to the lower-level anyway | 16:20 | |
Zoffix | And this largely exists (and I assume works) in newio branch | ||
TimToady | oh, is that why it's http:// with a double slash? | ||
Zoffix | no idea :) | ||
TimToady | except that's before the site name | 16:21 | |
Zoffix | There's file:// But it's file://C:/foo or file:///foo | ||
TimToady | I guess I've never used file: on a windows boxoid | 16:22 | |
the other weirdness we'll have to consider maybe is how to create utf8-c8 literals and such :/ | 16:23 | ||
there's an impedance mismatch between the Str type and POSIX filenames, anyway | 16:24 | ||
Zoffix | yeah | ||
TimToady | so we'll need ways to deal with non-Str-comfortable filenames | 16:25 | |
I know, we'll just run all filenames through EVAL, what could possibly go wrong? | 16:26 | ||
jnthn | That's why we decode command line args, environment, filenames coming from dir, etc. using utf8-c8 | ||
TimToady | yes, but we also need to be able to generate utf8-c8 literals, I said | 16:27 | |
jnthn | No idea how we'll do that | ||
TimToady | is why I said it :) | ||
jnthn | Even Q:uni is problematic | ||
TimToady | it has to be possible to think evil thoughts in Perl :) | 16:28 | |
b2gills | The thing with paths is older operating systems didn't use /. Though VMS, for example, does now have a UNIX mode so that is less of a problem than it is in Perl 5. | 16:35 | |
agentzh | pmurias: fan means translate in Chinese | 16:52 | |
fanlang aims to provide an excellent way of "translating" little DSLs for machines. | |||
and we've found perl 6 being an excellent language for that purpose. | 16:53 | ||
at least a subset of it. | |||
Zoffix | I don't see ::Spec::VMS, so presumably that isn't supported now either | 17:25 | |
SmokeMachine | Zoffix: hi there! | 17:29 | |
Zoffix | hi | ||
SmokeMachine | could you help me? did you see my questions on #perl? | ||
Zoffix | I don't follow that channel | ||
SmokeMachine | (and thanks for the wellcome :) ) | ||
m: my %a = a => {b => 1}; say %a{"a","a";"b"}; say %a{"a","a";"b"}:exists # should it return True, True? | 17:30 | ||
camelia | (1 1) False |
||
Zoffix | don't know | 17:31 | |
SmokeMachine | it shouldn't be False, right? | ||
im trying to fix this: rt.perl.org/Public/Bug/Display.htm...et-history | 17:32 | ||
Zoffix | Don't even know what that syntax is supposed to do with hashes. Why does it give (1 1)? | 17:41 | |
b2gills | m: my %a = a => {b => 1}; say %a{"a","a"}»{"b"}; | 17:43 | |
camelia | (1 1) | ||
Zoffix | O.o | 17:44 | |
m: my %a = a => {b => 1}, c => {b => 42}; say %a{"a","c";"b", "b", "b"}; | 17:45 | ||
camelia | (1 1 1 42 42 42) | ||
Zoffix | nuts | ||
b2gills | m: my %a = a => {b => 1}, c => {b => 2}; say %a{"a","c";"b"} | 17:46 | |
camelia | (1 2) | ||
b2gills | m: my %a = a => {b => 1}, c => {b => 2}; say %a{*;"b"} | ||
camelia | (1 2) | ||
Zoffix | cool | ||
m: my %a = a => {b => {d => 99}}, c => {b => { d => 100 }}; say %a{"a","c";"b", "b", "b";"d","d"}; | 17:47 | ||
camelia | (99 99 99 99 99 99 100 100 100 100 100 100) | ||
Zoffix | m: my %a = a => {b => 1}; say %a{"a","a";"b"}; say %a{"a";"b"}:exists | 17:48 | |
camelia | (1 1) True |
||
SmokeMachine | %a{"a", "a"; "b"} == %a<a><b>, %a<a><b> | ||
Zoffix | m: my %a = a => {b => 1}; say %a{"a","a";"b"}; say %a{"a","a"\}:exists | ||
camelia | 5===SORRY!5=== Error while compiling <tmp> Unexpected closing bracket at <tmp>:1 ------> 031}; say %a{"a","a";"b"}; say %a{"a","a"\7⏏5}:exists |
||
Zoffix | m: my %a = a => {b => 1}; say %a{"a","a";"b"}; say %a{"a","a"}:exists | ||
camelia | (1 1) (True True) |
||
Zoffix | SmokeMachine: yeah, looks like it should be True, True | ||
SmokeMachine | %hash{1;2;3} isn't prepared to receive list of lists... | ||
the postcircunfix:<{; }>(\SELF, @indices, :$exists!) doesn't expect to @indices be multidimensional... | 17:50 | ||
Zoffix: ok! ill fix that! | |||
where can I find all nap::* functions? | 17:52 | ||
*nqp::* | |||
Zoffix | SmokeMachine: a lot of them are not documented. There's a list here: github.com/perl6/nqp/blob/master/d...s.markdown and nqp::p6* ones are here: github.com/rakudo/rakudo/blob/nom/...s.markdown | 17:53 | |
SmokeMachine | Zoffix: thanks! | ||
[Coke] | In general, you don't want nqp routines unless you are writing things in rakudo core. | 18:14 | |
AlexDaniel | s: &infix:<~~>, \(False, True) | 18:20 | |
SourceBaby | AlexDaniel, Sauce is at github.com/rakudo/rakudo/blob/5ca9...Mu.pm#L849 | ||
SmokeMachine | [Coke]: that's the case, i think... Im editing src/core/hash_slice.pm | 18:25 | |
[Coke] | excellent. | 18:26 | |
SmokeMachine | m: use nqp; say nqp::islist([1, 2]) | 18:55 | |
camelia | 0 | ||
SmokeMachine | m: use nqp; say nqp::islist(1, 2) | ||
camelia | 0 | ||
SmokeMachine | ? | 18:56 | |
nqp: nqp::islist(1, 2) | |||
camelia | At Frame 0, Instruction 18, op 'decont', operand 1, MAST::Local of wrong type (4) specified; expected 8 at gen/moar/stage2/QAST.nqp:6577 (/home/camelia/rakudo-m-inst-2/share/nqp/lib/QAST.moarvm:assemble_and_load) from gen/moar/stage2/NQPHLL.nqp:512 (/h… |
||
SmokeMachine | nqp: nqp::islist([1, 2]) | ||
camelia | ( no output ) | ||
SmokeMachine | nqp: note(nqp::islist([1, 2])) | ||
camelia | 1 | ||
SmokeMachine | nqp: note(nqp::islist(1, 2)) | ||
camelia | At Frame 0, Instruction 19, op 'decont', operand 1, MAST::Local of wrong type (4) specified; expected 8 at gen/moar/stage2/QAST.nqp:6577 (/home/camelia/rakudo-m-inst-2/share/nqp/lib/QAST.moarvm:assemble_and_load) from gen/moar/stage2/NQPHLL.nqp:512 (/h… |
||
SmokeMachine | is there a different behavior of "pure" nqp and nqp inside perl6? | 18:57 | |
Zoffix | Yes, in Rakudo [] is not an nqp list, but an a Perl6 array | 18:59 | |
m: use nqp; say nqp::islist(nqp::list) | |||
camelia | 1 | ||
SmokeMachine | is there a way to (with nqp) discover if a var is a list? | ||
Zoffix | "is a list" is a bit ambiguous. What do you mean? | 19:00 | |
SmokeMachine | m: use nqp; say nqp::istype((1, 2), List) | 19:01 | |
camelia | 1 | ||
Zoffix | Note that Seqs aren't Lists | 19:02 | |
And neither are Ranges | |||
SmokeMachine | i think 1;2, 3 are lists... | ||
m: say (1; 2).WHAT | |||
camelia | (List) | ||
SmokeMachine | m: say (1; 2, 3)[1].WHAT | 19:03 | |
camelia | (List) | ||
Zoffix | Huh. Turns out Atom has a warning for when you try to open large files. Asking if you still want to proceed. Considerring how slow it gets when loading largish files without that warning, I think clicking "Proceed" is unwise :) | 19:04 | |
m: dd (1; 2, 3).Array | |||
camelia | [1, (2, 3)] | ||
Zoffix | m: dd (1; 2, 3)>>.Array | ||
camelia | ([1], [2, 3]) | ||
Zoffix | m: my @a = [[<b c d>], [<d e f>]]; my @wat = (*;1,2); dd @a[*;1,2] | 19:08 | |
camelia | ("c", "d", "e", "f") | ||
Zoffix | m: my @a = [[<b c d>], [<d e f>]]; my @wat = (*;1,2); dd @a[@wat] | ||
camelia | (($["b", "c", "d"], $["d", "e", "f"]), Any) | ||
Zoffix | m: my %a = a => {b => {d => 99}}, c => {b => { d => 100 }}; my @wat = ("a","c";"b", "b", "b";"d","d"); dd %a{"a","c";"b", "b", "b";"d","d"} | 19:09 | |
camelia | (99, 99, 99, 99, 99, 99, 100, 100, 100, 100, 100, 100) | ||
Zoffix | m: my %a = a => {b => {d => 99}}, c => {b => { d => 100 }}; my @wat = ("a","c";"b", "b", "b";"d","d"); dd %a{@wat} | ||
camelia | (Any, Any, Any) | ||
Zoffix surprised this doesn't work | |||
At least it's consistently inconsistent | |||
m: use nqp; my %h .= push: |"a:42\nbfdsasa:80\na:50\na:70".lines.map: { nqp::substr($_, 0, nqp::rindex($_, ':')) => nqp::substr($_, nqp::rindex($_, ':')+1)}; dd %h{*;}».Slip.flat.elems | 19:34 | ||
camelia | 4 | ||
Zoffix | Cool! Got to use {*;} stuff the same day I learned about it :) | ||
m: use nqp; my %h .= push: |"a:42\nbfdsasa:80\na:50\na:70".lines.map: { nqp::substr($_, 0, nqp::rindex($_, ':')) => nqp::substr($_, nqp::rindex($_, ':')+1)}; dd %h.values».elems.sum | 19:35 | ||
camelia | 4 | ||
Zoffix | Though this version is consiser and clearer :P | ||
And turns out I don't even need it at all >_< | 19:36 | ||
bartolin | some of the newly added tests to S32-io/open.t fail badly on JVM. didn't work through all of them, but the first error is an IllegalArgumentException, because read and append cannot be used together (see docs.oracle.com/javase/8/docs/api/...ibute...-) | 19:39 | |
$ ./perl6-j -e 'my $fh = open "foo", :append; $fh.close' | 19:40 | ||
java.lang.IllegalArgumentException: READ + APPEND not allowed | |||
Zoffix | bartolin: are those the only failures? I was just adding different combinations of the args, so I guess the simplest solution is to just toss these tests: github.com/perl6/roast/blob/master...#L232-L250 | 19:43 | |
bartolin | Zoffix: I'll take a closer look. would it make sense if I create a PR for roast for further discussion? | 19:45 | |
Zoffix | bartolin: if it's just the tests I linked to, I think you can just remove them and commit directly. | 19:47 | |
bartolin | Zoffix: it's at least the block before the linked one as well. | 19:48 | |
(plain :append) | |||
Zoffix | bartolin: oh, right, that can too go | ||
bartolin | Zoffix: I'm looking. it'll take some time, though ... | 19:51 | |
Zoffix | I should probably make a JVM build and do it myself. There's a whole ton of new tests coming in the next 4 weeks. | 20:04 | |
bartolin | aha, a second problem is that :create is ignored if the file is opened only for reading. that's why one gets NoSuchFileExceptions for these tests: github.com/perl6/roast/blob/master...#L272-L314 | ||
Zoffix | heh | ||
Looks like open's args need to be thought about a bit :) | 20:05 | ||
bartolin | hmm, well. I'd prefer if you are not slowed down from your work on rakudo-m. on the other hand I'm not too keen to look at all the fallout of rakudo-j :-) | 20:06 | |
Zoffix | :) | 20:07 | |
I'll take care of the JVM for the new IO tests | |||
bartolin | Zoffix++ # definitely not only for that commitment | 20:08 | |
SmokeMachine | my %a = a => {b => 42}; say %a{"a", "a"; "b", "b"}:exists should be (True, True, True, True) or ((True, True), (True, True)) ? | 20:20 | |
Zoffix | m: dd my %a = a => {b => 42}; say %a{"a", "a"; "b", "b"} | ||
camelia | Hash %a = {:a(${:b(42)})} (42 42 42 42) |
||
Zoffix | m: my %a = a => {b => 42}; dd %a{"a", "a"; "b", "b"} | 20:21 | |
camelia | (42, 42, 42, 42) | ||
Zoffix | (True, True, True, True) | ||
SmokeMachine | :( | ||
Zoffix | Well, I think :) | 20:22 | |
But it'd make sense to me that it follows the same pattern as looking up those keys | |||
SmokeMachine | Zoffix: I agree... but ((True, True),(True, True)) was already working... :P | ||
Any idea to how I make it return a list and no a list of lists? www.irccloud.com/pastebin/gEtL9QWM/ | 20:36 | ||
www.irccloud.com/pastebin/rpWJx5rN/ | 20:38 | ||
Zoffix | m: dd flat ((True, True), (True, True)) | 20:39 | |
camelia | (Bool::True, Bool::True, Bool::True, Bool::True).Seq | ||
Zoffix | Thgough I don't know if it's always the right answer | ||
or even at all, since it gives a Seq | |||
SmokeMachine | I tried to add a .Slip on the nqp::while... | 20:41 | |
Zoffix: with the flat() www.irccloud.com/pastebin/18Dsv1GR/ | 20:42 | ||
(Bool::True, Bool::False, Bool::True, Bool::False, Bool::True, Bool::False, Bool::True, Bool::False).Seq | |||
as you sad: it worked, but should it be a Seq? | |||
should I just add a .List and that's it? | 20:43 | ||
Zoffix | Dunno | ||
Zoffix is done for the night | |||
Zoffix & | |||
irc | 20:55 | ||
oops | |||
I'm still gone. I'm just waiting for my stupid video card driver to update.... :) | 20:57 | ||
timotimo | mhm | 21:02 | |
Zoffix | About to play Mass Effect 3 :) | 21:06 | |
I mean Mass Effect Andromeda | |||
finished analyzing source file. 185 line/filename annotations found. | |||
coverage report read: 2600 lines covered. | |||
timotimo | i think it's a fun game | ||
Zoffix | done analyzing annotations file: 37080 lines found | ||
w00t progress! | |||
timotimo | i don't have it yet, but i might get it | ||
Zoffix | Though the index.html file it made is empty :/ | ||
timotimo | i never played ME3 :( | ||
[Coke] | I only ever played ME2, wasn't psyched enough to get any of the others. | 21:18 | |
timotimo | i believe ME2 was much more shooter-esque than ME1, and ME3 continued that trend i think? | ||
samcv | nqp test for regex `\Qabc\E` it is todo'd and looking for the error `<Unrecognized>` that seems maybe outdated? | 21:22 | |
it doesn't say <Unrecognized> but the error is a description that it's removed and what to use instead | 21:23 | ||
so that test should be un-todo'd and changed probably right? | |||
Zoffix | m: /\Qabc\E/ | ||
camelia | 5===SORRY!5=== Error while compiling <tmp> Unsupported use of \Q as quotemeta; in Perl 6 please use quotes or literal variable match at <tmp>:1 ------> 3/\Q7⏏5abc\E/ |
||
Zoffix | yeah | ||
samcv | kk that's what i thought thanks | 21:24 | |
Zoffix | ME1 is what got me psyched. Dunno how it's like to start with ME2, since you don't know wtf Garius is etc. And in ME3 you meet all the characters from ME1 that you've not met in ME2, so it'll probably be quite nonsensical :) | 21:25 | |
Looks like coverage parser can be simplified now. Since annotations and coverage report use the SETTING::src/blah format. The loop that loops through the setting source just needs to be reworked and I think I'll unbust the tool \o/ | 21:30 | ||
SmokeMachine | we have this test: isa-ok %multi-dim{1;2;3}:exists, Bool, "Bool test for literal multi dim key;" should I change? | 21:37 | |
Zoffix | That looks like a single key tho, so it should be a bool | 21:39 | |
m: my %multi-dim = 1 => { 2 => { 3 => 42 } }; dd %multi-dim{1;2;3} | |||
camelia | (42,) | ||
Zoffix | m: my %multi-dim = 1 => { 2 => { 3 => 42 } }; dd %multi-dim{1;2;3}:exists | ||
camelia | Bool::True | ||
Zoffix | Oh | ||
Hm | 21:40 | ||
Zoffix has no idea | |||
SmokeMachine: maybe ask lizmat++? She was doing a lot of work with multi-dim stuff and might know what these things are meant to return | |||
SmokeMachine | Zoffix: ok! Ill try! | 21:42 | |
Geth | nqp: f04f5dbcda | (Samantha McVey)++ | 3 files Fix some regex tests and un-todo ~4 of them The tests were looking for the wrong words, and so have been todo'd even though they have actually been fixed. |
21:45 | |
lizmat | and another Perl 6 Weekly hits the Net: p6weekly.wordpress.com/2017/03/27/...-the-same/ | 22:16 | |
SmokeMachine | hi lizmat! could you, please, give me you opinion about what was discussed? irclog.perlgeek.de/perl6-dev/2017-...i_14331593 | 22:23 | |
lizmat: and thank you for the welcome! :) | 22:25 | ||
lizmat | yeah, that looks like a bug to me and it should say True,True :-) | ||
you're welcome | |||
samcv | ugh it's still slower. somewhere i feel nqp/rakudo must be lowercasing or foldcasing this string when i do regex | 22:28 | |
because i benched worst case performance on nqp and it was basically the same | |||
MasterDuke | stick a print in moar's lc and uc functions and see if it shows up? | ||
samcv | yeah i guess i could do that | 22:29 | |
i mean i removed at least one place where it foldcased in nqp. and so all tests pass, all the todo's pass. but worstcase takes ~1.8x as long to go through an entire string | |||
whereas on nqp it is even | 22:30 | ||
perl 6 grammar/ast gods please save me :X | |||
Zoffix | lizmat++ good weekly | 22:35 | |
timotimo | you know, you can also breakpoint those functions and rely on moar-gdb.py to properly print out the string in question | 22:39 | |
just a thought :P | |||
samcv | well --target=mast doesn't show any lc or uc calls | 22:41 | |
but it shows indexic_s which is right | 22:42 | ||
so hmm. wondering why it's slower :\ | |||
is comparing mast output useful? | |||
the speed diff changes only on changes to nqp. and nqp has no speed discrepency with case insensitive regex. | 22:43 | ||
SmokeMachine | lizmat: what should that do? Return the first position of the list if it's only 1 element? | 23:08 | |
samcv | timotimo, it seems using nqp it takes about the same time to do nqp::index as nqp::indexic, but on perl6... it's slower. running the same nqp ops | 23:56 | |
i *think* maybe i'm just doing something wrong here | 23:59 |