unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* window-list
@ 2004-08-17 17:25 Karl Chen
  2004-08-18 10:39 ` window-list Kim F. Storm
                   ` (2 more replies)
  0 siblings, 3 replies; 11+ messages in thread
From: Karl Chen @ 2004-08-17 17:25 UTC (permalink / raw)



There's been a change in window-list that removes available
functionality: getting the list of windows in canonical order,
starting with the first window.  This is important functionality
that I depend on; I don't see any way to get it now through only
ELisp.

I propose the following change to window-list:
  WINDOW t means return the list unrotated (in canonical order)

Due to the call to decode_next_window_args() which should not
allow WINDOW t, the patch would be more than 2 or 3 lines if
decode_next_window_args() and the call to it from window_list_1()
were not changed.


Relevant ChangeLog entry:

2004-07-17  Richard M. Stallman  <rms@gnu.org>

        * window.c ...
        (window_list_1): Rotate the list to start with WINDOW.



-- 
Karl 2004-08-17 10:00

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-17 17:25 window-list Karl Chen
@ 2004-08-18 10:39 ` Kim F. Storm
  2004-08-18 18:03   ` window-list Luc Teirlinck
  2004-08-18 17:41 ` window-list Luc Teirlinck
  2004-08-18 18:47 ` window-list Richard Stallman
  2 siblings, 1 reply; 11+ messages in thread
From: Kim F. Storm @ 2004-08-18 10:39 UTC (permalink / raw)
  Cc: emacs-devel

Karl Chen <quarl@nospam.quarl.org> writes:

> There's been a change in window-list that removes available
> functionality: getting the list of windows in canonical order,
> starting with the first window.  This is important functionality
> that I depend on; I don't see any way to get it now through only
> ELisp.
> 
> I propose the following change to window-list:
>   WINDOW t means return the list unrotated (in canonical order)
> 
> Due to the call to decode_next_window_args() which should not
> allow WINDOW t, the patch would be more than 2 or 3 lines if
> decode_next_window_args() and the call to it from window_list_1()
> were not changed.
> 
> 
> Relevant ChangeLog entry:
> 
> 2004-07-17  Richard M. Stallman  <rms@gnu.org>
> 
>         * window.c ...
>         (window_list_1): Rotate the list to start with WINDOW.


I don't recall any discussion about the need for that change, but
I guess there was a reason....

But I second your idea of using window=t to get the canonical list.


In any case, you can still get a canonical window list from lisp;
edebug does it like this --- you can probably tweak it to
your needs:

(defun edebug-window-list ()
  "Return a list of windows, in order of `next-window'."
  ;; This doesn't work for epoch.
  (let (window-list)
    (walk-windows (lambda (w) (push w window-list)))
    (nreverse window-list)))


-- 
Kim F. Storm <storm@cua.dk> http://www.cua.dk

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-17 17:25 window-list Karl Chen
  2004-08-18 10:39 ` window-list Kim F. Storm
@ 2004-08-18 17:41 ` Luc Teirlinck
  2004-08-18 20:18   ` window-list Karl Chen
  2004-08-18 18:47 ` window-list Richard Stallman
  2 siblings, 1 reply; 11+ messages in thread
From: Luc Teirlinck @ 2004-08-18 17:41 UTC (permalink / raw)
  Cc: emacs-devel

Karl Chen wrote:

   There's been a change in window-list that removes available
   functionality: getting the list of windows in canonical order,
   starting with the first window.  This is important functionality
   that I depend on; I don't see any way to get it now through only
   ELisp.

What about:

(window-list frame minibuf (frame-first-window frame))

If FRAME is the selected frame this can be simplified to:

(window-list nil minibuf (frame-first-window))

Or am I misunderstanding the problem?

Sincerely,

Luc.

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-18 10:39 ` window-list Kim F. Storm
@ 2004-08-18 18:03   ` Luc Teirlinck
  2004-08-19  9:50     ` window-list Kim F. Storm
  0 siblings, 1 reply; 11+ messages in thread
From: Luc Teirlinck @ 2004-08-18 18:03 UTC (permalink / raw)
  Cc: quarl+dated+1093194046.34955e, emacs-devel

Kim Storm wrote:

   I don't recall any discussion about the need for that change, but
   I guess there was a reason....

To make the function do what both its docstring and the documentation
in the Elisp manual claim it does:

 -- Function: window-list &optional frame minibuf window
     This function returns a list of the windows on FRAME, starting
     with WINDOW.  If FRAME is `nil' or omitted, the selected frame is
     used instead; if WINDOW is `nil' or omitted, the selected window
     is used instead.

So I do not believe that there _has_ been a change in documented
behavior.  The documentation was changed quite a while ago, for
"compatibility with XEmacs".  (Revision 1.322 to window.c on Nov 19,
2000, by Gerd.)  I guess the change must have been discussed back
then.  The new behavior was never correctly implemented, until
Richard's change.

As I already pointed out, unless I am misunderstanding, one can get
the behavior Karl wants, from Elisp, using:

(window-list frame minibuf (frame-first-window frame))

Sincerely,

Luc.

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-17 17:25 window-list Karl Chen
  2004-08-18 10:39 ` window-list Kim F. Storm
  2004-08-18 17:41 ` window-list Luc Teirlinck
@ 2004-08-18 18:47 ` Richard Stallman
  2 siblings, 0 replies; 11+ messages in thread
From: Richard Stallman @ 2004-08-18 18:47 UTC (permalink / raw)
  Cc: emacs-devel

    There's been a change in window-list that removes available
    functionality:

What you were using was a bug.

     getting the list of windows in canonical order,
    starting with the first window.

When you say "the first window", do you mean the one at the top
left?  If so, (window-list nil nil (frame-first-window)) should
do what you want.  There is no need for a new feature,
and I don't want to add one.

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-18 17:41 ` window-list Luc Teirlinck
@ 2004-08-18 20:18   ` Karl Chen
  0 siblings, 0 replies; 11+ messages in thread
From: Karl Chen @ 2004-08-18 20:18 UTC (permalink / raw)


>>>>> "Luc" == Luc Teirlinck <teirllm@dms.auburn.edu> writes:
    Luc> What about:
    Luc> 
    Luc> (window-list frame minibuf (frame-first-window frame))

Yes, that's what I wanted (didn't know about frame-first-window).
Thanks.  Then I agree, no new feature needed.


-- 
Karl 2004-08-18 13:16

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-18 18:03   ` window-list Luc Teirlinck
@ 2004-08-19  9:50     ` Kim F. Storm
  2004-08-20  4:49       ` window-list Richard Stallman
  0 siblings, 1 reply; 11+ messages in thread
From: Kim F. Storm @ 2004-08-19  9:50 UTC (permalink / raw)
  Cc: quarl+dated+1093194046.34955e, emacs-devel

Luc Teirlinck <teirllm@dms.auburn.edu> writes:

> Kim Storm wrote:
> 
>    I don't recall any discussion about the need for that change, but
>    I guess there was a reason....
> 
> To make the function do what both its docstring and the documentation
> in the Elisp manual claim it does:
> 
>  -- Function: window-list &optional frame minibuf window
>      This function returns a list of the windows on FRAME, starting
>      with WINDOW.  If FRAME is `nil' or omitted, the selected frame is
>      used instead; if WINDOW is `nil' or omitted, the selected window
>      is used instead.
> 
> So I do not believe that there _has_ been a change in documented
> behavior.  The documentation was changed quite a while ago, for
> "compatibility with XEmacs".  (Revision 1.322 to window.c on Nov 19,
> 2000, by Gerd.)  I guess the change must have been discussed back
> then.  The new behavior was never correctly implemented, until
> Richard's change.

Thank you for clarifying that.

> 
> As I already pointed out, unless I am misunderstanding, one can get
> the behavior Karl wants, from Elisp, using:
> 
> (window-list frame minibuf (frame-first-window frame))

Would it be an idea to mention that in the manual?

-- 
Kim F. Storm <storm@cua.dk> http://www.cua.dk

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-19  9:50     ` window-list Kim F. Storm
@ 2004-08-20  4:49       ` Richard Stallman
  2004-08-20 21:04         ` window-list Karl Chen
  0 siblings, 1 reply; 11+ messages in thread
From: Richard Stallman @ 2004-08-20  4:49 UTC (permalink / raw)
  Cc: quarl+dated+1093194046.34955e, teirllm, emacs-devel

    > (window-list frame minibuf (frame-first-window frame))

    Would it be an idea to mention that in the manual?

I don't think we need to clutter the manual by documenting erroneous
behavior that has been fixed.  The behavior of the function now agrees
with its documentation, so if anyone sees an incorrect use of it, he
will know how to fix it.

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-20  4:49       ` window-list Richard Stallman
@ 2004-08-20 21:04         ` Karl Chen
  2004-08-21 16:50           ` window-list Richard Stallman
  0 siblings, 1 reply; 11+ messages in thread
From: Karl Chen @ 2004-08-20 21:04 UTC (permalink / raw)


>>>>> "rms" == Richard Stallman <rms@gnu.org> writes:
    rms> 
    >> (window-list frame minibuf (frame-first-window frame))
    rms>     Would it be an idea to mention that in the manual?
    rms> 
    rms> I don't think we need to clutter the manual by
    rms> documenting erroneous behavior that has been fixed.  The
    rms> behavior of the function now agrees with its
    rms> documentation, so if anyone sees an incorrect use of it,
    rms> he will know how to fix it.
    rms> 

How about cluttering NEWS then?


-- 
Karl 2004-08-20 14:03

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-20 21:04         ` window-list Karl Chen
@ 2004-08-21 16:50           ` Richard Stallman
  2004-08-21 17:00             ` window-list Luc Teirlinck
  0 siblings, 1 reply; 11+ messages in thread
From: Richard Stallman @ 2004-08-21 16:50 UTC (permalink / raw)
  Cc: emacs-devel

    How about cluttering NEWS then?

Ok, I guess.

^ permalink raw reply	[flat|nested] 11+ messages in thread

* Re: window-list
  2004-08-21 16:50           ` window-list Richard Stallman
@ 2004-08-21 17:00             ` Luc Teirlinck
  0 siblings, 0 replies; 11+ messages in thread
From: Luc Teirlinck @ 2004-08-21 17:00 UTC (permalink / raw)
  Cc: quarl+dated+1093467834.aef62f, emacs-devel

Richard Stallman wrote (in response to Karl Chen):
       
       How about cluttering NEWS then?

   Ok, I guess.

Cluttering NEWS with _what_ exactly?  The behavior of `window-list'
_is_ already documented in the NEWS:

    ** The new function `window-list' has been defined

    - Function: window-list &optional FRAME WINDOW MINIBUF

    Return a list of windows on FRAME, starting with WINDOW.  FRAME nil or
    omitted means use the selected frame.  WINDOW nil or omitted means use
    the selected window.  MINIBUF t means include the minibuffer window,
    even if it isn't active.  MINIBUF nil or omitted means include the
    minibuffer window only if it's active.  MINIBUF neither nil nor t
    means never include the minibuffer window.

Sincerely,

Luc.

^ permalink raw reply	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2004-08-21 17:00 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-08-17 17:25 window-list Karl Chen
2004-08-18 10:39 ` window-list Kim F. Storm
2004-08-18 18:03   ` window-list Luc Teirlinck
2004-08-19  9:50     ` window-list Kim F. Storm
2004-08-20  4:49       ` window-list Richard Stallman
2004-08-20 21:04         ` window-list Karl Chen
2004-08-21 16:50           ` window-list Richard Stallman
2004-08-21 17:00             ` window-list Luc Teirlinck
2004-08-18 17:41 ` window-list Luc Teirlinck
2004-08-18 20:18   ` window-list Karl Chen
2004-08-18 18:47 ` window-list Richard Stallman

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).