- Grammar
- 0.6
- "extern mod", "use", items ordering
- ~[0, ..n]
- "as @Trait" with coercion
- "@mut Trait"
pcwalton, nmatsakis, brson, graydon, jclements, jld, metajack, tjc, azita, pnkfelix
- jc: Some of the lexer rules are a bit hairy.
- jc: It should parse all rust sources into token trees
- nmatsakis: Did you follow the discussion we had about how to deal with
>>
vs>
? - jc: proposal I recall was to actually make
>>
two separate tokens...? - nmatsakis: not quite... let's discuss on IRC
- G: Still 70 on the milestone, too many but we've made progress
- G: We also closed about 50, not just bumped milestones
- G: I'm just doing robot babysitting, polishing release notes, etc
- G: I've got a list of bugs that I didn't close and I didn't demilestone because I wanted to discuss some of them
- G: Not sure if everyone else did that?
- Yes. Everyone left 5 or 6 open.
- G: Release notes still coming into shape. If I post a release candidate this evening...
- G: ...does anyone have anything queued up that may destabilize things?
- P: I've got a lot of big "break the world" changes that haven't landed yet
- P: I'm going to need a quick turnaround for a review in some cases
- G: So we won't do it today. It's a short week (Friday off) in Canada.
- N: Shall we just take it day by day?
- G: I guess, Brian at least has the signing keys, so we could theoretically do the release on Friday.
- N: It's been suggested in the past that Friday is not the best day for a release anyhow, if the main purpose is to get people to take a look.
- G: Shall we review the remaining bugs?
- P: I have a few things to add to the agenda
- P: Currently you can write
use
declarations and items in any order, but resolve always treats all items as shadowing use statements, no matter where they appear. - P: This can be confusing and seems wrong.
- P: Also,
extern mod
shadows use statements but most people put it before theuse
- P: My proposal is to require that you must write (1) extern modules; (2) uses; and finally (3) items, and resolve treats them as shadowing in that order.
- P: So there are two changes here:
- flipping the shadowing rules for
extern mod
anduse
(e.g.,extern mod sdl; use sdl::sdl;
) - forcing people to write things in the shadowing order so as to give a better intution
- flipping the shadowing rules for
- ?: Is it an error to have two top-level bindings with the same name?
- P: Depends, two functions yes, but use is not an error
- jc: What about multiple extern mods?
- N: My first thought was to ask why we permit shadowing at all? But I guess that the sdl example is good. Also
use
- N: OK, if we permit shadowing, I think your proposal sounds good
- P: What should this mean?
- N: I think it should ideally mean
~[0, ..n]
, since we don't generally make the literal forms "compose" with ~ ... - jld: yes, all the other cases of
~[
are actual~
vectors - G: You can get around it by parenthesizing, right?
- P: Yes.
- N: In the future it'd be useful to special case
~[None, ..n]
where the option is non-copyable - P: I don't know the right thing to do there but we can defer that
- N: Yes, this just opens the door for that was my point
- P: Niko has brought up that it might be useful to allow
@T
to coerce to@Trait
automatically - P: My question is (a) do we want to do this and (b) should we still allow an explicit cast?
- P: Keep in mind that right now we have three notions of "type comparison"---
- Subtyping
- Implicit coercion (
let x: T = ...
, perhapsexpr: T
) - Explicit casts (
as
)
- P: So I think there's a deeper question of "what does
as
mean"? - P: I lean towards making
as
just for number conversion, - N: If we said that
as
is only for integers, it only needs to take a path, not a type, right? - G: You could almost rip it out and replace it with functions...
- P: ...except for consts.
- G: I think casting to a boxed vtable representation is counterintuitive
- G: It's cute that we figured out that we can do it, but nobody will ever guess it
- G: So I'm fine removing that but I'm not sure what we ought to use to produce objects
- G: Magically coercing thing seems a bit off?
- P: Go does it and it doesn't seem too confusing
- N: It seems convenient to me, e.g.,
do_printable(foo)
"auto-objects"foo
- G: So it's kind of analogous to how you'd use a trait parameter bound.
- N: That was the idea
- G: Do we have to decide now?
- P: No, we don't have to, 0.6 will not be totally backwards compatible
- B: My concern is that since objects are not that useful yet I don't know how imp't this will be
- P: I know that the Ruby users in the community complain :)
- P: A lot of people write little games with objects representing things in the game world
- P: And it's annoying to have to write
as @GameObject
all the time - jc: I went through that, until I read the tutorial more carefully
- P: To me it feels like, we have had complains and Go uses it so there is precedent
- G: I agree with Brian that we don't have a lot of experience, but I don't see this change making things worse or causing us to be committed to a strong reliance on objects
- G: If anything it makes them a bit more invisible
- P: I do use
&
objects in sprocket-nes - G: We use them in a few places, and we will use them more (e.g.,
I/O
) - N: They have a role.
- G: Like in C++, most everything is static, but not everything
- P: The invisibility with respect to I/O is a good point, because I'd like to have I/O yield the real types and not always objects
- P: But then people can write routines that just take
io::Reader
and things will still work fn read_my_thing(x: &Reader, ...) - G: I'm ok with this change, does anyone object?
- G: I don't think this forces you to use objects more (or even suggests you should) but makes it a little smoother if you do use them
- jc: At one point Niko proposed adding
:
for a type assertion, is that related? - jc: I always saw
as
as type assertion... - pcwalton: ...
as
isn't good for this role because it does explicit coercion too - jc: But is the
:
going to happen? - P: that seems like a separate, backwards compatible discussion
- P: there is a discussion to be had about what precisely that should mean anyhow
- pnkfelix: actual proposal here is to restrict
as
to work with numbers? - P: I don't have a strong opinion about it
- N: I think I like the idea of restricting
as
to numeric - G: Is it possible for us to generate an
&Trait
in a constant? - P: I don't know, but I think it's sort of tangential, coercions can happen there too
- N: I imagine we could make it work but I agree with P that it can be made to work
- G: I'm ok restricting it, I think if we remove it, newcomers will never even notice
- P: I think there is almost nothing to discuss, but...this should work, right?
- N: Not just
@mut
but&mut
too - P: Right, right
- N: Did you plan to put this in for 0.6?
- P: No...
- N: Ok.
- G: One bug I was concerned about was that
core::ops
is not showing up in the docs...? - B: I fixed that (#4800)
- G: Cleanup:
rustc
vsrustc.exe
on Windows? - G: Feeding LLVM patches upstream? (#4259)
- G: Does anyone even remember what they are anymore?
- B: I'm kind of working on that, Samsung has a number of changes that they are working on, and I've been encouraging them to bundle those up together to avoid disruption
- B: I've got a fork I gave to Samsung that removes all precise GC stuff
- B: There was one bugfix but I think it's upstream
- B: So I think there's not much else
- P: that might change with morestack?
- G: In terms of this release, is there anything where we feel like we've drifted so far it's scary...sounds like no.
- B: If we don't upgrade LLVM before the release, android will still be basically broken
- G: I think the premise that android will work for 0.6 is false
- G: In the 0.x series, our goal is just to throw something up for those who don't follow on a daily basis and show progress. I mostly expect people to just see the tarball go by and not to really use it. Let people know we are progressing, give release notes to read.
- G: I don't mean to minimize how much work went into it, it's a lot, but I think anyone who cares about the android port will have to use incoming anyhow
- Azita: So at what point will we be backwards compatible?
- P: Maybe 0.7?
- G: We don't know yet, I think it's hard to know what backwards compatible precisely means
- G: When we have a clear notion of how to define "BC" ... probably requires
- bug queue under control
- language versioning
- some semantic cleanup
- P: To me, BC is a goal to work towards, not yet a promise
- N: I think there are degrees of BC. So 1.0 is the true answer, but we've gotten almost all the syntactic changes out of the way thanks to pcwalton and others, I expect by 0.7 we'll be nearly 100% syntactically BC, but there will still be (hopefully small) semantic changes
- G: Biggest was probably 0.4 and we're still dealing with fallout, we haven't done change like that since
- G: I'm reasonably confident that we are converging now
- G: No new keywords added, only removed
- G: No new sections added, only removed
- G: Libraries were being moved around, cleaned up
- G: We are converging, but not there yet
- P: I'm pretty sure that 0.6 will be mostly BC, though "battle plans never survive contact with the enemy". Some known things: copy keyword, as @Object, some borrowed pointer changes.