annotate treepkg/util.py @ 494:31b64ebe4b42

determine upstream_version of a package original patch by Andre
author Bjoern Ricks <bricks@intevation.de>
date Wed, 13 Oct 2010 16:26:53 +0000
parents 058856954e2d
children ca95be9d033a
rev   line source
110
ba677506e95e Remove StatusFile. It has been superseded by the treepkg.util module
Bernhard Herzog <bh@intevation.de>
parents: 88
diff changeset
1 # Copyright (C) 2007, 2008 by Intevation GmbH
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
2 # Authors:
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
3 # Bernhard Herzog <bh@intevation.de>
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
4 #
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
5 # This program is free software under the GPL (>=v2)
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
6 # Read the file COPYING coming with the software for details.
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
7
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
8 """Collection of functions that didn't fit elsewhere"""
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
9
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
10 import os
111
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
11 import re
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
12 import tempfile
4
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
13 import shutil
169
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
14 import fnmatch
344
f06f707d9fda merged branches/scratchbox into trunk
Bjoern Ricks <bricks@intevation.de>
parents: 172
diff changeset
15 import pwd
394
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
16 import os.path
461
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
17
458
61e72399914c Use an exception to use either hashlib or md5
Andre Heinecke <aheinecke@intevation.de>
parents: 457
diff changeset
18 try:
61e72399914c Use an exception to use either hashlib or md5
Andre Heinecke <aheinecke@intevation.de>
parents: 457
diff changeset
19 from hashlib import md5 as new_md5
61e72399914c Use an exception to use either hashlib or md5
Andre Heinecke <aheinecke@intevation.de>
parents: 457
diff changeset
20 except ImportError:
61e72399914c Use an exception to use either hashlib or md5
Andre Heinecke <aheinecke@intevation.de>
parents: 457
diff changeset
21 # fall back to md5 for Python versions before 2.5
61e72399914c Use an exception to use either hashlib or md5
Andre Heinecke <aheinecke@intevation.de>
parents: 457
diff changeset
22 from md5 import new as new_md5
461
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
23
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
24 import run
461
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
25 from cmdexpand import cmdexpand
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
26
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
27
4
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
28 def import_dotted_name(dotted_name):
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
29 module = __import__(dotted_name)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
30 for name in dotted_name.split(".")[1:]:
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
31 module = getattr(module, name)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
32 return module
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
33
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
34 def extract_value_for_key(lines, key):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
35 """Parses a sequence of strings for a key and returns the associated value
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
36
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
37 The function determines the first string in lines that starts with
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
38 key. It returns the rest of the lines stripped of leading and
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
39 trailing whitespace.
83
83e48a76f759 Document what extract_value_for_key returns when the key is not found
Bernhard Herzog <bh@intevation.de>
parents: 57
diff changeset
40
83e48a76f759 Document what extract_value_for_key returns when the key is not found
Bernhard Herzog <bh@intevation.de>
parents: 57
diff changeset
41 If the key is not found in lines, the function returns None.
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
42 """
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
43 for line in lines:
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
44 if line.startswith(key):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
45 return line[len(key):].strip()
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
46
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
47 def extract_lsm_version(lsm_file):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
48 return extract_value_for_key(open(lsm_file), "Version:")
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
49
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
50 def debian_changelog_version(changelog):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
51 """Returns the newest version in a debian changelog."""
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
52 output = run.capture_output(["dpkg-parsechangelog", "-l" + changelog])
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
53 return extract_value_for_key(output.splitlines(), "Version:")
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
54
494
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
55 def extract_cmakefile_version(cmakelist):
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
56 """ Returns the version mentioned in a CMakeList.txt """
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
57 major = re.compile(r"VERSION_MAJOR\s+(\d+)", re.IGNORECASE)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
58 minor = re.compile(r"VERSION_MINOR\s+(\d+)", re.IGNORECASE)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
59 patch = re.compile(r"VERSION_PATCH\s+(\d+)", re.IGNORECASE)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
60 version = ""
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
61 try:
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
62 for line in open(cmakelist):
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
63 major_match = major.match(line)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
64 minor_match = minor.match(line)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
65 patch_match = patch.match(line)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
66 if major_match:
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
67 version = major_match.group(1)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
68 if minor_match and version:
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
69 version += "." + minor_match.group(1)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
70 if patch_match:
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
71 version += "." + patch_match.group(1)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
72 except: pass
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
73 finally:
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
74 return version
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
75
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
76 def extract_configureac_version(configure_ac):
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
77 match = re.match(r"m4_define\(\[?my_version\]?, \[([^]]+)\]\)",
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
78 line)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
79 if match:
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
80 return match.group(1)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
81
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
82 match = re.match(r"AC_INIT\([a-zA-Z_]+, ([0-9.]+)", line)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
83 if match:
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
84 return match.group(1)
31b64ebe4b42 determine upstream_version of a package
Bjoern Ricks <bricks@intevation.de>
parents: 462
diff changeset
85 return ""
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
86
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
87 def ensure_directory(directory):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
88 """Creates directory and all its parents.
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
89
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
90 Unlike os.makedirs, this function doesn't throw an exception
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
91 """
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
92 if not os.path.isdir(directory):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
93 os.makedirs(directory)
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
94
169
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
95 def listdir_abs(directory, pattern=None):
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
96 """Like os.listdir, but returns a list of absolute pathnames.
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
97 Optionally, a glob pattern can be given to restrict the names
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
98 returned by the function.
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
99 """
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
100 filenames = os.listdir(directory)
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
101 if pattern is not None:
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
102 filenames = fnmatch.filter(filenames, pattern)
261b75d7b972 Extend listdir_abs with an optional glob pattern
Bernhard Herzog <bh@intevation.de>
parents: 160
diff changeset
103 return [os.path.join(directory, filename) for filename in filenames]
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
104
4
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
105 def copytree(src, dst, symlinks=False):
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
106 """Recursively copy a directory tree using copy2().
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
107
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
108 This version is basically the same as the one in the shutil module
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
109 in the python standard library, however, it's OK if the destination
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
110 directory already exists.
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
111
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
112 If the optional symlinks flag is true, symbolic links in the
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
113 source tree result in symbolic links in the destination tree; if
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
114 it is false, the contents of the files pointed to by symbolic
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
115 links are copied.
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
116 """
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
117 names = os.listdir(src)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
118 ensure_directory(dst)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
119 errors = []
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
120 for name in names:
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
121 srcname = os.path.join(src, name)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
122 dstname = os.path.join(dst, name)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
123 try:
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
124 if symlinks and os.path.islink(srcname):
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
125 linkto = os.readlink(srcname)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
126 os.symlink(linkto, dstname)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
127 elif os.path.isdir(srcname):
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
128 copytree(srcname, dstname, symlinks)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
129 else:
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
130 shutil.copy2(srcname, dstname)
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
131 # XXX What about devices, sockets etc.?
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
132 except (IOError, os.error), why:
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
133 errors.append((srcname, dstname, why))
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
134 if errors:
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
135 raise Error, errors
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
136
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
137
fee641fec94e Separate the kolab specific parts.
Bernhard Herzog <bh@intevation.de>
parents: 0
diff changeset
138
57
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
139 def writefile(filename, contents, permissions=None):
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
140 """Write contents to filename in an atomic way.
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
141
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
142 The contents are first written to a temporary file in the same
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
143 directory as filename. Once the contents are written, the temporary
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
144 file is closed and renamed to filename.
57
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
145
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
146 The optional parameter permissions, if given, are the permissions
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
147 for the new file. By default, or if the parameter is None, the
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
148 default permissions set by the tempfile.mkstemp are used which means
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
149 that the file is only readable for the user that created the file.
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
150 The permissions value is used as the second parameter to os.chmod.
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
151 """
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
152 dirname, basename = os.path.split(filename)
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
153 fileno, tempname = tempfile.mkstemp("", basename, dirname)
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
154 try:
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
155 os.write(fileno, contents)
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
156 if not contents.endswith("\n"):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
157 os.write(fileno, "\n")
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
158 os.close(fileno)
57
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
159 if permissions is not None:
d0d08c7e7d37 allow optionally set the file permissions in writefile
Bernhard Herzog <bh@intevation.de>
parents: 14
diff changeset
160 os.chmod(tempname, permissions)
0
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
161 os.rename(tempname, filename)
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
162 finally:
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
163 if os.path.exists(tempname):
f78a02e79c84 initial checkin
Bernhard Herzog <bh@intevation.de>
parents:
diff changeset
164 os.remove(tempname)
111
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
165
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
166
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
167 def replace_in_file(filename, pattern, replacement):
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
168 """Replace all occurrences of pattern in a file with replacement.
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
169 The file is modified in place. The search and replace is done with
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
170 the re.sub function. The pattern and replacement parameter are passed
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
171 through to re.sub unmodified, so their semantics are determined by
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
172 re.sub.
160
017179427c7f Make treepkg/utilreplace_in_file return whether any substitutions were made.
Bernhard Herzog <bh@intevation.de>
parents: 111
diff changeset
173
017179427c7f Make treepkg/utilreplace_in_file return whether any substitutions were made.
Bernhard Herzog <bh@intevation.de>
parents: 111
diff changeset
174 The return value is True if the contents of the file have been
017179427c7f Make treepkg/utilreplace_in_file return whether any substitutions were made.
Bernhard Herzog <bh@intevation.de>
parents: 111
diff changeset
175 changed, False otherwise.
111
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
176 """
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
177 contents = open(filename).read()
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
178 modified = re.sub(pattern, replacement, contents)
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
179 f = open(filename, "w")
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
180 f.write(modified)
7f6fb8103db0 Move the sed-like replacement code from enterprise/kdepim.py to treepkg/util.py
Bernhard Herzog <bh@intevation.de>
parents: 110
diff changeset
181 f.close()
160
017179427c7f Make treepkg/utilreplace_in_file return whether any substitutions were made.
Bernhard Herzog <bh@intevation.de>
parents: 111
diff changeset
182 return modified != contents
172
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
183
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
184
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
185 def filenameproperty(filename, dir_attr="base_dir"):
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
186 """Create a property for a directory or filename.
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
187 If the filename is relative it is interpreted as relative to the
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
188 value of the attribute of self named by dir_attr which defaults to
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
189 'base_dir'.
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
190 """
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
191 def get(self):
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
192 return os.path.join(getattr(self, dir_attr), filename)
06af36f915f2 Move the filenameproperty factory from treepkg/packager.py to
Bernhard Herzog <bh@intevation.de>
parents: 169
diff changeset
193 return property(get)
344
f06f707d9fda merged branches/scratchbox into trunk
Bjoern Ricks <bricks@intevation.de>
parents: 172
diff changeset
194
f06f707d9fda merged branches/scratchbox into trunk
Bjoern Ricks <bricks@intevation.de>
parents: 172
diff changeset
195 def getuser():
f06f707d9fda merged branches/scratchbox into trunk
Bjoern Ricks <bricks@intevation.de>
parents: 172
diff changeset
196 """Returns the login name of the current user owning the proccess"""
f06f707d9fda merged branches/scratchbox into trunk
Bjoern Ricks <bricks@intevation.de>
parents: 172
diff changeset
197 return pwd.getpwuid(os.getuid())[0]
394
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
198
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
199 def md5sum(filename):
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
200 """ calculates the md5sum of a file """
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
201 if not os.path.isfile(filename):
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
202 raise RuntimeError("Could not create md5sum. File not found: %s"
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
203 % filename)
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
204 f = file(filename, 'rb')
458
61e72399914c Use an exception to use either hashlib or md5
Andre Heinecke <aheinecke@intevation.de>
parents: 457
diff changeset
205 m = new_md5()
394
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
206 while True:
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
207 d = f.read(8096)
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
208 if not d:
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
209 break
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
210 m.update(d)
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
211 f.close()
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
212 return m.hexdigest()
bfd1c6a155fa added md5sum function
Bjoern Ricks <bricks@intevation.de>
parents: 344
diff changeset
213
439
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
214 def remove_trailing_slashes(s):
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
215 return s.rstrip("/")
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
216
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
217 def expand_filename(filename):
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
218 """
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
219 Applies os.path.expanduser and os.path.expandvars to filename
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
220 """
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
221 return os.path.expandvars(os.path.expanduser(filename))
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
222
8e0c81870e5e cleanup modules
Bjoern Ricks <bricks@intevation.de>
parents: 418
diff changeset
223
461
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
224 def compress_all_logs(reference_log, cmd="gzip -9 $logfile"):
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
225 """
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
226 Takes the path of a reference log file and compresses all
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
227 files in same folder with the cmd command.
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
228 """
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
229 if reference_log and os.path.exists(reference_log):
462
058856954e2d Make the compress_all_logs call builder independent and also compress
Andre Heinecke <aheinecke@intevation.de>
parents: 461
diff changeset
230 log_dir = os.path.isdir(reference_log) and \
058856954e2d Make the compress_all_logs call builder independent and also compress
Andre Heinecke <aheinecke@intevation.de>
parents: 461
diff changeset
231 reference_log or os.path.dirname(reference_log)
058856954e2d Make the compress_all_logs call builder independent and also compress
Andre Heinecke <aheinecke@intevation.de>
parents: 461
diff changeset
232 for log_file in [os.path.join(log_dir, f)
461
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
233 for f in os.listdir(log_dir)]:
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
234 if os.path.isfile(log_file):
454967511f5c commit compress all logs patch from Sascha Teichmann
Bjoern Ricks <bricks@intevation.de>
parents: 458
diff changeset
235 run.call(cmdexpand(cmd, logfile=log_file))
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)