Re: [PATCH 2/2] rust: alloc: add `Vec::dec_len`
From: Tamir Duberstein
Date: Tue Mar 18 2025 - 16:15:24 EST
On Tue, Mar 18, 2025 at 4:05 PM Tamir Duberstein <tamird@xxxxxxxxx> wrote:
>
> On Tue, Mar 18, 2025 at 3:27 PM Danilo Krummrich <dakr@xxxxxxxxxx> wrote:
> >
> > On Tue, Mar 18, 2025 at 02:53:48PM -0400, Tamir Duberstein wrote:
> > > On Tue, Mar 18, 2025 at 2:46 PM Danilo Krummrich <dakr@xxxxxxxxxx> wrote:
> > > >
> > > > On Tue, Mar 18, 2025 at 02:28:02PM -0400, Tamir Duberstein wrote:
> > > > > On Tue, Mar 18, 2025 at 10:44 AM Alice Ryhl <aliceryhl@xxxxxxxxxx> wrote:
> > > > > >
> > > > > > On Tue, Mar 18, 2025 at 10:12:28AM -0400, Tamir Duberstein wrote:\
> > > > > > >
> > > > > > > The methods you're describing are all on Vec, right? In other words,
> > > > > > > their usage calls for a private `dec_len` or `set_len`. As I've said
> > > > > > > repeatedly in the course of this discussion: I would prefer not to
> > > > > > > introduce `dec_len` at all here. It (or `set_len`) can be introduced
> > > > > > > in the series that adds truncate or your patch that adds clear, where
> > > > > > > its signature can be properly scrutinized in the context of an actual
> > > > > > > caller.
> > > > > >
> > > > > > Oh I did not see that you said that. Dropping patch 2 is fine with me.
> > > > > >
> > > > > > Alice
> > > > >
> > > > > Benno, Danilo: are you both OK with this? I'll discard this patch on
> > > > > the respin and prepend the patch adding the len <= cap invariant.
> > > >
> > > > I mean, the whole reason to switch set_len() to inc_len() and have a separate
> > > > dec_len() was to properly cover things like [1] and Alice' patch by having
> > > > dec_len() return the abandoned entries.
> > > >
> > > > If we now only switch set_len() to inc_len() and drop dec_len() then what should
> > > > Andrew do?
> > >
> > > I'd be completely fine with Andrew (or Alice) taking this patch into
> > > the truncate/resize series[1] (or the series that introduces clear
> > > [2]). It can be properly reviewed there in context.
> >
> > Sorry, I'm not willing to make this Andrew's responsibility; set_len() worked
> > for his patches before.
> >
> > If you're uncomfortable implementing your proposal without the existence of
> > truncate(), please rebase onto Andrew's patches.
>
> This suits me just fine! I tried applying Andrew's patches locally but
> I don't have `Documentation/gpu/nova/core/todo.rst`. Do you know what
> his base commit is?
Nevermind, I can just specify the patch ID.