;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
-;; along with this program; if not, you can either send email to this
-;; program's maintainer or write to: The Free Software Foundation,
-;; Inc.; 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+;; along with GNU Emacs; see the file COPYING. If not, write to the
+;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+;; Boston, MA 02110-1301, USA.
;;; Commentary:
:type 'string
:group 'mixi)
+(defcustom mixi-atom-self ""
+ "*URI for retrieving Atom Feed Documents representing this Atom feed."
+ :type 'string
+ :group 'mixi)
+
(defcustom mixi-atom-title "Mixi Feed"
"*Title for feed."
:type 'string
:group 'mixi)
+(defcustom mixi-atom-file "~/atom.xml"
+ "*File name for `mixi-make-atom-file'."
+ :group 'mixi
+ :type 'string)
+
(defcustom mixi-atom-syndication-list
'((mixi-get-diaries . 10))
"*A list of atom syndication definition.
" <id>" (mixi-make-tag-uri object) "</id>\n"
" <updated>" (mixi-atom-make-date (mixi-object-time object))
"</updated>\n"
- " <summary>" (mixi-remove-markup (mixi-make-content object))
+ " <summary>" (mixi-encode-specials-string
+ (mixi-remove-markup (mixi-make-content object)))
"</summary>\n"
"</entry>\n"))
(concat entries (mixi-make-atom-entry object)))
(when (mixi-parent-p object)
(let ((comments (mixi-get-comments object range)))
- (mapc (lambda (comment)
- (setq entries
- (concat entries
- (mixi-make-atom-entry comment))))
- comments))))
- objects)
+ (while comments
+ (setq entries
+ (concat entries
+ (mixi-make-atom-entry (car comments))))
+ (setq comments (cdr comments))))))
+ objects)
entries))
-;;;###autoload
(defun mixi-make-atom ()
"Make Atom Syndication Format"
- (insert "<?xml version=\"1.0\" encoding=\""
+ (concat "<?xml version=\"1.0\" encoding=\""
(symbol-name mixi-atom-coding-system) "\"?>\n"
"<feed xmlns=\"" mixi-atom-namespace "\">\n"
+ "<link rel=\"self\" href=\"" mixi-atom-self "\"/>\n"
"\n"
"<title>" mixi-atom-title "</title>\n"
"<link href=\"" mixi-url "\"/>\n"
"</feed>\n"))
;;;###autoload
-(defun mixi-atom-write-file (file)
+(defun mixi-atom-cgi ()
+ (princ (concat "Content-Type: application/atom+xml; charset="
+ (symbol-name mixi-atom-coding-system) "\n"
+ "\n"
+ (encode-coding-string (mixi-make-atom)
+ mixi-atom-coding-system))))
+
+;;;###autoload
+(defun mixi-atom-file ()
(with-temp-buffer
- (mixi-make-atom)
+ (insert (mixi-make-atom))
(let ((coding-system-for-write mixi-atom-coding-system)
- (file (expand-file-name file)))
+ (file (expand-file-name mixi-atom-file)))
(write-region (point-min) (point-max) file))))
(provide 'mixi-atom)