/usr/share/emacs/site-lisp/w3m/shimbun/sb-wincefan.el is in w3m-el-snapshot 1.4.527+0.20140108-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 | ;;; sb-wincefan.el --- shimbun backend for WindowsCE FAN -*- coding: iso-2022-7bit; -*-
;; Copyright (C) 2003, 2004, 2005 NAKAJIMA Mikio <minakaji@osaka.email.ne.jp>
;; Author: NAKAJIMA Mikio <minakaji@osaka.email.ne.jp>
;; Keywords: news
;; This file is a part of shimbun.
;; 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:
;;; Code:
(require 'shimbun)
(luna-define-class shimbun-wincefan (shimbun) ())
(defconst shimbun-wincefan-url "http://www.wince.ne.jp/")
(defvar shimbun-wincefan-groups '("news"))
(defconst shimbun-wincefan-from-address "webmaster@wince.ne.jp")
(defvar shimbun-wincefan-coding-system 'japanese-shift-jis)
(defvar shimbun-wincefan-content-start "\\(<!-- *$B%=%U%H>\:Y>pJs(B *-->\\|<B>$B"#%H%T%C%/%9$NFbMF(B<\/B>\\)")
(defvar shimbun-wincefan-content-end "<!-- \\/*\\($B5-;v(B\\|$B%=%U%H>\:Y>pJs(B\\)-->")
(defvar shimbun-wincefan-expiration-days 14)
(luna-define-method shimbun-get-headers ((shimbun shimbun-wincefan)
&optional outbuf)
(let* ((from (shimbun-from-address shimbun))
(group (shimbun-current-group-internal shimbun))
(baseurl (when (string-match "^http://\\([^/]+\\)/*$"
shimbun-wincefan-url)
(match-string 1 shimbun-wincefan-url)))
(case-fold-search t)
url headers)
(catch 'stop
(if (not (re-search-forward "^<!--What's New-->" nil t nil))
(throw 'stop nil)
(delete-region (point-min) (point)))
(if (not (re-search-forward "^<!--//Whats' New-->" nil t nil))
(throw 'stop nil)
(delete-region (point-max) (point)))
(goto-char (point-min))
(while (re-search-forward
;;<FONT SIZE="-1" COLOR="#008000">1$B7n(B30$BF|(B($BF|(B)</FONT>
"<FONT [^<>]+>\\([0-9]+\\)$B7n(B\\([0-9]+\\)$BF|(B(\\($B7n(B\\|$B2P(B\\|$B?e(B\\|$BLZ(B\\|$B6b(B\\|$BEZ(B\\|$BF|(B\\))<\/FONT>"
nil t nil)
(let* ((month (string-to-number (match-string-no-properties 1)))
(day (string-to-number (match-string-no-properties 2)))
(year (string-to-number (substring (current-time-string) 20)))
(date (shimbun-make-date-string year month day))
(rawdate (string-to-number
(format "%04d%02d%02d"year month day)))
(end (save-excursion
(or (re-search-forward
"<FONT [^<>]+>\\([0-9]+\\)$B7n(B\\([0-9]+\\)$BF|(B(\\($B7n(B\\|$B2P(B\\|$B?e(B\\|$BLZ(B\\|$B6b(B\\|$BEZ(B\\|$BF|(B\\))<\/FONT>"
nil t nil)
(point-max))))
(count -1)
subject id)
(while (re-search-forward
;;<TD><A HREF="/frame.asp?/soft2002/detail.asp?PID=3141" TARGET="_top"><FONT SIZE="-1" >$B$/$i$I$%(B vA20($B%i%8%'%s%@MQ(B ToDo)</FONT></A></TD>
;;<TD><A HREF="/NewsLink/" TARGET="_top"><FONT SIZE="-1" COLOR="#FF0000">$B!Z(BNews$B![(B</FONT><BR></A><A HREF="http://www.wince.ne.jp/snap/cnBoard.asp?PID=1376" TARGET="_top"><FONT SIZE="-1" >$B%7%c!<%W$,(B HDD $BHsEk:\$NNw2AHG(B SL $B%6%&%k%9!V(BSL-C1000$B!W$rH/Gd(B</FONT><BR></A><FONT SIZE="-1" ></FONT></TD>
"<A HREF=\"\\([^\"]+\\)\" TARGET=\"_top\"><FONT SIZE=[^<>]+>\\([^<>]+\\)<\\/FONT>"
end t nil)
(setq url (match-string-no-properties 1)
subject (match-string-no-properties 2))
;; ("/NewsLink/" "$B!Z(BNews$B![(B")
(when (not (and (string-match "^/.*/$" url)
(string-match "^$B!Z(B.*$B![(B$" subject)))
(setq count (1+ count))
;; building ID
(setq id (format "<%02d%08d%%%s@%s>" count rawdate group baseurl))
(if (shimbun-search-id shimbun id)
(throw 'stop nil))
;; not to use frame
(when (string-match "/frame\\.asp\\?" url)
(setq url (concat (substring url 0 (match-beginning 0))
(substring url (match-end 0)))))
(setq url (shimbun-expand-url url shimbun-wincefan-url))
(push (shimbun-make-header
0 (shimbun-mime-encode-string subject)
from date id "" 0 0 url)
headers))))))
headers))
;;(nreverse headers)))
(luna-define-method shimbun-make-contents :before
((shimbun shimbun-wincefan) header)
(let ((case-fold-search t))
(save-excursion
(while (re-search-forward "<IMG SRC=\\(\"?/[^ ]+\\)" nil t nil)
(let ((url (shimbun-expand-url (match-string-no-properties 1)
shimbun-wincefan-url)))
(delete-region (match-beginning 0) (match-end 0))
(insert "<IMG SRC=" url))))))
(provide 'sb-wincefan)
;;; sb-wincefan.el ends here
|