This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: Patch: implement new dynamic varobj spec


> From: Tom Tromey <tromey@redhat.com>
> Date: Thu, 10 Sep 2009 14:58:05 -0600
> 
> This is the long-awaited dynamic varobj patch.
> It implements the spec as described by Vladimir:
> 
>     http://sourceware.org/ml/gdb/2009-07/msg00088.html

Thanks.

> This patch needs a doc review.

Sorry for a delay in providing this review.

> +Once sent, this command cannot be undone.

A minor stylistic nit: I suggest the following variant:

  Once enabled, this feature cannot be disabled.

> +Note that if Python support has not been compiled into @value{GDBN},
> +this command will still succeed.

Suggest to add "(and do nothing)" to the end of the sentence

Btw, does this silent failure have good reasons?

> +This operation returns attributes of the newly-created varobj.  These
> +include, but are not limited to:

Why don't we have an exhaustive list here?

> +@item thread-id
> +If a fixed variable object is bound to a specific thread, then this is
> +the thread's identifier.

Is "fixed" used here as opposed to "dynamic"?  If so, it would be a
good idea to say explicitly what, if anything, this attribute means
for a dynamic varobj.  (If that's not the intent, please explain the
significance of the word "fixed" here; I cannot find "fixed varobj"
anywhere else in the manual.)

> +reset and all children will be reported.  Otherwise, children starting
> +at @var{from} (zero-based) and ending just before @var{to} will be
> +reported.

Since "ending just before" is a bit ambiguous, suggest to reword
thusly:

  Otherwise, children starting at @var{from} (zero-based) and up to
  and excluding @var{to} will be reported.

> +If a child range is requested, it will not affect the range of
> +children reported by a future call to @code{-var-update}.

Would it be better to say explicitly that only the current calls are
affected?  Like this:

  If a child range is requested, it will only affect the current call
  to @code{-var-update}, but not the future calls.

> +For a dynamic varobj, this value cannot reliably be used to form an
> +expression.  Also, a dynamic varobj will not report the access
> +qualifying pseudo-children, regardless of the language.

Do we want to give the reader some hints as to how to achieve these
with dynamic varobjs?

> +A dynamic varobj can supply a display hint to the front end.  The
> +comes directly from the Python pretty-printer object's
> +@code{display_hint} method.  @xref{Pretty Printing}.

Something is missing in the second sentence.

> +children will be reported.  Otherwise, children starting at @var{from}
> +(zero-based) and ending just before @var{to} will be reported.

Same comment as above about "ending just before".

Finally, I think we need a @cindex entry for "dynamic varobj" pointing
to the section where they are introduced (with a @dfn).

Thanks.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]