iso-insert.el 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631
  1. ;;; iso-insert.el --- insert functions for ISO 8859/1 -*- coding: iso-8859-1;-*-
  2. ;; Copyright (C) 1987, 1994, 2001-2012 Free Software Foundation, Inc.
  3. ;; Author: Howard Gayle
  4. ;; Maintainer: FSF
  5. ;; Keywords: i18n
  6. ;; Obsolete-since: 22.1
  7. ;; This file is part of GNU Emacs.
  8. ;; GNU Emacs is free software: you can redistribute it and/or modify
  9. ;; it under the terms of the GNU General Public License as published by
  10. ;; the Free Software Foundation, either version 3 of the License, or
  11. ;; (at your option) any later version.
  12. ;; GNU Emacs is distributed in the hope that it will be useful,
  13. ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. ;; GNU General Public License for more details.
  16. ;; You should have received a copy of the GNU General Public License
  17. ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
  18. ;;; Commentary:
  19. ;; Provides keys for inserting ISO Latin-1 characters. They use the
  20. ;; prefix key C-x 8. Type C-x 8 C-h for a list.
  21. ;;; Code:
  22. (defun insert-no-break-space ()
  23. (interactive "*")
  24. (insert ?\ )
  25. )
  26. (defun insert-inverted-exclamation-mark ()
  27. (interactive "*")
  28. (insert ?\¡)
  29. )
  30. (defun insert-cent-sign ()
  31. (interactive "*")
  32. (insert ?\¢)
  33. )
  34. (defun insert-pound-sign ()
  35. (interactive "*")
  36. (insert ?\£)
  37. )
  38. (defun insert-general-currency-sign ()
  39. (interactive "*")
  40. (insert ?\¤)
  41. )
  42. (defun insert-yen-sign ()
  43. (interactive "*")
  44. (insert ?\¥)
  45. )
  46. (defun insert-broken-vertical-line ()
  47. (interactive "*")
  48. (insert ?\¦)
  49. )
  50. (defun insert-section-sign ()
  51. (interactive "*")
  52. (insert ?\§)
  53. )
  54. (defun insert-diaeresis ()
  55. (interactive "*")
  56. (insert ?\¨)
  57. )
  58. (defun insert-copyright-sign ()
  59. (interactive "*")
  60. (insert ?\©)
  61. )
  62. (defun insert-ordinal-indicator-feminine ()
  63. (interactive "*")
  64. (insert ?\ª)
  65. )
  66. (defun insert-angle-quotation-mark-left ()
  67. (interactive "*")
  68. (insert ?\«)
  69. )
  70. (defun insert-not-sign ()
  71. (interactive "*")
  72. (insert ?\¬)
  73. )
  74. (defun insert-soft-hyphen ()
  75. (interactive "*")
  76. (insert ?\­)
  77. )
  78. (defun insert-registered-sign ()
  79. (interactive "*")
  80. (insert ?\®)
  81. )
  82. (defun insert-macron ()
  83. (interactive "*")
  84. (insert ?\¯)
  85. )
  86. (defun insert-degree-sign ()
  87. (interactive "*")
  88. (insert ?\°)
  89. )
  90. (defun insert-plus-or-minus-sign ()
  91. (interactive "*")
  92. (insert ?\±)
  93. )
  94. (defun insert-superscript-two ()
  95. (interactive "*")
  96. (insert ?\²)
  97. )
  98. (defun insert-superscript-three ()
  99. (interactive "*")
  100. (insert ?\³)
  101. )
  102. (defun insert-acute-accent ()
  103. (interactive "*")
  104. (insert ?\´)
  105. )
  106. (defun insert-micro-sign ()
  107. (interactive "*")
  108. (insert ?\µ)
  109. )
  110. (defun insert-pilcrow ()
  111. (interactive "*")
  112. (insert ?\¶)
  113. )
  114. (defun insert-middle-dot ()
  115. (interactive "*")
  116. (insert ?\·)
  117. )
  118. (defun insert-cedilla ()
  119. (interactive "*")
  120. (insert ?\¸)
  121. )
  122. (defun insert-superscript-one ()
  123. (interactive "*")
  124. (insert ?\¹)
  125. )
  126. (defun insert-ordinal-indicator-masculine ()
  127. (interactive "*")
  128. (insert ?\º)
  129. )
  130. (defun insert-angle-quotation-mark-right ()
  131. (interactive "*")
  132. (insert ?\»)
  133. )
  134. (defun insert-fraction-one-quarter ()
  135. (interactive "*")
  136. (insert ?\¼)
  137. )
  138. (defun insert-fraction-one-half ()
  139. (interactive "*")
  140. (insert ?\½)
  141. )
  142. (defun insert-fraction-three-quarters ()
  143. (interactive "*")
  144. (insert ?\¾)
  145. )
  146. (defun insert-inverted-question-mark ()
  147. (interactive "*")
  148. (insert ?\¿)
  149. )
  150. (defun insert-A-grave ()
  151. (interactive "*")
  152. (insert ?\À)
  153. )
  154. (defun insert-A-acute ()
  155. (interactive "*")
  156. (insert ?\Á)
  157. )
  158. (defun insert-A-circumflex ()
  159. (interactive "*")
  160. (insert ?\Â)
  161. )
  162. (defun insert-A-tilde ()
  163. (interactive "*")
  164. (insert ?\Ã)
  165. )
  166. (defun insert-A-umlaut ()
  167. (interactive "*")
  168. (insert ?\Ä)
  169. )
  170. (defun insert-A-ring ()
  171. (interactive "*")
  172. (insert ?\Å)
  173. )
  174. (defun insert-AE ()
  175. (interactive "*")
  176. (insert ?\Æ)
  177. )
  178. (defun insert-C-cedilla ()
  179. (interactive "*")
  180. (insert ?\Ç)
  181. )
  182. (defun insert-E-grave ()
  183. (interactive "*")
  184. (insert ?\È)
  185. )
  186. (defun insert-E-acute ()
  187. (interactive "*")
  188. (insert ?\É)
  189. )
  190. (defun insert-E-circumflex ()
  191. (interactive "*")
  192. (insert ?\Ê)
  193. )
  194. (defun insert-E-umlaut ()
  195. (interactive "*")
  196. (insert ?\Ë)
  197. )
  198. (defun insert-I-grave ()
  199. (interactive "*")
  200. (insert ?\Ì)
  201. )
  202. (defun insert-I-acute ()
  203. (interactive "*")
  204. (insert ?\Í)
  205. )
  206. (defun insert-I-circumflex ()
  207. (interactive "*")
  208. (insert ?\Î)
  209. )
  210. (defun insert-I-umlaut ()
  211. (interactive "*")
  212. (insert ?\Ï)
  213. )
  214. (defun insert-D-stroke ()
  215. (interactive "*")
  216. (insert ?\Ð)
  217. )
  218. (defun insert-N-tilde ()
  219. (interactive "*")
  220. (insert ?\Ñ)
  221. )
  222. (defun insert-O-grave ()
  223. (interactive "*")
  224. (insert ?\Ò)
  225. )
  226. (defun insert-O-acute ()
  227. (interactive "*")
  228. (insert ?\Ó)
  229. )
  230. (defun insert-O-circumflex ()
  231. (interactive "*")
  232. (insert ?\Ô)
  233. )
  234. (defun insert-O-tilde ()
  235. (interactive "*")
  236. (insert ?\Õ)
  237. )
  238. (defun insert-O-umlaut ()
  239. (interactive "*")
  240. (insert ?\Ö)
  241. )
  242. (defun insert-multiplication-sign ()
  243. (interactive "*")
  244. (insert ?\×)
  245. )
  246. (defun insert-O-slash ()
  247. (interactive "*")
  248. (insert ?\Ø)
  249. )
  250. (defun insert-U-grave ()
  251. (interactive "*")
  252. (insert ?\Ù)
  253. )
  254. (defun insert-U-acute ()
  255. (interactive "*")
  256. (insert ?\Ú)
  257. )
  258. (defun insert-U-circumflex ()
  259. (interactive "*")
  260. (insert ?\Û)
  261. )
  262. (defun insert-U-umlaut ()
  263. (interactive "*")
  264. (insert ?\Ü)
  265. )
  266. (defun insert-Y-acute ()
  267. (interactive "*")
  268. (insert ?\Ý)
  269. )
  270. (defun insert-THORN ()
  271. (interactive "*")
  272. (insert ?\Þ)
  273. )
  274. (defun insert-ss ()
  275. (interactive "*")
  276. (insert ?\ß)
  277. )
  278. (defun insert-a-grave ()
  279. (interactive "*")
  280. (insert ?\à)
  281. )
  282. (defun insert-a-acute ()
  283. (interactive "*")
  284. (insert ?\á)
  285. )
  286. (defun insert-a-circumflex ()
  287. (interactive "*")
  288. (insert ?\â)
  289. )
  290. (defun insert-a-tilde ()
  291. (interactive "*")
  292. (insert ?\ã)
  293. )
  294. (defun insert-a-umlaut ()
  295. (interactive "*")
  296. (insert ?\ä)
  297. )
  298. (defun insert-a-ring ()
  299. (interactive "*")
  300. (insert ?\å)
  301. )
  302. (defun insert-ae ()
  303. (interactive "*")
  304. (insert ?\æ)
  305. )
  306. (defun insert-c-cedilla ()
  307. (interactive "*")
  308. (insert ?\ç)
  309. )
  310. (defun insert-e-grave ()
  311. (interactive "*")
  312. (insert ?\è)
  313. )
  314. (defun insert-e-acute ()
  315. (interactive "*")
  316. (insert ?\é)
  317. )
  318. (defun insert-e-circumflex ()
  319. (interactive "*")
  320. (insert ?\ê)
  321. )
  322. (defun insert-e-umlaut ()
  323. (interactive "*")
  324. (insert ?\ë)
  325. )
  326. (defun insert-i-grave ()
  327. (interactive "*")
  328. (insert ?\ì)
  329. )
  330. (defun insert-i-acute ()
  331. (interactive "*")
  332. (insert ?\í)
  333. )
  334. (defun insert-i-circumflex ()
  335. (interactive "*")
  336. (insert ?\î)
  337. )
  338. (defun insert-i-umlaut ()
  339. (interactive "*")
  340. (insert ?\ï)
  341. )
  342. (defun insert-d-stroke ()
  343. (interactive "*")
  344. (insert ?\ð)
  345. )
  346. (defun insert-n-tilde ()
  347. (interactive "*")
  348. (insert ?\ñ)
  349. )
  350. (defun insert-o-grave ()
  351. (interactive "*")
  352. (insert ?\ò)
  353. )
  354. (defun insert-o-acute ()
  355. (interactive "*")
  356. (insert ?\ó)
  357. )
  358. (defun insert-o-circumflex ()
  359. (interactive "*")
  360. (insert ?\ô)
  361. )
  362. (defun insert-o-tilde ()
  363. (interactive "*")
  364. (insert ?\õ)
  365. )
  366. (defun insert-o-umlaut ()
  367. (interactive "*")
  368. (insert ?\ö)
  369. )
  370. (defun insert-division-sign ()
  371. (interactive "*")
  372. (insert ?\÷)
  373. )
  374. (defun insert-o-slash ()
  375. (interactive "*")
  376. (insert ?\ø)
  377. )
  378. (defun insert-u-grave ()
  379. (interactive "*")
  380. (insert ?\ù)
  381. )
  382. (defun insert-u-acute ()
  383. (interactive "*")
  384. (insert ?\ú)
  385. )
  386. (defun insert-u-circumflex ()
  387. (interactive "*")
  388. (insert ?\û)
  389. )
  390. (defun insert-u-umlaut ()
  391. (interactive "*")
  392. (insert ?\ü)
  393. )
  394. (defun insert-y-acute ()
  395. (interactive "*")
  396. (insert ?\ý)
  397. )
  398. (defun insert-thorn ()
  399. (interactive "*")
  400. (insert ?\þ)
  401. )
  402. (defun insert-y-umlaut ()
  403. (interactive "*")
  404. (insert ?\ÿ)
  405. )
  406. (defvar 8859-1-map nil "Keymap for ISO 8859/1 character insertion.")
  407. (if 8859-1-map nil
  408. (setq 8859-1-map (make-keymap))
  409. (define-key 8859-1-map " " 'insert-no-break-space)
  410. (define-key 8859-1-map "!" 'insert-inverted-exclamation-mark)
  411. (define-key 8859-1-map "\"" (make-sparse-keymap))
  412. (define-key 8859-1-map "\"\"" 'insert-diaeresis)
  413. (define-key 8859-1-map "\"A" 'insert-A-umlaut)
  414. (define-key 8859-1-map "\"E" 'insert-E-umlaut)
  415. (define-key 8859-1-map "\"I" 'insert-I-umlaut)
  416. (define-key 8859-1-map "\"O" 'insert-O-umlaut)
  417. (define-key 8859-1-map "\"U" 'insert-U-umlaut)
  418. (define-key 8859-1-map "\"a" 'insert-a-umlaut)
  419. (define-key 8859-1-map "\"e" 'insert-e-umlaut)
  420. (define-key 8859-1-map "\"i" 'insert-i-umlaut)
  421. (define-key 8859-1-map "\"o" 'insert-o-umlaut)
  422. (define-key 8859-1-map "\"u" 'insert-u-umlaut)
  423. (define-key 8859-1-map "\"y" 'insert-y-umlaut)
  424. (define-key 8859-1-map "'" (make-sparse-keymap))
  425. (define-key 8859-1-map "''" 'insert-acute-accent)
  426. (define-key 8859-1-map "'A" 'insert-A-acute)
  427. (define-key 8859-1-map "'E" 'insert-E-acute)
  428. (define-key 8859-1-map "'I" 'insert-I-acute)
  429. (define-key 8859-1-map "'O" 'insert-O-acute)
  430. (define-key 8859-1-map "'U" 'insert-U-acute)
  431. (define-key 8859-1-map "'Y" 'insert-Y-acute)
  432. (define-key 8859-1-map "'a" 'insert-a-acute)
  433. (define-key 8859-1-map "'e" 'insert-e-acute)
  434. (define-key 8859-1-map "'i" 'insert-i-acute)
  435. (define-key 8859-1-map "'o" 'insert-o-acute)
  436. (define-key 8859-1-map "'u" 'insert-u-acute)
  437. (define-key 8859-1-map "'y" 'insert-y-acute)
  438. (define-key 8859-1-map "$" 'insert-general-currency-sign)
  439. (define-key 8859-1-map "+" 'insert-plus-or-minus-sign)
  440. (define-key 8859-1-map "," (make-sparse-keymap))
  441. (define-key 8859-1-map ",," 'insert-cedilla)
  442. (define-key 8859-1-map ",C" 'insert-C-cedilla)
  443. (define-key 8859-1-map ",c" 'insert-c-cedilla)
  444. (define-key 8859-1-map "-" 'insert-soft-hyphen)
  445. (define-key 8859-1-map "." 'insert-middle-dot)
  446. (define-key 8859-1-map "/" (make-sparse-keymap))
  447. (define-key 8859-1-map "//" 'insert-division-sign)
  448. (define-key 8859-1-map "/O" 'insert-O-slash)
  449. (define-key 8859-1-map "/o" 'insert-o-slash)
  450. (define-key 8859-1-map "1" (make-sparse-keymap))
  451. (define-key 8859-1-map "1/" (make-sparse-keymap))
  452. (define-key 8859-1-map "1/2" 'insert-fraction-one-half)
  453. (define-key 8859-1-map "1/4" 'insert-fraction-one-quarter)
  454. (define-key 8859-1-map "3" (make-sparse-keymap))
  455. (define-key 8859-1-map "3/" (make-sparse-keymap))
  456. (define-key 8859-1-map "3/4" 'insert-fraction-three-quarters)
  457. (define-key 8859-1-map "<" 'insert-angle-quotation-mark-left)
  458. (define-key 8859-1-map "=" 'insert-macron)
  459. (define-key 8859-1-map ">" 'insert-angle-quotation-mark-right)
  460. (define-key 8859-1-map "?" 'insert-inverted-question-mark)
  461. (define-key 8859-1-map "A" 'insert-A-ring)
  462. (define-key 8859-1-map "E" 'insert-AE)
  463. (define-key 8859-1-map "C" 'insert-copyright-sign)
  464. (define-key 8859-1-map "D" 'insert-D-stroke)
  465. (define-key 8859-1-map "L" 'insert-pound-sign)
  466. (define-key 8859-1-map "P" 'insert-pilcrow)
  467. (define-key 8859-1-map "R" 'insert-registered-sign)
  468. (define-key 8859-1-map "S" 'insert-section-sign)
  469. (define-key 8859-1-map "T" 'insert-THORN)
  470. (define-key 8859-1-map "Y" 'insert-yen-sign)
  471. (define-key 8859-1-map "^" (make-sparse-keymap))
  472. (define-key 8859-1-map "^1" 'insert-superscript-one)
  473. (define-key 8859-1-map "^2" 'insert-superscript-two)
  474. (define-key 8859-1-map "^3" 'insert-superscript-three)
  475. (define-key 8859-1-map "^A" 'insert-A-circumflex)
  476. (define-key 8859-1-map "^E" 'insert-E-circumflex)
  477. (define-key 8859-1-map "^I" 'insert-I-circumflex)
  478. (define-key 8859-1-map "^O" 'insert-O-circumflex)
  479. (define-key 8859-1-map "^U" 'insert-U-circumflex)
  480. (define-key 8859-1-map "^a" 'insert-a-circumflex)
  481. (define-key 8859-1-map "^e" 'insert-e-circumflex)
  482. (define-key 8859-1-map "^i" 'insert-i-circumflex)
  483. (define-key 8859-1-map "^o" 'insert-o-circumflex)
  484. (define-key 8859-1-map "^u" 'insert-u-circumflex)
  485. (define-key 8859-1-map "_" (make-sparse-keymap))
  486. (define-key 8859-1-map "_a" 'insert-ordinal-indicator-feminine)
  487. (define-key 8859-1-map "_o" 'insert-ordinal-indicator-masculine)
  488. (define-key 8859-1-map "`" (make-sparse-keymap))
  489. (define-key 8859-1-map "`A" 'insert-A-grave)
  490. (define-key 8859-1-map "`E" 'insert-E-grave)
  491. (define-key 8859-1-map "`I" 'insert-I-grave)
  492. (define-key 8859-1-map "`O" 'insert-O-grave)
  493. (define-key 8859-1-map "`U" 'insert-U-grave)
  494. (define-key 8859-1-map "`a" 'insert-a-grave)
  495. (define-key 8859-1-map "`e" 'insert-e-grave)
  496. (define-key 8859-1-map "`i" 'insert-i-grave)
  497. (define-key 8859-1-map "`o" 'insert-o-grave)
  498. (define-key 8859-1-map "`u" 'insert-u-grave)
  499. (define-key 8859-1-map "a" 'insert-a-ring)
  500. (define-key 8859-1-map "e" 'insert-ae)
  501. (define-key 8859-1-map "c" 'insert-cent-sign)
  502. (define-key 8859-1-map "d" 'insert-d-stroke)
  503. (define-key 8859-1-map "o" 'insert-degree-sign)
  504. (define-key 8859-1-map "s" 'insert-ss)
  505. (define-key 8859-1-map "t" 'insert-thorn)
  506. (define-key 8859-1-map "u" 'insert-micro-sign)
  507. (define-key 8859-1-map "x" 'insert-multiplication-sign)
  508. (define-key 8859-1-map "|" 'insert-broken-vertical-line)
  509. (define-key 8859-1-map "~" (make-sparse-keymap))
  510. (define-key 8859-1-map "~A" 'insert-A-tilde)
  511. (define-key 8859-1-map "~N" 'insert-N-tilde)
  512. (define-key 8859-1-map "~O" 'insert-O-tilde)
  513. (define-key 8859-1-map "~a" 'insert-a-tilde)
  514. (define-key 8859-1-map "~n" 'insert-n-tilde)
  515. (define-key 8859-1-map "~o" 'insert-o-tilde)
  516. (define-key 8859-1-map "~~" 'insert-not-sign)
  517. (if (not (lookup-key global-map "\C-x8"))
  518. (define-key global-map "\C-x8" 8859-1-map))
  519. )
  520. (defalias '8859-1-map 8859-1-map)
  521. (provide 'iso-insert)
  522. ;;; iso-insert.el ends here