1994-05-09 15:59:10 +00:00
|
|
|
|
/* keymaps.c -- Functions and keymaps for the GNU Readline library. */
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
/* Copyright (C) 1988,1989 Free Software Foundation, Inc.
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
|
|
|
|
This file is part of GNU Readline, a library for reading lines
|
|
|
|
|
of text with interactive input and history editing.
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
Readline 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 1, or (at your option) any
|
|
|
|
|
later version.
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
Readline is distributed in the hope that it will be useful, but
|
|
|
|
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
General Public License for more details.
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
1994-05-09 23:24:44 +00:00
|
|
|
|
along with Readline; see the file COPYING. If not, write to the Free
|
|
|
|
|
Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
|
1994-12-06 03:16:45 +00:00
|
|
|
|
#define READLINE_LIBRARY
|
1994-05-09 23:24:44 +00:00
|
|
|
|
|
1994-12-12 03:23:04 +00:00
|
|
|
|
#if defined (HAVE_CONFIG_H)
|
|
|
|
|
# include "config.h"
|
|
|
|
|
#endif
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
#if defined (HAVE_STDLIB_H)
|
|
|
|
|
# include <stdlib.h>
|
|
|
|
|
#else
|
|
|
|
|
# include "ansi_stdlib.h"
|
|
|
|
|
#endif /* HAVE_STDLIB_H */
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
1994-05-13 15:48:04 +00:00
|
|
|
|
#include "rlconf.h"
|
1994-12-06 03:16:45 +00:00
|
|
|
|
#include "keymaps.h"
|
1994-05-09 15:59:10 +00:00
|
|
|
|
#include "emacs_keymap.c"
|
|
|
|
|
|
1994-12-06 03:16:45 +00:00
|
|
|
|
#if defined (VI_MODE)
|
1994-05-09 15:59:10 +00:00
|
|
|
|
#include "vi_keymap.c"
|
|
|
|
|
#endif
|
|
|
|
|
|
1994-05-13 15:48:04 +00:00
|
|
|
|
extern int rl_do_lowercase_version ();
|
|
|
|
|
extern int rl_rubout (), rl_insert ();
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
#if defined (STATIC_MALLOC)
|
1994-05-09 15:59:10 +00:00
|
|
|
|
static char *xmalloc (), *xrealloc ();
|
1994-05-09 23:24:44 +00:00
|
|
|
|
#else
|
|
|
|
|
extern char *xmalloc (), *xrealloc ();
|
1994-05-09 20:36:08 +00:00
|
|
|
|
#endif /* STATIC_MALLOC */
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
|
|
|
|
/* **************************************************************** */
|
|
|
|
|
/* */
|
|
|
|
|
/* Functions for manipulating Keymaps. */
|
|
|
|
|
/* */
|
|
|
|
|
/* **************************************************************** */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Return a new, empty keymap.
|
|
|
|
|
Free it with free() when you are done. */
|
|
|
|
|
Keymap
|
|
|
|
|
rl_make_bare_keymap ()
|
|
|
|
|
{
|
|
|
|
|
register int i;
|
1994-05-09 23:24:44 +00:00
|
|
|
|
Keymap keymap = (Keymap)xmalloc (KEYMAP_SIZE * sizeof (KEYMAP_ENTRY));
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
for (i = 0; i < KEYMAP_SIZE; i++)
|
1994-05-09 15:59:10 +00:00
|
|
|
|
{
|
|
|
|
|
keymap[i].type = ISFUNC;
|
|
|
|
|
keymap[i].function = (Function *)NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (i = 'A'; i < ('Z' + 1); i++)
|
|
|
|
|
{
|
|
|
|
|
keymap[i].type = ISFUNC;
|
|
|
|
|
keymap[i].function = rl_do_lowercase_version;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return (keymap);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Return a new keymap which is a copy of MAP. */
|
|
|
|
|
Keymap
|
|
|
|
|
rl_copy_keymap (map)
|
|
|
|
|
Keymap map;
|
|
|
|
|
{
|
|
|
|
|
register int i;
|
|
|
|
|
Keymap temp = rl_make_bare_keymap ();
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
for (i = 0; i < KEYMAP_SIZE; i++)
|
1994-05-09 15:59:10 +00:00
|
|
|
|
{
|
|
|
|
|
temp[i].type = map[i].type;
|
|
|
|
|
temp[i].function = map[i].function;
|
|
|
|
|
}
|
|
|
|
|
return (temp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Return a new keymap with the printing characters bound to rl_insert,
|
|
|
|
|
the uppercase Meta characters bound to run their lowercase equivalents,
|
|
|
|
|
and the Meta digits bound to produce numeric arguments. */
|
|
|
|
|
Keymap
|
|
|
|
|
rl_make_keymap ()
|
|
|
|
|
{
|
|
|
|
|
register int i;
|
|
|
|
|
Keymap newmap;
|
|
|
|
|
|
|
|
|
|
newmap = rl_make_bare_keymap ();
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
/* All ASCII printing characters are self-inserting. */
|
1994-12-12 03:23:04 +00:00
|
|
|
|
for (i = ' '; i < 127; i++)
|
1994-05-09 15:59:10 +00:00
|
|
|
|
newmap[i].function = rl_insert;
|
|
|
|
|
|
|
|
|
|
newmap[TAB].function = rl_insert;
|
|
|
|
|
newmap[RUBOUT].function = rl_rubout;
|
|
|
|
|
newmap[CTRL('H')].function = rl_rubout;
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
#if KEYMAP_SIZE > 128
|
|
|
|
|
/* Printing characters in some 8-bit character sets. */
|
|
|
|
|
for (i = 128; i < 160; i++)
|
|
|
|
|
newmap[i].function = rl_insert;
|
|
|
|
|
|
|
|
|
|
/* ISO Latin-1 printing characters should self-insert. */
|
|
|
|
|
for (i = 160; i < 256; i++)
|
|
|
|
|
newmap[i].function = rl_insert;
|
|
|
|
|
#endif /* KEYMAP_SIZE > 128 */
|
|
|
|
|
|
1994-05-09 15:59:10 +00:00
|
|
|
|
return (newmap);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Free the storage associated with MAP. */
|
1994-05-13 15:48:04 +00:00
|
|
|
|
void
|
1994-05-09 15:59:10 +00:00
|
|
|
|
rl_discard_keymap (map)
|
|
|
|
|
Keymap (map);
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
if (!map)
|
|
|
|
|
return;
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
for (i = 0; i < KEYMAP_SIZE; i++)
|
1994-05-09 15:59:10 +00:00
|
|
|
|
{
|
|
|
|
|
switch (map[i].type)
|
|
|
|
|
{
|
|
|
|
|
case ISFUNC:
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case ISKMAP:
|
|
|
|
|
rl_discard_keymap ((Keymap)map[i].function);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case ISMACR:
|
|
|
|
|
free ((char *)map[i].function);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
1994-05-09 23:24:44 +00:00
|
|
|
|
#if defined (STATIC_MALLOC)
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
|
|
|
|
/* **************************************************************** */
|
|
|
|
|
/* */
|
|
|
|
|
/* xmalloc and xrealloc () */
|
|
|
|
|
/* */
|
|
|
|
|
/* **************************************************************** */
|
|
|
|
|
|
|
|
|
|
static void memory_error_and_abort ();
|
|
|
|
|
|
|
|
|
|
static char *
|
|
|
|
|
xmalloc (bytes)
|
|
|
|
|
int bytes;
|
|
|
|
|
{
|
|
|
|
|
char *temp = (char *)malloc (bytes);
|
|
|
|
|
|
|
|
|
|
if (!temp)
|
|
|
|
|
memory_error_and_abort ();
|
|
|
|
|
return (temp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static char *
|
|
|
|
|
xrealloc (pointer, bytes)
|
|
|
|
|
char *pointer;
|
|
|
|
|
int bytes;
|
|
|
|
|
{
|
1994-05-09 20:36:08 +00:00
|
|
|
|
char *temp;
|
|
|
|
|
|
|
|
|
|
if (!pointer)
|
|
|
|
|
temp = (char *)malloc (bytes);
|
|
|
|
|
else
|
|
|
|
|
temp = (char *)realloc (pointer, bytes);
|
1994-05-09 15:59:10 +00:00
|
|
|
|
|
|
|
|
|
if (!temp)
|
|
|
|
|
memory_error_and_abort ();
|
|
|
|
|
return (temp);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
memory_error_and_abort ()
|
|
|
|
|
{
|
|
|
|
|
fprintf (stderr, "readline: Out of virtual memory!\n");
|
|
|
|
|
abort ();
|
|
|
|
|
}
|
|
|
|
|
#endif /* STATIC_MALLOC */
|