-
Notifications
You must be signed in to change notification settings - Fork 2
/
pjb-date.el
58 lines (51 loc) · 1.98 KB
/
pjb-date.el
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
;;;; -*- mode:emacs-lisp;coding:utf-8 -*-
;;;;**************************************************************************
;;;;FILE: pjb-date.el
;;;;LANGUAGE: emacs lisp
;;;;SYSTEM: POSIX
;;;;USER-INTERFACE: NONE
;;;;DESCRIPTION
;;;;
;;;; Date formats.
;;;;
;;;;AUTHORS
;;;; <PJB> Pascal J. Bourguignon <[email protected]>
;;;;MODIFICATIONS
;;;; 2015-10-19 <PJB> Created.
;;;;BUGS
;;;;LEGAL
;;;; AGPL3
;;;;
;;;; Copyright Pascal J. Bourguignon 2015 - 2015
;;;;
;;;; This program is free software: you can redistribute it and/or modify
;;;; it under the terms of the GNU Affero General Public License as published by
;;;; the Free Software Foundation, either version 3 of the License, 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 Affero General Public License for more details.
;;;;
;;;; You should have received a copy of the GNU Affero General Public License
;;;; along with this program. If not, see <http://www.gnu.org/licenses/>.
;;;;**************************************************************************
(require 'parse-time)
(defun parse-iso8601-date (string)
;; For now, we parse only "yyyymmddThhmmss"
(encode-time (parse-integer string 13 15)
(parse-integer string 11 13)
(parse-integer string 9 11)
(parse-integer string 6 8)
(parse-integer string 4 6)
(parse-integer string 0 4)))
(defun format-rfc822-date (universal-time)
(format-time-string "%a, %d %b %Y %H:%M:%S %z" universal-time))
(defun iso8601-to-rfc822 (start end)
(interactive "r")
(let ((date (buffer-substring start end)))
(delete-region start end)
(insert (format-rfc822-date (parse-iso8601-date date)))))
(provide 'pjb-date)
;;;; THE END ;;;;