X7ROOT File Manager
Current Path:
/lib64/python2.7/Tools/scripts
lib64
/
python2.7
/
Tools
/
scripts
/
??
..
??
analyze_dxp.py
(4.11 KB)
??
analyze_dxp.pyc
(4.64 KB)
??
analyze_dxp.pyo
(4.64 KB)
??
byext.py
(3.85 KB)
??
byext.pyc
(4.42 KB)
??
byext.pyo
(4.42 KB)
??
byteyears.py
(1.6 KB)
??
byteyears.pyc
(1.37 KB)
??
byteyears.pyo
(1.37 KB)
??
checkappend.py
(4.55 KB)
??
checkappend.pyc
(4.77 KB)
??
checkappend.pyo
(4.77 KB)
??
checkpip.py
(757 B)
??
checkpip.pyc
(1.02 KB)
??
checkpip.pyo
(1.02 KB)
??
checkpyc.py
(1.96 KB)
??
checkpyc.pyc
(1.93 KB)
??
checkpyc.pyo
(1.93 KB)
??
classfix.py
(5.81 KB)
??
classfix.pyc
(4.09 KB)
??
classfix.pyo
(4.09 KB)
??
cleanfuture.py
(8.38 KB)
??
cleanfuture.pyc
(7.22 KB)
??
cleanfuture.pyo
(7.19 KB)
??
combinerefs.py
(4.28 KB)
??
combinerefs.pyc
(4.16 KB)
??
combinerefs.pyo
(4.12 KB)
??
copytime.py
(663 B)
??
copytime.pyc
(937 B)
??
copytime.pyo
(937 B)
??
crlf.py
(610 B)
??
crlf.pyc
(855 B)
??
crlf.pyo
(855 B)
??
cvsfiles.py
(1.74 KB)
??
cvsfiles.pyc
(2.11 KB)
??
cvsfiles.pyo
(2.11 KB)
??
db2pickle.py
(3.49 KB)
??
db2pickle.pyc
(3.42 KB)
??
db2pickle.pyo
(3.42 KB)
??
diff.py
(2.02 KB)
??
diff.pyc
(2.33 KB)
??
diff.pyo
(2.33 KB)
??
dutree.py
(1.58 KB)
??
dutree.pyc
(2.18 KB)
??
dutree.pyo
(2.18 KB)
??
eptags.py
(1.45 KB)
??
eptags.pyc
(1.83 KB)
??
eptags.pyo
(1.83 KB)
??
find_recursionlimit.py
(3.39 KB)
??
find_recursionlimit.pyc
(5.54 KB)
??
find_recursionlimit.pyo
(5.54 KB)
??
finddiv.py
(2.46 KB)
??
finddiv.pyc
(3.22 KB)
??
finddiv.pyo
(3.22 KB)
??
findlinksto.py
(1.04 KB)
??
findlinksto.pyc
(1.39 KB)
??
findlinksto.pyo
(1.39 KB)
??
findnocoding.py
(2.74 KB)
??
findnocoding.pyc
(3.13 KB)
??
findnocoding.pyo
(3.13 KB)
??
fixcid.py
(9.76 KB)
??
fixcid.pyc
(7.67 KB)
??
fixcid.pyo
(7.67 KB)
??
fixdiv.py
(13.52 KB)
??
fixdiv.pyc
(13.52 KB)
??
fixdiv.pyo
(13.44 KB)
??
fixheader.py
(1.16 KB)
??
fixheader.pyc
(1.44 KB)
??
fixheader.pyo
(1.44 KB)
??
fixnotice.py
(2.98 KB)
??
fixnotice.pyc
(3.42 KB)
??
fixnotice.pyo
(3.42 KB)
??
fixps.py
(893 B)
??
fixps.pyc
(969 B)
??
fixps.pyo
(969 B)
??
google.py
(519 B)
??
google.pyc
(792 B)
??
google.pyo
(792 B)
??
gprof2html.py
(2.12 KB)
??
gprof2html.pyc
(2.22 KB)
??
gprof2html.pyo
(2.22 KB)
??
h2py.py
(5.81 KB)
??
h2py.pyc
(4.29 KB)
??
h2py.pyo
(4.29 KB)
??
hotshotmain.py
(1.45 KB)
??
hotshotmain.pyc
(1.82 KB)
??
hotshotmain.pyo
(1.82 KB)
??
ifdef.py
(3.63 KB)
??
ifdef.pyc
(2.21 KB)
??
ifdef.pyo
(2.21 KB)
??
lfcr.py
(618 B)
??
lfcr.pyc
(880 B)
??
lfcr.pyo
(880 B)
??
linktree.py
(2.37 KB)
??
linktree.pyc
(1.98 KB)
??
linktree.pyo
(1.98 KB)
??
lll.py
(742 B)
??
lll.pyc
(942 B)
??
lll.pyo
(942 B)
??
logmerge.py
(5.44 KB)
??
logmerge.pyc
(4.96 KB)
??
logmerge.pyo
(4.96 KB)
??
mailerdaemon.py
(7.76 KB)
??
mailerdaemon.pyc
(7.19 KB)
??
mailerdaemon.pyo
(7.19 KB)
??
md5sum.py
(2.33 KB)
??
md5sum.pyc
(2.85 KB)
??
md5sum.pyo
(2.85 KB)
??
methfix.py
(5.33 KB)
??
methfix.pyc
(4.03 KB)
??
methfix.pyo
(4.03 KB)
??
mkreal.py
(1.59 KB)
??
mkreal.pyc
(1.93 KB)
??
mkreal.pyo
(1.93 KB)
??
ndiff.py
(3.72 KB)
??
ndiff.pyc
(3.77 KB)
??
ndiff.pyo
(3.77 KB)
??
nm2def.py
(2.39 KB)
??
nm2def.pyc
(2.89 KB)
??
nm2def.pyo
(2.89 KB)
??
objgraph.py
(5.88 KB)
??
objgraph.pyc
(4.82 KB)
??
objgraph.pyo
(4.82 KB)
??
parseentities.py
(1.68 KB)
??
parseentities.pyc
(2.03 KB)
??
parseentities.pyo
(2.03 KB)
??
patchcheck.py
(7.5 KB)
??
patchcheck.pyc
(8.91 KB)
??
patchcheck.pyo
(8.91 KB)
??
pathfix.py
(4.23 KB)
??
pathfix.pyc
(3.75 KB)
??
pathfix.pyo
(3.75 KB)
??
pdeps.py
(3.84 KB)
??
pdeps.pyc
(3.14 KB)
??
pdeps.pyo
(3.14 KB)
??
pickle2db.py
(3.85 KB)
??
pickle2db.pyc
(3.73 KB)
??
pickle2db.pyo
(3.73 KB)
??
pindent.py
(16.77 KB)
??
pindent.pyc
(11.29 KB)
??
pindent.pyo
(11.29 KB)
??
ptags.py
(1.2 KB)
??
ptags.pyc
(1.37 KB)
??
ptags.pyo
(1.37 KB)
??
pysource.py
(3.76 KB)
??
pysource.pyc
(3.92 KB)
??
pysource.pyo
(3.92 KB)
??
redemo.py
(5.66 KB)
??
redemo.pyc
(5.13 KB)
??
redemo.pyo
(5.13 KB)
??
reindent-rst.py
(278 B)
??
reindent-rst.pyc
(481 B)
??
reindent-rst.pyo
(481 B)
??
reindent.py
(11.15 KB)
??
reindent.pyc
(9.4 KB)
??
reindent.pyo
(9.37 KB)
??
rgrep.py
(1.46 KB)
??
rgrep.pyc
(1.84 KB)
??
rgrep.pyo
(1.84 KB)
??
serve.py
(1.12 KB)
??
serve.pyc
(1.56 KB)
??
serve.pyo
(1.56 KB)
??
setup.py
(421 B)
??
setup.pyc
(548 B)
??
setup.pyo
(548 B)
??
suff.py
(621 B)
??
suff.pyc
(904 B)
??
suff.pyo
(904 B)
??
svneol.py
(2.86 KB)
??
svneol.pyc
(2.84 KB)
??
svneol.pyo
(2.76 KB)
??
texcheck.py
(9.04 KB)
??
texcheck.pyc
(8.18 KB)
??
texcheck.pyo
(8.18 KB)
??
texi2html.py
(68.19 KB)
??
texi2html.pyc
(81.37 KB)
??
texi2html.pyo
(81.37 KB)
??
treesync.py
(5.65 KB)
??
treesync.pyc
(5.85 KB)
??
treesync.pyo
(5.85 KB)
??
untabify.py
(1.19 KB)
??
untabify.pyc
(1.55 KB)
??
untabify.pyo
(1.55 KB)
??
which.py
(1.59 KB)
??
which.pyc
(1.59 KB)
??
which.pyo
(1.59 KB)
??
win_add2path.py
(1.58 KB)
??
win_add2path.pyc
(2.02 KB)
??
win_add2path.pyo
(2.02 KB)
??
xxci.py
(2.73 KB)
??
xxci.pyc
(3.92 KB)
??
xxci.pyo
(3.92 KB)
Editing: treesync.py
#! /usr/bin/python2.7 """Script to synchronize two source trees. Invoke with two arguments: python treesync.py slave master The assumption is that "master" contains CVS administration while slave doesn't. All files in the slave tree that have a CVS/Entries entry in the master tree are synchronized. This means: If the files differ: if the slave file is newer: normalize the slave file if the files still differ: copy the slave to the master else (the master is newer): copy the master to the slave normalizing the slave means replacing CRLF with LF when the master doesn't use CRLF """ import os, sys, stat, getopt # Interactivity options default_answer = "ask" create_files = "yes" create_directories = "no" write_slave = "ask" write_master = "ask" def main(): global always_no, always_yes global create_directories, write_master, write_slave opts, args = getopt.getopt(sys.argv[1:], "nym:s:d:f:a:") for o, a in opts: if o == '-y': default_answer = "yes" if o == '-n': default_answer = "no" if o == '-s': write_slave = a if o == '-m': write_master = a if o == '-d': create_directories = a if o == '-f': create_files = a if o == '-a': create_files = create_directories = write_slave = write_master = a try: [slave, master] = args except ValueError: print "usage: python", sys.argv[0] or "treesync.py", print "[-n] [-y] [-m y|n|a] [-s y|n|a] [-d y|n|a] [-f n|y|a]", print "slavedir masterdir" return process(slave, master) def process(slave, master): cvsdir = os.path.join(master, "CVS") if not os.path.isdir(cvsdir): print "skipping master subdirectory", master print "-- not under CVS" return print "-"*40 print "slave ", slave print "master", master if not os.path.isdir(slave): if not okay("create slave directory %s?" % slave, answer=create_directories): print "skipping master subdirectory", master print "-- no corresponding slave", slave return print "creating slave directory", slave try: os.mkdir(slave) except os.error, msg: print "can't make slave directory", slave, ":", msg return else: print "made slave directory", slave cvsdir = None subdirs = [] names = os.listdir(master) for name in names: mastername = os.path.join(master, name) slavename = os.path.join(slave, name) if name == "CVS": cvsdir = mastername else: if os.path.isdir(mastername) and not os.path.islink(mastername): subdirs.append((slavename, mastername)) if cvsdir: entries = os.path.join(cvsdir, "Entries") for e in open(entries).readlines(): words = e.split('/') if words[0] == '' and words[1:]: name = words[1] s = os.path.join(slave, name) m = os.path.join(master, name) compare(s, m) for (s, m) in subdirs: process(s, m) def compare(slave, master): try: sf = open(slave, 'r') except IOError: sf = None try: mf = open(master, 'rb') except IOError: mf = None if not sf: if not mf: print "Neither master nor slave exists", master return print "Creating missing slave", slave copy(master, slave, answer=create_files) return if not mf: print "Not updating missing master", master return if sf and mf: if identical(sf, mf): return sft = mtime(sf) mft = mtime(mf) if mft > sft: # Master is newer -- copy master to slave sf.close() mf.close() print "Master ", master print "is newer than slave", slave copy(master, slave, answer=write_slave) return # Slave is newer -- copy slave to master print "Slave is", sft-mft, "seconds newer than master" # But first check what to do about CRLF mf.seek(0) fun = funnychars(mf) mf.close() sf.close() if fun: print "***UPDATING MASTER (BINARY COPY)***" copy(slave, master, "rb", answer=write_master) else: print "***UPDATING MASTER***" copy(slave, master, "r", answer=write_master) BUFSIZE = 16*1024 def identical(sf, mf): while 1: sd = sf.read(BUFSIZE) md = mf.read(BUFSIZE) if sd != md: return 0 if not sd: break return 1 def mtime(f): st = os.fstat(f.fileno()) return st[stat.ST_MTIME] def funnychars(f): while 1: buf = f.read(BUFSIZE) if not buf: break if '\r' in buf or '\0' in buf: return 1 return 0 def copy(src, dst, rmode="rb", wmode="wb", answer='ask'): print "copying", src print " to", dst if not okay("okay to copy? ", answer): return f = open(src, rmode) g = open(dst, wmode) while 1: buf = f.read(BUFSIZE) if not buf: break g.write(buf) f.close() g.close() def okay(prompt, answer='ask'): answer = answer.strip().lower() if not answer or answer[0] not in 'ny': answer = raw_input(prompt) answer = answer.strip().lower() if not answer: answer = default_answer if answer[:1] == 'y': return 1 if answer[:1] == 'n': return 0 print "Yes or No please -- try again:" return okay(prompt) if __name__ == '__main__': main()
Upload File
Create Folder