1 ;; internal.el -- setup support for PC keyboards and screens, internal terminal
3 ;; Copyright (C) 1993, 1994 Free Software Foundation, Inc.
5 ;; Author: Morten Welinder <terra@diku.dk>
8 ;; This file is part of GNU Emacs.
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
11 ;; it under the terms of the GNU General Public License as published by
12 ;; the Free Software Foundation; either version 2, or (at your option)
15 ;; GNU Emacs is distributed in the hope that it will be useful,
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 ;; GNU General Public License for more details.
20 ;; You should have received a copy of the GNU General Public License
21 ;; along with GNU Emacs; see the file COPYING. If not, write to
22 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
23 ;; ---------------------------------------------------------------------------
24 ;; screen setup -- that's easy!
25 (standard-display-8bit 127 254)
26 ;; ---------------------------------------------------------------------------
27 ;; keyboard setup -- that's simple!
28 (set-input-mode nil nil 0)
29 (define-key function-key-map [backspace] "\177") ; Normal behavior for BS
30 (define-key function-key-map [delete] "\C-d") ; ... and Delete
31 (define-key function-key-map [tab] [?\t])
32 (define-key function-key-map [linefeed] [?\n])
33 (define-key function-key-map [clear] [11])
34 (define-key function-key-map [return] [13])
35 (define-key function-key-map [escape] [?\e])
36 (define-key function-key-map [M-backspace] [?\M-\d])
37 (define-key function-key-map [M-delete] [?\M-\d])
38 (define-key function-key-map [M-tab] [?\M-\t])
39 (define-key function-key-map [M-linefeed] [?\M-\n])
40 (define-key function-key-map [M-clear] [?\M-\013])
41 (define-key function-key-map [M-return] [?\M-\015])
42 (define-key function-key-map [M-escape] [?\M-\e])
44 ;; ---------------------------------------------------------------------------
45 ;; We want to do this when Emacs is started because it depends on the
50 (modify-syntax-entry ch sy text-mode-syntax-table)
51 (if (boundp 'tex-mode-syntax-table)
52 (modify-syntax-entry ch sy tex-mode-syntax-table))
53 (modify-syntax-entry ch sy (standard-syntax-table))
55 (table (standard-case-table))
56 ;; The following are strings of letters, first lower then upper case.
57 ;; This will look funny on terminals which display other code pages.
61 "
\87\80\81\9a\82\90\83¶
\84\8e\85·
\86\8fÆÇ µ
\88Ò
\89Ó
\8aÔ
\8bØ
\8c×
\8dÞ¡Ö
\91\92\93â
\94\99\95ã¢à
\9b\9d\96ê£é
\97ë
\98Yìí¡I£é¤¥ÐÑçè")
63 "
\87\80\81\9a\82\90\83A
\84\8e\85A
\86\8f\88E
\89E
\8aE
\8bI
\8cI
\8dI
\91\92\93O
\94\99\95O
\96U£U
\98Y
\9b\9d A¡I¢O£U¤¥")
65 (t "
\87\80\81\9a\82\90\83A
\84\8e\85A
\86\8f\88E
\89E
\8aE
\8bI
\8cI
\8dI
\91\92\93O
\94\99\95O
\96U£U
\98Y A¡I¢O£U¤¥"))))
68 (funcall modify i "_")
72 (while (< i (length chars))
73 (let ((ch1 (aref chars i))
74 (ch2 (aref chars (1+ i))))
76 (set-case-syntax-pair ch2 ch1 table))
79 (mapcar (lambda (b) (set-buffer b) (set-case-table table))
81 (set-standard-case-table table))