2001-07-16 07:46:48 +00:00
|
|
|
|
;;; pcvs-info.el --- internal representation of a fileinfo entry
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
2004-09-07 04:51:47 +00:00
|
|
|
|
;; Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
|
2010-01-13 08:35:10 +00:00
|
|
|
|
;; 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010
|
2008-04-12 03:17:19 +00:00
|
|
|
|
;; Free Software Foundation, Inc.
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
2006-04-30 15:49:08 +00:00
|
|
|
|
;; Author: Stefan Monnier <monnier@iro.umontreal.ca>
|
2000-03-11 03:51:31 +00:00
|
|
|
|
;; Keywords: pcl-cvs
|
|
|
|
|
|
|
|
|
|
;; This file is part of GNU Emacs.
|
|
|
|
|
|
2008-05-06 08:06:51 +00:00
|
|
|
|
;; GNU Emacs is free software: you can redistribute it and/or modify
|
2000-03-11 03:51:31 +00:00
|
|
|
|
;; it under the terms of the GNU General Public License as published by
|
2008-05-06 08:06:51 +00:00
|
|
|
|
;; the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
;; (at your option) any later version.
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
;; GNU Emacs 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
|
2008-05-06 08:06:51 +00:00
|
|
|
|
;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
|
|
|
|
|
;; The cvs-fileinfo data structure:
|
|
|
|
|
;;
|
|
|
|
|
;; When the `cvs update' is ready we parse the output. Every file
|
|
|
|
|
;; that is affected in some way is added to the cookie collection as
|
|
|
|
|
;; a "fileinfo" (as defined below in cvs-create-fileinfo).
|
|
|
|
|
|
|
|
|
|
;;; Code:
|
|
|
|
|
|
|
|
|
|
(eval-when-compile (require 'cl))
|
|
|
|
|
(require 'pcvs-util)
|
|
|
|
|
;;(require 'pcvs-defs)
|
|
|
|
|
|
|
|
|
|
;;;;
|
|
|
|
|
;;;; config variables
|
|
|
|
|
;;;;
|
|
|
|
|
|
2008-04-18 10:31:54 +00:00
|
|
|
|
(define-obsolete-variable-alias 'cvs-display-full-path
|
|
|
|
|
'cvs-display-full-name "22.1")
|
2008-04-12 03:17:19 +00:00
|
|
|
|
|
2005-04-26 20:35:42 +00:00
|
|
|
|
(defcustom cvs-display-full-name t
|
2008-12-03 05:48:14 +00:00
|
|
|
|
"Specifies how the filenames should be displayed in the listing.
|
2005-04-26 20:35:42 +00:00
|
|
|
|
If non-nil, their full filename name will be displayed, else only the
|
|
|
|
|
non-directory part."
|
2000-03-11 03:51:31 +00:00
|
|
|
|
:group 'pcl-cvs
|
|
|
|
|
:type '(boolean))
|
|
|
|
|
|
|
|
|
|
(defcustom cvs-allow-dir-commit nil
|
2008-12-03 05:48:14 +00:00
|
|
|
|
"Allow `cvs-mode-commit' on directories.
|
2000-03-11 03:51:31 +00:00
|
|
|
|
If you commit without any marked file and with the cursor positioned
|
|
|
|
|
on a directory entry, cvs would commit the whole directory. This seems
|
|
|
|
|
to confuse some users sometimes."
|
|
|
|
|
:group 'pcl-cvs
|
|
|
|
|
:type '(boolean))
|
|
|
|
|
|
|
|
|
|
;;;;
|
|
|
|
|
;;;; Faces for fontification
|
|
|
|
|
;;;;
|
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defface cvs-header
|
2000-03-11 03:51:31 +00:00
|
|
|
|
'((((class color) (background dark))
|
2001-12-31 20:43:36 +00:00
|
|
|
|
(:foreground "lightyellow" :weight bold))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(((class color) (background light))
|
2001-12-31 20:43:36 +00:00
|
|
|
|
(:foreground "blue4" :weight bold))
|
|
|
|
|
(t (:weight bold)))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
"PCL-CVS face used to highlight directory changes."
|
|
|
|
|
:group 'pcl-cvs)
|
2009-09-01 07:24:13 +00:00
|
|
|
|
(define-obsolete-face-alias 'cvs-header-face 'cvs-header "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defface cvs-filename
|
2000-03-11 03:51:31 +00:00
|
|
|
|
'((((class color) (background dark))
|
|
|
|
|
(:foreground "lightblue"))
|
|
|
|
|
(((class color) (background light))
|
|
|
|
|
(:foreground "blue4"))
|
|
|
|
|
(t ()))
|
|
|
|
|
"PCL-CVS face used to highlight file names."
|
|
|
|
|
:group 'pcl-cvs)
|
2009-09-01 07:24:13 +00:00
|
|
|
|
(define-obsolete-face-alias 'cvs-filename-face 'cvs-filename "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defface cvs-unknown
|
2000-03-11 03:51:31 +00:00
|
|
|
|
'((((class color) (background dark))
|
2007-07-13 02:50:19 +00:00
|
|
|
|
(:foreground "red1"))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(((class color) (background light))
|
2007-07-13 02:50:19 +00:00
|
|
|
|
(:foreground "red1"))
|
2001-12-31 20:43:36 +00:00
|
|
|
|
(t (:slant italic)))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
"PCL-CVS face used to highlight unknown file status."
|
|
|
|
|
:group 'pcl-cvs)
|
2009-09-01 07:24:13 +00:00
|
|
|
|
(define-obsolete-face-alias 'cvs-unknown-face 'cvs-unknown "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defface cvs-handled
|
2000-03-11 03:51:31 +00:00
|
|
|
|
'((((class color) (background dark))
|
|
|
|
|
(:foreground "pink"))
|
|
|
|
|
(((class color) (background light))
|
|
|
|
|
(:foreground "pink"))
|
|
|
|
|
(t ()))
|
|
|
|
|
"PCL-CVS face used to highlight handled file status."
|
|
|
|
|
:group 'pcl-cvs)
|
2009-09-01 07:24:13 +00:00
|
|
|
|
(define-obsolete-face-alias 'cvs-handled-face 'cvs-handled "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defface cvs-need-action
|
2000-03-11 03:51:31 +00:00
|
|
|
|
'((((class color) (background dark))
|
|
|
|
|
(:foreground "orange"))
|
|
|
|
|
(((class color) (background light))
|
|
|
|
|
(:foreground "orange"))
|
2001-12-31 20:43:36 +00:00
|
|
|
|
(t (:slant italic)))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
"PCL-CVS face used to highlight status of files needing action."
|
|
|
|
|
:group 'pcl-cvs)
|
2009-09-01 07:24:13 +00:00
|
|
|
|
(define-obsolete-face-alias 'cvs-need-action-face 'cvs-need-action "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defface cvs-marked
|
* mh-customize.el (mh-speedbar-selected-folder-face): Special case
high number of colors displays.
* textmodes/table.el (table-cell-face): Add special case for
displays supporting a high number of colors.
* progmodes/vhdl-mode.el (vhdl-font-lock-prompt-face)
(vhdl-font-lock-reserved-words-face)
(vhdl-speedbar-architecture-face)
(vhdl-speedbar-instantiation-face)
(vhdl-speedbar-architecture-selected-face)
(vhdl-speedbar-instantiation-selected-face): Likewise.
* progmodes/sh-script.el (sh-heredoc-face): Likewise.
* progmodes/idlw-help.el (idlwave-help-link-face): Likewise.
* progmodes/ebrowse.el (ebrowse-tree-mark-face)
(ebrowse-root-class-face, ebrowse-member-attribute-face)
(ebrowse-progress-face): Likewise.
* progmodes/compile.el (compilation-info-face): Likewise.
* progmodes/cc-fonts.el (c-invalid-face): Likewise.
* emacs-lisp/re-builder.el (reb-match-3): Likewise.
* calendar/calendar.el (diary-face): Likewise.
* woman.el (woman-italic-face, woman-bold-face)
(woman-unknown-face): Likewise.
* wid-edit.el (widget-button-pressed-face): Likewise.
* whitespace.el (whitespace-highlight-face): Likewise.
* smerge-mode.el (smerge-mine-face, smerge-base-face): Likewise.
* pcvs-info.el (cvs-marked-face): Likewise.
* info.el (info-xref): Likewise.
* ido.el (ido-subdir-face, ido-indicator-face): Likewise.
* hilit-chg.el (highlight-changes-face)
(highlight-changes-delete-face): Likewise.
* hi-lock.el (hi-yellow, hi-green, hi-blue-b, hi-green-b)
(hi-red-b): Likewise.
* generic-x.el (show-tabs-tab-face, show-tabs-space-face): Likewise.
* font-lock.el (font-lock-keyword-face)
(font-lock-function-name-face, font-lock-warning-face): Likewise.
* cus-edit.el (custom-invalid-face, custom-modified-face)
(custom-set-face, custom-changed-face, custom-variable-tag-face)
(custom-group-tag-face-1, custom-group-tag-face): Likewise.
* comint.el (comint-highlight-prompt): Likewise.
2005-04-08 14:26:13 +00:00
|
|
|
|
'((((min-colors 88) (class color) (background dark))
|
|
|
|
|
(:foreground "green1" :weight bold))
|
|
|
|
|
(((class color) (background dark))
|
2001-12-31 20:43:36 +00:00
|
|
|
|
(:foreground "green" :weight bold))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(((class color) (background light))
|
2001-12-31 20:43:36 +00:00
|
|
|
|
(:foreground "green3" :weight bold))
|
|
|
|
|
(t (:weight bold)))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
"PCL-CVS face used to highlight marked file indicator."
|
|
|
|
|
:group 'pcl-cvs)
|
2009-09-01 07:24:13 +00:00
|
|
|
|
(define-obsolete-face-alias 'cvs-marked-face 'cvs-marked "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defface cvs-msg
|
2001-12-31 20:43:36 +00:00
|
|
|
|
'((t (:slant italic)))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
"PCL-CVS face used to highlight CVS messages."
|
|
|
|
|
:group 'pcl-cvs)
|
2009-09-01 07:24:13 +00:00
|
|
|
|
(define-obsolete-face-alias 'cvs-msg-face 'cvs-msg "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(defvar cvs-fi-up-to-date-face 'cvs-handled)
|
|
|
|
|
(defvar cvs-fi-unknown-face 'cvs-unknown)
|
2000-11-12 16:52:53 +00:00
|
|
|
|
(defvar cvs-fi-conflict-face 'font-lock-warning-face)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
;; There is normally no need to alter the following variable, but if
|
|
|
|
|
;; your site has installed CVS in a non-standard way you might have
|
|
|
|
|
;; to change it.
|
|
|
|
|
|
|
|
|
|
(defvar cvs-bakprefix ".#"
|
|
|
|
|
"The prefix that CVS prepends to files when rcsmerge'ing.")
|
|
|
|
|
|
|
|
|
|
(easy-mmode-defmap cvs-status-map
|
2004-04-14 17:38:23 +00:00
|
|
|
|
'(([(mouse-2)] . cvs-mode-toggle-mark))
|
2000-06-12 04:37:50 +00:00
|
|
|
|
"Local keymap for text properties of status")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
;; Constructor:
|
|
|
|
|
|
|
|
|
|
(defstruct (cvs-fileinfo
|
|
|
|
|
(:constructor nil)
|
|
|
|
|
(:copier nil)
|
|
|
|
|
(:constructor -cvs-create-fileinfo (type dir file full-log
|
|
|
|
|
&key marked subtype
|
|
|
|
|
merge
|
|
|
|
|
base-rev
|
|
|
|
|
head-rev))
|
|
|
|
|
(:conc-name cvs-fileinfo->))
|
|
|
|
|
marked ;; t/nil.
|
|
|
|
|
type ;; See below
|
|
|
|
|
subtype ;; See below
|
|
|
|
|
dir ;; Relative directory the file resides in.
|
|
|
|
|
;; (concat dir file) should give a valid path.
|
|
|
|
|
file ;; The file name sans the directory.
|
|
|
|
|
base-rev ;; During status: This is the revision that the
|
|
|
|
|
;; working file is based on.
|
|
|
|
|
head-rev ;; During status: This is the highest revision in
|
|
|
|
|
;; the repository.
|
|
|
|
|
merge ;; A cons cell containing the (ancestor . head) revisions
|
|
|
|
|
;; of the merge that resulted in the current file.
|
|
|
|
|
;;removed ;; t if the file no longer exists.
|
|
|
|
|
full-log ;; The output from cvs, unparsed.
|
|
|
|
|
;;mod-time ;; Not used.
|
|
|
|
|
|
|
|
|
|
;; In addition to the above, the following values can be extracted:
|
|
|
|
|
|
|
|
|
|
;; handled ;; t if this file doesn't require further action.
|
2005-04-26 20:35:42 +00:00
|
|
|
|
;; full-name ;; The complete relative filename.
|
2000-03-11 03:51:31 +00:00
|
|
|
|
;; pp-name ;; The printed file name
|
|
|
|
|
;; backup-file;; For MERGED and CONFLICT files after a \"cvs update\",
|
|
|
|
|
;; this is a full path to the backup file where the
|
|
|
|
|
;; untouched version resides.
|
|
|
|
|
|
|
|
|
|
;; The meaning of the type field:
|
2003-02-04 12:29:42 +00:00
|
|
|
|
|
2000-03-11 03:51:31 +00:00
|
|
|
|
;; Value ---Used by--- Explanation
|
|
|
|
|
;; update status
|
|
|
|
|
;; NEED-UPDATE x file needs update
|
|
|
|
|
;; MODIFIED x x modified by you, unchanged in repository
|
|
|
|
|
;; MERGED x x successful merge
|
|
|
|
|
;; ADDED x x added by you, not yet committed
|
|
|
|
|
;; MISSING x rm'd, but not yet `cvs remove'd
|
|
|
|
|
;; REMOVED x x removed by you, not yet committed
|
|
|
|
|
;; NEED-MERGE x need merge
|
|
|
|
|
;; CONFLICT x conflict when merging
|
|
|
|
|
;; ;;MOD-CONFLICT x removed locally, changed in repository.
|
|
|
|
|
;; DIRCHANGE x x A change of directory.
|
|
|
|
|
;; UNKNOWN x An unknown file.
|
|
|
|
|
;; UP-TO-DATE x The file is up-to-date.
|
|
|
|
|
;; UPDATED x x file copied from repository
|
|
|
|
|
;; PATCHED x x diff applied from repository
|
|
|
|
|
;; COMMITTED x x cvs commit'd
|
|
|
|
|
;; DEAD An entry that should be removed
|
|
|
|
|
;; MESSAGE x x This is a special fileinfo that is used
|
|
|
|
|
;; to display a text that should be in
|
|
|
|
|
;; full-log."
|
|
|
|
|
;; TEMP A temporary message that should be removed
|
|
|
|
|
)
|
|
|
|
|
(defun cvs-create-fileinfo (type dir file msg &rest keys)
|
|
|
|
|
(cvs-check-fileinfo (apply #'-cvs-create-fileinfo type dir file msg keys)))
|
|
|
|
|
|
|
|
|
|
;; Fake selectors:
|
|
|
|
|
|
2005-04-26 20:35:42 +00:00
|
|
|
|
(defun cvs-fileinfo->full-name (fileinfo)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
"Return the full path for the file that is described in FILEINFO."
|
|
|
|
|
(let ((dir (cvs-fileinfo->dir fileinfo)))
|
|
|
|
|
(if (eq (cvs-fileinfo->type fileinfo) 'DIRCHANGE)
|
|
|
|
|
(if (string= dir "") "." (directory-file-name dir))
|
|
|
|
|
;; Here, I use `concat' rather than `expand-file-name' because I want
|
|
|
|
|
;; the resulting path to stay relative if `dir' is relative.
|
|
|
|
|
(concat dir (cvs-fileinfo->file fileinfo)))))
|
2008-04-18 10:31:54 +00:00
|
|
|
|
(define-obsolete-function-alias 'cvs-fileinfo->full-path
|
|
|
|
|
'cvs-fileinfo->full-name "22.1")
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
(defun cvs-fileinfo->pp-name (fi)
|
|
|
|
|
"Return the filename of FI as it should be displayed."
|
2005-04-26 20:35:42 +00:00
|
|
|
|
(if cvs-display-full-name
|
|
|
|
|
(cvs-fileinfo->full-name fi)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(cvs-fileinfo->file fi)))
|
|
|
|
|
|
|
|
|
|
(defun cvs-fileinfo->backup-file (fileinfo)
|
|
|
|
|
"Construct the file name of the backup file for FILEINFO."
|
|
|
|
|
(let* ((dir (cvs-fileinfo->dir fileinfo))
|
|
|
|
|
(file (cvs-fileinfo->file fileinfo))
|
|
|
|
|
(default-directory (file-name-as-directory (expand-file-name dir)))
|
|
|
|
|
(files (directory-files "." nil
|
2004-03-04 22:44:23 +00:00
|
|
|
|
(concat "\\`" (regexp-quote cvs-bakprefix)
|
|
|
|
|
(regexp-quote file) "\\(\\.[0-9]+\\.[0-9]+\\)+\\'")))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
bf)
|
2005-04-26 20:35:42 +00:00
|
|
|
|
(dolist (f files)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(when (and (file-readable-p f)
|
|
|
|
|
(or (null bf) (file-newer-than-file-p f bf)))
|
2005-04-26 20:35:42 +00:00
|
|
|
|
(setq bf f)))
|
|
|
|
|
(concat dir bf)))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
;; (defun cvs-fileinfo->handled (fileinfo)
|
|
|
|
|
;; "Tell if this requires further action"
|
|
|
|
|
;; (memq (cvs-fileinfo->type fileinfo) '(UP-TO-DATE DEAD)))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
;; Predicate:
|
|
|
|
|
|
|
|
|
|
(defun cvs-check-fileinfo (fi)
|
|
|
|
|
"Check FI's conformance to some conventions."
|
|
|
|
|
(let ((check 'none)
|
|
|
|
|
(type (cvs-fileinfo->type fi))
|
|
|
|
|
(subtype (cvs-fileinfo->subtype fi))
|
|
|
|
|
(marked (cvs-fileinfo->marked fi))
|
|
|
|
|
(dir (cvs-fileinfo->dir fi))
|
|
|
|
|
(file (cvs-fileinfo->file fi))
|
|
|
|
|
(base-rev (cvs-fileinfo->base-rev fi))
|
|
|
|
|
(head-rev (cvs-fileinfo->head-rev fi))
|
|
|
|
|
(full-log (cvs-fileinfo->full-log fi)))
|
2002-09-11 01:56:47 +00:00
|
|
|
|
(if (and (setq check 'marked) (memq marked '(t nil))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(setq check 'base-rev) (or (null base-rev) (stringp base-rev))
|
|
|
|
|
(setq check 'head-rev) (or (null head-rev) (stringp head-rev))
|
|
|
|
|
(setq check 'full-log) (stringp full-log)
|
|
|
|
|
(setq check 'dir)
|
|
|
|
|
(and (stringp dir)
|
|
|
|
|
(not (file-name-absolute-p dir))
|
|
|
|
|
(or (string= dir "")
|
|
|
|
|
(string= dir (file-name-as-directory dir))))
|
|
|
|
|
(setq check 'file)
|
|
|
|
|
(and (stringp file)
|
|
|
|
|
(string= file (file-name-nondirectory file)))
|
|
|
|
|
(setq check 'type) (symbolp type)
|
|
|
|
|
(setq check 'consistency)
|
|
|
|
|
(case type
|
|
|
|
|
(DIRCHANGE (and (null subtype) (string= "." file)))
|
|
|
|
|
((NEED-UPDATE ADDED MISSING DEAD MODIFIED MESSAGE UP-TO-DATE
|
|
|
|
|
REMOVED NEED-MERGE CONFLICT UNKNOWN MESSAGE)
|
|
|
|
|
t)))
|
|
|
|
|
fi
|
|
|
|
|
(error "Invalid :%s in cvs-fileinfo %s" check fi))))
|
|
|
|
|
|
|
|
|
|
|
2003-02-04 12:29:42 +00:00
|
|
|
|
;;;;
|
2000-03-11 03:51:31 +00:00
|
|
|
|
;;;; State table to indicate what you can do when.
|
2003-02-04 12:29:42 +00:00
|
|
|
|
;;;;
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
(defconst cvs-states
|
2004-09-07 04:51:47 +00:00
|
|
|
|
`((NEED-UPDATE update diff ignore)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(UP-TO-DATE update nil remove diff safe-rm revert)
|
|
|
|
|
(MODIFIED update commit undo remove diff merge diff-base)
|
|
|
|
|
(ADDED update commit remove)
|
|
|
|
|
(MISSING remove undo update safe-rm revert)
|
|
|
|
|
(REMOVED commit add undo safe-rm)
|
|
|
|
|
(NEED-MERGE update undo diff diff-base)
|
|
|
|
|
(CONFLICT merge remove undo commit diff diff-base)
|
|
|
|
|
(DIRCHANGE remove update diff ,(if cvs-allow-dir-commit 'commit) tag)
|
|
|
|
|
(UNKNOWN ignore add remove)
|
|
|
|
|
(DEAD )
|
|
|
|
|
(MESSAGE))
|
|
|
|
|
"Fileinfo state descriptions for pcl-cvs.
|
|
|
|
|
This is an assoc list. Each element consists of (STATE . FUNS)
|
|
|
|
|
- STATE (described in `cvs-create-fileinfo') is the key
|
|
|
|
|
- FUNS is the list of applicable operations.
|
|
|
|
|
The first one (if any) should be the \"default\" action.
|
|
|
|
|
Most of the actions have the obvious meaning.
|
|
|
|
|
`safe-rm' indicates that the file can be removed without losing
|
|
|
|
|
any information.")
|
|
|
|
|
|
|
|
|
|
;;;;
|
|
|
|
|
;;;; Utility functions
|
|
|
|
|
;;;;
|
|
|
|
|
|
|
|
|
|
(defun cvs-applicable-p (fi-or-type func)
|
|
|
|
|
"Check if FUNC is applicable to FI-OR-TYPE.
|
|
|
|
|
If FUNC is nil, always return t.
|
|
|
|
|
FI-OR-TYPE can either be a symbol (a fileinfo-type) or a fileinfo."
|
|
|
|
|
(let ((type (if (symbolp fi-or-type) fi-or-type
|
|
|
|
|
(cvs-fileinfo->type fi-or-type))))
|
|
|
|
|
(and (not (eq type 'MESSAGE))
|
|
|
|
|
(eq (car (memq func (cdr (assq type cvs-states)))) func))))
|
|
|
|
|
|
2002-06-18 21:47:41 +00:00
|
|
|
|
(defun cvs-add-face (str face &optional keymap &rest props)
|
2002-06-18 23:03:55 +00:00
|
|
|
|
(when keymap
|
|
|
|
|
(when (keymapp keymap)
|
|
|
|
|
(setq props (list* 'keymap keymap props)))
|
|
|
|
|
(setq props (list* 'mouse-face 'highlight props)))
|
|
|
|
|
(add-text-properties 0 (length str) (list* 'font-lock-face face props) str)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
str)
|
|
|
|
|
|
|
|
|
|
(defun cvs-fileinfo-pp (fileinfo)
|
|
|
|
|
"Pretty print FILEINFO. Insert a printed representation in current buffer.
|
|
|
|
|
For use by the cookie package."
|
|
|
|
|
(cvs-check-fileinfo fileinfo)
|
|
|
|
|
(let ((type (cvs-fileinfo->type fileinfo))
|
|
|
|
|
(subtype (cvs-fileinfo->subtype fileinfo)))
|
|
|
|
|
(insert
|
|
|
|
|
(case type
|
|
|
|
|
(DIRCHANGE (concat "In directory "
|
2005-04-26 20:35:42 +00:00
|
|
|
|
(cvs-add-face (cvs-fileinfo->full-name fileinfo)
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
'cvs-header t 'cvs-goal-column t)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
":"))
|
|
|
|
|
(MESSAGE
|
2000-03-22 02:57:23 +00:00
|
|
|
|
(cvs-add-face (format "Message: %s" (cvs-fileinfo->full-log fileinfo))
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
'cvs-msg))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(t
|
|
|
|
|
(let* ((status (if (cvs-fileinfo->marked fileinfo)
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
(cvs-add-face "*" 'cvs-marked)
|
2000-03-11 03:51:31 +00:00
|
|
|
|
" "))
|
|
|
|
|
(file (cvs-add-face (cvs-fileinfo->pp-name fileinfo)
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
'cvs-filename t 'cvs-goal-column t))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(base (or (cvs-fileinfo->base-rev fileinfo) ""))
|
|
|
|
|
(head (cvs-fileinfo->head-rev fileinfo))
|
|
|
|
|
(type
|
|
|
|
|
(let ((str (case type
|
|
|
|
|
;;(MOD-CONFLICT "Not Removed")
|
|
|
|
|
(DEAD "")
|
|
|
|
|
(t (capitalize (symbol-name type)))))
|
2000-06-12 04:37:50 +00:00
|
|
|
|
(face (let ((sym (intern
|
|
|
|
|
(concat "cvs-fi-"
|
|
|
|
|
(downcase (symbol-name type))
|
|
|
|
|
"-face"))))
|
|
|
|
|
(or (and (boundp sym) (symbol-value sym))
|
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-379
Remove "-face" suffix from pcvs faces
2005-06-10 Miles Bader <miles@gnu.org>
* lisp/pcvs-info.el (cvs-header, cvs-filename, cvs-unknown)
(cvs-handled, cvs-need-action, cvs-marked, cvs-msg):
Remove "-face" suffix from face names.
(cvs-header-face, cvs-filename-face, cvs-unknown-face)
(cvs-handled-face, cvs-need-action-face, cvs-marked-face)
(cvs-msg-face): New backward-compatibility aliases for renamed faces.
(cvs-fi-up-to-date-face, cvs-fi-unknown-face, cvs-fileinfo-pp):
Use renamed pcvs faces.
2005-06-10 09:06:16 +00:00
|
|
|
|
'cvs-need-action))))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(cvs-add-face str face cvs-status-map)))
|
|
|
|
|
(side (or
|
|
|
|
|
;; maybe a subtype
|
|
|
|
|
(when subtype (downcase (symbol-name subtype)))
|
|
|
|
|
;; or the head-rev
|
|
|
|
|
(when (and head (not (string= head base))) head)
|
|
|
|
|
;; or nothing
|
2000-03-22 02:57:23 +00:00
|
|
|
|
"")))
|
2002-04-03 16:56:36 +00:00
|
|
|
|
(format "%-11s %s %-11s %-11s %s"
|
2006-05-18 12:09:16 +00:00
|
|
|
|
side status type base file))))
|
|
|
|
|
"\n")))
|
2000-03-11 03:51:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(defun cvs-fileinfo-update (fi fi-new)
|
|
|
|
|
"Update FI with the information provided in FI-NEW."
|
|
|
|
|
(let ((type (cvs-fileinfo->type fi-new))
|
|
|
|
|
(merge (cvs-fileinfo->merge fi-new)))
|
|
|
|
|
(setf (cvs-fileinfo->type fi) type)
|
|
|
|
|
(setf (cvs-fileinfo->subtype fi) (cvs-fileinfo->subtype fi-new))
|
|
|
|
|
(setf (cvs-fileinfo->full-log fi) (cvs-fileinfo->full-log fi-new))
|
|
|
|
|
(setf (cvs-fileinfo->base-rev fi) (cvs-fileinfo->base-rev fi-new))
|
|
|
|
|
(setf (cvs-fileinfo->head-rev fi) (cvs-fileinfo->head-rev fi-new))
|
|
|
|
|
(cond
|
|
|
|
|
(merge (setf (cvs-fileinfo->merge fi) merge))
|
|
|
|
|
((memq type '(UP-TO-DATE NEED-UPDATE))
|
|
|
|
|
(setf (cvs-fileinfo->merge fi) nil)))))
|
|
|
|
|
|
|
|
|
|
(defun cvs-fileinfo< (a b)
|
|
|
|
|
"Compare fileinfo A with fileinfo B and return t if A is `less'.
|
|
|
|
|
The ordering defined by this function is such that directories are
|
|
|
|
|
sorted alphabetically, and inside every directory the DIRCHANGE
|
|
|
|
|
fileinfo will appear first, followed by all files (alphabetically)."
|
|
|
|
|
(let ((subtypea (cvs-fileinfo->subtype a))
|
|
|
|
|
(subtypeb (cvs-fileinfo->subtype b)))
|
|
|
|
|
(cond
|
|
|
|
|
;; Sort according to directories.
|
|
|
|
|
((string< (cvs-fileinfo->dir a) (cvs-fileinfo->dir b)) t)
|
|
|
|
|
((not (string= (cvs-fileinfo->dir a) (cvs-fileinfo->dir b))) nil)
|
|
|
|
|
|
|
|
|
|
;; The DIRCHANGE entry is always first within the directory.
|
|
|
|
|
((eq (cvs-fileinfo->type b) 'DIRCHANGE) nil)
|
|
|
|
|
((eq (cvs-fileinfo->type a) 'DIRCHANGE) t)
|
|
|
|
|
|
|
|
|
|
;; All files are sorted by file name.
|
|
|
|
|
((string< (cvs-fileinfo->file a) (cvs-fileinfo->file b))))))
|
|
|
|
|
|
2000-06-12 04:37:50 +00:00
|
|
|
|
;;;
|
|
|
|
|
;;; Look at CVS/Entries to quickly find a first approximation of the status
|
|
|
|
|
;;;
|
|
|
|
|
|
|
|
|
|
(defun cvs-fileinfo-from-entries (dir &optional all)
|
|
|
|
|
"List of fileinfos for DIR, extracted from CVS/Entries.
|
|
|
|
|
Unless ALL is optional, returns only the files that are not up-to-date.
|
|
|
|
|
DIR can also be a file."
|
|
|
|
|
(let* ((singlefile
|
|
|
|
|
(cond
|
|
|
|
|
((equal dir "") nil)
|
|
|
|
|
((file-directory-p dir) (setq dir (file-name-as-directory dir)) nil)
|
|
|
|
|
(t (prog1 (file-name-nondirectory dir)
|
|
|
|
|
(setq dir (or (file-name-directory dir) ""))))))
|
|
|
|
|
(file (expand-file-name "CVS/Entries" dir))
|
|
|
|
|
(fis nil))
|
|
|
|
|
(if (not (file-readable-p file))
|
|
|
|
|
(push (cvs-create-fileinfo (if singlefile 'UNKNOWN 'DIRCHANGE)
|
|
|
|
|
dir (or singlefile ".") "") fis)
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert-file-contents file)
|
|
|
|
|
(goto-char (point-min))
|
|
|
|
|
;; Select the single file entry in case we're only interested in a file.
|
|
|
|
|
(cond
|
|
|
|
|
((not singlefile)
|
|
|
|
|
(push (cvs-create-fileinfo 'DIRCHANGE dir "." "") fis))
|
|
|
|
|
((re-search-forward
|
|
|
|
|
(concat "^[^/]*/" (regexp-quote singlefile) "/.*") nil t)
|
|
|
|
|
(setq all t)
|
|
|
|
|
(goto-char (match-beginning 0))
|
|
|
|
|
(narrow-to-region (point) (match-end 0)))
|
|
|
|
|
(t
|
|
|
|
|
(push (cvs-create-fileinfo 'UNKNOWN dir singlefile "") fis)
|
|
|
|
|
(narrow-to-region (point-min) (point-min))))
|
|
|
|
|
(while (looking-at "\\([^/]*\\)/\\([^/]*\\)/\\([^/]*\\)/\\([^/]*\\)/")
|
|
|
|
|
(if (/= (match-beginning 1) (match-end 1))
|
|
|
|
|
(setq fis (append (cvs-fileinfo-from-entries
|
|
|
|
|
(concat dir (file-name-as-directory
|
|
|
|
|
(match-string 2)))
|
|
|
|
|
all)
|
|
|
|
|
fis))
|
|
|
|
|
(let ((f (match-string 2))
|
|
|
|
|
(rev (match-string 3))
|
|
|
|
|
(date (match-string 4))
|
|
|
|
|
timestamp
|
|
|
|
|
(type 'MODIFIED)
|
|
|
|
|
(subtype nil))
|
|
|
|
|
(cond
|
|
|
|
|
((equal (substring rev 0 1) "-")
|
|
|
|
|
(setq type 'REMOVED rev (substring rev 1)))
|
|
|
|
|
((not (file-exists-p (concat dir f))) (setq type 'MISSING))
|
|
|
|
|
((equal rev "0") (setq type 'ADDED rev nil))
|
|
|
|
|
((equal date "Result of merge") (setq subtype 'MERGED))
|
|
|
|
|
((let ((mtime (nth 5 (file-attributes (concat dir f))))
|
|
|
|
|
(system-time-locale "C"))
|
2003-01-14 21:53:39 +00:00
|
|
|
|
(setq timestamp (format-time-string "%c" mtime 'utc))
|
|
|
|
|
;; Solaris sometimes uses "Wed Sep 05", not "Wed Sep 5".
|
|
|
|
|
;; See "grep '[^a-z_]ctime' cvs/src/*.c" for reference.
|
|
|
|
|
(if (= (aref timestamp 8) ?0)
|
|
|
|
|
(setq timestamp (concat (substring timestamp 0 8)
|
|
|
|
|
" " (substring timestamp 9))))
|
|
|
|
|
(equal timestamp date))
|
2000-06-12 04:37:50 +00:00
|
|
|
|
(setq type (if all 'UP-TO-DATE)))
|
|
|
|
|
((equal date (concat "Result of merge+" timestamp))
|
|
|
|
|
(setq type 'CONFLICT)))
|
|
|
|
|
(when type
|
|
|
|
|
(push (cvs-create-fileinfo type dir f ""
|
|
|
|
|
:base-rev rev :subtype subtype)
|
|
|
|
|
fis))))
|
|
|
|
|
(forward-line 1))))
|
|
|
|
|
fis))
|
|
|
|
|
|
2000-03-11 03:51:31 +00:00
|
|
|
|
(provide 'pcvs-info)
|
|
|
|
|
|
2004-09-07 04:51:47 +00:00
|
|
|
|
;; arch-tag: d85dde07-bdc2-400a-882f-92f398c7b0ba
|
2001-07-16 07:46:48 +00:00
|
|
|
|
;;; pcvs-info.el ends here
|