Mercurial > hg > xemacs-beta
view netinstall/autoload.c @ 5047:07dcc7000bbf
put width before height consistently, fix a real bug found in the process
-------------------- ChangeLog entries follow: --------------------
src/ChangeLog addition:
2010-02-20 Ben Wing <ben@xemacs.org>
* EmacsFrame.c (EmacsFrameRecomputeCellSize):
* faces.c (default_face_font_info):
* faces.c (default_face_width_and_height):
* faces.c (Fface_list):
* faces.h:
* frame-gtk.c (gtk_set_initial_frame_size):
* frame-gtk.c (gtk_set_frame_size):
* frame-gtk.c (gtk_recompute_cell_sizes):
* frame.c:
* frame.c (frame_conversion_internal_1):
* frame.c (change_frame_size_1):
* frame.c (change_frame_size):
* glyphs-msw.c (mswindows_combo_box_instantiate):
* glyphs-widget.c (widget_instantiate):
* glyphs-widget.c (tree_view_query_geometry):
* glyphs-widget.c (Fwidget_logical_to_character_width):
* glyphs-widget.c (Fwidget_logical_to_character_height):
* indent.c (vmotion_pixels):
* redisplay-output.c (get_cursor_size_and_location):
* redisplay-xlike-inc.c (XLIKE_output_eol_cursor):
* redisplay-xlike-inc.c (XLIKE_flash):
* redisplay.c (calculate_baseline):
* redisplay.c (start_with_point_on_display_line):
* redisplay.c (glyph_to_pixel_translation):
* redisplay.c (pixel_to_glyph_translation):
* window.c (margin_width_internal):
* window.c (frame_size_valid_p):
* window.c (frame_pixsize_valid_p):
* window.c (check_frame_size):
* window.c (set_window_pixsize):
* window.c (window_pixel_height_to_char_height):
* window.c (window_char_height_to_pixel_height):
* window.c (window_displayed_height):
* window.c (window_pixel_width_to_char_width):
* window.c (window_char_width_to_pixel_width):
* window.c (change_window_height):
* window.c (window_scroll):
* window.h:
IMPORTANT: Aidan and Carbon Repo, please pay attention and fix
appropriately!
Rename: default_face_height_and_width -> default_face_width_and_height
and reverse width/height arguments.
Reverse width/height arguments to the following functions:
-- default_face_font_info
-- default_face_height_and_width (see above)
-- check_frame_size
-- frame_size_valid_p (made into a static function)
Fix a redisplay bug where args to default_face_height_and_width
were in the wrong order.
| author | Ben Wing <ben@xemacs.org> |
|---|---|
| date | Sat, 20 Feb 2010 18:56:01 -0600 |
| parents | 3078fd1074e8 |
| children |
line wrap: on
line source
/* * Copyright (c) 2000, Red Hat, Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * A copy of the GNU General Public License can be found at * http://www.gnu.org/ * * Written by DJ Delorie <dj@cygnus.com> * */ #include "win32.h" typedef struct { char *name; HINSTANCE handle; } DllInfo; #define DLL(n) static DllInfo n ## _info __asm__ (#n "_info") = { #n, 0} #define Auto(dll, func, size) \ __asm__ ("\t.data"); \ __asm__ ("\t.global\t_" #func "@" #size); \ __asm__ ("_" #func "@" #size ":"); \ __asm__ ("\tcall\tautoload_common"); \ __asm__ ("\t.long\t" #dll "_info"); \ __asm__ ("\t.ascii\t\"" #func "\\0\"") DLL (wininet); Auto (wininet, InternetAttemptConnect, 4); Auto (wininet, InternetCloseHandle, 4); Auto (wininet, InternetGetLastResponseInfoA, 12); Auto (wininet, InternetOpenA, 20); Auto (wininet, InternetOpenUrlA, 24); Auto (wininet, InternetReadFile, 16); Auto (wininet, InternetSetOptionA, 16); Auto (wininet, InternetQueryOptionA, 16); Auto (wininet, HttpQueryInfoA, 20); Auto (wininet, HttpSendRequestA, 20); typedef struct { DllInfo *dll; char name[100]; } AutoEntry; static void autoload_common () __asm__ ("autoload_common"); static void autoload_common (int x) { int fp, rel; unsigned char *proc; HINSTANCE h; AutoEntry *a; a = *(AutoEntry **)(&x - 1); if (a->dll->handle == 0) { h = LoadLibrary (a->dll->name); a->dll->handle = h; } fp = (int) GetProcAddress (a->dll->handle, a->name); proc = ((unsigned char *)a) - 5; rel = fp - (int)(a); /* now it's a relative call */ *proc++ = 0xe9; /* jump near 32-bit relative */ *proc++ = rel; *proc++ = rel>>8; *proc++ = rel>>16; *proc++ = rel>>24; *(int *)(&x-1) = (int)proc-5; }
