Mercurial > hg > xemacs-beta
annotate src/gui-gtk.c @ 5327:d1b17a33450b
Move the heavy lifting from cl-seq.el to C.
src/ChangeLog addition:
2010-12-30 Aidan Kehoe <kehoea@parhasard.net>
Move the heavy lifting from cl-seq.el to C, finally making those
functions first-class XEmacs citizens, with circularity checking,
built-in support for tests other than #'eql, and as much
compatibility with current Common Lisp as Paul Dietz' tests require.
* fns.c (check_eq_nokey, check_eq_key, check_eql_nokey)
(check_eql_key, check_equal_nokey, check_equal_key)
(check_equalp_nokey, check_equalp_key, check_string_match_nokey)
(check_string_match_key, check_other_nokey, check_other_key)
(check_if_nokey, check_if_key, check_match_eq_key)
(check_match_eql_key, check_match_equal_key)
(check_match_equalp_key, check_match_other_key): New. These are
basically to provide function pointers to be used by Lisp
functions that take TEST, TEST-NOT and KEY arguments.
(get_check_match_function_1, get_check_test_function)
(get_check_match_function): These functions work out which of the
previous list of functions to use, given the keywords supplied by
the user.
(count_with_tail): New. This is the bones of #'count.
(list_count_from_end, string_count_from_end): Utility functions
for #'count.
(Fcount): New, moved from cl-seq.el.
(list_position_cons_before): New. The implementation of #'member*,
and important in implementing various other functions.
(FmemberX, Fadjoin, FassocX, FrassocX, Fposition, Ffind)
(FdeleteX, FremoveX, Fdelete_duplicates, Fremove_duplicates)
(Fnsubstitute, Fsubstitute, Fsublis, Fnsublis, Fsubst, Fnsubst)
(Ftree_equal, Fmismatch, Fsearch, Fintersection, Fnintersection)
(Fsubsetp, Fset_difference, Fnset_difference, Fnunion, Funion)
(Fset_exclusive_or, Fnset_exclusive_or): New, moved here from
cl-seq.el.
(position): New. The implementation of #'find and #'position.
(list_delete_duplicates_from_end, subst, sublis, nsublis)
(tree_equal, mismatch_from_end, mismatch_list_list)
(mismatch_list_string, mismatch_list_array)
(mismatch_string_array, mismatch_string_string)
(mismatch_array_array, get_mismatch_func): Helper C functions for
the Lisp-visible functions.
(venn, nvenn): New. The implementation of the main Lisp functions that
treat lists as sets.
lisp/ChangeLog addition:
2010-12-30 Aidan Kehoe <kehoea@parhasard.net>
* cl-seq.el:
Move the heavy lifting from this file to C. Dump the
cl-parsing-keywords macro, but don't use defun* for the functions
we define that do take keywords, dynamic scope lossage makes that
not practical.
* subr.el (sort, fillarray): Move these aliases here.
(map-plist): #'nsublis is now built-in, but at this point #'eql
isn't necessarily available as a test; use #'eq.
* obsolete.el (cl-delete-duplicates): Make this available for old
compiler macros and old code.
(memql): Document that this is equivalent to #'member*, and worse.
* cl.el (adjoin, subst): Removed. These are in C.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Thu, 30 Dec 2010 01:59:52 +0000 |
parents | 166ed8151e62 |
children | 308d34e9f07d |
rev | line source |
---|---|
2168 | 1 /* General GUI code -- GTK-specific. (menubars, scrollbars, toolbars, dialogs) |
462 | 2 Copyright (C) 1995 Board of Trustees, University of Illinois. |
872 | 3 Copyright (C) 1995, 1996, 2002 Ben Wing. |
462 | 4 Copyright (C) 1995 Sun Microsystems, Inc. |
5 Copyright (C) 1998 Free Software Foundation, Inc. | |
6 | |
7 This file is part of XEmacs. | |
8 | |
9 XEmacs is free software; you can redistribute it and/or modify it | |
10 under the terms of the GNU General Public License as published by the | |
11 Free Software Foundation; either version 2, or (at your option) any | |
12 later version. | |
13 | |
14 XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
16 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
17 for more details. | |
18 | |
19 You should have received a copy of the GNU General Public License | |
20 along with XEmacs; see the file COPYING. If not, write to | |
21 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
22 Boston, MA 02111-1307, USA. */ | |
23 | |
24 /* Synched up with: Not in FSF. */ | |
25 | |
26 #include <config.h> | |
27 #include "lisp.h" | |
28 | |
29 #include "buffer.h" | |
872 | 30 #include "device-impl.h" |
462 | 31 #include "frame.h" |
32 #include "gui.h" | |
33 #include "opaque.h" | |
34 | |
872 | 35 #include "console-gtk-impl.h" |
36 | |
462 | 37 static GUI_ID gui_id_ctr = 0; |
38 | |
39 GUI_ID | |
40 new_gui_id (void) | |
41 { | |
42 return (++gui_id_ctr); | |
43 } | |
44 | |
45 /* This is like FRAME_MENUBAR_DATA (f), but contains an alist of | |
46 (id . popup-data) for GCPRO'ing the callbacks of the popup menus | |
47 and dialog boxes. */ | |
48 static Lisp_Object Vpopup_callbacks; | |
49 | |
50 void | |
51 gcpro_popup_callbacks (GUI_ID id, Lisp_Object data) | |
52 { | |
53 Vpopup_callbacks = Fcons (Fcons (make_int (id), data), Vpopup_callbacks); | |
54 } | |
55 | |
56 void | |
57 ungcpro_popup_callbacks (GUI_ID id) | |
58 { | |
59 Lisp_Object lid = make_int (id); | |
2552 | 60 Lisp_Object this_callback = assq_no_quit (lid, Vpopup_callbacks); |
61 Vpopup_callbacks = delq_no_quit (this_callback, Vpopup_callbacks); | |
462 | 62 } |
63 | |
64 Lisp_Object | |
65 get_gcpro_popup_callbacks (GUI_ID id) | |
66 { | |
67 Lisp_Object lid = make_int (id); | |
2552 | 68 Lisp_Object this_callback = assq_no_quit (lid, Vpopup_callbacks); |
462 | 69 |
2552 | 70 if (!NILP (this_callback)) |
462 | 71 { |
2552 | 72 return (XCDR (this_callback)); |
462 | 73 } |
74 return (Qnil); | |
75 } | |
76 | |
77 void | |
78 syms_of_gui_gtk (void) | |
79 { | |
80 #ifdef HAVE_POPUPS | |
563 | 81 DEFSYMBOL (Qmenu_no_selection_hook); |
462 | 82 #endif |
83 } | |
84 | |
85 void | |
86 vars_of_gui_gtk (void) | |
87 { | |
88 staticpro (&Vpopup_callbacks); | |
89 Vpopup_callbacks = Qnil; | |
90 #ifdef HAVE_POPUPS | |
91 popup_up_p = 0; | |
92 | |
93 #if 0 | |
94 /* This DEFVAR_LISP is just for the benefit of make-docfile. */ | |
95 /* #### misnamed */ | |
96 DEFVAR_LISP ("menu-no-selection-hook", &Vmenu_no_selection_hook /* | |
97 Function or functions to call when a menu or dialog box is dismissed | |
98 without a selection having been made. | |
99 */ ); | |
100 #endif | |
101 | |
102 Fset (Qmenu_no_selection_hook, Qnil); | |
103 #endif /* HAVE_POPUPS */ | |
104 } |