summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xDemo/pdist/rcvs.py118
1 files changed, 70 insertions, 48 deletions
diff --git a/Demo/pdist/rcvs.py b/Demo/pdist/rcvs.py
index 9d14ad4..aeff6c8 100755
--- a/Demo/pdist/rcvs.py
+++ b/Demo/pdist/rcvs.py
@@ -34,6 +34,10 @@ class MyFile(File):
'c' -- create entry
'u' -- update entry
"""
+ if not self.lseen:
+ self.getlocal()
+ if not self.rseen:
+ self.getremote()
if not self.eseen:
if not self.lseen:
if not self.rseen: return '0' # Never heard of
@@ -114,6 +118,7 @@ class MyFile(File):
self.file
def diff(self, opts = []):
+ self.action() # To update lseen, rseen
if self.lsum == self.rsum:
return
import tempfile
@@ -170,25 +175,63 @@ class RCVS(CVS):
def __init__(self):
CVS.__init__(self)
- def checkfiles(self, files):
- if not files:
- def ok(file, self=self):
- e = self.entries[file]
- return e.eseen or e.rseen
- files[:] = filter(ok, self.entries.keys())
- files.sort()
- if not files:
- print "no files to be processed"
- return 1
- else:
- return None
- else:
- sts = None
+ def update(self, files):
+ for e in self.whichentries(files, 1):
+ e.update()
+
+ def commit(self, files, message = ""):
+ list = self.whichentries(files)
+ ok = 1
+ for e in list:
+ if not e.commitcheck():
+ ok = 0
+ if not ok:
+ print "correct above errors first"
+ return
+ if not message:
+ message = raw_input("One-liner: ")
+ for e in list:
+ e.commit(message)
+
+ def report(self, files):
+ for e in self.whichentries(files):
+ e.report()
+
+ def diff(self, files, opts):
+ for e in self.whichentries(files):
+ e.diff(opts)
+
+ def whichentries(self, files, localfilestoo = 0):
+ if files:
+ list = []
for file in files:
- if not self.entries.has_key(file):
- print "%s: nothing known" % file
- sts = 1
- return sts
+ if self.entries.has_key(file):
+ e = self.entries[file]
+ else:
+ e = self.FileClass(file)
+ self.entries[file] = e
+ list.append(e)
+ else:
+ list = self.entries.values()
+ for file in self.proxy.listfiles():
+ if self.entries.has_key(file):
+ continue
+ e = self.FileClass(file)
+ self.entries[file] = e
+ list.append(e)
+ if localfilestoo:
+ for file in os.listdir(os.curdir):
+ if not self.entries.has_key(file) \
+ and not self.ignored(file):
+ e = self.FileClass(file)
+ self.entries[file] = e
+ list.append(e)
+ list.sort()
+ if self.proxy:
+ for e in list:
+ if e.proxy is None:
+ e.proxy = self.proxy
+ return list
class rcvs(CommandFrameWork):
@@ -213,50 +256,29 @@ class rcvs(CommandFrameWork):
self.proxy = rcsclient.openrcsclient(self.opts)
self.cvs.setproxy(self.proxy)
self.cvs.getentries()
- self.cvs.getlocalfiles()
- self.cvs.getremotefiles(self.proxy)
def default(self):
- files = []
- if self.cvs.checkfiles(files):
- return 1
- for file in files:
- print self.cvs.entries[file].action(), file
+ self.cvs.report([])
def do_update(self, opts, files):
"""update [file] ..."""
- if self.cvs.checkfiles(files):
- return 1
- for file in files:
- if not self.cvs.entries.has_key(file):
- print "%s: not found" % file
- else:
- self.cvs.entries[file].update()
+ self.cvs.update(files)
self.cvs.putentries()
do_up = do_update
def do_commit(self, opts, files):
- """commit [file] ..."""
- if self.cvs.checkfiles(files):
- return 1
- sts = 0
- for file in files:
- if not self.cvs.entries[file].commitcheck():
- sts = 1
- if sts:
- return sts
- message = raw_input("One-liner: ")
- for file in files:
- self.cvs.entries[file].commit(message)
+ """commit [-m message] [file] ..."""
+ message = ""
+ for o, a in opts:
+ if o == '-m': message = a
+ self.cvs.commit(files, message)
self.cvs.putentries()
do_com = do_commit
+ flags_commit = 'm:'
def do_diff(self, opts, files):
"""diff [difflags] [file] ..."""
- if self.cvs.checkfiles(files):
- return 1
- for file in files:
- self.cvs.entries[file].diff(opts)
+ self.cvs.diff(files, opts)
do_dif = do_diff
flags_diff = 'cbitwcefhnlrsD:S:'