bug-gnu-emacs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#18136: 24.4.50; crash in redisplay when calling load-theme


From: martin rudalics
Subject: bug#18136: 24.4.50; crash in redisplay when calling load-theme
Date: Thu, 31 Jul 2014 18:53:33 +0200

>> But I don't really understand about `set-frame-height' and friends on a
>> TTY and what they are supposed to do.  Should these be allowed to change
>> the frame size?
>
> Yes.

In the sense that the frame can get larger or smaller than the terminal
window?  So we internally work with say 100 frame lines although the
terminal can display only 80?  Or am I missing something?

>> Now about the
>>
>>       change_frame_size (XFRAME (selected_frame),
>>                          FrameCols (t->display_info.tty),
>>                          FrameRows (t->display_info.tty)
>>                       - FRAME_MENU_BAR_LINES (f), 0, 0, 1, 0);
>>
>> call in init_display.  What precisely is this supposed to accomplish?
>
> Allocate the glyph matrices, at the very least, I guess.

OK.  BTW doesn't adjust_frame_glyphs_for_frame_redisplay count the
menubar specially?  What is

  top_window_y = FRAME_TOP_MARGIN (f);

for?

>> Back to init_display and the question I asked earlier: Why should the
>> subsequent adjust_frame_size call do
>>
>>         if ((FRAME_TERMCAP_P (f) && !pretend) || FRAME_MSDOS_P (f))
>>        FrameRows (FRAME_TTY (f)) = new_lines;
>>
>> here?
>
> Maybe it shouldn't, when called from init_display.  But we should at
> least leave an eassert there, in case we overlook something.

Can I call adjust_frame_size directly from init_display?

IIUC FrameRows is the height of the terminal window and when I change
the height of that window I want to change the height of the Emacs frame
as well via handle_window_change_signal/change_frame_size.  This means I
can set FrameCols where I do it now because whenever I change the size
of the outer frame that of the frame's windows changes too.

Still it seems to me contrived to set FrameCols/FrameRows when adjusting
the sizes of a frame's windows.  And setting FrameCols when called from
init_display is certainly not TRT IMHO.

> In any case, this begs the question: why do you at all call
> adjust_frame_size in this case, if the frame already has the required
> size?  I think the answer is that adjust_frame_size does something
> else: it calls adjust_frame_glyphs.  That call is required at
> init_display time for obvious reasons, but it is inside
> adjust_frame_size which is only called when the frame size changes,
> which sounds like a contradiction in the design.

Think of turning off/on the menubar of a maximized frame.  In this case
I do not change the size of the frame either.  Yet I have to call
adjust_frame_glyphs.  BTW in an earlier mail you said that

> E.g., with your suggested semantics, what would you expect from this:
>
>   emacs -Q
>   M-: (frame-height) RET
>   M-x menu-bar-mode RET
>   M-: (frame-height) RET
>
> Would you expect to see the 2 results of frame-height identical or
> different?
>
> The current trunk displays 2 identical results, and actually resizes
> the root window to be consistent with that, so that there's an unused
> empty line below the echo area.  Is that intended?  It looks like a
> misfeature to me.

Where and how did you get that?  I can't reproduce it here.

>> Now please tell me one thing: Which calls of change_frame_size or
>> adjust_frame_size _should_ set FrameRows or FrameCols
>
> Any calls that actually change the frame size.

Is turning off/on the TTY menubar one of them?  I think not.  Yet we set
FrameCols.  Wouldn't it be principally cleaner if we set FrameCols and
FrameRows after calling get_tty_size only?

martin





reply via email to

[Prev in Thread] Current Thread [Next in Thread]