|
|
1.1 ! root 1: /* keymaps.h -- Manipulation of readline keymaps. */ ! 2: ! 3: #ifndef _KEYMAPS_H_ ! 4: #define _KEYMAPS_H_ ! 5: ! 6: #include "chardefs.h" ! 7: ! 8: #ifndef __FUNCTION_DEF ! 9: typedef int Function (); ! 10: #define __FUNCTION_DEF ! 11: #endif ! 12: ! 13: /* A keymap contains one entry for each key in the ASCII set. ! 14: Each entry consists of a type and a pointer. ! 15: POINTER is the address of a function to run, or the ! 16: address of a keymap to indirect through. ! 17: TYPE says which kind of thing POINTER is. */ ! 18: typedef struct _keymap_entry { ! 19: char type; ! 20: Function *function; ! 21: } KEYMAP_ENTRY; ! 22: ! 23: /* I wanted to make the above structure contain a union of: ! 24: union { Function *function; struct _keymap_entry *keymap; } value; ! 25: but this made it impossible for me to create a static array. ! 26: Maybe I need C lessons. */ ! 27: ! 28: typedef KEYMAP_ENTRY KEYMAP_ENTRY_ARRAY[128]; ! 29: typedef KEYMAP_ENTRY *Keymap; ! 30: ! 31: /* The values that TYPE can have in a keymap entry. */ ! 32: #define ISFUNC 0 ! 33: #define ISKMAP 1 ! 34: #define ISMACR 2 ! 35: ! 36: extern KEYMAP_ENTRY_ARRAY emacs_standard_keymap, emacs_meta_keymap, emacs_ctlx_keymap; ! 37: extern KEYMAP_ENTRY_ARRAY vi_insertion_keymap, vi_movement_keymap; ! 38: ! 39: /* Return a new, empty keymap. ! 40: Free it with free() when you are done. */ ! 41: Keymap rl_make_bare_keymap (); ! 42: ! 43: /* Return a new keymap which is a copy of MAP. */ ! 44: Keymap rl_copy_keymap (); ! 45: ! 46: /* Return a new keymap with the printing characters bound to rl_insert, ! 47: the lowercase Meta characters bound to run their equivalents, and ! 48: the Meta digits bound to produce numeric arguments. */ ! 49: Keymap rl_make_keymap (); ! 50: ! 51: #endif /* _KEYMAPS_H_ */
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.