xref: /dflybsd-src/contrib/gdb-7/readline/kill.c (revision 16003dcfd2baa152f5dd24794ec9f36e139eaeb8)
1*6b445a62SJohn Marino /* kill.c -- kill ring management. */
2*6b445a62SJohn Marino 
3*6b445a62SJohn Marino /* Copyright (C) 1994 Free Software Foundation, Inc.
4*6b445a62SJohn Marino 
5*6b445a62SJohn Marino    This file is part of the GNU Readline Library (Readline), a library
6*6b445a62SJohn Marino    for reading lines of text with interactive input and history editing.
7*6b445a62SJohn Marino 
8*6b445a62SJohn Marino    Readline is free software: you can redistribute it and/or modify
9*6b445a62SJohn Marino    it under the terms of the GNU General Public License as published by
10*6b445a62SJohn Marino    the Free Software Foundation, either version 3 of the License, or
11*6b445a62SJohn Marino    (at your option) any later version.
12*6b445a62SJohn Marino 
13*6b445a62SJohn Marino    Readline is distributed in the hope that it will be useful,
14*6b445a62SJohn Marino    but WITHOUT ANY WARRANTY; without even the implied warranty of
15*6b445a62SJohn Marino    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16*6b445a62SJohn Marino    GNU General Public License for more details.
17*6b445a62SJohn Marino 
18*6b445a62SJohn Marino    You should have received a copy of the GNU General Public License
19*6b445a62SJohn Marino    along with Readline.  If not, see <http://www.gnu.org/licenses/>.
20*6b445a62SJohn Marino */
21*6b445a62SJohn Marino 
22*6b445a62SJohn Marino #define READLINE_LIBRARY
23*6b445a62SJohn Marino 
24*6b445a62SJohn Marino #if defined (HAVE_CONFIG_H)
25*6b445a62SJohn Marino #  include <config.h>
26*6b445a62SJohn Marino #endif
27*6b445a62SJohn Marino 
28*6b445a62SJohn Marino #include <sys/types.h>
29*6b445a62SJohn Marino 
30*6b445a62SJohn Marino #if defined (HAVE_UNISTD_H)
31*6b445a62SJohn Marino #  include <unistd.h>           /* for _POSIX_VERSION */
32*6b445a62SJohn Marino #endif /* HAVE_UNISTD_H */
33*6b445a62SJohn Marino 
34*6b445a62SJohn Marino #if defined (HAVE_STDLIB_H)
35*6b445a62SJohn Marino #  include <stdlib.h>
36*6b445a62SJohn Marino #else
37*6b445a62SJohn Marino #  include "ansi_stdlib.h"
38*6b445a62SJohn Marino #endif /* HAVE_STDLIB_H */
39*6b445a62SJohn Marino 
40*6b445a62SJohn Marino #include <stdio.h>
41*6b445a62SJohn Marino 
42*6b445a62SJohn Marino /* System-specific feature definitions and include files. */
43*6b445a62SJohn Marino #include "rldefs.h"
44*6b445a62SJohn Marino 
45*6b445a62SJohn Marino /* Some standard library routines. */
46*6b445a62SJohn Marino #include "readline.h"
47*6b445a62SJohn Marino #include "history.h"
48*6b445a62SJohn Marino 
49*6b445a62SJohn Marino #include "rlprivate.h"
50*6b445a62SJohn Marino #include "xmalloc.h"
51*6b445a62SJohn Marino 
52*6b445a62SJohn Marino /* **************************************************************** */
53*6b445a62SJohn Marino /*								    */
54*6b445a62SJohn Marino /*			Killing Mechanism			    */
55*6b445a62SJohn Marino /*								    */
56*6b445a62SJohn Marino /* **************************************************************** */
57*6b445a62SJohn Marino 
58*6b445a62SJohn Marino /* What we assume for a max number of kills. */
59*6b445a62SJohn Marino #define DEFAULT_MAX_KILLS 10
60*6b445a62SJohn Marino 
61*6b445a62SJohn Marino /* The real variable to look at to find out when to flush kills. */
62*6b445a62SJohn Marino static int rl_max_kills =  DEFAULT_MAX_KILLS;
63*6b445a62SJohn Marino 
64*6b445a62SJohn Marino /* Where to store killed text. */
65*6b445a62SJohn Marino static char **rl_kill_ring = (char **)NULL;
66*6b445a62SJohn Marino 
67*6b445a62SJohn Marino /* Where we are in the kill ring. */
68*6b445a62SJohn Marino static int rl_kill_index;
69*6b445a62SJohn Marino 
70*6b445a62SJohn Marino /* How many slots we have in the kill ring. */
71*6b445a62SJohn Marino static int rl_kill_ring_length;
72*6b445a62SJohn Marino 
73*6b445a62SJohn Marino static int _rl_copy_to_kill_ring PARAMS((char *, int));
74*6b445a62SJohn Marino static int region_kill_internal PARAMS((int));
75*6b445a62SJohn Marino static int _rl_copy_word_as_kill PARAMS((int, int));
76*6b445a62SJohn Marino static int rl_yank_nth_arg_internal PARAMS((int, int, int));
77*6b445a62SJohn Marino 
78*6b445a62SJohn Marino /* How to say that you only want to save a certain amount
79*6b445a62SJohn Marino    of kill material. */
80*6b445a62SJohn Marino int
rl_set_retained_kills(num)81*6b445a62SJohn Marino rl_set_retained_kills (num)
82*6b445a62SJohn Marino      int num;
83*6b445a62SJohn Marino {
84*6b445a62SJohn Marino   return 0;
85*6b445a62SJohn Marino }
86*6b445a62SJohn Marino 
87*6b445a62SJohn Marino /* Add TEXT to the kill ring, allocating a new kill ring slot as necessary.
88*6b445a62SJohn Marino    This uses TEXT directly, so the caller must not free it.  If APPEND is
89*6b445a62SJohn Marino    non-zero, and the last command was a kill, the text is appended to the
90*6b445a62SJohn Marino    current kill ring slot, otherwise prepended. */
91*6b445a62SJohn Marino static int
_rl_copy_to_kill_ring(text,append)92*6b445a62SJohn Marino _rl_copy_to_kill_ring (text, append)
93*6b445a62SJohn Marino      char *text;
94*6b445a62SJohn Marino      int append;
95*6b445a62SJohn Marino {
96*6b445a62SJohn Marino   char *old, *new;
97*6b445a62SJohn Marino   int slot;
98*6b445a62SJohn Marino 
99*6b445a62SJohn Marino   /* First, find the slot to work with. */
100*6b445a62SJohn Marino   if (_rl_last_command_was_kill == 0)
101*6b445a62SJohn Marino     {
102*6b445a62SJohn Marino       /* Get a new slot.  */
103*6b445a62SJohn Marino       if (rl_kill_ring == 0)
104*6b445a62SJohn Marino 	{
105*6b445a62SJohn Marino 	  /* If we don't have any defined, then make one. */
106*6b445a62SJohn Marino 	  rl_kill_ring = (char **)
107*6b445a62SJohn Marino 	    xmalloc (((rl_kill_ring_length = 1) + 1) * sizeof (char *));
108*6b445a62SJohn Marino 	  rl_kill_ring[slot = 0] = (char *)NULL;
109*6b445a62SJohn Marino 	}
110*6b445a62SJohn Marino       else
111*6b445a62SJohn Marino 	{
112*6b445a62SJohn Marino 	  /* We have to add a new slot on the end, unless we have
113*6b445a62SJohn Marino 	     exceeded the max limit for remembering kills. */
114*6b445a62SJohn Marino 	  slot = rl_kill_ring_length;
115*6b445a62SJohn Marino 	  if (slot == rl_max_kills)
116*6b445a62SJohn Marino 	    {
117*6b445a62SJohn Marino 	      register int i;
118*6b445a62SJohn Marino 	      xfree (rl_kill_ring[0]);
119*6b445a62SJohn Marino 	      for (i = 0; i < slot; i++)
120*6b445a62SJohn Marino 		rl_kill_ring[i] = rl_kill_ring[i + 1];
121*6b445a62SJohn Marino 	    }
122*6b445a62SJohn Marino 	  else
123*6b445a62SJohn Marino 	    {
124*6b445a62SJohn Marino 	      slot = rl_kill_ring_length += 1;
125*6b445a62SJohn Marino 	      rl_kill_ring = (char **)xrealloc (rl_kill_ring, slot * sizeof (char *));
126*6b445a62SJohn Marino 	    }
127*6b445a62SJohn Marino 	  rl_kill_ring[--slot] = (char *)NULL;
128*6b445a62SJohn Marino 	}
129*6b445a62SJohn Marino     }
130*6b445a62SJohn Marino   else
131*6b445a62SJohn Marino     slot = rl_kill_ring_length - 1;
132*6b445a62SJohn Marino 
133*6b445a62SJohn Marino   /* If the last command was a kill, prepend or append. */
134*6b445a62SJohn Marino   if (_rl_last_command_was_kill && rl_editing_mode != vi_mode)
135*6b445a62SJohn Marino     {
136*6b445a62SJohn Marino       old = rl_kill_ring[slot];
137*6b445a62SJohn Marino       new = (char *)xmalloc (1 + strlen (old) + strlen (text));
138*6b445a62SJohn Marino 
139*6b445a62SJohn Marino       if (append)
140*6b445a62SJohn Marino 	{
141*6b445a62SJohn Marino 	  strcpy (new, old);
142*6b445a62SJohn Marino 	  strcat (new, text);
143*6b445a62SJohn Marino 	}
144*6b445a62SJohn Marino       else
145*6b445a62SJohn Marino 	{
146*6b445a62SJohn Marino 	  strcpy (new, text);
147*6b445a62SJohn Marino 	  strcat (new, old);
148*6b445a62SJohn Marino 	}
149*6b445a62SJohn Marino       xfree (old);
150*6b445a62SJohn Marino       xfree (text);
151*6b445a62SJohn Marino       rl_kill_ring[slot] = new;
152*6b445a62SJohn Marino     }
153*6b445a62SJohn Marino   else
154*6b445a62SJohn Marino     rl_kill_ring[slot] = text;
155*6b445a62SJohn Marino 
156*6b445a62SJohn Marino   rl_kill_index = slot;
157*6b445a62SJohn Marino   return 0;
158*6b445a62SJohn Marino }
159*6b445a62SJohn Marino 
160*6b445a62SJohn Marino /* The way to kill something.  This appends or prepends to the last
161*6b445a62SJohn Marino    kill, if the last command was a kill command.  if FROM is less
162*6b445a62SJohn Marino    than TO, then the text is appended, otherwise prepended.  If the
163*6b445a62SJohn Marino    last command was not a kill command, then a new slot is made for
164*6b445a62SJohn Marino    this kill. */
165*6b445a62SJohn Marino int
rl_kill_text(from,to)166*6b445a62SJohn Marino rl_kill_text (from, to)
167*6b445a62SJohn Marino      int from, to;
168*6b445a62SJohn Marino {
169*6b445a62SJohn Marino   char *text;
170*6b445a62SJohn Marino 
171*6b445a62SJohn Marino   /* Is there anything to kill? */
172*6b445a62SJohn Marino   if (from == to)
173*6b445a62SJohn Marino     {
174*6b445a62SJohn Marino       _rl_last_command_was_kill++;
175*6b445a62SJohn Marino       return 0;
176*6b445a62SJohn Marino     }
177*6b445a62SJohn Marino 
178*6b445a62SJohn Marino   text = rl_copy_text (from, to);
179*6b445a62SJohn Marino 
180*6b445a62SJohn Marino   /* Delete the copied text from the line. */
181*6b445a62SJohn Marino   rl_delete_text (from, to);
182*6b445a62SJohn Marino 
183*6b445a62SJohn Marino   _rl_copy_to_kill_ring (text, from < to);
184*6b445a62SJohn Marino 
185*6b445a62SJohn Marino   _rl_last_command_was_kill++;
186*6b445a62SJohn Marino   return 0;
187*6b445a62SJohn Marino }
188*6b445a62SJohn Marino 
189*6b445a62SJohn Marino /* Now REMEMBER!  In order to do prepending or appending correctly, kill
190*6b445a62SJohn Marino    commands always make rl_point's original position be the FROM argument,
191*6b445a62SJohn Marino    and rl_point's extent be the TO argument. */
192*6b445a62SJohn Marino 
193*6b445a62SJohn Marino /* **************************************************************** */
194*6b445a62SJohn Marino /*								    */
195*6b445a62SJohn Marino /*			Killing Commands			    */
196*6b445a62SJohn Marino /*								    */
197*6b445a62SJohn Marino /* **************************************************************** */
198*6b445a62SJohn Marino 
199*6b445a62SJohn Marino /* Delete the word at point, saving the text in the kill ring. */
200*6b445a62SJohn Marino int
rl_kill_word(count,key)201*6b445a62SJohn Marino rl_kill_word (count, key)
202*6b445a62SJohn Marino      int count, key;
203*6b445a62SJohn Marino {
204*6b445a62SJohn Marino   int orig_point;
205*6b445a62SJohn Marino 
206*6b445a62SJohn Marino   if (count < 0)
207*6b445a62SJohn Marino     return (rl_backward_kill_word (-count, key));
208*6b445a62SJohn Marino   else
209*6b445a62SJohn Marino     {
210*6b445a62SJohn Marino       orig_point = rl_point;
211*6b445a62SJohn Marino       rl_forward_word (count, key);
212*6b445a62SJohn Marino 
213*6b445a62SJohn Marino       if (rl_point != orig_point)
214*6b445a62SJohn Marino 	rl_kill_text (orig_point, rl_point);
215*6b445a62SJohn Marino 
216*6b445a62SJohn Marino       rl_point = orig_point;
217*6b445a62SJohn Marino       if (rl_editing_mode == emacs_mode)
218*6b445a62SJohn Marino 	rl_mark = rl_point;
219*6b445a62SJohn Marino     }
220*6b445a62SJohn Marino   return 0;
221*6b445a62SJohn Marino }
222*6b445a62SJohn Marino 
223*6b445a62SJohn Marino /* Rubout the word before point, placing it on the kill ring. */
224*6b445a62SJohn Marino int
rl_backward_kill_word(count,ignore)225*6b445a62SJohn Marino rl_backward_kill_word (count, ignore)
226*6b445a62SJohn Marino      int count, ignore;
227*6b445a62SJohn Marino {
228*6b445a62SJohn Marino   int orig_point;
229*6b445a62SJohn Marino 
230*6b445a62SJohn Marino   if (count < 0)
231*6b445a62SJohn Marino     return (rl_kill_word (-count, ignore));
232*6b445a62SJohn Marino   else
233*6b445a62SJohn Marino     {
234*6b445a62SJohn Marino       orig_point = rl_point;
235*6b445a62SJohn Marino       rl_backward_word (count, ignore);
236*6b445a62SJohn Marino 
237*6b445a62SJohn Marino       if (rl_point != orig_point)
238*6b445a62SJohn Marino 	rl_kill_text (orig_point, rl_point);
239*6b445a62SJohn Marino 
240*6b445a62SJohn Marino       if (rl_editing_mode == emacs_mode)
241*6b445a62SJohn Marino 	rl_mark = rl_point;
242*6b445a62SJohn Marino     }
243*6b445a62SJohn Marino   return 0;
244*6b445a62SJohn Marino }
245*6b445a62SJohn Marino 
246*6b445a62SJohn Marino /* Kill from here to the end of the line.  If DIRECTION is negative, kill
247*6b445a62SJohn Marino    back to the line start instead. */
248*6b445a62SJohn Marino int
rl_kill_line(direction,ignore)249*6b445a62SJohn Marino rl_kill_line (direction, ignore)
250*6b445a62SJohn Marino      int direction, ignore;
251*6b445a62SJohn Marino {
252*6b445a62SJohn Marino   int orig_point;
253*6b445a62SJohn Marino 
254*6b445a62SJohn Marino   if (direction < 0)
255*6b445a62SJohn Marino     return (rl_backward_kill_line (1, ignore));
256*6b445a62SJohn Marino   else
257*6b445a62SJohn Marino     {
258*6b445a62SJohn Marino       orig_point = rl_point;
259*6b445a62SJohn Marino       rl_end_of_line (1, ignore);
260*6b445a62SJohn Marino       if (orig_point != rl_point)
261*6b445a62SJohn Marino 	rl_kill_text (orig_point, rl_point);
262*6b445a62SJohn Marino       rl_point = orig_point;
263*6b445a62SJohn Marino       if (rl_editing_mode == emacs_mode)
264*6b445a62SJohn Marino 	rl_mark = rl_point;
265*6b445a62SJohn Marino     }
266*6b445a62SJohn Marino   return 0;
267*6b445a62SJohn Marino }
268*6b445a62SJohn Marino 
269*6b445a62SJohn Marino /* Kill backwards to the start of the line.  If DIRECTION is negative, kill
270*6b445a62SJohn Marino    forwards to the line end instead. */
271*6b445a62SJohn Marino int
rl_backward_kill_line(direction,ignore)272*6b445a62SJohn Marino rl_backward_kill_line (direction, ignore)
273*6b445a62SJohn Marino      int direction, ignore;
274*6b445a62SJohn Marino {
275*6b445a62SJohn Marino   int orig_point;
276*6b445a62SJohn Marino 
277*6b445a62SJohn Marino   if (direction < 0)
278*6b445a62SJohn Marino     return (rl_kill_line (1, ignore));
279*6b445a62SJohn Marino   else
280*6b445a62SJohn Marino     {
281*6b445a62SJohn Marino       if (!rl_point)
282*6b445a62SJohn Marino 	rl_ding ();
283*6b445a62SJohn Marino       else
284*6b445a62SJohn Marino 	{
285*6b445a62SJohn Marino 	  orig_point = rl_point;
286*6b445a62SJohn Marino 	  rl_beg_of_line (1, ignore);
287*6b445a62SJohn Marino 	  if (rl_point != orig_point)
288*6b445a62SJohn Marino 	    rl_kill_text (orig_point, rl_point);
289*6b445a62SJohn Marino 	  if (rl_editing_mode == emacs_mode)
290*6b445a62SJohn Marino 	    rl_mark = rl_point;
291*6b445a62SJohn Marino 	}
292*6b445a62SJohn Marino     }
293*6b445a62SJohn Marino   return 0;
294*6b445a62SJohn Marino }
295*6b445a62SJohn Marino 
296*6b445a62SJohn Marino /* Kill the whole line, no matter where point is. */
297*6b445a62SJohn Marino int
rl_kill_full_line(count,ignore)298*6b445a62SJohn Marino rl_kill_full_line (count, ignore)
299*6b445a62SJohn Marino      int count, ignore;
300*6b445a62SJohn Marino {
301*6b445a62SJohn Marino   rl_begin_undo_group ();
302*6b445a62SJohn Marino   rl_point = 0;
303*6b445a62SJohn Marino   rl_kill_text (rl_point, rl_end);
304*6b445a62SJohn Marino   rl_mark = 0;
305*6b445a62SJohn Marino   rl_end_undo_group ();
306*6b445a62SJohn Marino   return 0;
307*6b445a62SJohn Marino }
308*6b445a62SJohn Marino 
309*6b445a62SJohn Marino /* The next two functions mimic unix line editing behaviour, except they
310*6b445a62SJohn Marino    save the deleted text on the kill ring.  This is safer than not saving
311*6b445a62SJohn Marino    it, and since we have a ring, nobody should get screwed. */
312*6b445a62SJohn Marino 
313*6b445a62SJohn Marino /* This does what C-w does in Unix.  We can't prevent people from
314*6b445a62SJohn Marino    using behaviour that they expect. */
315*6b445a62SJohn Marino int
rl_unix_word_rubout(count,key)316*6b445a62SJohn Marino rl_unix_word_rubout (count, key)
317*6b445a62SJohn Marino      int count, key;
318*6b445a62SJohn Marino {
319*6b445a62SJohn Marino   int orig_point;
320*6b445a62SJohn Marino 
321*6b445a62SJohn Marino   if (rl_point == 0)
322*6b445a62SJohn Marino     rl_ding ();
323*6b445a62SJohn Marino   else
324*6b445a62SJohn Marino     {
325*6b445a62SJohn Marino       orig_point = rl_point;
326*6b445a62SJohn Marino       if (count <= 0)
327*6b445a62SJohn Marino 	count = 1;
328*6b445a62SJohn Marino 
329*6b445a62SJohn Marino       while (count--)
330*6b445a62SJohn Marino 	{
331*6b445a62SJohn Marino 	  while (rl_point && whitespace (rl_line_buffer[rl_point - 1]))
332*6b445a62SJohn Marino 	    rl_point--;
333*6b445a62SJohn Marino 
334*6b445a62SJohn Marino 	  while (rl_point && (whitespace (rl_line_buffer[rl_point - 1]) == 0))
335*6b445a62SJohn Marino 	    rl_point--;
336*6b445a62SJohn Marino 	}
337*6b445a62SJohn Marino 
338*6b445a62SJohn Marino       rl_kill_text (orig_point, rl_point);
339*6b445a62SJohn Marino       if (rl_editing_mode == emacs_mode)
340*6b445a62SJohn Marino 	rl_mark = rl_point;
341*6b445a62SJohn Marino     }
342*6b445a62SJohn Marino 
343*6b445a62SJohn Marino   return 0;
344*6b445a62SJohn Marino }
345*6b445a62SJohn Marino 
346*6b445a62SJohn Marino /* This deletes one filename component in a Unix pathname.  That is, it
347*6b445a62SJohn Marino    deletes backward to directory separator (`/') or whitespace.  */
348*6b445a62SJohn Marino int
rl_unix_filename_rubout(count,key)349*6b445a62SJohn Marino rl_unix_filename_rubout (count, key)
350*6b445a62SJohn Marino      int count, key;
351*6b445a62SJohn Marino {
352*6b445a62SJohn Marino   int orig_point, c;
353*6b445a62SJohn Marino 
354*6b445a62SJohn Marino   if (rl_point == 0)
355*6b445a62SJohn Marino     rl_ding ();
356*6b445a62SJohn Marino   else
357*6b445a62SJohn Marino     {
358*6b445a62SJohn Marino       orig_point = rl_point;
359*6b445a62SJohn Marino       if (count <= 0)
360*6b445a62SJohn Marino 	count = 1;
361*6b445a62SJohn Marino 
362*6b445a62SJohn Marino       while (count--)
363*6b445a62SJohn Marino 	{
364*6b445a62SJohn Marino 	  c = rl_line_buffer[rl_point - 1];
365*6b445a62SJohn Marino 	  while (rl_point && (whitespace (c) || c == '/'))
366*6b445a62SJohn Marino 	    {
367*6b445a62SJohn Marino 	      rl_point--;
368*6b445a62SJohn Marino 	      c = rl_line_buffer[rl_point - 1];
369*6b445a62SJohn Marino 	    }
370*6b445a62SJohn Marino 
371*6b445a62SJohn Marino 	  while (rl_point && (whitespace (c) == 0) && c != '/')
372*6b445a62SJohn Marino 	    {
373*6b445a62SJohn Marino 	      rl_point--;
374*6b445a62SJohn Marino 	      c = rl_line_buffer[rl_point - 1];
375*6b445a62SJohn Marino 	    }
376*6b445a62SJohn Marino 	}
377*6b445a62SJohn Marino 
378*6b445a62SJohn Marino       rl_kill_text (orig_point, rl_point);
379*6b445a62SJohn Marino       if (rl_editing_mode == emacs_mode)
380*6b445a62SJohn Marino 	rl_mark = rl_point;
381*6b445a62SJohn Marino     }
382*6b445a62SJohn Marino 
383*6b445a62SJohn Marino   return 0;
384*6b445a62SJohn Marino }
385*6b445a62SJohn Marino 
386*6b445a62SJohn Marino /* Here is C-u doing what Unix does.  You don't *have* to use these
387*6b445a62SJohn Marino    key-bindings.  We have a choice of killing the entire line, or
388*6b445a62SJohn Marino    killing from where we are to the start of the line.  We choose the
389*6b445a62SJohn Marino    latter, because if you are a Unix weenie, then you haven't backspaced
390*6b445a62SJohn Marino    into the line at all, and if you aren't, then you know what you are
391*6b445a62SJohn Marino    doing. */
392*6b445a62SJohn Marino int
rl_unix_line_discard(count,key)393*6b445a62SJohn Marino rl_unix_line_discard (count, key)
394*6b445a62SJohn Marino      int count, key;
395*6b445a62SJohn Marino {
396*6b445a62SJohn Marino   if (rl_point == 0)
397*6b445a62SJohn Marino     rl_ding ();
398*6b445a62SJohn Marino   else
399*6b445a62SJohn Marino     {
400*6b445a62SJohn Marino       rl_kill_text (rl_point, 0);
401*6b445a62SJohn Marino       rl_point = 0;
402*6b445a62SJohn Marino       if (rl_editing_mode == emacs_mode)
403*6b445a62SJohn Marino 	rl_mark = rl_point;
404*6b445a62SJohn Marino     }
405*6b445a62SJohn Marino   return 0;
406*6b445a62SJohn Marino }
407*6b445a62SJohn Marino 
408*6b445a62SJohn Marino /* Copy the text in the `region' to the kill ring.  If DELETE is non-zero,
409*6b445a62SJohn Marino    delete the text from the line as well. */
410*6b445a62SJohn Marino static int
region_kill_internal(delete)411*6b445a62SJohn Marino region_kill_internal (delete)
412*6b445a62SJohn Marino      int delete;
413*6b445a62SJohn Marino {
414*6b445a62SJohn Marino   char *text;
415*6b445a62SJohn Marino 
416*6b445a62SJohn Marino   if (rl_mark != rl_point)
417*6b445a62SJohn Marino     {
418*6b445a62SJohn Marino       text = rl_copy_text (rl_point, rl_mark);
419*6b445a62SJohn Marino       if (delete)
420*6b445a62SJohn Marino 	rl_delete_text (rl_point, rl_mark);
421*6b445a62SJohn Marino       _rl_copy_to_kill_ring (text, rl_point < rl_mark);
422*6b445a62SJohn Marino     }
423*6b445a62SJohn Marino 
424*6b445a62SJohn Marino   _rl_last_command_was_kill++;
425*6b445a62SJohn Marino   return 0;
426*6b445a62SJohn Marino }
427*6b445a62SJohn Marino 
428*6b445a62SJohn Marino /* Copy the text in the region to the kill ring. */
429*6b445a62SJohn Marino int
rl_copy_region_to_kill(count,ignore)430*6b445a62SJohn Marino rl_copy_region_to_kill (count, ignore)
431*6b445a62SJohn Marino      int count, ignore;
432*6b445a62SJohn Marino {
433*6b445a62SJohn Marino   return (region_kill_internal (0));
434*6b445a62SJohn Marino }
435*6b445a62SJohn Marino 
436*6b445a62SJohn Marino /* Kill the text between the point and mark. */
437*6b445a62SJohn Marino int
rl_kill_region(count,ignore)438*6b445a62SJohn Marino rl_kill_region (count, ignore)
439*6b445a62SJohn Marino      int count, ignore;
440*6b445a62SJohn Marino {
441*6b445a62SJohn Marino   int r, npoint;
442*6b445a62SJohn Marino 
443*6b445a62SJohn Marino   npoint = (rl_point < rl_mark) ? rl_point : rl_mark;
444*6b445a62SJohn Marino   r = region_kill_internal (1);
445*6b445a62SJohn Marino   _rl_fix_point (1);
446*6b445a62SJohn Marino   rl_point = npoint;
447*6b445a62SJohn Marino   return r;
448*6b445a62SJohn Marino }
449*6b445a62SJohn Marino 
450*6b445a62SJohn Marino /* Copy COUNT words to the kill ring.  DIR says which direction we look
451*6b445a62SJohn Marino    to find the words. */
452*6b445a62SJohn Marino static int
_rl_copy_word_as_kill(count,dir)453*6b445a62SJohn Marino _rl_copy_word_as_kill (count, dir)
454*6b445a62SJohn Marino      int count, dir;
455*6b445a62SJohn Marino {
456*6b445a62SJohn Marino   int om, op, r;
457*6b445a62SJohn Marino 
458*6b445a62SJohn Marino   om = rl_mark;
459*6b445a62SJohn Marino   op = rl_point;
460*6b445a62SJohn Marino 
461*6b445a62SJohn Marino   if (dir > 0)
462*6b445a62SJohn Marino     rl_forward_word (count, 0);
463*6b445a62SJohn Marino   else
464*6b445a62SJohn Marino     rl_backward_word (count, 0);
465*6b445a62SJohn Marino 
466*6b445a62SJohn Marino   rl_mark = rl_point;
467*6b445a62SJohn Marino 
468*6b445a62SJohn Marino   if (dir > 0)
469*6b445a62SJohn Marino     rl_backward_word (count, 0);
470*6b445a62SJohn Marino   else
471*6b445a62SJohn Marino     rl_forward_word (count, 0);
472*6b445a62SJohn Marino 
473*6b445a62SJohn Marino   r = region_kill_internal (0);
474*6b445a62SJohn Marino 
475*6b445a62SJohn Marino   rl_mark = om;
476*6b445a62SJohn Marino   rl_point = op;
477*6b445a62SJohn Marino 
478*6b445a62SJohn Marino   return r;
479*6b445a62SJohn Marino }
480*6b445a62SJohn Marino 
481*6b445a62SJohn Marino int
rl_copy_forward_word(count,key)482*6b445a62SJohn Marino rl_copy_forward_word (count, key)
483*6b445a62SJohn Marino      int count, key;
484*6b445a62SJohn Marino {
485*6b445a62SJohn Marino   if (count < 0)
486*6b445a62SJohn Marino     return (rl_copy_backward_word (-count, key));
487*6b445a62SJohn Marino 
488*6b445a62SJohn Marino   return (_rl_copy_word_as_kill (count, 1));
489*6b445a62SJohn Marino }
490*6b445a62SJohn Marino 
491*6b445a62SJohn Marino int
rl_copy_backward_word(count,key)492*6b445a62SJohn Marino rl_copy_backward_word (count, key)
493*6b445a62SJohn Marino      int count, key;
494*6b445a62SJohn Marino {
495*6b445a62SJohn Marino   if (count < 0)
496*6b445a62SJohn Marino     return (rl_copy_forward_word (-count, key));
497*6b445a62SJohn Marino 
498*6b445a62SJohn Marino   return (_rl_copy_word_as_kill (count, -1));
499*6b445a62SJohn Marino }
500*6b445a62SJohn Marino 
501*6b445a62SJohn Marino /* Yank back the last killed text.  This ignores arguments. */
502*6b445a62SJohn Marino int
rl_yank(count,ignore)503*6b445a62SJohn Marino rl_yank (count, ignore)
504*6b445a62SJohn Marino      int count, ignore;
505*6b445a62SJohn Marino {
506*6b445a62SJohn Marino   if (rl_kill_ring == 0)
507*6b445a62SJohn Marino     {
508*6b445a62SJohn Marino       _rl_abort_internal ();
509*6b445a62SJohn Marino       return -1;
510*6b445a62SJohn Marino     }
511*6b445a62SJohn Marino 
512*6b445a62SJohn Marino   _rl_set_mark_at_pos (rl_point);
513*6b445a62SJohn Marino   rl_insert_text (rl_kill_ring[rl_kill_index]);
514*6b445a62SJohn Marino   return 0;
515*6b445a62SJohn Marino }
516*6b445a62SJohn Marino 
517*6b445a62SJohn Marino /* If the last command was yank, or yank_pop, and the text just
518*6b445a62SJohn Marino    before point is identical to the current kill item, then
519*6b445a62SJohn Marino    delete that text from the line, rotate the index down, and
520*6b445a62SJohn Marino    yank back some other text. */
521*6b445a62SJohn Marino int
rl_yank_pop(count,key)522*6b445a62SJohn Marino rl_yank_pop (count, key)
523*6b445a62SJohn Marino      int count, key;
524*6b445a62SJohn Marino {
525*6b445a62SJohn Marino   int l, n;
526*6b445a62SJohn Marino 
527*6b445a62SJohn Marino   if (((rl_last_func != rl_yank_pop) && (rl_last_func != rl_yank)) ||
528*6b445a62SJohn Marino       !rl_kill_ring)
529*6b445a62SJohn Marino     {
530*6b445a62SJohn Marino       _rl_abort_internal ();
531*6b445a62SJohn Marino       return -1;
532*6b445a62SJohn Marino     }
533*6b445a62SJohn Marino 
534*6b445a62SJohn Marino   l = strlen (rl_kill_ring[rl_kill_index]);
535*6b445a62SJohn Marino   n = rl_point - l;
536*6b445a62SJohn Marino   if (n >= 0 && STREQN (rl_line_buffer + n, rl_kill_ring[rl_kill_index], l))
537*6b445a62SJohn Marino     {
538*6b445a62SJohn Marino       rl_delete_text (n, rl_point);
539*6b445a62SJohn Marino       rl_point = n;
540*6b445a62SJohn Marino       rl_kill_index--;
541*6b445a62SJohn Marino       if (rl_kill_index < 0)
542*6b445a62SJohn Marino 	rl_kill_index = rl_kill_ring_length - 1;
543*6b445a62SJohn Marino       rl_yank (1, 0);
544*6b445a62SJohn Marino       return 0;
545*6b445a62SJohn Marino     }
546*6b445a62SJohn Marino   else
547*6b445a62SJohn Marino     {
548*6b445a62SJohn Marino       _rl_abort_internal ();
549*6b445a62SJohn Marino       return -1;
550*6b445a62SJohn Marino     }
551*6b445a62SJohn Marino }
552*6b445a62SJohn Marino 
553*6b445a62SJohn Marino /* Yank the COUNTh argument from the previous history line, skipping
554*6b445a62SJohn Marino    HISTORY_SKIP lines before looking for the `previous line'. */
555*6b445a62SJohn Marino static int
rl_yank_nth_arg_internal(count,ignore,history_skip)556*6b445a62SJohn Marino rl_yank_nth_arg_internal (count, ignore, history_skip)
557*6b445a62SJohn Marino      int count, ignore, history_skip;
558*6b445a62SJohn Marino {
559*6b445a62SJohn Marino   register HIST_ENTRY *entry;
560*6b445a62SJohn Marino   char *arg;
561*6b445a62SJohn Marino   int i, pos;
562*6b445a62SJohn Marino 
563*6b445a62SJohn Marino   pos = where_history ();
564*6b445a62SJohn Marino 
565*6b445a62SJohn Marino   if (history_skip)
566*6b445a62SJohn Marino     {
567*6b445a62SJohn Marino       for (i = 0; i < history_skip; i++)
568*6b445a62SJohn Marino 	entry = previous_history ();
569*6b445a62SJohn Marino     }
570*6b445a62SJohn Marino 
571*6b445a62SJohn Marino   entry = previous_history ();
572*6b445a62SJohn Marino 
573*6b445a62SJohn Marino   history_set_pos (pos);
574*6b445a62SJohn Marino 
575*6b445a62SJohn Marino   if (entry == 0)
576*6b445a62SJohn Marino     {
577*6b445a62SJohn Marino       rl_ding ();
578*6b445a62SJohn Marino       return -1;
579*6b445a62SJohn Marino     }
580*6b445a62SJohn Marino 
581*6b445a62SJohn Marino   arg = history_arg_extract (count, count, entry->line);
582*6b445a62SJohn Marino   if (!arg || !*arg)
583*6b445a62SJohn Marino     {
584*6b445a62SJohn Marino       rl_ding ();
585*6b445a62SJohn Marino       FREE (arg);
586*6b445a62SJohn Marino       return -1;
587*6b445a62SJohn Marino     }
588*6b445a62SJohn Marino 
589*6b445a62SJohn Marino   rl_begin_undo_group ();
590*6b445a62SJohn Marino 
591*6b445a62SJohn Marino   _rl_set_mark_at_pos (rl_point);
592*6b445a62SJohn Marino 
593*6b445a62SJohn Marino #if defined (VI_MODE)
594*6b445a62SJohn Marino   /* Vi mode always inserts a space before yanking the argument, and it
595*6b445a62SJohn Marino      inserts it right *after* rl_point. */
596*6b445a62SJohn Marino   if (rl_editing_mode == vi_mode)
597*6b445a62SJohn Marino     {
598*6b445a62SJohn Marino       rl_vi_append_mode (1, ignore);
599*6b445a62SJohn Marino       rl_insert_text (" ");
600*6b445a62SJohn Marino     }
601*6b445a62SJohn Marino #endif /* VI_MODE */
602*6b445a62SJohn Marino 
603*6b445a62SJohn Marino   rl_insert_text (arg);
604*6b445a62SJohn Marino   xfree (arg);
605*6b445a62SJohn Marino 
606*6b445a62SJohn Marino   rl_end_undo_group ();
607*6b445a62SJohn Marino   return 0;
608*6b445a62SJohn Marino }
609*6b445a62SJohn Marino 
610*6b445a62SJohn Marino /* Yank the COUNTth argument from the previous history line. */
611*6b445a62SJohn Marino int
rl_yank_nth_arg(count,ignore)612*6b445a62SJohn Marino rl_yank_nth_arg (count, ignore)
613*6b445a62SJohn Marino      int count, ignore;
614*6b445a62SJohn Marino {
615*6b445a62SJohn Marino   return (rl_yank_nth_arg_internal (count, ignore, 0));
616*6b445a62SJohn Marino }
617*6b445a62SJohn Marino 
618*6b445a62SJohn Marino /* Yank the last argument from the previous history line.  This `knows'
619*6b445a62SJohn Marino    how rl_yank_nth_arg treats a count of `$'.  With an argument, this
620*6b445a62SJohn Marino    behaves the same as rl_yank_nth_arg. */
621*6b445a62SJohn Marino int
rl_yank_last_arg(count,key)622*6b445a62SJohn Marino rl_yank_last_arg (count, key)
623*6b445a62SJohn Marino      int count, key;
624*6b445a62SJohn Marino {
625*6b445a62SJohn Marino   static int history_skip = 0;
626*6b445a62SJohn Marino   static int explicit_arg_p = 0;
627*6b445a62SJohn Marino   static int count_passed = 1;
628*6b445a62SJohn Marino   static int direction = 1;
629*6b445a62SJohn Marino   static int undo_needed = 0;
630*6b445a62SJohn Marino   int retval;
631*6b445a62SJohn Marino 
632*6b445a62SJohn Marino   if (rl_last_func != rl_yank_last_arg)
633*6b445a62SJohn Marino     {
634*6b445a62SJohn Marino       history_skip = 0;
635*6b445a62SJohn Marino       explicit_arg_p = rl_explicit_arg;
636*6b445a62SJohn Marino       count_passed = count;
637*6b445a62SJohn Marino       direction = 1;
638*6b445a62SJohn Marino     }
639*6b445a62SJohn Marino   else
640*6b445a62SJohn Marino     {
641*6b445a62SJohn Marino       if (undo_needed)
642*6b445a62SJohn Marino 	rl_do_undo ();
643*6b445a62SJohn Marino       if (count < 0)		/* XXX - was < 1 */
644*6b445a62SJohn Marino         direction = -direction;
645*6b445a62SJohn Marino       history_skip += direction;
646*6b445a62SJohn Marino       if (history_skip < 0)
647*6b445a62SJohn Marino 	history_skip = 0;
648*6b445a62SJohn Marino     }
649*6b445a62SJohn Marino 
650*6b445a62SJohn Marino   if (explicit_arg_p)
651*6b445a62SJohn Marino     retval = rl_yank_nth_arg_internal (count_passed, key, history_skip);
652*6b445a62SJohn Marino   else
653*6b445a62SJohn Marino     retval = rl_yank_nth_arg_internal ('$', key, history_skip);
654*6b445a62SJohn Marino 
655*6b445a62SJohn Marino   undo_needed = retval == 0;
656*6b445a62SJohn Marino   return retval;
657*6b445a62SJohn Marino }
658*6b445a62SJohn Marino 
659*6b445a62SJohn Marino /* A special paste command for users of Cygnus's cygwin32. */
660*6b445a62SJohn Marino #if defined (__CYGWIN__)
661*6b445a62SJohn Marino #include <windows.h>
662*6b445a62SJohn Marino 
663*6b445a62SJohn Marino int
rl_paste_from_clipboard(count,key)664*6b445a62SJohn Marino rl_paste_from_clipboard (count, key)
665*6b445a62SJohn Marino      int count, key;
666*6b445a62SJohn Marino {
667*6b445a62SJohn Marino   char *data, *ptr;
668*6b445a62SJohn Marino   int len;
669*6b445a62SJohn Marino 
670*6b445a62SJohn Marino   if (OpenClipboard (NULL) == 0)
671*6b445a62SJohn Marino     return (0);
672*6b445a62SJohn Marino 
673*6b445a62SJohn Marino   data = (char *)GetClipboardData (CF_TEXT);
674*6b445a62SJohn Marino   if (data)
675*6b445a62SJohn Marino     {
676*6b445a62SJohn Marino       ptr = strchr (data, '\r');
677*6b445a62SJohn Marino       if (ptr)
678*6b445a62SJohn Marino 	{
679*6b445a62SJohn Marino 	  len = ptr - data;
680*6b445a62SJohn Marino 	  ptr = (char *)xmalloc (len + 1);
681*6b445a62SJohn Marino 	  ptr[len] = '\0';
682*6b445a62SJohn Marino 	  strncpy (ptr, data, len);
683*6b445a62SJohn Marino 	}
684*6b445a62SJohn Marino       else
685*6b445a62SJohn Marino         ptr = data;
686*6b445a62SJohn Marino       _rl_set_mark_at_pos (rl_point);
687*6b445a62SJohn Marino       rl_insert_text (ptr);
688*6b445a62SJohn Marino       if (ptr != data)
689*6b445a62SJohn Marino 	xfree (ptr);
690*6b445a62SJohn Marino       CloseClipboard ();
691*6b445a62SJohn Marino     }
692*6b445a62SJohn Marino   return (0);
693*6b445a62SJohn Marino }
694*6b445a62SJohn Marino #endif /* __CYGWIN__ */
695