annotate src/select-msw.c @ 412:697ef44129c6 r21-2-14

Import from CVS: tag r21-2-14
author cvs
date Mon, 13 Aug 2007 11:20:41 +0200
parents de805c49cfc1
children da8ed4261e83
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
221
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
1 /* mswindows selection processing for XEmacs
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
2 Copyright (C) 1990, 1991, 1992, 1993, 1994 Free Software Foundation, Inc.
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
3
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
4 This file is part of XEmacs.
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
5
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
6 XEmacs is free software; you can redistribute it and/or modify it
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
7 under the terms of the GNU General Public License as published by the
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
8 Free Software Foundation; either version 2, or (at your option) any
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
9 later version.
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
10
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
14 for more details.
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
15
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
17 along with XEmacs; see the file COPYING. If not, write to
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
19 Boston, MA 02111-1307, USA. */
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
20
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
21 /* Synched up with: Not synched with FSF. */
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
22
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
23 /* Authorship:
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
24
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
25 Written by Kevin Gallo for FSF Emacs.
272
c5d627a313b1 Import from CVS: tag r21-0b34
cvs
parents: 249
diff changeset
26 Rewritten for mswindows by Jonathan Harris, December 1997 for 21.0.
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
27 */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
28
221
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
29
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
30 #include <config.h>
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
31 #include "lisp.h"
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
32
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
33 #include "console-msw.h"
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
34
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
35 DEFUN ("mswindows-set-clipboard", Fmswindows_set_clipboard, 1, 1, 0, /*
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
36 Copy STRING to the mswindows clipboard.
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
37 */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
38 (string))
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
39 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
40 int rawsize, size, i;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
41 unsigned char *src, *dst, *next;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
42 HGLOBAL h = NULL;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
43
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
44 CHECK_STRING (string);
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
45
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
46 /* Calculate size with LFs converted to CRLFs because
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
47 * CF_TEXT format uses CRLF delimited ASCIIZ */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
48 src = XSTRING_DATA (string);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
49 size = rawsize = XSTRING_LENGTH (string) + 1;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
50 for (i=0; i<rawsize; i++)
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
51 if (src[i] == '\n')
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
52 size++;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
53
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
54 if (!OpenClipboard (NULL))
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
55 return Qnil;
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
56
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
57 if (!EmptyClipboard () ||
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
58 (h = GlobalAlloc (GMEM_MOVEABLE | GMEM_DDESHARE, size)) == NULL ||
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
59 (dst = (unsigned char *) GlobalLock (h)) == NULL)
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
60 {
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
61 if (h != NULL) GlobalFree (h);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
62 CloseClipboard ();
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
63 return Qnil;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
64 }
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
65
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
66 /* Convert LFs to CRLFs */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
67 do
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
68 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
69 /* copy next line or remaining bytes including '\0' */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
70 next = memccpy (dst, src, '\n', rawsize);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
71 if (next)
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
72 {
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
73 /* copied one line ending with '\n' */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
74 int copied = next - dst;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
75 rawsize -= copied;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
76 src += copied;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
77 /* insert '\r' before '\n' */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
78 next[-1] = '\r';
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
79 next[0] = '\n';
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
80 dst = next+1;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
81 }
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
82 }
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
83 while (next);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
84
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
85 GlobalUnlock (h);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
86
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
87 i = (SetClipboardData (CF_TEXT, h) != NULL);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
88
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
89 CloseClipboard ();
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
90 GlobalFree (h);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
91
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
92 return i ? Qt : Qnil;
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
93 }
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
94
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
95 DEFUN ("mswindows-get-clipboard", Fmswindows_get_clipboard, 0, 0, 0, /*
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
96 Return the contents of the mswindows clipboard.
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
97 */
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
98 ())
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 288
diff changeset
99 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
100 HANDLE h;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
101 unsigned char *src, *dst, *next;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
102 Lisp_Object ret = Qnil;
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
103
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
104 if (!OpenClipboard (NULL))
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
105 return Qnil;
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
106
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
107 if ((h = GetClipboardData (CF_TEXT)) != NULL &&
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
108 (src = (unsigned char *) GlobalLock (h)) != NULL)
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
109 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
110 int i;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
111 int size, rawsize;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
112 size = rawsize = strlen (src);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
113
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
114 for (i=0; i<rawsize; i++)
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
115 if (src[i] == '\r' && src[i+1] == '\n')
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
116 size--;
404
2f8bb876ab1d Import from CVS: tag r21-2-32
cvs
parents: 400
diff changeset
117
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
118 /* Convert CRLFs to LFs */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
119 ret = make_uninit_string (size);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
120 dst = XSTRING_DATA (ret);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
121 do
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
122 {
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
123 /* copy next line or remaining bytes excluding '\0' */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
124 next = memccpy (dst, src, '\r', rawsize);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
125 if (next)
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
126 {
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
127 /* copied one line ending with '\r' */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
128 int copied = next - dst;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
129 rawsize -= copied;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
130 src += copied;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
131 if (*src == '\n')
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
132 dst += copied - 1; /* overwrite '\r' */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
133 else
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
134 dst += copied;
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
135 }
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
136 }
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
137 while (next);
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
138
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
139 GlobalUnlock (h);
404
2f8bb876ab1d Import from CVS: tag r21-2-32
cvs
parents: 400
diff changeset
140 }
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 288
diff changeset
141
410
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
142 CloseClipboard ();
de805c49cfc1 Import from CVS: tag r21-2-35
cvs
parents: 404
diff changeset
143
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
144 return ret;
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 288
diff changeset
145 }
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 288
diff changeset
146
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
147 DEFUN ("mswindows-selection-exists-p", Fmswindows_selection_exists_p, 0, 0, 0, /*
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
148 Whether there is an MS-Windows selection.
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
149 */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
150 ())
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 288
diff changeset
151 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
152 return IsClipboardFormatAvailable (CF_TEXT) ? Qt : Qnil;
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 288
diff changeset
153 }
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 288
diff changeset
154
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
155 DEFUN ("mswindows-delete-selection", Fmswindows_delete_selection, 0, 0, 0, /*
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
156 Remove the current MS-Windows selection from the clipboard.
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
157 */
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
158 ())
404
2f8bb876ab1d Import from CVS: tag r21-2-32
cvs
parents: 400
diff changeset
159 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
160 return EmptyClipboard () ? Qt : Qnil;
286
57709be46d1b Import from CVS: tag r21-0b41
cvs
parents: 278
diff changeset
161 }
57709be46d1b Import from CVS: tag r21-0b41
cvs
parents: 278
diff changeset
162
221
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
163
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
164 /************************************************************************/
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
165 /* initialization */
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
166 /************************************************************************/
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
167
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
168 void
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
169 syms_of_select_mswindows (void)
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
170 {
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
171 DEFSUBR (Fmswindows_set_clipboard);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
172 DEFSUBR (Fmswindows_get_clipboard);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
173 DEFSUBR (Fmswindows_selection_exists_p);
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 410
diff changeset
174 DEFSUBR (Fmswindows_delete_selection);
221
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
175 }
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
176
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
177 void
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
178 vars_of_select_mswindows (void)
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
179 {
6c0ae1f9357f Import from CVS: tag r20-4b9
cvs
parents:
diff changeset
180 }