Mercurial > hg > xemacs-beta
annotate lwlib/lwlib-internal.h @ 611:38db05db9cb5
[xemacs-hg @ 2001-06-08 12:21:09 by ben]
------ gc-in-window-procedure fixes ------
alloc.c: Create "post-gc actions", to avoid those dreaded "GC during window
procedure" problems.
event-msw.c: Abort, clean and simple, when GC in window procedure. We want
to flush these puppies out.
glyphs-msw.c: Use a post-gc action when destroying subwindows.
lisp.h: Declare register_post_gc_action().
scrollbar-msw.c: Use a post-gc action when unshowing scrollbar windows, if in gc.
redisplay.c: Add comment about the utter evilness of what's going down here.
------ cygwin setitimer fixes ------
Makefile.in.in: Compile profile.c only when HAVE_SETITIMER.
nt.c: Style fixes.
nt.c: Move setitimer() emulation to win32.c, because Cygwin needs it too.
profile.c: Make sure we don't compile if no setitimer(). Use qxe_setitimer()
instead of just plain setitimer().
signal.c: Define qxe_setitimer() as an encapsulation around setitimer() --
call setitimer() directly unless Cygwin or MS Win, in which case
we use our simulated version in win32.c.
systime.h: Prototype mswindows_setitimer() and qxe_setitimer(). Long
comment about "qxe" and the policy regarding encapsulation.
win32.c: Move setitimer() emulation here, so Cygwin can use it.
Rename a couple of functions and variables to be longer and more
descriptive. In setitimer_helper_proc(), send the signal
using either mswindows_raise() or (on Cygwin) kill(). If for
some reason we are still getting lockups, we'll change the kill()
to directly invoke the signal handlers.
------ windows shell fixes ------
callproc.c, ntproc.c: Comments about how these two files must die.
callproc.c: On MS Windows, init shell-file-name from SHELL, then COMSPEC,
not just COMSPEC. (more correct and closer to FSF.) Don't
force a value for SHELL into the environment. (Comments added
to explain why not.)
nt.c: Don't shove a fabricated SHELL into the environment. See above.
------ misc fixes ------
glyphs-shared.c: Style correction.
xemacs-faq.texi: Merge in the rest of Hrvoje's Windows FAQ. Redo section 7
to update current reality and add condensed versions of
new changes for 21.1 and 21.4. (Not quite done for 21.4.)
Lots more Windows updates.
process.el: Need to quote a null
argument, too. From Dan Holmsand.
startup.el:
startup.el: Call MS Windows init function.
win32-native.el: Correct comments at top. Correctly handle passing arguments
to Cygwin programs and to bash. Fix quoting of zero-length
arguments (from Dan Holmsand). Set shell-command-switch based
on shell-file-name, which in turn comes from env var SHELL.
author | ben |
---|---|
date | Fri, 08 Jun 2001 12:21:27 +0000 |
parents | 3078fd1074e8 |
children | 943eaba38521 |
rev | line source |
---|---|
440 | 1 #ifndef INCLUDED_lwlib_internal_h_ |
2 #define INCLUDED_lwlib_internal_h_ | |
428 | 3 |
4 #include "lwlib.h" | |
5 | |
448 | 6 #ifdef USE_ASSERTIONS |
7 /* Highly dubious kludge */ | |
8 /* (thanks, Jamie, I feel better now -- ben) */ | |
9 void assert_failed (const char *, int, const char *); | |
10 # define abort() (assert_failed (__FILE__, __LINE__, "abort()")) | |
11 # define assert(x) ((x) ? (void) 0 : assert_failed (__FILE__, __LINE__, #x)) | |
12 #else | |
13 # ifdef DEBUG_XEMACS | |
14 # define assert(x) ((x) ? (void) 0 : (void) abort ()) | |
15 # else | |
16 # define assert(x) | |
17 # endif | |
18 #endif | |
19 | |
428 | 20 /* This represents a single widget within a widget tree. All the |
21 widgets in a widget tree are chained through the `next' field. | |
22 `info' is a back pointer to the widget tree. */ | |
23 | |
24 typedef struct _widget_instance | |
25 { | |
26 Widget widget; | |
27 Widget parent; | |
28 Boolean pop_up_p; | |
29 struct _widget_info* info; | |
30 struct _widget_instance* next; | |
31 } widget_instance; | |
32 | |
33 /* This represents a single widget tree, such as a single menubar. | |
34 The global variable `all_widget_info' lists all widget trees, | |
35 chained through the `next' field of this structure. */ | |
36 | |
37 typedef struct _widget_info | |
38 { | |
39 char* type; | |
40 char* name; | |
41 LWLIB_ID id; | |
42 widget_value* val; | |
43 Boolean busy; | |
44 lw_callback pre_activate_cb; | |
45 lw_callback selection_cb; | |
46 lw_callback post_activate_cb; | |
47 struct _widget_instance* instances; | |
48 struct _widget_info* next; | |
49 } widget_info; | |
50 | |
51 typedef Widget | |
52 (*widget_creation_function) (widget_instance* instance); | |
53 | |
54 typedef struct _widget_creation_entry | |
55 { | |
442 | 56 const char* type; |
428 | 57 widget_creation_function function; |
58 } widget_creation_entry; | |
59 | |
60 /* update all other instances of a widget. Can be used in a callback when | |
442 | 61 a widget has been used by the user */ |
428 | 62 void |
63 lw_internal_update_other_instances (Widget widget, XtPointer closure, | |
64 XtPointer call_data); | |
65 | |
66 /* get the widget_value for a widget in a given instance */ | |
67 widget_value* | |
68 lw_get_widget_value_for_widget (widget_instance* instance, Widget w); | |
69 | |
70 widget_info *lw_get_widget_info (LWLIB_ID id); | |
71 | |
440 | 72 #endif /* INCLUDED_lwlib_internal_h_ */ |