From f7b9d4d15e6050bd69f0cde149153531eddd089b Mon Sep 17 00:00:00 2001 From: Jason Rumney Date: Mon, 18 Feb 2002 00:04:14 +0000 Subject: [PATCH] *** empty log message *** --- lisp/ChangeLog | 7 +++ nt/ChangeLog | 5 ++ src/ChangeLog | 32 +++++++++++++ src/w32bdf.c | 7 +++ src/w32fns.c | 128 ++++++++++++++++++++++++++++++++++++++++++------- 5 files changed, 161 insertions(+), 18 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 8047982ccac..717a63b30c2 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,10 @@ +2002-02-17 Jason Rumney + + * w32-win.el (x-option-alist, x-long-option-alist) + (x-switch-definitions): Remove, use command-line-x-option-alist + instead to be consistent with X. + (x-handle-initial-switch): New function. + 2002-02-17 Eli Zaretskii * faces.el (mode-line-inactive, header-line): Add the :inherit diff --git a/nt/ChangeLog b/nt/ChangeLog index 2f033315f8e..28196f04ca1 100644 --- a/nt/ChangeLog +++ b/nt/ChangeLog @@ -1,3 +1,8 @@ +2002-02-18 Jason Rumney + + * emacs.rc: Define VS_VERSION_INFO if not already. + Update version info. + 2002-01-04 Andrew Innes * gmake.defs (CFLAGS): Define _WIN32_WINNT as 0x0400, in order to diff --git a/src/ChangeLog b/src/ChangeLog index 3ac11d89b6a..94fb586be40 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,35 @@ +2002-02-17 Jason Rumney + + * w32term.c (x_autoselect_window_p): New variable. + (syms_of_w32term): DEFVAR_BOOL and initialize it. + (note_mouse_movement): Use it. + + * w32fns.c (w32_load_system_font): Never set fonts_changed_p to zero. + + * w32bdf.c (w32_load_bdf_font): Maybe set fonts_changed_p. + + * w32fns.c (Qfullscreen, Qfullwidth, Qfullheight, Qfullboth): + New variables. + (syms_of_w32fns): Intern and staticpro them. + (x_frame_parms) <"fullscreen">: New parameter. + (x_fullscreen_move, x_set_fullscreen): New functions. + (x_set_frame_parameters): Support Qfullscreen. + (x_real_positions): Save x/y_pixels_diff frame params. + (x_figure_window_size): Support full-screen frames. + (Fx_create_frame): Default the fullscreen parameter. + + * w32term.c (x_check_fullscreen, x_check_fullscreen_move) + (x_fullscreen_adjust): New functions. + (w32_read_socket) : Don't resize to + fullscreen. Call x_check_fullscreen_move, and set the + want_fullscreen member of output_data.w32 + : Call x_check_fullscreen. + + * w32term.h: New enum for FULLSCREEN_* constants. + (struct w32_output): New members want_fullscreen, x_pixels_diff, + y_pixels_diff, x_pixels_outer_diff, and y_pixels_outer_diff. + (x-fullscreen-adjust): New prototype. + 2002-02-17 Kim F. Storm * frame.c: (Vmouse_highlight): New variable. diff --git a/src/w32bdf.c b/src/w32bdf.c index 801c914d8d9..5bb5ba72bba 100644 --- a/src/w32bdf.c +++ b/src/w32bdf.c @@ -790,6 +790,13 @@ struct font_info *w32_load_bdf_font (struct frame *f, char *fontname, fontp->relative_compose = bdf_font->relative_compose; fontp->default_ascent = bdf_font->default_ascent; + /* Set global flag fonts_changed_p to non-zero if the font loaded + has a character with a smaller width than any other character + before, or if the font loaded has a smaller height than any + other font loaded before. If this happens, it will make a + glyph matrix reallocation necessary. */ + fonts_changed_p |= x_compute_min_glyph_bounds (f); + UNBLOCK_INPUT; dpyinfo->n_fonts++; return fontp; diff --git a/src/w32fns.c b/src/w32fns.c index d7e0f7bcd0f..1ecc7169065 100644 --- a/src/w32fns.c +++ b/src/w32fns.c @@ -270,6 +270,11 @@ Lisp_Object Qw32_charset_mac; Lisp_Object Qw32_charset_unicode; #endif +Lisp_Object Qfullscreen; +Lisp_Object Qfullwidth; +Lisp_Object Qfullheight; +Lisp_Object Qfullboth; + extern Lisp_Object Qtop; extern Lisp_Object Qdisplay; extern Lisp_Object Qtool_bar_lines; @@ -681,6 +686,7 @@ static void x_change_window_heights P_ ((Lisp_Object, int)); /* TODO: Native Input Method support; see x_create_im. */ void x_set_foreground_color P_ ((struct frame *, Lisp_Object, Lisp_Object)); static void x_set_line_spacing P_ ((struct frame *, Lisp_Object, Lisp_Object)); +static void x_set_fullscreen P_ ((struct frame *, Lisp_Object, Lisp_Object)); void x_set_background_color P_ ((struct frame *, Lisp_Object, Lisp_Object)); void x_set_mouse_color P_ ((struct frame *, Lisp_Object, Lisp_Object)); void x_set_cursor_color P_ ((struct frame *, Lisp_Object, Lisp_Object)); @@ -734,7 +740,8 @@ static struct x_frame_parm_table x_frame_parms[] = {"screen-gamma", x_set_screen_gamma}, {"line-spacing", x_set_line_spacing}, {"left-fringe", x_set_fringe_width}, - {"right-fringe", x_set_fringe_width} + {"right-fringe", x_set_fringe_width}, + {"fullscreen", x_set_fullscreen}, }; /* Attach the `x-frame-parameter' properties to @@ -750,6 +757,27 @@ init_x_parm_symbols () make_number (i)); } +/* Really try to move where we want to be in case of fullscreen. Some WMs + moves the window where we tell them. Some (mwm, twm) moves the outer + window manager window there instead. + Try to compensate for those WM here. */ +static void +x_fullscreen_move (f, new_top, new_left) + struct frame *f; + int new_top; + int new_left; +{ + if (new_top != f->output_data.w32->top_pos + || new_left != f->output_data.w32->left_pos) + { + int move_x = new_left; + int move_y = new_top; + + f->output_data.w32->want_fullscreen |= FULLSCREEN_MOVE_WAIT; + x_set_offset (f, move_x, move_y, 1); + } +} + /* Change the parameters of frame F as specified by ALIST. If a parameter is not specially recognized, do nothing; otherwise call the `x_set_...' function for that parameter. */ @@ -778,6 +806,7 @@ x_set_frame_parameters (f, alist) int i, p; int left_no_change = 0, top_no_change = 0; int icon_left_no_change = 0, icon_top_no_change = 0; + int fullscreen_is_being_set = 0; struct gcpro gcpro1, gcpro2; @@ -835,11 +864,13 @@ x_set_frame_parameters (f, alist) val = values[p]; if (EQ (prop, Qforeground_color) || EQ (prop, Qbackground_color) - || EQ (prop, Qfont)) + || EQ (prop, Qfont) + || EQ (prop, Qfullscreen)) { register Lisp_Object param_index, old_value; old_value = get_frame_param (f, prop); + fullscreen_is_being_set |= EQ (prop, Qfullscreen); if (NILP (Fequal (val, old_value))) { @@ -876,7 +907,8 @@ x_set_frame_parameters (f, alist) icon_left = val; else if (EQ (prop, Qforeground_color) || EQ (prop, Qbackground_color) - || EQ (prop, Qfont)) + || EQ (prop, Qfont) + || EQ (prop, Qfullscreen)) /* Processed above. */ continue; else @@ -929,6 +961,21 @@ x_set_frame_parameters (f, alist) XSETINT (icon_top, 0); } + if (FRAME_VISIBLE_P (f) && fullscreen_is_being_set) + { + /* If the frame is visible already and the fullscreen parameter is + being set, it is too late to set WM manager hints to specify + size and position. + Here we first get the width, height and position that applies to + fullscreen. We then move the frame to the appropriate + position. Resize of the frame is taken care of in the code after + this if-statement. */ + int new_left, new_top; + + x_fullscreen_adjust (f, &width, &height, &new_top, &new_left); + x_fullscreen_move (f, new_top, new_left); + } + /* Don't set these parameters unless they've been explicitly specified. The window might be mapped or resized while we're in this function, and we don't want to override that unless the lisp @@ -1032,19 +1079,20 @@ x_real_positions (f, xptr, yptr) int *xptr, *yptr; { POINT pt; + RECT rect; - { - RECT rect; - - GetClientRect(FRAME_W32_WINDOW(f), &rect); - AdjustWindowRect(&rect, f->output_data.w32->dwStyle, FRAME_EXTERNAL_MENU_BAR(f)); - - pt.x = rect.left; - pt.y = rect.top; - } + GetClientRect(FRAME_W32_WINDOW(f), &rect); + AdjustWindowRect(&rect, f->output_data.w32->dwStyle, FRAME_EXTERNAL_MENU_BAR(f)); + + pt.x = rect.left; + pt.y = rect.top; ClientToScreen (FRAME_W32_WINDOW(f), &pt); + /* Remember x_pixels_diff and y_pixels_diff. */ + f->output_data.w32->x_pixels_diff = pt.x - rect.left; + f->output_data.w32->y_pixels_diff = pt.y - rect.top; + *xptr = pt.x; *yptr = pt.y; } @@ -1967,6 +2015,25 @@ x_set_line_spacing (f, new_value, old_value) } +/* Change the `fullscreen' frame parameter of frame F. OLD_VALUE is + the previous value of that parameter, NEW_VALUE is the new value. */ + +static void +x_set_fullscreen (f, new_value, old_value) + struct frame *f; + Lisp_Object new_value, old_value; +{ + if (NILP (new_value)) + f->output_data.w32->want_fullscreen = FULLSCREEN_NONE; + else if (EQ (new_value, Qfullboth)) + f->output_data.w32->want_fullscreen = FULLSCREEN_BOTH; + else if (EQ (new_value, Qfullwidth)) + f->output_data.w32->want_fullscreen = FULLSCREEN_WIDTH; + else if (EQ (new_value, Qfullheight)) + f->output_data.w32->want_fullscreen = FULLSCREEN_HEIGHT; +} + + /* Change the `screen-gamma' frame parameter of frame F. OLD_VALUE is the previous value of that parameter, NEW_VALUE is the new value. */ @@ -3285,7 +3352,9 @@ x_figure_window_size (f, parms) : FRAME_SCROLL_BAR_PIXEL_WIDTH (f) > 0 ? FRAME_SCROLL_BAR_PIXEL_WIDTH (f) : (FRAME_SCROLL_BAR_COLS (f) * FONT_WIDTH (f->output_data.w32->font))); + x_compute_fringe_widths (f, 0); + f->output_data.w32->pixel_width = CHAR_TO_PIXEL_WIDTH (f, f->width); f->output_data.w32->pixel_height = CHAR_TO_PIXEL_HEIGHT (f, f->height); @@ -3356,6 +3425,22 @@ x_figure_window_size (f, parms) window_prompting |= PPosition; } + if (f->output_data.w32->want_fullscreen != FULLSCREEN_NONE) + { + int left, top; + int width, height; + + /* It takes both for some WM:s to place it where we want */ + window_prompting = USPosition | PPosition; + x_fullscreen_adjust (f, &width, &height, &top, &left); + f->width = width; + f->height = height; + f->output_data.w32->pixel_width = CHAR_TO_PIXEL_WIDTH (f, f->width); + f->output_data.w32->pixel_height = CHAR_TO_PIXEL_HEIGHT (f, f->height); + f->output_data.w32->left_pos = left; + f->output_data.w32->top_pos = top; + } + return window_prompting; } @@ -5564,6 +5649,8 @@ This function is an internal primitive--use `make-frame' instead. */) "bufferPredicate", "BufferPredicate", RES_TYPE_SYMBOL); x_default_parameter (f, parms, Qtitle, Qnil, "title", "Title", RES_TYPE_STRING); + x_default_parameter (f, parms, Qfullscreen, Qnil, + "fullscreen", "Fullscreen", RES_TYPE_SYMBOL); f->output_data.w32->dwStyle = WS_OVERLAPPEDWINDOW; f->output_data.w32->parent_desc = FRAME_W32_DISPLAY_INFO (f)->root_window; @@ -5959,10 +6046,10 @@ w32_load_system_font (f,fontname,size) /* Set global flag fonts_changed_p to non-zero if the font loaded has a character with a smaller width than any other character - before, or if the font loaded has a smalle>r height than any + before, or if the font loaded has a smaller height than any other font loaded before. If this happens, it will make a glyph matrix reallocation necessary. */ - fonts_changed_p = x_compute_min_glyph_bounds (f); + fonts_changed_p |= x_compute_min_glyph_bounds (f); UNBLOCK_INPUT; return fontp; } @@ -14487,9 +14574,6 @@ syms_of_w32fns () w32_visible_system_caret_hwnd = NULL; - /* The section below is built by the lisp expression at the top of the file, - just above where these variables are declared. */ - /*&&& init symbols here &&&*/ Qauto_raise = intern ("auto-raise"); staticpro (&Qauto_raise); Qauto_lower = intern ("auto-lower"); @@ -14556,7 +14640,14 @@ syms_of_w32fns () staticpro (&Qcenter); Qcancel_timer = intern ("cancel-timer"); staticpro (&Qcancel_timer); - /* This is the end of symbol initialization. */ + Qfullscreen = intern ("fullscreen"); + staticpro (&Qfullscreen); + Qfullwidth = intern ("fullwidth"); + staticpro (&Qfullwidth); + Qfullheight = intern ("fullheight"); + staticpro (&Qfullheight); + Qfullboth = intern ("fullboth"); + staticpro (&Qfullboth); Qhyper = intern ("hyper"); staticpro (&Qhyper); @@ -14572,6 +14663,7 @@ syms_of_w32fns () staticpro (&Qcontrol); Qshift = intern ("shift"); staticpro (&Qshift); + /* This is the end of symbol initialization. */ /* Text property `display' should be nonsticky by default. */ Vtext_property_default_nonsticky -- 2.39.5