summaryrefslogtreecommitdiff
path: root/share/emacs/site-lisp/w3m/w3m-ccl.el
diff options
context:
space:
mode:
Diffstat (limited to 'share/emacs/site-lisp/w3m/w3m-ccl.el')
-rw-r--r--share/emacs/site-lisp/w3m/w3m-ccl.el202
1 files changed, 0 insertions, 202 deletions
diff --git a/share/emacs/site-lisp/w3m/w3m-ccl.el b/share/emacs/site-lisp/w3m/w3m-ccl.el
deleted file mode 100644
index e8bea09c0ec..00000000000
--- a/share/emacs/site-lisp/w3m/w3m-ccl.el
+++ /dev/null
@@ -1,202 +0,0 @@
-;;; w3m-ccl.el --- CCL programs to process Unicode and internal characters.
-
-;; Copyright (C) 2001, 2003, 2004, 2005, 2006, 2007
-;; TSUCHIYA Masatoshi <tsuchiya@namazu.org>
-
-;; Authors: TSUCHIYA Masatoshi <tsuchiya@namazu.org>,
-;; ARISAWA Akihiro <ari@mbf.sphere.ne.jp>
-;; Keywords: w3m, WWW, hypermedia
-
-;; This file is a part of emacs-w3m.
-
-;; This program 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 2, or (at your option)
-;; any later version.
-
-;; This program 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.
-
-;; You should have received a copy of the GNU General Public License
-;; along with this program; see the file COPYING. If not, write to
-;; the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
-;; Boston, MA 02110-1301, USA.
-
-;;; Commentary:
-
-;; This file contains CCL programs to process Unicode and internal
-;; characters of w3m. For more detail about emacs-w3m, see:
-;;
-;; http://emacs-w3m.namazu.org/
-
-;;; MEMO:
-
-;; It is possible to support multi scripts without Mule-UCS. For more
-;; detail, see [emacs-w3m:01950]
-
-;;; Code:
-
-(eval-and-compile
- (cond
- ((featurep 'xemacs)
- (require 'pccl))
- (t
- (require 'ccl))))
-
-;;; CCL programs:
-
-(eval-when-compile
- (when (and (not (fboundp 'charset-id))
- (fboundp 'charset-id-internal))
- (defmacro charset-id (charset)
- "Return charset identification number of CHARSET."
- `(charset-id-internal ,charset))))
-
-(eval-and-compile
- (defconst w3m-internal-characters-alist
- '((?\x90 . ? ) ; ANSP (use for empty anchor)
- (?\x91 . ? ) ; IMSP (blank around image)
- (?\xa0 . ? )) ; NBSP (non breakble space)
- "Alist of internal characters v.s. ASCII characters.")
-
- (defun w3m-ccl-write-repeat (charset &optional r0 r1)
- (unless r0
- (setq r0 'r0))
- (unless r1
- (setq r1 (if (eq r0 'r1) 'r0 'r1)))
- (let ((unibyte (memq charset '(latin-iso8859-1 katakana-jisx0201))))
- (if (fboundp 'ccl-compile-write-multibyte-character)
- `((,r1 &= ?\x7f)
- ,@(unless unibyte
- `((,r1 |= ((,r0 & ?\x7f) << 7))))
- (,r0 = ,(charset-id charset))
- (write-multibyte-character ,r0 ,r1)
- (repeat))
- `((write ,(charset-id charset))
- ,@(unless unibyte
- `((write ,r0)))
- (write-repeat ,r1)))))
-
- (defconst w3m-ccl-write-euc-japan-character
- (when (fboundp 'ccl-compile-read-multibyte-character)
- `((read-multibyte-character r1 r0)
- (if (r1 == ,(charset-id 'ascii))
- ;; (1) ASCII characters
- (write-repeat r0))
- (if (r1 == ,(charset-id 'latin-jisx0201))
- ;; (2) Latin Part of Japanese JISX0201.1976
- ;; Convert to ASCII
- (write-repeat r0))
- (r2 = (r1 == ,(charset-id 'japanese-jisx0208-1978)))
- (if ((r1 == ,(charset-id 'japanese-jisx0208)) | r2)
- ;; (3) Characters of Japanese JISX0208.
- ((r1 = ((r0 & 127) | 128))
- (r0 = ((r0 >> 7) | 128))
- (write r0)
- (write-repeat r1)))
- (if (r1 == ,(charset-id 'katakana-jisx0201))
- ;; (4) Katakana Part of Japanese JISX0201.1976
- ((r0 |= 128)
- (write ?\x8e)
- (write-repeat r0)))))
- "CCL program to write characters represented in `euc-japan'.")
-
- (defconst w3m-ccl-write-iso-latin-1-character
- (when (fboundp 'ccl-compile-read-multibyte-character)
- `((read-multibyte-character r1 r0)
- (if (r1 == ,(charset-id 'ascii))
- ;; (1) ASCII characters
- (write-repeat r0))
- (if (r1 == ,(charset-id 'latin-jisx0201))
- ;; (2) Latin Part of Japanese JISX0201.1976
- ;; Convert to ASCII
- (write-repeat r0))
- (if (r1 == ,(charset-id 'latin-iso8859-1))
- ;; (3) Latin-1 characters
- ((r0 |= ?\x80)
- (write-repeat r0)))))
- "CCL program to write characters represented in `iso-latin-1'.")
-
- (defconst w3m-ccl-generate-ncr
- `((r1 = 0)
- (r2 = 0)
- (loop
- (r1 = (r1 << 4))
- (r1 |= (r0 & 15))
- (r0 = (r0 >> 4))
- (if (r0 == 0)
- (break)
- ((r2 += 1)
- (repeat))))
- (write "&#x")
- (loop
- (branch (r1 & 15)
- ,@(mapcar
- (lambda (i)
- (list 'write (string-to-char (format "%x" i))))
- '(0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15)))
- (r1 = (r1 >> 4))
- (if (r2 == 0)
- ((write ?\;)
- (break))
- ((r2 -= 1)
- (repeat))))
- (repeat))
- "CCL program to generate a string which represents a UCS codepoint
-in NCR (Numeric Character References)."))
-
-(define-ccl-program w3m-euc-japan-decoder
- `(2
- (loop
- (read r0)
- ;; Process normal EUC characters.
- (if (r0 < ?\x80)
- (write-repeat r0))
- (if (r0 > ?\xa0)
- ((read r1)
- ,@(w3m-ccl-write-repeat 'japanese-jisx0208)))
- (if (r0 == ?\x8e)
- ((read r1)
- ,@(w3m-ccl-write-repeat 'katakana-jisx0201)))
- (if (r0 == ?\x8f)
- ((read r0)
- (read r1)
- ,@(w3m-ccl-write-repeat 'japanese-jisx0212)))
- ;; Process internal characters used in w3m.
- ,@(mapcar (lambda (pair)
- `(if (r0 == ,(car pair))
- (write-repeat ,(cdr pair))))
- w3m-internal-characters-alist)
- (write-repeat r0))))
-
-(unless (get 'w3m-euc-japan-encoder 'ccl-program-idx)
- (define-ccl-program w3m-euc-japan-encoder
- `(1 (loop (read r0) (write-repeat r0)))))
-
-(define-ccl-program w3m-iso-latin-1-decoder
- `(2
- (loop
- (read r0)
- ;; Process ASCII characters.
- (if (r0 < ?\x80)
- (write-repeat r0))
- ;; Process Latin-1 characters.
- (if (r0 > ?\xa0)
- (,@(w3m-ccl-write-repeat 'latin-iso8859-1 'r1)))
- ;; Process internal characters used in w3m.
- ,@(mapcar (lambda (pair)
- `(if (r0 == ,(car pair))
- (write-repeat ,(cdr pair))))
- w3m-internal-characters-alist)
- (write-repeat r0))))
-
-(unless (get 'w3m-iso-latin-1-encoder 'ccl-program-idx)
- (define-ccl-program w3m-iso-latin-1-encoder
- `(1 (loop (read r0) (write-repeat r0)))))
-
-
-(provide 'w3m-ccl)
-
-;;; w3m-ccl.el ends here