changeset 47226:31f2c4b2c82f

Require vc.el at compile-time. (vc-workfile-unchanged-p, vc-default-workfile-unchanged-p): Moved here from vc.el.
author André Spiegel <spiegel@gnu.org>
date Wed, 04 Sep 2002 20:45:34 +0000
parents 076200146323
children e7b1564342e2
files lisp/vc-hooks.el
diffstat 1 files changed, 17 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/vc-hooks.el	Wed Sep 04 19:11:28 2002 +0000
+++ b/lisp/vc-hooks.el	Wed Sep 04 20:45:34 2002 +0000
@@ -5,7 +5,7 @@
 ;; Author:     FSF (see vc.el for full credits)
 ;; Maintainer: Andre Spiegel <spiegel@gnu.org>
 
-;; $Id: vc-hooks.el,v 1.142 2002/07/29 02:40:40 rms Exp $
+;; $Id: vc-hooks.el,v 1.143 2002/08/23 13:23:14 spiegel Exp $
 
 ;; This file is part of GNU Emacs.
 
@@ -34,6 +34,7 @@
 ;;; Code:
 
 (eval-when-compile
+  (require 'vc)
   (require 'cl))
 
 ;; Customization Variables (the rest is in vc.el)
@@ -382,6 +383,21 @@
 and does not employ any heuristic at all."
    (vc-call-backend backend 'state file))
 
+(defun vc-workfile-unchanged-p (file)
+  "Return non-nil if FILE has not changed since the last checkout."
+  (let ((checkout-time (vc-file-getprop file 'vc-checkout-time))
+        (lastmod (nth 5 (file-attributes file))))
+    (if checkout-time
+        (equal checkout-time lastmod)
+      (let ((unchanged (vc-call workfile-unchanged-p file)))
+        (vc-file-setprop file 'vc-checkout-time (if unchanged lastmod 0))
+        unchanged))))
+
+(defun vc-default-workfile-unchanged-p (backend file)
+  "Check if FILE is unchanged by diffing against the master version.
+Return non-nil if FILE is unchanged."
+  (zerop (vc-call diff file (vc-workfile-version file))))
+
 (defun vc-workfile-version (file)
   "Return the version level of the current workfile FILE.
 If FILE is not registered, this function always returns nil."
@@ -390,8 +406,6 @@
           (vc-file-setprop file 'vc-workfile-version
                            (vc-call workfile-version file)))))
 
-;;; actual version-control code starts here
-
 (defun vc-default-registered (backend file)
   "Check if FILE is registered in BACKEND using vc-BACKEND-master-templates."
   (let ((sym (vc-make-backend-sym backend 'master-templates)))