* About the 'minibuffer' frame parameter
@ 2016-07-31 18:12 martin rudalics
2016-08-05 13:33 ` Eli Zaretskii
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-07-31 18:12 UTC (permalink / raw)
To: emacs-devel
With emacs -Q evaluate:
(progn
(setq minibuffer-less-frame (make-frame '((minibuffer . nil))))
(setq minibuffer-only-frame (make-frame '((minibuffer . only))))
(set-frame-parameter
minibuffer-less-frame 'minibuffer (frame-root-window minibuffer-only-frame))
(frame-parameter minibuffer-less-frame 'minibuffer))
This reveals a number of problems with how we currently handle the
'minibuffer' frame parameter and how it's documented. In section
28.4.3.5 we say about this parameter:
`minibuffer'
Whether this frame has its own minibuffer. The value `t' means
yes, `nil' means no, `only' means this frame is just a minibuffer.
If the value is a minibuffer window (in some other frame), the
frame uses that minibuffer.
This frame parameter takes effect when the frame is created, and
can not be changed afterwards.
The sentence "If the value is a minibuffer window (in some other frame),
the frame uses that minibuffer." is misleading. A minibuffer window is
reported iff that window is on the _same_ frame and that frame is not a
minibuffer-only frame. A minibuffer window in some other frame is never
reported.
But if the frame is minibuffer-less and uses the minibuffer window of
some other frame, we return as value nil although the real, internal
frame parameter's value (not the one produced by the
store_in_alist (&alist, Qminibuffer,
(! FRAME_HAS_MINIBUF_P (f) ? Qnil
: FRAME_MINIBUF_ONLY_P (f) ? Qonly
: FRAME_MINIBUF_WINDOW (f)));
construct) is actually that window. Otherwise, evaluating the
‘set-frame-parameter’ above would have produced an error. Which means
that the sentence "This frame parameter takes effect when the frame is
created, and can not be changed afterwards." is misleading as well. In
fact, setting the 'minibuffer' frame parameter is the only way to change
the minibuffer window for a specific frame.
Note in this context that ‘minibuffer-window’ returns the correct
minibuffer window for its FRAME argument while ‘set-minibuffer-window’
does not allow to set the minibuffer window for a specific frame.
I'm not sure how to deal with this situation. Personally, I'd prefer to
report the real, internal 'minibuffer' parameter but am afraid that
might break existing code. In any case, the documentation should be
fixed. Somehow.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-07-31 18:12 About the 'minibuffer' frame parameter martin rudalics
@ 2016-08-05 13:33 ` Eli Zaretskii
2016-08-05 16:37 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-05 13:33 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Sun, 31 Jul 2016 20:12:46 +0200
> From: martin rudalics <rudalics@gmx.at>
>
> I'm not sure how to deal with this situation. Personally, I'd prefer to
> report the real, internal 'minibuffer' parameter but am afraid that
> might break existing code.
You mean, you think there's some code out there that expects to
receive nil in that case? Do we have any code in our tree that might
expect that?
> In any case, the documentation should be fixed. Somehow.
Before fixing the docs we should decide what the code should do.
Thanks.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-05 13:33 ` Eli Zaretskii
@ 2016-08-05 16:37 ` martin rudalics
2016-08-05 17:18 ` Drew Adams
2016-08-05 19:25 ` Eli Zaretskii
0 siblings, 2 replies; 43+ messages in thread
From: martin rudalics @ 2016-08-05 16:37 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
>> I'm not sure how to deal with this situation. Personally, I'd prefer to
>> report the real, internal 'minibuffer' parameter but am afraid that
>> might break existing code.
>
> You mean, you think there's some code out there that expects to
> receive nil in that case? Do we have any code in our tree that might
> expect that?
I'm afraid so, yes. Otherwise this rigmarole would hardly make sense.
But I haven't checked all places because I rather soonish stumbled upon
things like
(eq (cdr (or (assq 'minibuffer initial-frame-alist)
(assq 'minibuffer window-system-frame-alist)
(assq 'minibuffer default-frame-alist)
'(minibuffer . t)))
t)
in ‘frame-notice-user-settings’. And one revealing comment is in
‘set-frame-configuration’:
;; Since we can't set a frame's minibuffer status,
;; we might as well omit the parameter altogether.
>> In any case, the documentation should be fixed. Somehow.
>
> Before fixing the docs we should decide what the code should do.
That's what I tried to initiate. Is there anyone out there who has an
idea how the 'minibuffer' parameter should be set and used? Maybe
nobody uses them any more.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* RE: About the 'minibuffer' frame parameter
2016-08-05 16:37 ` martin rudalics
@ 2016-08-05 17:18 ` Drew Adams
2016-08-05 17:35 ` martin rudalics
2016-08-05 19:25 ` Eli Zaretskii
1 sibling, 1 reply; 43+ messages in thread
From: Drew Adams @ 2016-08-05 17:18 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
> Is there anyone out there who has an idea how the 'minibuffer'
> parameter should be set and used? Maybe nobody uses them any more.
If by "them" you mean frame parameter `minibuffer' then yes, I use it.
I create a standalone minibuffer frame, so my `minibuffer-frame-alist'
has (minibuffer . only), using (setq minibuffer-frame-alist ...).
And my `default-frame-alist' has (minibuffer), aka (minibuffer . nil).
I do that similarly: (setq default-frame-alist...).
But I think you probably knew all that, so it is perhaps not really
what you are asking.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-05 17:18 ` Drew Adams
@ 2016-08-05 17:35 ` martin rudalics
2016-08-05 17:52 ` Drew Adams
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-05 17:35 UTC (permalink / raw)
To: Drew Adams, Eli Zaretskii; +Cc: emacs-devel
>> Is there anyone out there who has an idea how the 'minibuffer'
>> parameter should be set and used? Maybe nobody uses them any more.
>
> If by "them" you mean frame parameter `minibuffer' then yes, I use it.
>
> I create a standalone minibuffer frame, so my `minibuffer-frame-alist'
> has (minibuffer . only), using (setq minibuffer-frame-alist ...).
>
> And my `default-frame-alist' has (minibuffer), aka (minibuffer . nil).
> I do that similarly: (setq default-frame-alist...).
>
> But I think you probably knew all that, so it is perhaps not really
> what you are asking.
I know that you use stand-alone minibuffers and that you have to _set_
the 'minibuffer' frame parameter for that. I wanted to know how people
_use_ that parameter after, for example, doing
(frame-parameter nil 'minibuffer)
If nobody _uses_ it then we don't have to care about it.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* RE: About the 'minibuffer' frame parameter
2016-08-05 17:35 ` martin rudalics
@ 2016-08-05 17:52 ` Drew Adams
2016-08-05 18:19 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Drew Adams @ 2016-08-05 17:52 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
> >> Is there anyone out there who has an idea how the 'minibuffer'
> >> parameter should be set and used? Maybe nobody uses them any more.
> >
> > If by "them" you mean frame parameter `minibuffer' then yes, I use it.
> > I create a standalone minibuffer frame, so my `minibuffer-frame-alist'
> > has (minibuffer . only), using (setq minibuffer-frame-alist ...).
> > And my `default-frame-alist' has (minibuffer), aka (minibuffer . nil).
> > I do that similarly: (setq default-frame-alist...).
>
> I know that you use stand-alone minibuffers and that you have to _set_
> the 'minibuffer' frame parameter for that. I wanted to know how people
> _use_ that parameter after, for example, doing
>
> (frame-parameter nil 'minibuffer)
>
> If nobody _uses_ it then we don't have to care about it.
Dunno what you mean by "care about it". Just what are you proposing
to change, so as to no longer "care about it"?
I have code that does things to frames, and checks whether a given
frame is a standalone minibuffer frame. My code typically checks
whether it is just MY standalone minibuffer frame, by checking variable
`1on1-minibuffer-frame'. But more generally such code would check
the `minibuffer' frame parameter. I don't see why we would eliminate
that possibility.
And I believe that Juanma's frameset code carefully distinguishes
standalone minibuffer frames from others, by checking that parameter.
I think that Emacs users should continue to be able to test, as well
as set the `minibuffer' frame parameter. Why shouldn't they?
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-05 17:52 ` Drew Adams
@ 2016-08-05 18:19 ` martin rudalics
2016-08-05 18:37 ` Drew Adams
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-05 18:19 UTC (permalink / raw)
To: Drew Adams, Eli Zaretskii; +Cc: emacs-devel
> Dunno what you mean by "care about it".
Care about the issue(s) that started this thread.
> Just what are you proposing
> to change, so as to no longer "care about it"?
Nothing. As long as nobody cares about these issues.
> I have code that does things to frames, and checks whether a given
> frame is a standalone minibuffer frame. My code typically checks
> whether it is just MY standalone minibuffer frame, by checking variable
> `1on1-minibuffer-frame'. But more generally such code would check
> the `minibuffer' frame parameter. I don't see why we would eliminate
> that possibility.
I don't want to eliminate anything.
> And I believe that Juanma's frameset code carefully distinguishes
> standalone minibuffer frames from others, by checking that parameter.
>
> I think that Emacs users should continue to be able to test, as well
> as set the `minibuffer' frame parameter. Why shouldn't they?
Because IIUC they do not care much about "testing" it. Otherwise they
would have complained already.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* RE: About the 'minibuffer' frame parameter
2016-08-05 18:19 ` martin rudalics
@ 2016-08-05 18:37 ` Drew Adams
2016-08-06 9:32 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Drew Adams @ 2016-08-05 18:37 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
> > Dunno what you mean by "care about it".
>
> Care about the issue(s) that started this thread.
They are not clear to me, even on re-reading.
> > Just what are you proposing
> > to change, so as to no longer "care about it"?
>
> Nothing. As long as nobody cares about these issues.
I don't know what the issues are. But I definitely care about
frame parameter `minibuffer'. But if you are proposing doing
"Nothing" then I guess I have nothing to worry about. ;-)
> I don't want to eliminate anything.
Good.
> > And I believe that Juanma's frameset code carefully distinguishes
> > standalone minibuffer frames from others, by checking that parameter.
> >
> > I think that Emacs users should continue to be able to test, as well
> > as set the `minibuffer' frame parameter. Why shouldn't they?
>
> Because IIUC they do not care much about "testing" it. Otherwise they
> would have complained already.
What is the problem with testing it?
frameset.el tests it. And I test it. I `redirect-frame-focus' of a
minibuffer-less frame for *Completions* to my standalone minibuffer
frame, for example:
(let ((redirect (if (active-minibuffer-window)
1on1-minibuffer-frame
(and completion-reference-buffer
(get-buffer-window completion-reference-buffer
'visible)
(not (eq (get-buffer "*Completions*")
completion-reference-buffer))
(window-frame
(get-buffer-window
completion-reference-buffer t))))))
(when redirect (redirect-frame-focus (selected-frame) redirect)))
Okay, I don't actually test the frame parameter here explicitly, but
the code depends on it being and acting as it does, I think.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-05 16:37 ` martin rudalics
2016-08-05 17:18 ` Drew Adams
@ 2016-08-05 19:25 ` Eli Zaretskii
2016-08-06 9:33 ` martin rudalics
1 sibling, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-05 19:25 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Fri, 05 Aug 2016 18:37:50 +0200
> From: martin rudalics <rudalics@gmx.at>
> CC: emacs-devel@gnu.org
>
> > You mean, you think there's some code out there that expects to
> > receive nil in that case? Do we have any code in our tree that might
> > expect that?
>
> I'm afraid so, yes. Otherwise this rigmarole would hardly make sense.
>
> But I haven't checked all places because I rather soonish stumbled upon
> things like
>
> (eq (cdr (or (assq 'minibuffer initial-frame-alist)
> (assq 'minibuffer window-system-frame-alist)
> (assq 'minibuffer default-frame-alist)
> '(minibuffer . t)))
> t)
>
> in ‘frame-notice-user-settings’. And one revealing comment is in
> ‘set-frame-configuration’:
>
> ;; Since we can't set a frame's minibuffer status,
> ;; we might as well omit the parameter altogether.
We could simply change the above code to follow suit.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-05 18:37 ` Drew Adams
@ 2016-08-06 9:32 ` martin rudalics
2016-08-06 16:46 ` Drew Adams
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-06 9:32 UTC (permalink / raw)
To: Drew Adams, Eli Zaretskii; +Cc: emacs-devel
> They are not clear to me, even on re-reading.
Sorry for being unclear. Let me try once more: With emacs -Q, yank the
following forms into *scratch*
(defvar initial-frame (selected-frame))
(defvar minibuffer-less-frame (make-frame '((minibuffer . nil))))
(defvar minibuffer-only-frame (make-frame '((minibuffer . only))))
and evaluate them. You should see three frames - the "normal" initial
one, a minibuffer-less frame, and a minibuffer-only one. Correct?
Now in the minibuffer-less frame evaluate
(frame-parameter minibuffer-less-frame 'minibuffer)
and Emacs will print nil in the minibuffer window of the initial frame.
Next evaluate
(set-frame-parameter
minibuffer-less-frame 'minibuffer (frame-root-window minibuffer-only-frame))
and you will see nil in the minibuffer window of the minibuffer-only
frame. Now evaluate
(set-frame-parameter
minibuffer-less-frame 'minibuffer (minibuffer-window initial-frame))
and you will see nil in the minibuffer window of the initial frame
again.
From this we can conclude the following:
(1) Emacs does redirect output to the minibuffer window of the frame
specified via ‘set-frame-parameter’. This follows from the
experiment above because you see the value reported by
‘frame-parameter’ appear in different minibuffer windows.
(2) Any such redirection is not reflected in the 'minibuffer' value
reported by ‘frame-parameter’: That value remains nil invariably.
Do you agree so far? Then I see the following problems.
From (2) the 'minibuffer' value assigned by ‘set-frame-parameter’ is not
reflected in the 'minibuffer' value returned by ‘frame-parameter’. This
is not critical per se (a similar thing may happen to geometry
parameters) but it's misleading because, as we can conclude from (1),
something has changed.
Moreover in section 28.4.3.5 Buffer Parameters of the Elisp manual we
say:
`minibuffer'
Whether this frame has its own minibuffer. The value `t' means
yes, `nil' means no, `only' means this frame is just a minibuffer.
If the value is a minibuffer window (in some other frame), the
frame uses that minibuffer.
This frame parameter takes effect when the frame is created, and
can not be changed afterwards.
But apparently it is possible to change the 'minibuffer' frame parameter
after a frame was created since otherwise we were not able to redirect
output as mentioned in (1).
Regardless of whatever ‘frame-parameter’ reports, the value of the frame
parameter stored by Emacs internally is the window specified by
(frame-root-window minibuffer-only-frame). The routine constructing the
‘frame-parameters’ alist replaces the real internal value by the value
nil.
Finally evaluate the form
(frame-parameter initial-frame 'minibuffer)
You will see something like
#<window 4 on *Minibuf-0*>
appear in the minibuffer window. This is a window on the initial frame.
‘frame-parameter’ returns a minibuffer window if and only if that
minibuffer window is on the _same_ frame as the one whose minibuffer
value I try to retrieve. You can't convince ‘frame-parameter’ to report
a minibuffer window "in some other frame" as the manual suggests.
Am I still unclear?
>> Because IIUC they do not care much about "testing" it. Otherwise they
>> would have complained already.
>
> What is the problem with testing it?
That the "reported" value does not reflect the "set" value as described
above.
> frameset.el tests it. And I test it. I `redirect-frame-focus' of a
> minibuffer-less frame for *Completions* to my standalone minibuffer
> frame, for example:
[...]
> Okay, I don't actually test the frame parameter here explicitly, but
> the code depends on it being and acting as it does, I think.
I don't think so. You just use the return value of ‘make-frame’ invoked
with a (minibuffer . only) parameter. Alternatively, you might use
(window-frame (minibuffer-window my-minibuffer-less-frame))
In general, ‘frame-parameter’ is useless for finding the minibuffer frame.
As long as nobody works with the return value of ‘frame-parameter’ there
are no problems. On the C-level code works with the "real" value of the
parameter as set by ‘set-frame-parameter’ and does not have the problems
I mentioned here. Actually, C-code never even consults that value - it
only sets it.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-05 19:25 ` Eli Zaretskii
@ 2016-08-06 9:33 ` martin rudalics
2016-08-07 13:54 ` Eli Zaretskii
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-06 9:33 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
> We could simply change the above code to follow suit.
Change what? Initially I only wanted to simplify code like
(FRAME_HAS_MINIBUF_P (f) && !FRAME_MINIBUF_ONLY_P (f))
because once f has been created, FRAME_HAS_MINIBUF_P (f) and
!FRAME_MINIBUF_ONLY_P (f) invariantly hold for the entire lifetime of f.
A bit field telling whether a frame owns a minibuffer or is
minibuffer-only/-less seems more practical instead of these macros. The
value stored in that bit field would have to reflect the value stored in
the 'minibuffer' frame parameter. But for a minibuffer-less frame we
OT1H store the minibuffer window in that parameter and OTOH we report
the value nil for that parameter in ‘frame-parameters’.
We could either modify that code in store_frame_param
if (EQ (prop, Qminibuffer) && WINDOWP (val))
{
if (! MINI_WINDOW_P (XWINDOW (val)))
error ("Surrogate minibuffer windows must be minibuffer windows");
if ((FRAME_HAS_MINIBUF_P (f) || FRAME_MINIBUF_ONLY_P (f))
&& !EQ (val, f->minibuffer_window))
error ("Can't change the surrogate minibuffer of a frame with its own minibuffer");
/* Install the chosen minibuffer window, with proper buffer. */
fset_minibuffer_window (f, val);
}
to store Qnil instead of the minibuffer window or do away with the
special treatment of the 'minibuffer' parameter in ‘frame-parameters’ as
I mentioned earlier.
The former should be sane because so far C-code always goes for the
value of FRAME_MINIBUF_WINDOW to find the minibuffer window of a frame.
However, we'd still have to explain that ‘set-frame-parameter’ can
change a frame's minibuffer window without reflecting the change in the
return value of ‘frame-parameters’.
As mentioned before, removing the special treatment of the 'minibuffer'
parameter in ‘frame-parameters’ would imply that Elisp code relying on
the values we report currently might be broken in the future. The doc
change required for this solution would be marginal.
Things would be much clearer if we had provided some orthogonality of
‘minibuffer-window’ and ‘set-minibuffer-window’.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* RE: About the 'minibuffer' frame parameter
2016-08-06 9:32 ` martin rudalics
@ 2016-08-06 16:46 ` Drew Adams
2016-08-07 8:46 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Drew Adams @ 2016-08-06 16:46 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
> With emacs -Q, yank the following forms into *scratch*
> (defvar initial-frame (selected-frame))
> (defvar minibuffer-less-frame (make-frame '((minibuffer . nil))))
> (defvar minibuffer-only-frame (make-frame '((minibuffer . only))))
> and evaluate them. You should see three frames - the "normal" initial
> one, a minibuffer-less frame, and a minibuffer-only one. Correct?
Yes.
> Now in the minibuffer-less frame evaluate
> (frame-parameter minibuffer-less-frame 'minibuffer)
> and Emacs will print nil in the minibuffer window of the initial frame.
Yes.
> Next evaluate
> (set-frame-parameter minibuffer-less-frame 'minibuffer
> (frame-root-window minibuffer-only-frame))
> and you will see nil in the minibuffer window of the
> minibuffer-only frame.
Yes.
> Now evaluate
> (set-frame-parameter minibuffer-less-frame 'minibuffer
> (minibuffer-window initial-frame))
> and you will see nil in the minibuffer window of the initial
> frame again.
Yes.
> From this we can conclude the following:
>
> (1) Emacs does redirect output to the minibuffer window of the frame
> specified via ‘set-frame-parameter’. This follows from the
> experiment above because you see the value reported by
> ‘frame-parameter’ appear in different minibuffer windows.
Yes.
> (2) Any such redirection is not reflected in the 'minibuffer' value
> reported by ‘frame-parameter’: That value remains nil invariably.
>
> Do you agree so far?
Yes... Or maybe not. Doesn't that conclusion depend on
supposing that `set-frame-parameter' returns the new parameter
value? I don't see the return value of that function mentioned
in its doc string or in the manual. (Maybe it should be?)
But anyway, if you're sure that the value of `frame-parameter'
is nil (I assume you checked this in the C code), then OK.
> Then I see the following problems.
>
> From (2) the 'minibuffer' value assigned by ‘set-frame-parameter’ is not
> reflected in the 'minibuffer' value returned by ‘frame-parameter’. This
> is not critical per se (a similar thing may happen to geometry
> parameters) but it's misleading because, as we can conclude from (1),
> something has changed.
Yes, it is misleading. But why is it not critical (a problem)?
And why does it happen also for geometry parameters? (And why
does it happen for `frame-parameter'?)
> Moreover in section 28.4.3.5 Buffer Parameters of the Elisp
> manual we say:
>
> `minibuffer'
> Whether this frame has its own minibuffer. The value `t' means
> yes, `nil' means no, `only' means this frame is just a minibuffer.
> If the value is a minibuffer window (in some other frame), the
> frame uses that minibuffer.
>
> This frame parameter takes effect when the frame is created, and
> can not be changed afterwards.
^^^^^^^
cannot (typo)
> But apparently it is possible to change the 'minibuffer' frame parameter
> after a frame was created since otherwise we were not able to redirect
> output as mentioned in (1).
Yes. And why not be able to do that? And if there is a good
reason not to, then maybe Emacs should be fixed to not do it (?).
> Regardless of whatever ‘frame-parameter’ reports, the value of the frame
> parameter stored by Emacs internally is the window specified by
> (frame-root-window minibuffer-only-frame). The routine constructing the
> ‘frame-parameters’ alist replaces the real internal value by the value
> nil.
Hm.
> Finally evaluate the form
> (frame-parameter initial-frame 'minibuffer)
> You will see something like #<window 4 on *Minibuf-0*>
Yes.
> appear in the minibuffer window. This is a window on the initial frame.
> ‘frame-parameter’ returns a minibuffer window if and only if that
> minibuffer window is on the _same_ frame as the one whose minibuffer
> value I try to retrieve. You can't convince ‘frame-parameter’ to report
> a minibuffer window "in some other frame" as the manual suggests.
>
> Am I still unclear?
No.
> >> Because IIUC they do not care much about "testing" it.
> >> Otherwise they would have complained already.
> > What is the problem with testing it?
>
> That the "reported" value does not reflect the "set" value as
> described above.
>
> > frameset.el tests it.
> > And I test it. I `redirect-frame-focus' of a minibuffer-less
> > frame for *Completions* to my standalone minibuffer frame,
> > for example:
> [...]
> > Okay, I don't actually test the frame parameter here explicitly,
> > but the code depends on it being and acting as it does, I think.
>
> I don't think so. You just use the return value of ‘make-frame’
> invoked with a (minibuffer . only) parameter. Alternatively,
> you might use (window-frame (minibuffer-window
> my-minibuffer-less-frame))
Yes. I don't test it with `frame-parameter'. And I understand
that what you are saying is that it is only the value of
`frame-parameter' that is useless.
But `frameset.el' does test it, AFAICT. Take a look at
`frameset--record-minibuffer-relationships', for example.
Perhaps there is a bug lurking there (?).
> In general, ‘frame-parameter’ is useless for finding the
> minibuffer frame.
If that is the correct behavior then it should be doc'd.
Is it the correct behavior?
> As long as nobody works with the return value of ‘frame-parameter’ there
> are no problems. On the C-level code works with the "real" value of the
> parameter as set by ‘set-frame-parameter’ and does not have the problems
> I mentioned here. Actually, C-code never even consults that value - it
> only sets it.
It seems that Lisp code generally does likewise: set it but
not test it. The `frameset.el' code does seem to test it,
however.
Thanks for explaining.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-06 16:46 ` Drew Adams
@ 2016-08-07 8:46 ` martin rudalics
2017-01-14 0:59 ` Juanma Barranquero
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-07 8:46 UTC (permalink / raw)
To: Drew Adams, Eli Zaretskii; +Cc: emacs-devel
> Yes... Or maybe not. Doesn't that conclusion depend on
> supposing that `set-frame-parameter' returns the new parameter
> value? I don't see the return value of that function mentioned
> in its doc string or in the manual. (Maybe it should be?)
It's irrelevant - the return value is that of ‘modify-frame-parameters’
and that's always nil. Here I only care about _where_ nil gets printed,
that is, in which minibuffer window.
> But anyway, if you're sure that the value of `frame-parameter'
> is nil (I assume you checked this in the C code), then OK.
(set-frame-parameter
minibuffer-less-frame 'minibuffer (frame-root-window minibuffer-only-frame))
sets the internal value of the 'minibuffer' frame parameter to the
specified minibuffer window. Only the value reported afterwards by
‘frame-parameter’ is nil.
> Yes, it is misleading. But why is it not critical (a problem)?
Because internally Emacs ignores the frame parameter's value and relies
on the value returned by ‘minibuffer-window’ instead. The corresponding
macro is FRAME_MINIBUF_WINDOW. C code hardly ever consults frame
parameter alists, probably for two reasons: (1) Their values are either
inaccurate or don't exist, and (2) it might be too costly to do so.
> And why does it happen also for geometry parameters? (And why
> does it happen for `frame-parameter'?)
Because the frame geometry changes for a number of reasons, for example,
when you maximize a frame or use the mouse to resize it. In this case
Emacs has to tediously approximate the values of the 'height' or 'width'
parameters from the real ones, the ones the user sees on the screen.
The values of many parameters reported by ‘frame-parameters’ are
constructed ad-hoc from internal values (see Fframe_parameters for some
general parameters and x_report_frame_params for the X Window related
ones).
What annoys me about the 'minibuffer' parameter is that it OT1H does not
depend on any extraneous issue like a toolkit that is only able to draw
things in certain sizes (like scroll bars on GTK) and that OTOH someone
decided that in some cases it should specify a window which is not its
task.
>> This frame parameter takes effect when the frame is created, and
>> can not be changed afterwards.
> ^^^^^^^
> cannot (typo)
A Freudian one, perhaps.
>> But apparently it is possible to change the 'minibuffer' frame parameter
>> after a frame was created since otherwise we were not able to redirect
>> output as mentioned in (1).
>
> Yes. And why not be able to do that? And if there is a good
> reason not to, then maybe Emacs should be fixed to not do it (?).
Conceptually, it's a bad idea to set the value of that frame parameter:
When, for a minibuffer-less frame, you want to use another minibuffer
window, you do not (and cannot) change the frame's minibuffer-less
status. So the frame parameter's value should stay unaltered indeed,
ideally.
But how else change the minibuffer window of a minibuffer-less frame?
> Yes. I don't test it with `frame-parameter'. And I understand
> that what you are saying is that it is only the value of
> `frame-parameter' that is useless.
>
> But `frameset.el' does test it, AFAICT. Take a look at
> `frameset--record-minibuffer-relationships', for example.
> Perhaps there is a bug lurking there (?).
IIUC ‘frameset--record-minibuffer-relationships’ is an attempt to fix
what gets reported via ‘frame-parameters’. It must have been a hair
raising experience for Juanma to code that. Given a doc-string like
default-minibuffer-frame is a variable defined in ‘frame.c’.
Its value is #<frame frameset.el 02204f48>
It is a terminal-local variable; global value is the same.
Documentation:
Minibufferless frames use this frame’s minibuffer.
Emacs cannot create minibufferless frames unless this is set to an
appropriate surrogate.
Emacs consults this variable only when creating minibufferless
frames; once the frame is created, it sticks with its assigned
minibuffer, no matter what this variable is set to. This means that
this variable doesn’t necessarily say anything meaningful about the
current set of frames, or where the minibuffer is currently being
displayed.
This variable is local to the current terminal and cannot be buffer-local.
which is wrong (because a frame does not necessarily "stick" with its
assigned minibuffer) and not useful either (what should I make of
information like "this variable doesn’t necessarily say anything
meaningful about the current set of frames, or where the minibuffer is
currently being displayed").
Also, ‘frameset-filter-minibuffer’ seems to do the right thing. It's
doc-string says
When saving, convert (minibuffer . #<window>) to (minibuffer . t).
which fixes the mind-boggling sillyness that ‘frame-parameter’ reports a
frame's own minibuffer window when it has one.
I slowly begin to understand why Juanma gave up coding for Emacs :-(
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-06 9:33 ` martin rudalics
@ 2016-08-07 13:54 ` Eli Zaretskii
2016-08-08 8:27 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-07 13:54 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Sat, 06 Aug 2016 11:33:55 +0200
> From: martin rudalics <rudalics@gmx.at>
> Cc: emacs-devel@gnu.org
I must admit I'm a bit confused about the issues you raise. So let me
make a step or two back, before we continue.
You started by saying:
> (progn
> (setq minibuffer-less-frame (make-frame '((minibuffer . nil))))
> (setq minibuffer-only-frame (make-frame '((minibuffer . only))))
>
> (set-frame-parameter
> minibuffer-less-frame 'minibuffer (frame-root-window minibuffer-only-frame))
> (frame-parameter minibuffer-less-frame 'minibuffer))
> [...]
> But if the frame is minibuffer-less and uses the minibuffer window of
> some other frame, we return as value nil although the real, internal
> frame parameter's value (not the one produced by the
>
> store_in_alist (&alist, Qminibuffer,
> (! FRAME_HAS_MINIBUF_P (f) ? Qnil
> : FRAME_MINIBUF_ONLY_P (f) ? Qonly
> : FRAME_MINIBUF_WINDOW (f)));
>
> construct) is actually that window. Otherwise, evaluating the
> ‘set-frame-parameter’ above would have produced an error.
I don't understand the last sentence: it starts with "otherwise",
which seems to imply that if frame-parameter did not produce nil for a
minibuffer-less frame, the call to set-frame-parameter would somehow
signal an error. However, I don't see any relation between what
(frame-parameter FRAME 'minibuffer) returns and any calls to
set-frame-parameter for the same frame. So what error were you
talking about?
Next, the documentation issue:
`minibuffer'
Whether this frame has its own minibuffer. The value `t' means
yes, `nil' means no, `only' means this frame is just a minibuffer.
If the value is a minibuffer window (in some other frame), the
frame uses that minibuffer.
This frame parameter takes effect when the frame is created, and
can not be changed afterwards.
The sentence "If the value is a minibuffer window (in some other frame),
the frame uses that minibuffer." is misleading. A minibuffer window is
reported iff that window is on the _same_ frame and that frame is not a
minibuffer-only frame. A minibuffer window in some other frame is never
reported.
So when do we report t? It sounds like the answer is "never", right?
IOW, the documentation seems to describe some situation that existed
in the past, and is now OBE due to code changes. Correct?
> Note in this context that ‘minibuffer-window’ returns the correct
> minibuffer window for its FRAME argument while ‘set-minibuffer-window’
> does not allow to set the minibuffer window for a specific frame.
IMO, this is a separate, albeit probably related, issue. Are there
any problems to let set-minibuffer-window allow setting the minibuffer
window of a frame?
> I'm not sure how to deal with this situation. Personally, I'd prefer to
> report the real, internal 'minibuffer' parameter
And I implicitly agreed with that.
> but am afraid that might break existing code.
And for that, I proposed:
> > But I haven't checked all places because I rather soonish stumbled upon
> > things like
> >
> > (eq (cdr (or (assq 'minibuffer initial-frame-alist)
> > (assq 'minibuffer window-system-frame-alist)
> > (assq 'minibuffer default-frame-alist)
> > '(minibuffer . t)))
> > t)
> >
> > in ‘frame-notice-user-settings’. And one revealing comment is in
> > ‘set-frame-configuration’:
> >
> > ;; Since we can't set a frame's minibuffer status,
> > ;; we might as well omit the parameter altogether.
>
> We could simply change the above code to follow suit.
To which you replied:
> Change what?
Obviously, change the Lisp snippet shown above, which expects to see a
nil minibuffer parameter for minibuffer-less frames. Change it not to
expect that, and instead test the minibuffer window for whether it is
on the same frame or not.
> Initially I only wanted to simplify code like
>
> (FRAME_HAS_MINIBUF_P (f) && !FRAME_MINIBUF_ONLY_P (f))
>
> because once f has been created, FRAME_HAS_MINIBUF_P (f) and
> !FRAME_MINIBUF_ONLY_P (f) invariantly hold for the entire lifetime of f.
> A bit field telling whether a frame owns a minibuffer or is
> minibuffer-only/-less seems more practical instead of these macros. The
> value stored in that bit field would have to reflect the value stored in
> the 'minibuffer' frame parameter. But for a minibuffer-less frame we
> OT1H store the minibuffer window in that parameter and OTOH we report
> the value nil for that parameter in ‘frame-parameters’.
I think we should report the window, i.e. the actual value stored in
that parameter.
> We could either modify that code in store_frame_param
>
> if (EQ (prop, Qminibuffer) && WINDOWP (val))
> {
> if (! MINI_WINDOW_P (XWINDOW (val)))
> error ("Surrogate minibuffer windows must be minibuffer windows");
> if ((FRAME_HAS_MINIBUF_P (f) || FRAME_MINIBUF_ONLY_P (f))
> && !EQ (val, f->minibuffer_window))
> error ("Can't change the surrogate minibuffer of a frame with its own
> minibuffer");
>
> /* Install the chosen minibuffer window, with proper buffer. */
> fset_minibuffer_window (f, val);
> }
>
> to store Qnil instead of the minibuffer window or do away with the
> special treatment of the 'minibuffer' parameter in ‘frame-parameters’ as
> I mentioned earlier.
I like the latter possibility much better. In general, I prefer to
report the actual values whenever possible, especially when we have no
reason to hide the value from Lisp applications.
> As mentioned before, removing the special treatment of the 'minibuffer'
> parameter in ‘frame-parameters’ would imply that Elisp code relying on
> the values we report currently might be broken in the future.
And my suggestion to that was to fix that code, wherever we find it.
> Things would be much clearer if we had provided some orthogonality of
> ‘minibuffer-window’ and ‘set-minibuffer-window’.
Not sure what you mean by "orthogonality" here.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-07 13:54 ` Eli Zaretskii
@ 2016-08-08 8:27 ` martin rudalics
2016-08-08 15:34 ` Eli Zaretskii
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-08 8:27 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
> You started by saying:
>
>> (progn
>> (setq minibuffer-less-frame (make-frame '((minibuffer . nil))))
>> (setq minibuffer-only-frame (make-frame '((minibuffer . only))))
>>
>> (set-frame-parameter
>> minibuffer-less-frame 'minibuffer (frame-root-window minibuffer-only-frame))
>> (frame-parameter minibuffer-less-frame 'minibuffer))
>> [...]
>> But if the frame is minibuffer-less and uses the minibuffer window of
>> some other frame, we return as value nil although the real, internal
>> frame parameter's value (not the one produced by the
>>
>> store_in_alist (&alist, Qminibuffer,
>> (! FRAME_HAS_MINIBUF_P (f) ? Qnil
>> : FRAME_MINIBUF_ONLY_P (f) ? Qonly
>> : FRAME_MINIBUF_WINDOW (f)));
>>
>> construct) is actually that window. Otherwise, evaluating the
>> ‘set-frame-parameter’ above would have produced an error.
>
> I don't understand the last sentence: it starts with "otherwise",
> which seems to imply that if frame-parameter did not produce nil for a
> minibuffer-less frame, the call to set-frame-parameter would somehow
> signal an error.
If with emacs -Q I do
(let ((minibuffer-only-frame (make-frame '((minibuffer . only)))))
(set-frame-parameter
nil 'minibuffer (frame-root-window minibuffer-only-frame)))
I get an error like "Can’t change the surrogate minibuffer of a frame
with its own minibuffer". Now, an application that wants to assign a
new minibuffer window for an arbitrary frame has two ways to avoid that
error: Either it uses
(not (eq (window-frame (minibuffer-window frame))) frame)
or
(not (frame-parameter frame 'minibuffer))
The former is pretty contrived. For example, the coder would have to
know that the frame of a minibuffer-only frame's minibuffer window is
that frame. So I expect that most applications would prefer the latter.
But in order to make that feasible, ‘frame-parameter’ has to report nil
for the 'minibuffer' parameter of a minibuffer-less frame.
However, the judgment whether to raise an error is based on evaluating
FRAME_HAS_MINIBUF_P and _not_ on checking the frame parameter. So when
you look at the implementation of ‘set-frame-parameter’, my sentence is
indeed misleading.
> However, I don't see any relation between what
> (frame-parameter FRAME 'minibuffer) returns and any calls to
> set-frame-parameter for the same frame. So what error were you
> talking about?
I'm not talking about an error here but about the fact that setting a
frame's minibuffer window via ‘set-frame-parameter’ is not reflected in
the value returned by ‘frame-parameter’ for that frame's 'minibuffer'
parameter. You have to call ‘minibuffer-window’ for that frame to see
whether something has effectively changed.
> Next, the documentation issue:
>
> `minibuffer'
> Whether this frame has its own minibuffer. The value `t' means
> yes, `nil' means no, `only' means this frame is just a minibuffer.
> If the value is a minibuffer window (in some other frame), the
> frame uses that minibuffer.
>
> This frame parameter takes effect when the frame is created, and
> can not be changed afterwards.
>
> The sentence "If the value is a minibuffer window (in some other frame),
> the frame uses that minibuffer." is misleading. A minibuffer window is
> reported iff that window is on the _same_ frame and that frame is not a
> minibuffer-only frame. A minibuffer window in some other frame is never
> reported.
>
> So when do we report t? It sounds like the answer is "never", right?
Yes.
> IOW, the documentation seems to describe some situation that existed
> in the past, and is now OBE due to code changes. Correct?
Not really. While t never gets reported, it can be used either in alist
specifications or in the 'minibuffer' frame parameter of ‘make-frame’.
It is redundant in both but allowed AFAICT. You can even get away with
nonsense like
(let ((minibuffer-only-frame (make-frame '((minibuffer . only)))))
(set-frame-parameter minibuffer-only-frame 'minibuffer t)
(frame-parameter minibuffer-only-frame 'minibuffer))
No error gets reported and the parameter of the minibuffer-only frame
appears unchanged. It simply does not matter that it has been set to t
internally.
>> Note in this context that ‘minibuffer-window’ returns the correct
>> minibuffer window for its FRAME argument while ‘set-minibuffer-window’
>> does not allow to set the minibuffer window for a specific frame.
>
> IMO, this is a separate, albeit probably related, issue. Are there
> any problems to let set-minibuffer-window allow setting the minibuffer
> window of a frame?
Certainly not - if checked and documented orderly. But when you already
have a minibuffer window at hand and want to make a new minibuffer-less
frame use that window, you currently can write
(let ((window (minibuffer-window)))
(make-frame `((minibuffer . ,window))))
BTW ‘set-minibuffer-window’ is a very obscure function. It's nowhere
used and I wouldn't know why and how to use it.
> And for that, I proposed:
>
>>> But I haven't checked all places because I rather soonish stumbled upon
>>> things like
>>>
>>> (eq (cdr (or (assq 'minibuffer initial-frame-alist)
>>> (assq 'minibuffer window-system-frame-alist)
>>> (assq 'minibuffer default-frame-alist)
>>> '(minibuffer . t)))
>>> t)
>>>
>>> in ‘frame-notice-user-settings’. And one revealing comment is in
>>> ‘set-frame-configuration’:
>>>
>>> ;; Since we can't set a frame's minibuffer status,
>>> ;; we might as well omit the parameter altogether.
>>
>> We could simply change the above code to follow suit.
>
> To which you replied:
>
>> Change what?
>
> Obviously, change the Lisp snippet shown above, which expects to see a
> nil minibuffer parameter for minibuffer-less frames. Change it not to
> expect that, and instead test the minibuffer window for whether it is
> on the same frame or not.
If you mean the snippet
(eq (cdr (or (assq 'minibuffer initial-frame-alist) ... t)
then I suppose that it is correct: The value t _is_ meaningful for the
alist variables. It just never gets reported for an actual frame. In
frameset.el Juanma wrote about the 'minibuffer' frame parameter:
;; - `minibuffer': It can contain a reference to a live window, which cannot
;; be serialized. Because of Emacs' idiosyncratic treatment of this
;; parameter, frames created with (minibuffer . t) have a parameter
;; (minibuffer . #<window...>), while frames created with
;; (minibuffer . #<window...>) have (minibuffer . nil), which is madness
;; but helps to differentiate between minibufferless and "normal" frames.
Here I think that Juanma's wrong BTW. It does not help IMHO.
;; So, changing (minibuffer . #<window...>) to (minibuffer . t) allows
;; Emacs to set up the new frame correctly. Nice, uh?
But for the rest I fully agree with him. And his (local) fix explains
why t would be a good value. So I still do not know what you propose to
change.
>> But for a minibuffer-less frame we
>> OT1H store the minibuffer window in that parameter and OTOH we report
>> the value nil for that parameter in ‘frame-parameters’.
>
> I think we should report the window, i.e. the actual value stored in
> that parameter.
[...]
> In general, I prefer to
> report the actual values whenever possible, especially when we have no
> reason to hide the value from Lisp applications.
Modulo the fact that, as I mentioned above, some application might want
to use (not (frame-parameter frame 'minibuffer)) to check whether it is
allowed to change the minibuffer window of an arbitrary frame.
>> As mentioned before, removing the special treatment of the 'minibuffer'
>> parameter in ‘frame-parameters’ would imply that Elisp code relying on
>> the values we report currently might be broken in the future.
>
> And my suggestion to that was to fix that code, wherever we find it.
frameset.el already fixes the code internally so we would have to revert
those fixes. That's hairy. And I don't know how many times anyone else
already has invented a workaround for all these idiosyncrasies.
>> Things would be much clearer if we had provided some orthogonality of
>> ‘minibuffer-window’ and ‘set-minibuffer-window’.
>
> Not sure what you mean by "orthogonality" here.
I meant "duality". In the sense that both should take a FRAME argument.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-08 8:27 ` martin rudalics
@ 2016-08-08 15:34 ` Eli Zaretskii
2016-08-09 8:27 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-08 15:34 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Mon, 08 Aug 2016 10:27:02 +0200
> From: martin rudalics <rudalics@gmx.at>
> CC: emacs-devel@gnu.org
>
> > In general, I prefer to
> > report the actual values whenever possible, especially when we have no
> > reason to hide the value from Lisp applications.
>
> Modulo the fact that, as I mentioned above, some application might want
> to use (not (frame-parameter frame 'minibuffer)) to check whether it is
> allowed to change the minibuffer window of an arbitrary frame.
>
> >> As mentioned before, removing the special treatment of the 'minibuffer'
> >> parameter in ‘frame-parameters’ would imply that Elisp code relying on
> >> the values we report currently might be broken in the future.
> >
> > And my suggestion to that was to fix that code, wherever we find it.
>
> frameset.el already fixes the code internally so we would have to revert
> those fixes. That's hairy. And I don't know how many times anyone else
> already has invented a workaround for all these idiosyncrasies.
So what is your suggestion for the course of actions?
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-08 15:34 ` Eli Zaretskii
@ 2016-08-09 8:27 ` martin rudalics
2016-08-09 14:51 ` Eli Zaretskii
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-09 8:27 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
> So what is your suggestion for the course of actions?
(1) Make sure that store_frame_param doesn't store invalid parameter
values.
(2) Never store a minibuffer window as frame parameter.
(3) Have ‘frame-parameter’ return the 'minibuffer' parameter as stored
internally. If no stored value is available, return t.
(4) Wait for regression reports.
(5) Fix the documentation.
(6) Fix/remove related comments.
Together (1) and (2) mean that the parameter becomes immutable as
occasionally already claimed. (3) will require changes to frameset.el.
FWIW, the only code in frameset.el that seems to depend on the old
behavior is:
(let ((w (frame-parameter f 'minibuffer)))
(and (window-live-p w)
(window-minibuffer-p w)
(eq (window-frame w) f))))
This would be probably replaced by:
(let ((w (minibuffer-window f)))
(and (window-live-p w)
(eq (window-frame w) f))))
If anyone knows about code that does similar things in this or any other
package please tell us.
One open question is how to handle the minibuffer window in frame
configurations. For example, the valid form
(let ((minibuffer-less-frame (make-frame '((minibuffer . nil))))
(configuration (current-frame-configuration))
(minibuffer-only-frame (make-frame '((minibuffer . only)))))
(set-frame-parameter
minibuffer-less-frame 'minibuffer (frame-root-window minibuffer-only-frame))
(set-frame-configuration configuration))
currently throws an error while
(let ((initial-frame (selected-frame))
(minibuffer-less-frame (make-frame '((minibuffer . nil))))
(configuration (current-frame-configuration))
(minibuffer-only-frame (make-frame '((minibuffer . only)))))
(set-frame-parameter
minibuffer-less-frame 'minibuffer (frame-root-window minibuffer-only-frame))
(delete-frame initial-frame)
(set-frame-configuration configuration))
in addition leaves me with a minibuffer-less frame I can't neither make
visible nor deiconify.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-09 8:27 ` martin rudalics
@ 2016-08-09 14:51 ` Eli Zaretskii
2016-08-09 16:07 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-09 14:51 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Tue, 09 Aug 2016 10:27:55 +0200
> From: martin rudalics <rudalics@gmx.at>
> CC: emacs-devel@gnu.org
>
> > So what is your suggestion for the course of actions?
>
> (1) Make sure that store_frame_param doesn't store invalid parameter
> values.
>
> (2) Never store a minibuffer window as frame parameter.
>
> (3) Have ‘frame-parameter’ return the 'minibuffer' parameter as stored
> internally. If no stored value is available, return t.
>
> (4) Wait for regression reports.
>
> (5) Fix the documentation.
>
> (6) Fix/remove related comments.
I'm okay with that, but I'm surprised by (2): won't storing the
minibuffer window there allow us to report the correct value in (3)?
What am I missing?
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-09 14:51 ` Eli Zaretskii
@ 2016-08-09 16:07 ` martin rudalics
2016-08-09 16:21 ` Eli Zaretskii
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-09 16:07 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
>> (1) Make sure that store_frame_param doesn't store invalid parameter
>> values.
>>
>> (2) Never store a minibuffer window as frame parameter.
>>
>> (3) Have ‘frame-parameter’ return the 'minibuffer' parameter as stored
>> internally. If no stored value is available, return t.
>>
>> (4) Wait for regression reports.
>>
>> (5) Fix the documentation.
>>
>> (6) Fix/remove related comments.
>
> I'm okay with that, but I'm surprised by (2): won't storing the
> minibuffer window there allow us to report the correct value in (3)?
> What am I missing?
If we did that we would invert the values returned by ‘frame-parameter’
for the "normal" frame and minibuffer-less frame cases. Currently, we
return the minibuffer window for a normal frame and nil for a
minibuffer-less frame. You would return the minibuffer window for a
minibuffer-less frame and t for a normal frame. Correct?
This would have the benefit that after
(set-frame-parameter minibuffer-less-frame 'minibuffer some-minibuffer-window)
the value returned by ‘frame-parameter’ would be consistent with the
requested value. However, most minibuffer-less frames are created via
(make-frame '((minibuffer . nil)))
and whatever we do here we would introduce another inconsistency: Either
the stored value is the minibuffer window chosen by Emacs and the value
returned by ‘frame-parameter’ would not be the value from the PARAMETERS
argument of ‘make-frame’. Or we would sometimes return nil and
sometimes a window as value of the 'minibuffer' frame parameter of a
minibuffer-less frame.
Given the fact that changing the frame parameter of a minibuffer-less
frame is a pretty rare operation, I would prefer the solution sketched
in (2). WDYT?
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-09 16:07 ` martin rudalics
@ 2016-08-09 16:21 ` Eli Zaretskii
2016-08-09 17:34 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-09 16:21 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Tue, 09 Aug 2016 18:07:58 +0200
> From: martin rudalics <rudalics@gmx.at>
> CC: emacs-devel@gnu.org
>
> >> (1) Make sure that store_frame_param doesn't store invalid parameter
> >> values.
> >>
> >> (2) Never store a minibuffer window as frame parameter.
> >>
> >> (3) Have ‘frame-parameter’ return the 'minibuffer' parameter as stored
> >> internally. If no stored value is available, return t.
> >>
> >> (4) Wait for regression reports.
> >>
> >> (5) Fix the documentation.
> >>
> >> (6) Fix/remove related comments.
> >
> > I'm okay with that, but I'm surprised by (2): won't storing the
> > minibuffer window there allow us to report the correct value in (3)?
> > What am I missing?
>
> If we did that we would invert the values returned by ‘frame-parameter’
> for the "normal" frame and minibuffer-less frame cases. Currently, we
> return the minibuffer window for a normal frame and nil for a
> minibuffer-less frame. You would return the minibuffer window for a
> minibuffer-less frame and t for a normal frame. Correct?
Maybe. Another alternative would be to return a window in both cases.
> This would have the benefit that after
>
> (set-frame-parameter minibuffer-less-frame 'minibuffer some-minibuffer-window)
>
> the value returned by ‘frame-parameter’ would be consistent with the
> requested value. However, most minibuffer-less frames are created via
>
> (make-frame '((minibuffer . nil)))
>
> and whatever we do here we would introduce another inconsistency: Either
> the stored value is the minibuffer window chosen by Emacs and the value
> returned by ‘frame-parameter’ would not be the value from the PARAMETERS
> argument of ‘make-frame’. Or we would sometimes return nil and
> sometimes a window as value of the 'minibuffer' frame parameter of a
> minibuffer-less frame.
We have already a few cases where frame-parameter returns a value
different from the one specified when make-frame was called. There's
nothing wrong about that, if it's Emacs that chooses the actual value.
> Given the fact that changing the frame parameter of a minibuffer-less
> frame is a pretty rare operation, I would prefer the solution sketched
> in (2). WDYT?
Do you still prefer (2)? I prefer storing a window because then we
could naturally return it, like we do with frame colors.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-09 16:21 ` Eli Zaretskii
@ 2016-08-09 17:34 ` martin rudalics
2016-08-09 17:51 ` Eli Zaretskii
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-09 17:34 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
> Another alternative would be to return a window in both cases.
But then we can't discriminate minibuffer-less from normal frames by
looking at the parameter value only.
> We have already a few cases where frame-parameter returns a value
> different from the one specified when make-frame was called. There's
> nothing wrong about that, if it's Emacs that chooses the actual value.
This goes both ways. With (2) Emacs would choose nil when
‘set-frame-position’ explicitly asks for a window. And with no
'minibuffer' specified we'd have to return t or a window in any case.
> Do you still prefer (2)? I prefer storing a window because then we
> could naturally return it, like we do with frame colors.
C code never consults the frame parameter. Elisp code currently
consults the parameter in four places only, three of them to find out
whether the frame is minibuffer-only. If Elisp code wants the window,
it uses ‘minibuffer-window’ which handles all types of frames. And with
(2) the values t, nil and 'only' would immediately tell the type of any
frame.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-09 17:34 ` martin rudalics
@ 2016-08-09 17:51 ` Eli Zaretskii
2016-08-10 12:15 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-09 17:51 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Tue, 09 Aug 2016 19:34:20 +0200
> From: martin rudalics <rudalics@gmx.at>
> CC: emacs-devel@gnu.org
>
> > Another alternative would be to return a window in both cases.
>
> But then we can't discriminate minibuffer-less from normal frames by
> looking at the parameter value only.
We can look at what window-frame returns for that window, can't we?
> > We have already a few cases where frame-parameter returns a value
> > different from the one specified when make-frame was called. There's
> > nothing wrong about that, if it's Emacs that chooses the actual value.
>
> This goes both ways. With (2) Emacs would choose nil when
> ‘set-frame-position’ explicitly asks for a window. And with no
> 'minibuffer' specified we'd have to return t or a window in any case.
Yes, but IMO nil is not a meaningful value. If we know better, we
should return a more concrete value.
> > Do you still prefer (2)? I prefer storing a window because then we
> > could naturally return it, like we do with frame colors.
>
> C code never consults the frame parameter. Elisp code currently
> consults the parameter in four places only, three of them to find out
> whether the frame is minibuffer-only. If Elisp code wants the window,
> it uses ‘minibuffer-window’ which handles all types of frames. And with
> (2) the values t, nil and 'only' would immediately tell the type of any
> frame.
Yes, of course, the current situation is not impossible. We are
talking about improving it.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-09 17:51 ` Eli Zaretskii
@ 2016-08-10 12:15 ` martin rudalics
2016-08-10 14:23 ` Stefan Monnier
2016-08-10 14:49 ` Eli Zaretskii
0 siblings, 2 replies; 43+ messages in thread
From: martin rudalics @ 2016-08-10 12:15 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 766 bytes --]
>> But then we can't discriminate minibuffer-less from normal frames by
>> looking at the parameter value only.
>
> We can look at what window-frame returns for that window, can't we?
Tediously so, yes.
>> This goes both ways. With (2) Emacs would choose nil when
>> ‘set-frame-position’ explicitly asks for a window. And with no
>> 'minibuffer' specified we'd have to return t or a window in any case.
>
> Yes, but IMO nil is not a meaningful value. If we know better, we
> should return a more concrete value.
Sounds convincing.
> Yes, of course, the current situation is not impossible. We are
> talking about improving it.
I attached a preliminary version of the code changes. Please have a
look.
Thanks, martin
[-- Attachment #2: minibuffer-frame-parameter.diff --]
[-- Type: text/plain, Size: 4532 bytes --]
diff --git a/lisp/frameset.el b/lisp/frameset.el
index 2453f57..aa16647 100644
--- a/lisp/frameset.el
+++ b/lisp/frameset.el
@@ -908,10 +908,7 @@ frameset--reuse-frame
(unless (or frame (eq (cdr (assq 'minibuffer parameters)) 'only))
(setq frame (frameset--find-frame-if
(lambda (f)
- (let ((w (frame-parameter f 'minibuffer)))
- (and (window-live-p w)
- (window-minibuffer-p w)
- (eq (window-frame w) f))))
+ (eq (frame-parameter f 'minibuffer) t))
display))))
(mini
;; For minibufferless frames, check whether they already exist,
@@ -1028,7 +1025,7 @@ frameset-keep-original-display-p
(defun frameset-minibufferless-first-p (frame1 _frame2)
"Predicate to sort minibufferless frames before other frames."
- (not (frame-parameter frame1 'minibuffer)))
+ (windowp (frame-parameter frame1 'minibuffer)))
;;;###autoload
(cl-defun frameset-restore (frameset
diff --git a/src/frame.c b/src/frame.c
index 899c315..e550e51 100644
--- a/src/frame.c
+++ b/src/frame.c
@@ -658,6 +658,7 @@ struct frame *
mw->mini = 1;
wset_frame (mw, frame);
fset_minibuffer_window (f, mini_window);
+ store_frame_param (f, Qminibuffer, Qt);
}
else
{
@@ -770,6 +771,7 @@ struct frame *
}
fset_minibuffer_window (f, mini_window);
+ store_frame_param (f, Qminibuffer, mini_window);
/* Make the chosen minibuffer window display the proper minibuffer,
unless it is already showing a minibuffer. */
@@ -807,6 +809,7 @@ struct frame *
mini_window = f->root_window;
fset_minibuffer_window (f, mini_window);
+ store_frame_param (f, Qminibuffer, Qonly);
XWINDOW (mini_window)->mini = 1;
wset_next (XWINDOW (mini_window), Qnil);
wset_prev (XWINDOW (mini_window), Qnil);
@@ -2404,6 +2407,46 @@ of them (the selected terminal frame) is actually displayed.
{
register Lisp_Object old_alist_elt;
+ if (EQ (prop, Qminibuffer))
+ {
+ if (WINDOWP (val))
+ {
+ if (!MINI_WINDOW_P (XWINDOW (val)))
+ error ("The 'minibuffer' parameter does not specify a valid minibuffer window");
+ else if (FRAME_HAS_MINIBUF_P (f))
+ {
+ if (EQ (val, FRAME_MINIBUF_WINDOW (f)))
+ val = Qt;
+ else
+ error ("Can't change the minibuffer window of a frame with its own minibuffer");
+ }
+ else if (FRAME_MINIBUF_ONLY_P (f))
+ {
+ if (EQ (val, FRAME_MINIBUF_WINDOW (f)))
+ val = Qonly;
+ else
+ error ("Can't change the minibuffer window of a minibuffer-only frame");
+ }
+ else
+ /* Store the chosen minibuffer window. */
+ fset_minibuffer_window (f, val);
+ }
+ else
+ {
+ Lisp_Object old_val = Fcdr (Fassq (Qminibuffer, f->param_alist));
+
+ if (!NILP (old_val))
+ {
+ if (WINDOWP (old_val) && NILP (val))
+ /* Don't change the value for a minibuffer-less frame if
+ only nil was specified as new value. */
+ val = old_val;
+ else if (!EQ (old_val, val))
+ error ("Can't change the 'minibuffer' parameter of this frame");
+ }
+ }
+ }
+
/* The buffer-list parameters are stored in a special place and not
in the alist. All buffers must be live. */
if (EQ (prop, Qbuffer_list))
@@ -2475,19 +2518,6 @@ of them (the selected terminal frame) is actually displayed.
else if (EQ (prop, Qname))
set_term_frame_name (f, val);
}
-
- if (EQ (prop, Qminibuffer) && WINDOWP (val))
- {
- if (! MINI_WINDOW_P (XWINDOW (val)))
- error ("Surrogate minibuffer windows must be minibuffer windows");
-
- if ((FRAME_HAS_MINIBUF_P (f) || FRAME_MINIBUF_ONLY_P (f))
- && !EQ (val, f->minibuffer_window))
- error ("Can't change the surrogate minibuffer of a frame with its own minibuffer");
-
- /* Install the chosen minibuffer window, with proper buffer. */
- fset_minibuffer_window (f, val);
- }
}
/* Return color matches UNSPEC on frame F or nil if UNSPEC
@@ -2565,10 +2595,6 @@ It is a list of elements of the form (PARM . VALUE), where PARM is a symbol.
: FRAME_COLS (f));
store_in_alist (&alist, Qwidth, make_number (width));
store_in_alist (&alist, Qmodeline, (FRAME_WANTS_MODELINE_P (f) ? Qt : Qnil));
- store_in_alist (&alist, Qminibuffer,
- (! FRAME_HAS_MINIBUF_P (f) ? Qnil
- : FRAME_MINIBUF_ONLY_P (f) ? Qonly
- : FRAME_MINIBUF_WINDOW (f)));
store_in_alist (&alist, Qunsplittable, (FRAME_NO_SPLIT_P (f) ? Qt : Qnil));
store_in_alist (&alist, Qbuffer_list, f->buffer_list);
store_in_alist (&alist, Qburied_buffer_list, f->buried_buffer_list);
^ permalink raw reply related [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-10 12:15 ` martin rudalics
@ 2016-08-10 14:23 ` Stefan Monnier
2016-08-10 14:54 ` Eli Zaretskii
2016-08-10 14:49 ` Eli Zaretskii
1 sibling, 1 reply; 43+ messages in thread
From: Stefan Monnier @ 2016-08-10 14:23 UTC (permalink / raw)
To: emacs-devel
>>> But then we can't discriminate minibuffer-less from normal frames by
>>> looking at the parameter value only.
>> We can look at what window-frame returns for that window, can't we?
> Tediously so, yes.
For minibuffer-free frames, we could return the *frame* whose minibuffer
we use.
Stefan
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-10 12:15 ` martin rudalics
2016-08-10 14:23 ` Stefan Monnier
@ 2016-08-10 14:49 ` Eli Zaretskii
2016-08-21 9:41 ` martin rudalics
1 sibling, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-10 14:49 UTC (permalink / raw)
To: martin rudalics; +Cc: emacs-devel
> Date: Wed, 10 Aug 2016 14:15:45 +0200
> From: martin rudalics <rudalics@gmx.at>
> CC: emacs-devel@gnu.org
>
> >> This goes both ways. With (2) Emacs would choose nil when
> >> ‘set-frame-position’ explicitly asks for a window. And with no
> >> 'minibuffer' specified we'd have to return t or a window in any case.
> >
> > Yes, but IMO nil is not a meaningful value. If we know better, we
> > should return a more concrete value.
>
> Sounds convincing.
>
> > Yes, of course, the current situation is not impossible. We are
> > talking about improving it.
>
> I attached a preliminary version of the code changes. Please have a
> look.
I took a cursory look, and it looks OK to me.
Thanks.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-10 14:23 ` Stefan Monnier
@ 2016-08-10 14:54 ` Eli Zaretskii
0 siblings, 0 replies; 43+ messages in thread
From: Eli Zaretskii @ 2016-08-10 14:54 UTC (permalink / raw)
To: Stefan Monnier; +Cc: emacs-devel
> From: Stefan Monnier <monnier@iro.umontreal.ca>
> Date: Wed, 10 Aug 2016 10:23:55 -0400
>
> >>> But then we can't discriminate minibuffer-less from normal frames by
> >>> looking at the parameter value only.
> >> We can look at what window-frame returns for that window, can't we?
> > Tediously so, yes.
>
> For minibuffer-free frames, we could return the *frame* whose minibuffer
> we use.
Why? The frame parameter's value is a window, so the most natural
value would be the window used for the minibuffer. Given the window,
accessing its frame, if it's needed, is trivial.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-10 14:49 ` Eli Zaretskii
@ 2016-08-21 9:41 ` martin rudalics
2016-08-21 20:51 ` Kaushal Modi
0 siblings, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-21 9:41 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: emacs-devel
> I took a cursory look, and it looks OK to me.
I installed a slightly modified version on master/trunk. Doc and
comments will be changed later. If people notice any problems with
desktop-saving please complain immediately.
Thanks, martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-21 9:41 ` martin rudalics
@ 2016-08-21 20:51 ` Kaushal Modi
2016-08-22 12:49 ` Kaushal Modi
0 siblings, 1 reply; 43+ messages in thread
From: Kaushal Modi @ 2016-08-21 20:51 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 459 bytes --]
On Sun, Aug 21, 2016 at 5:41 AM martin rudalics <rudalics@gmx.at> wrote:
> I installed a slightly modified version on master/trunk. Doc and
> comments will be changed later.
> If people notice any problems with
> desktop-saving please complain immediately.
>
This is not a complaint. Just emailing to say that everything works as
before. I use desktop-mode with frame/window restore (default) using
emacsclient and it works as before.
--
Kaushal Modi
[-- Attachment #2: Type: text/html, Size: 998 bytes --]
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-21 20:51 ` Kaushal Modi
@ 2016-08-22 12:49 ` Kaushal Modi
2016-08-22 13:03 ` Kaushal Modi
0 siblings, 1 reply; 43+ messages in thread
From: Kaushal Modi @ 2016-08-22 12:49 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 1185 bytes --]
Actually I noticed some pretty strange minibuffer behavior today. I don't
know what caused that to happen so I cannot explain how to recreate that.
I am on the aed22ca build of master.
Here's my best attempt to explain this:
- The minibuffer height increased to 2 characters (so I saw 2 rows instead
of 1)
- And I got 2 cursors in there.. one cursor had the default cursor face,
and other looked like the cursor face in inactive window.
That probably doesn't give you any hint.. but I thought of at least
mentioning it. I hope to get a recipe for that so that you can recreate the
issue consistently.
On Sun, Aug 21, 2016 at 4:51 PM Kaushal Modi <kaushal.modi@gmail.com> wrote:
> On Sun, Aug 21, 2016 at 5:41 AM martin rudalics <rudalics@gmx.at> wrote:
>
>> I installed a slightly modified version on master/trunk. Doc and
>> comments will be changed later.
>
>
>
>> If people notice any problems with
>> desktop-saving please complain immediately.
>>
>
> This is not a complaint. Just emailing to say that everything works as
> before. I use desktop-mode with frame/window restore (default) using
> emacsclient and it works as before.
> --
>
> Kaushal Modi
>
--
Kaushal Modi
[-- Attachment #2: Type: text/html, Size: 2375 bytes --]
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-22 12:49 ` Kaushal Modi
@ 2016-08-22 13:03 ` Kaushal Modi
2016-08-22 15:51 ` Kaushal Modi
2016-08-22 16:01 ` martin rudalics
0 siblings, 2 replies; 43+ messages in thread
From: Kaushal Modi @ 2016-08-22 13:03 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
[-- Attachment #1.1: Type: text/plain, Size: 1968 bytes --]
Actually, it seems like one of the existing windows gets cloned and that is
put on top of the minibuffer without modeline.
It looks something like this.
So the minibuffer looks completely fused with Win 2 of Buf x (that somehow
got created automatically when I enabled debug-on-error).
After some window switching, the mode line for Win 2 appears automatically.
==============================================
| Win 1 - Buf x |
----------------------------------------------
| Mode-line for Win 1 |
==============================================
| Win 2 - Buf x |
----------------------------------------------
| Minibuffer |
==============================================
(I put to white box there to mask my work stuff. If I close that window,
the missing modeline for the bottom "Win 2 - Buf x" is created
automatically. Note that the same "-Searchd" string is shown in the actual
window on the top right and the bottom window auto-created exactly above
the minibuffer (so I thought earlier that the minibuffer had 2 rows; it was
in fact an inactive window and thus that inactive window cursor face).
[image: pasted1]
On Mon, Aug 22, 2016 at 8:49 AM Kaushal Modi <kaushal.modi@gmail.com> wrote:
> Actually I noticed some pretty strange minibuffer behavior today. I don't
> know what caused that to happen so I cannot explain how to recreate that.
>
> I am on the aed22ca build of master.
>
> Here's my best attempt to explain this:
>
> - The minibuffer height increased to 2 characters (so I saw 2 rows instead
> of 1)
> - And I got 2 cursors in there.. one cursor had the default cursor face,
> and other looked like the cursor face in inactive window.
>
> That probably doesn't give you any hint.. but I thought of at least
> mentioning it. I hope to get a recipe for that so that you can recreate the
> issue consistently.
>
--
Kaushal Modi
[-- Attachment #1.2: Type: text/html, Size: 3476 bytes --]
[-- Attachment #2: pasted1 --]
[-- Type: image/png, Size: 29108 bytes --]
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-22 13:03 ` Kaushal Modi
@ 2016-08-22 15:51 ` Kaushal Modi
2016-08-22 16:01 ` martin rudalics
1 sibling, 0 replies; 43+ messages in thread
From: Kaushal Modi @ 2016-08-22 15:51 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii; +Cc: emacs-devel
[-- Attachment #1.1: Type: text/plain, Size: 1309 bytes --]
Please ignore that.. that bug is there but has nothing to do with your
recent commit.
I see it on emacs 25.1 RC2 too when I end up causing a timer error in
pdf-tools package:
=====
Interleave enabled
doc-view-goto-page: Wrong type argument: stringp, nil
Error running timer ‘pdf-cache--prefetch-start’: (error "epdfinfo: No such
page 0")
=====
On Mon, Aug 22, 2016 at 9:03 AM Kaushal Modi <kaushal.modi@gmail.com> wrote:
> Actually, it seems like one of the existing windows gets cloned and that
> is put on top of the minibuffer without modeline.
>
> It looks something like this.
>
> So the minibuffer looks completely fused with Win 2 of Buf x (that somehow
> got created automatically when I enabled debug-on-error).
> After some window switching, the mode line for Win 2 appears automatically.
>
> ==============================================
> | Win 1 - Buf x |
> ----------------------------------------------
> | Mode-line for Win 1 |
> ==============================================
> | Win 2 - Buf x |
> ----------------------------------------------
> | Minibuffer |
> ==============================================
>
--
Kaushal Modi
[-- Attachment #1.2: Type: text/html, Size: 2551 bytes --]
[-- Attachment #2: pasted1 --]
[-- Type: image/png, Size: 29108 bytes --]
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-22 13:03 ` Kaushal Modi
2016-08-22 15:51 ` Kaushal Modi
@ 2016-08-22 16:01 ` martin rudalics
2016-08-22 16:27 ` Kaushal Modi
1 sibling, 1 reply; 43+ messages in thread
From: martin rudalics @ 2016-08-22 16:01 UTC (permalink / raw)
To: Kaushal Modi, Eli Zaretskii; +Cc: emacs-devel
> Actually, it seems like one of the existing windows gets cloned and that is
> put on top of the minibuffer without modeline.
>
> It looks something like this.
>
> So the minibuffer looks completely fused with Win 2 of Buf x (that somehow
> got created automatically when I enabled debug-on-error).
> After some window switching, the mode line for Win 2 appears automatically.
>
> ==============================================
> | Win 1 - Buf x |
> ----------------------------------------------
> | Mode-line for Win 1 |
> ==============================================
> | Win 2 - Buf x |
> ----------------------------------------------
> | Minibuffer |
> ==============================================
>
> (I put to white box there to mask my work stuff. If I close that window,
You mean "If I delete Win 1"?
> the missing modeline for the bottom "Win 2 - Buf x" is created
> automatically.
And what else do you see now in Win 2 besides the "- Searchd" string?
> Note that the same "-Searchd" string is shown in the actual
> window on the top right and the bottom window auto-created exactly above
> the minibuffer (so I thought earlier that the minibuffer had 2 rows; it was
> in fact an inactive window and thus that inactive window cursor face).
In any case please do (window--dump-frame) for that frame - the result
of that dump is in a buffer called *window-frame-dump* and post the
result here. I think that the appearance of that one line window is
more or less intentional but I have no idea who's responsible for it.
At least that someone seems to do very tricky things to your window
layout ;-)
> Please ignore that.. that bug is there but has nothing to do with your
> recent commit.
> I see it on emacs 25.1 RC2 too when I end up causing a timer error in
> pdf-tools package:
I'd still want to see the output of ‘window--dump-frame’ for this frame
(no fear - it doesn't reveal any buffer contents).
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-22 16:01 ` martin rudalics
@ 2016-08-22 16:27 ` Kaushal Modi
2016-08-23 8:19 ` martin rudalics
0 siblings, 1 reply; 43+ messages in thread
From: Kaushal Modi @ 2016-08-22 16:27 UTC (permalink / raw)
To: martin rudalics, Eli Zaretskii, Oleh Krehel; +Cc: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 5198 bytes --]
On Mon, Aug 22, 2016 at 12:01 PM martin rudalics <rudalics@gmx.at> wrote:
> > ==============================================
> > | Win 1 - Buf x |
> > ----------------------------------------------
> > | Mode-line for Win 1 |
> > ==============================================
> > | Win 2 - Buf x |
> > ----------------------------------------------
> > | Minibuffer |
> > ==============================================
> >
> > (I put to white box there to mask my work stuff. If I close that window,
>
> You mean "If I delete Win 1"?
>
Correct (C-x 0).
> > the missing modeline for the bottom "Win 2 - Buf x" is created
> > automatically.
>
> And what else do you see now in Win 2 besides the "- Searchd" string?
>
I see just one line and I can scroll that window up/down (but now I know
exactly what's causing there.. copying Oleh to throw some light here too;
more detail below).
> > Note that the same "-Searchd" string is shown in the actual
> > window on the top right and the bottom window auto-created exactly above
> > the minibuffer (so I thought earlier that the minibuffer had 2 rows; it
> was
> > in fact an inactive window and thus that inactive window cursor face).
>
> In any case please do (window--dump-frame) for that frame - the result
> of that dump is in a buffer called *window-frame-dump* and post the
> result here.
frame pixel: 1910 x 1096 cols/lines: 212 x 57 units: 9 x 19
frame text pixel: 1894 x 1096 cols/lines: 210 x 57
tool: 0 scroll: 0/0 fringe: 16 border: 0 right: 0 bottom: 0
#<window 9> parent: nil
pixel left: 0 top: 0 size: 1910 x 1077 new: 906
char left: 0 top: 0 size: 212 x 56 new: 48
normal: 1.0 x 1.0 new: nil
#<window 7> parent: #<window 9>
pixel left: 0 top: 0 size: 1910 x 1001 new: 830
char left: 0 top: 0 size: 212 x 52 new: 44
normal: 1.0 x 0.9294336118848654 new: nil
#<window 6 on Quick_Start_for_RTL_Users_9June16.pdf> parent: #<window 7>
pixel left: 0 top: 0 size: 956 x 1001 new: 830
char left: 0 top: 0 size: 106 x 52 new: 44
normal: 0.5 x 1.0 new: nil
body pixel: 940 x 981 char: 104 x 51
width left fringe: 8 left margin: 0 right margin: 0
width right fringe: 8 scroll-bar: 0 divider: 0
height header-line: 0 mode-line: 20 divider: 0
#<window 8 on Quick_Start_for_RTL_Users_9June16.org> parent: #<window 7>
pixel left: 956 top: 0 size: 954 x 1001 new: 830
char left: 106 top: 0 size: 106 x 52 new: 44
normal: 0.5 x 1.0 new: nil
body pixel: 938 x 981 char: 104 x 51
width left fringe: 8 left margin: 0 right margin: 0
width right fringe: 8 scroll-bar: 0 divider: 0
height header-line: 0 mode-line: 20 divider: 0
#<window 10 on Quick_Start_for_RTL_Users_9June16.pdf> parent: #<window 9>
pixel left: 0 top: 1001 size: 1910 x 76 new: 76
char left: 0 top: 52 size: 212 x 4 new: 4
normal: 1.0 x 0.07056638811513463 new: nil
body pixel: 1894 x 56 char: 210 x 2
width left fringe: 8 left margin: 0 right margin: 0
width right fringe: 8 scroll-bar: 0 divider: 0
height header-line: 0 mode-line: 20 divider: 0
#<window 4 on *Minibuf-0*> parent: nil
pixel left: 0 top: 1077 size: 1910 x 19 new: 190
char left: 0 top: 56 size: 212 x 1 new: 10
normal: 1.0 x 1.0 new: 0
body pixel: 1894 x 19 char: 210 x 1
width left fringe: 8 left margin: 0 right margin: 0
width right fringe: 8 scroll-bar: 0 divider: 0
height header-line: 0 mode-line: 0 divider: 0
> I think that the appearance of that one line window is
> more or less intentional but I have no idea who's responsible for it.
> At least that someone seems to do very tricky things to your window
> layout ;-)
>
I strongly believe it's this:
http://git.savannah.gnu.org/cgit/emacs/elpa.git/tree/packages/hydra/lv.el
The mode-line-less window is exactly what lv.el does for creating hydras.
What seems to happen is that the pdf-tools timer error does not allow a
hydra to finish doing its job.
=====
Error running timer ‘pdf-cache--prefetch-start’: (error "epdfinfo: No such
page 0")
=====
.. and I had bound toggling debug-on-error to a hydra head (hydra package
jargon).
I was able to recreate the same issue when calling any hydra.
> > Please ignore that.. that bug is there but has nothing to do with your
> > recent commit.
> > I see it on emacs 25.1 RC2 too when I end up causing a timer error in
> > pdf-tools package:
>
> I'd still want to see the output of ‘window--dump-frame’ for this frame
> (no fear - it doesn't reveal any buffer contents).
>
Thanks for the retained interest in fixing this :)
There are 2 things here:
- I need to figure out why the pdf-tools timer issue is caused. Once that
is fixed, with window issue should not happen as the hydras I launch will
be allowed to do all the needed window layout cleanup.
- Hopefully Oleh gets a chance to investigate the hydra/lv behavior under
the timer error circumstances.
--
Kaushal Modi
[-- Attachment #2: Type: text/html, Size: 7227 bytes --]
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-22 16:27 ` Kaushal Modi
@ 2016-08-23 8:19 ` martin rudalics
0 siblings, 0 replies; 43+ messages in thread
From: martin rudalics @ 2016-08-23 8:19 UTC (permalink / raw)
To: Kaushal Modi, Eli Zaretskii, Oleh Krehel; +Cc: emacs-devel
> #<window 10 on Quick_Start_for_RTL_Users_9June16.pdf> parent: #<window 9>
> pixel left: 0 top: 1001 size: 1910 x 76 new: 76
> char left: 0 top: 52 size: 212 x 4 new: 4
> normal: 1.0 x 0.07056638811513463 new: nil
> body pixel: 1894 x 56 char: 210 x 2
> width left fringe: 8 left margin: 0 right margin: 0
> width right fringe: 8 scroll-bar: 0 divider: 0
> height header-line: 0 mode-line: 20 divider: 0
>
> #<window 4 on *Minibuf-0*> parent: nil
> pixel left: 0 top: 1077 size: 1910 x 19 new: 190
> char left: 0 top: 56 size: 212 x 1 new: 10
> normal: 1.0 x 1.0 new: 0
> body pixel: 1894 x 19 char: 210 x 1
> width left fringe: 8 left margin: 0 right margin: 0
> width right fringe: 8 scroll-bar: 0 divider: 0
> height header-line: 0 mode-line: 0 divider: 0
That's not what I see in the image you posted earlier. In the dump,
Window 9 is 76 pixels high (4 lines) while the minibuffer window is 19
pixels high (one line). In the image, the window corresponding to
window 9 is only one line high as the minibuffer window. Also, I doubt
that deleting the other windows via C-x 1 will automatically give Window
9 its modeline back.
> I strongly believe it's this:
> http://git.savannah.gnu.org/cgit/emacs/elpa.git/tree/packages/hydra/lv.el
>
> The mode-line-less window is exactly what lv.el does for creating hydras.
> What seems to happen is that the pdf-tools timer error does not allow a
> hydra to finish doing its job.
lv should give that window a different background so it can be
distinguished as such. As a rule, if people use neither dividers nor
scrollbars/modelines, they should find some other way to distinguish
windows. Otherwise, it's too easy to mix up their contents.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2016-08-07 8:46 ` martin rudalics
@ 2017-01-14 0:59 ` Juanma Barranquero
2017-01-14 7:47 ` Eli Zaretskii
0 siblings, 1 reply; 43+ messages in thread
From: Juanma Barranquero @ 2017-01-14 0:59 UTC (permalink / raw)
To: martin rudalics; +Cc: Eli Zaretskii, Drew Adams, Emacs developers
[Answering to something from a few months ago...]
> IIUC ‘frameset--record-minibuffer-relationships’ is an attempt to fix
> what gets reported via ‘frame-parameters’. It must have been a hair
> raising experience for Juanma to code that.
It had its moments (so the long comment/rant section), but it was also fun.
> I slowly begin to understand why Juanma gave up coding for Emacs :-(
I didn't gave up, life just dealt me a really weird couple of years.
Juanma
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2017-01-14 0:59 ` Juanma Barranquero
@ 2017-01-14 7:47 ` Eli Zaretskii
2017-01-14 9:18 ` Juanma Barranquero
0 siblings, 1 reply; 43+ messages in thread
From: Eli Zaretskii @ 2017-01-14 7:47 UTC (permalink / raw)
To: Juanma Barranquero; +Cc: rudalics, drew.adams, emacs-devel
> From: Juanma Barranquero <lekktu@gmail.com>
> Date: Sat, 14 Jan 2017 01:59:59 +0100
> Cc: Drew Adams <drew.adams@oracle.com>, Eli Zaretskii <eliz@gnu.org>,
> Emacs developers <emacs-devel@gnu.org>
>
> > I slowly begin to understand why Juanma gave up coding for Emacs :-(
>
> I didn't gave up, life just dealt me a really weird couple of years.
Are we lucky to have you back?
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2017-01-14 7:47 ` Eli Zaretskii
@ 2017-01-14 9:18 ` Juanma Barranquero
2017-01-14 10:42 ` Eli Zaretskii
` (2 more replies)
0 siblings, 3 replies; 43+ messages in thread
From: Juanma Barranquero @ 2017-01-14 9:18 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: martin rudalics, Drew Adams, Emacs developers
On Sat, Jan 14, 2017 at 8:47 AM, Eli Zaretskii <eliz@gnu.org> wrote:
> Are we lucky to have you back?
I think so. But first I'll have to spend a little time setting my
building environment.
Juanma
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2017-01-14 9:18 ` Juanma Barranquero
@ 2017-01-14 10:42 ` Eli Zaretskii
2017-01-14 11:05 ` martin rudalics
2017-01-15 3:01 ` Richard Stallman
2 siblings, 0 replies; 43+ messages in thread
From: Eli Zaretskii @ 2017-01-14 10:42 UTC (permalink / raw)
To: Juanma Barranquero; +Cc: rudalics, drew.adams, emacs-devel
> From: Juanma Barranquero <lekktu@gmail.com>
> Date: Sat, 14 Jan 2017 10:18:36 +0100
> Cc: martin rudalics <rudalics@gmx.at>, Drew Adams <drew.adams@oracle.com>,
> Emacs developers <emacs-devel@gnu.org>
>
> On Sat, Jan 14, 2017 at 8:47 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>
> > Are we lucky to have you back?
>
> I think so. But first I'll have to spend a little time setting my
> building environment.
Great, thanks.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2017-01-14 9:18 ` Juanma Barranquero
2017-01-14 10:42 ` Eli Zaretskii
@ 2017-01-14 11:05 ` martin rudalics
2017-01-14 14:01 ` Juanma Barranquero
2017-01-14 15:56 ` Drew Adams
2017-01-15 3:01 ` Richard Stallman
2 siblings, 2 replies; 43+ messages in thread
From: martin rudalics @ 2017-01-14 11:05 UTC (permalink / raw)
To: Juanma Barranquero, Eli Zaretskii; +Cc: Drew Adams, Emacs developers
> I think so. But first I'll have to spend a little time setting my
> building environment.
We've been missing you.
martin
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2017-01-14 11:05 ` martin rudalics
@ 2017-01-14 14:01 ` Juanma Barranquero
2017-01-19 3:54 ` John Wiegley
2017-01-14 15:56 ` Drew Adams
1 sibling, 1 reply; 43+ messages in thread
From: Juanma Barranquero @ 2017-01-14 14:01 UTC (permalink / raw)
To: martin rudalics; +Cc: Eli Zaretskii, Drew Adams, Emacs developers
On Sat, Jan 14, 2017 at 12:05 PM, martin rudalics <rudalics@gmx.at> wrote:
> We've been missing you.
Thanks, I've been missing Emacs and its motley crew.
^ permalink raw reply [flat|nested] 43+ messages in thread
* RE: About the 'minibuffer' frame parameter
2017-01-14 11:05 ` martin rudalics
2017-01-14 14:01 ` Juanma Barranquero
@ 2017-01-14 15:56 ` Drew Adams
1 sibling, 0 replies; 43+ messages in thread
From: Drew Adams @ 2017-01-14 15:56 UTC (permalink / raw)
To: martin rudalics, Juanma Barranquero, Eli Zaretskii; +Cc: Emacs developers
> > I think so. But first I'll have to spend a little time setting my
> > building environment.
>
> We've been missing you.
+1
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2017-01-14 9:18 ` Juanma Barranquero
2017-01-14 10:42 ` Eli Zaretskii
2017-01-14 11:05 ` martin rudalics
@ 2017-01-15 3:01 ` Richard Stallman
2 siblings, 0 replies; 43+ messages in thread
From: Richard Stallman @ 2017-01-15 3:01 UTC (permalink / raw)
To: Juanma Barranquero; +Cc: rudalics, eliz, drew.adams, emacs-devel
[[[ To any NSA and FBI agents reading my email: please consider ]]]
[[[ whether defending the US Constitution against all enemies, ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]
Thank you for rejoining us.
--
Dr Richard Stallman
President, Free Software Foundation (gnu.org, fsf.org)
Internet Hall-of-Famer (internethalloffame.org)
Skype: No way! See stallman.org/skype.html.
^ permalink raw reply [flat|nested] 43+ messages in thread
* Re: About the 'minibuffer' frame parameter
2017-01-14 14:01 ` Juanma Barranquero
@ 2017-01-19 3:54 ` John Wiegley
0 siblings, 0 replies; 43+ messages in thread
From: John Wiegley @ 2017-01-19 3:54 UTC (permalink / raw)
To: Juanma Barranquero
Cc: martin rudalics, Eli Zaretskii, Drew Adams, Emacs developers
>>>>> "JB" == Juanma Barranquero <lekktu@gmail.com> writes:
JB> Thanks, I've been missing Emacs and its motley crew.
Welcome back, Juanma!
--
John Wiegley GPG fingerprint = 4710 CF98 AF9B 327B B80F
http://newartisans.com 60E1 46C4 BD1A 7AC1 4BA2
^ permalink raw reply [flat|nested] 43+ messages in thread
end of thread, other threads:[~2017-01-19 3:54 UTC | newest]
Thread overview: 43+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-07-31 18:12 About the 'minibuffer' frame parameter martin rudalics
2016-08-05 13:33 ` Eli Zaretskii
2016-08-05 16:37 ` martin rudalics
2016-08-05 17:18 ` Drew Adams
2016-08-05 17:35 ` martin rudalics
2016-08-05 17:52 ` Drew Adams
2016-08-05 18:19 ` martin rudalics
2016-08-05 18:37 ` Drew Adams
2016-08-06 9:32 ` martin rudalics
2016-08-06 16:46 ` Drew Adams
2016-08-07 8:46 ` martin rudalics
2017-01-14 0:59 ` Juanma Barranquero
2017-01-14 7:47 ` Eli Zaretskii
2017-01-14 9:18 ` Juanma Barranquero
2017-01-14 10:42 ` Eli Zaretskii
2017-01-14 11:05 ` martin rudalics
2017-01-14 14:01 ` Juanma Barranquero
2017-01-19 3:54 ` John Wiegley
2017-01-14 15:56 ` Drew Adams
2017-01-15 3:01 ` Richard Stallman
2016-08-05 19:25 ` Eli Zaretskii
2016-08-06 9:33 ` martin rudalics
2016-08-07 13:54 ` Eli Zaretskii
2016-08-08 8:27 ` martin rudalics
2016-08-08 15:34 ` Eli Zaretskii
2016-08-09 8:27 ` martin rudalics
2016-08-09 14:51 ` Eli Zaretskii
2016-08-09 16:07 ` martin rudalics
2016-08-09 16:21 ` Eli Zaretskii
2016-08-09 17:34 ` martin rudalics
2016-08-09 17:51 ` Eli Zaretskii
2016-08-10 12:15 ` martin rudalics
2016-08-10 14:23 ` Stefan Monnier
2016-08-10 14:54 ` Eli Zaretskii
2016-08-10 14:49 ` Eli Zaretskii
2016-08-21 9:41 ` martin rudalics
2016-08-21 20:51 ` Kaushal Modi
2016-08-22 12:49 ` Kaushal Modi
2016-08-22 13:03 ` Kaushal Modi
2016-08-22 15:51 ` Kaushal Modi
2016-08-22 16:01 ` martin rudalics
2016-08-22 16:27 ` Kaushal Modi
2016-08-23 8:19 ` martin rudalics
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).