1 ;;; postpet.el --- Postpet support for GNU Emacs
3 ;; Copyright (C) 1999,2000 Free Software Foundation, Inc.
5 ;; Author: Tanaka Akira <akr@jaist.ac.jp>
6 ;; Keywords: Postpet, MIME, multimedia, mail, news
8 ;; This file is part of SEMI (Sample of Elastic MIME Interfaces).
10 ;; This program is free software; you can redistribute it and/or
11 ;; modify it under the terms of the GNU General Public License as
12 ;; published by the Free Software Foundation; either version 2, or (at
13 ;; your option) any later version.
15 ;; This program is distributed in the hope that it will be useful, but
16 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 ;; 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 the
22 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
23 ;; Boston, MA 02111-1307, USA.
30 (put 'unpack 'lisp-indent-function 1)
31 (defmacro unpack (string &rest body)
32 `(let* ((*unpack*string* (string-as-unibyte ,string))
36 (defun unpack-skip (len)
37 (setq *unpack*index* (+ len *unpack*index*)))
39 (defun unpack-fixed (len)
41 (substring *unpack*string* *unpack*index* (+ *unpack*index* len))
45 (char-int (aref (unpack-fixed 1) 0)))
47 (defun unpack-short ()
48 (let* ((b0 (unpack-byte))
53 (let* ((s0 (unpack-short))
57 (defun unpack-string ()
58 (let ((len (unpack-byte)))
61 (defun unpack-string-sjis ()
62 (decode-mime-charset-string (unpack-string) 'shift_jis))
65 (defun postpet-decode (string)
70 (set-alist 'res 'carryingcount (unpack-long))
72 (set-alist 'res 'sentyear (unpack-short))
73 (set-alist 'res 'sentmonth (unpack-short))
74 (set-alist 'res 'sentday (unpack-short))
76 (set-alist 'res 'petname (unpack-string-sjis))
77 (set-alist 'res 'owner (unpack-string-sjis))
78 (set-alist 'res 'pettype (unpack-fixed 4))
79 (set-alist 'res 'health (unpack-short))
81 (set-alist 'res 'sex (unpack-long))
83 (set-alist 'res 'brain (unpack-byte))
85 (set-alist 'res 'happiness (unpack-byte))
87 (set-alist 'res 'petbirthyear (unpack-short))
88 (set-alist 'res 'petbirthmonth (unpack-short))
89 (set-alist 'res 'petbirthday (unpack-short))
91 (set-alist 'res 'from (unpack-string))
98 (set-alist 'res 'treasure (unpack-short))
99 (set-alist 'res 'money (unpack-long))
104 (defun mime-display-application/x-postpet (entity situation)
106 (narrow-to-region (point-max)(point-max))
107 (let ((pet (postpet-decode (mime-entity-content entity))))
110 "Petname: " (cdr (assq 'petname pet))
112 "Owner: " (cdr (assq 'owner pet))
114 "Pettype: " (cdr (assq 'pettype pet))
116 "From: " (cdr (assq 'from pet))
118 "CarryingCount: " (int-to-string (cdr (assq 'carryingcount pet)))
120 "SentYear: " (int-to-string (cdr (assq 'sentyear pet)))
122 "SentMonth: " (int-to-string (cdr (assq 'sentmonth pet)))
124 "SentDay: " (int-to-string (cdr (assq 'sentday pet)))
126 "PetbirthYear: " (int-to-string (cdr (assq 'petbirthyear pet)))
128 "PetbirthMonth: " (int-to-string (cdr (assq 'petbirthmonth pet)))
130 "PetbirthDay: " (int-to-string (cdr (assq 'petbirthday pet)))
132 "Health: " (int-to-string (cdr (assq 'health pet)))
134 "Sex: " (int-to-string (cdr (assq 'sex pet)))
136 "Brain: " (int-to-string (cdr (assq 'brain pet)))
138 "Happiness: " (int-to-string (cdr (assq 'happiness pet)))
140 "Treasure: " (int-to-string (cdr (assq 'treasure pet)))
142 "Money: " (int-to-string (cdr (assq 'money pet)))
144 (insert "Invalid format\n"))
145 (run-hooks 'mime-display-application/x-postpet-hook))))
153 ;;; postpet.el ends here