(U-000216B4): Copied from Ideograph-R038-Woman.el.
[chise/xemacs-chise.git.1] / lisp / version.el
1 ;; version.el --- Record version number of Emacs.
2
3 ;; Copyright (C) 1985, 1991-1994, 1997 Free Software Foundation, Inc.
4
5 ;; Maintainer: XEmacs Development Team
6 ;; Keywords: internal, dumped
7
8 ;; This file is part of XEmacs.
9
10 ;; XEmacs is free software; you can redistribute it and/or modify
11 ;; it under the terms of the GNU General Public License as published by
12 ;; the Free Software Foundation; either version 2, or (at your option)
13 ;; any later version.
14
15 ;; XEmacs is distributed in the hope that it will be useful,
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18 ;; GNU General Public License for more details.
19
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.
24
25 ;;; Synched up with: FSF 19.34.
26
27 ;;; Commentary:
28
29 ;; This file is dumped with XEmacs.
30
31 ;;; Code:
32
33 (defconst xemacs-betaname
34   (and emacs-beta-version (format "(beta%d)" emacs-beta-version))
35   "Non-nil when this is a test (beta) version of XEmacs.
36 Warning, this variable did not exist in XEmacs versions prior to 20.3")
37
38 (defconst emacs-version
39   (format "%d.%d %s%s%s%s"
40           emacs-major-version
41           emacs-minor-version
42           (if emacs-patch-level
43               (format "(patch %d)" emacs-patch-level)
44             "")
45           (or xemacs-betaname "")
46           (if xemacs-codename
47               (concat " \"" xemacs-codename "\"")
48             "")
49           " XEmacs Lucid")
50   "Version numbers of this version of XEmacs.")
51
52 (if (featurep 'infodock)
53     (require 'id-vers))
54
55 ;; Moved to C code as of XEmacs 20.3
56 ;(defconst emacs-major-version
57 ;  (progn (or (string-match "^[0-9]+" emacs-version)
58 ;            (error "emacs-version unparsable"))
59 ;         (string-to-int (match-string 0 emacs-version)))
60 ;  "Major version number of this version of Emacs, as an integer.
61 ;Warning, this variable did not exist in Emacs versions earlier than:
62 ;  FSF Emacs:   19.23
63 ;  XEmacs:      19.10")
64
65 ;; Moved to C code as of XEmacs 20.3
66 ;(defconst emacs-minor-version
67 ;  (progn (or (string-match "^[0-9]+\\.\\([0-9]+\\)" emacs-version)
68 ;            (error "emacs-version unparsable"))
69 ;         (string-to-int (match-string 1 emacs-version)))
70 ;  "Minor version number of this version of Emacs, as an integer.
71 ;Warning, this variable did not exist in Emacs versions earlier than:
72 ;  FSF Emacs:   19.23
73 ;  XEmacs:      19.10")
74
75 (defconst emacs-build-time (current-time-string)
76   "Time at which Emacs was dumped out.")
77
78 (defconst emacs-build-system (system-name))
79
80 (defun emacs-version (&optional arg)
81   "Return string describing the version of Emacs that is running.
82 When called interactively with a prefix argument, insert string at point.
83 Don't use this function in programs to choose actions according
84 to the system configuration; look at `system-configuration' instead."
85   (interactive "p")
86   (save-match-data
87     (let ((version-string
88            (format
89             "XEmacs %s %s(%s%s)%s of %s %s on %s"
90             (substring emacs-version 0 (string-match " XEmacs" emacs-version))
91             (if (not (featurep 'infodock))
92                 "[Lucid] "
93               "")
94             system-configuration
95             (cond ((or (and (fboundp 'featurep)
96                             (featurep 'mule))
97                        (memq 'mule features)) ", Mule")
98                   (t ""))
99             (cond ((or (and (fboundp 'featurep)
100                             (featurep 'utf-2000))
101                        (memq 'utf-2000 features))
102                    (concat "  CHISE v" xemacs-chise-version))
103                   (t ""))
104             (substring emacs-build-time 0
105                        (string-match " *[0-9]*:" emacs-build-time))
106             (substring emacs-build-time
107                        (string-match "[0-9]*$" emacs-build-time))
108             emacs-build-system)))
109       (cond
110        ((null arg) version-string)
111        ((eq arg 1) (message "%s" version-string))
112        (t          (insert version-string))))))
113
114 ;; from emacs-vers.el
115 (defun emacs-version>= (major &optional minor patch)
116   "Return true if the Emacs version is >= to the given MAJOR, MINOR,
117    and PATCH numbers.
118 The MAJOR version number argument is required, but the other arguments
119 argument are optional. Only the Non-nil arguments are used in the test."
120   (let ((emacs-patch (or emacs-patch-level emacs-beta-version -1)))
121     (cond ((> emacs-major-version major))
122           ((< emacs-major-version major) nil)
123           ((null minor))
124           ((> emacs-minor-version minor))
125           ((< emacs-minor-version minor) nil)
126           ((null patch))
127           ((>= emacs-patch patch)))))
128
129 ;;; We hope that this alias is easier for people to find.
130 (define-function 'version 'emacs-version)
131
132 ;; Put the emacs version number into the `pure[]' array in a form that
133 ;; `what(1)' can extract from the executable or a core file.  We don't
134 ;; actually need this to be pointed to from lisp; pure objects can't
135 ;; be GCed.
136 (concat "\n@" "(#)" (emacs-version)
137         "\n@" "(#)" "Configuration: "
138         system-configuration "\n")
139
140 ;;Local variables:
141 ;;version-control: never
142 ;;End:
143
144 ;;; version.el ends here