8 from string import Template
10 prev_tag = 'EMPATHY_0_21_4'
14 $name $version is now available for download from:
23 Where can I find out more?
24 ==========================
25 You can visit the project web site:
36 return os.popen(cmd).read()
48 if self.message[len(self.message) - 1] == ')':
49 p1 = self.message.rfind('(')
50 self.author = self.message[p1+1:len(self.message) - 1]
51 self.message = self.message[:p1]
53 p1 = self.message.find('#')
54 p2 = self.message.find(' ', p1)
56 self.bug = self.message[p1+1:p2]
58 message = self.message.lower()
59 if message.find('translation') != -1 and\
60 message.find('updated') != -1:
61 self.translation = True
62 exp = '.*pdated(?P<name>.*).ranslation.*'
63 lang_re = re.compile(exp, re.S | re.M)
64 match = lang_re.match(self.message)
66 lang = match.group('name').strip()
67 self.summary = "Updated " + lang + " Translation"
69 self.summary = self.message
70 self.summary += ' (' + self.author + ').'
89 self.get_package_info()
91 self.get_bugzilla_info()
98 url1 = exec_cmd('git-config svn-remote.svn.url').strip()
99 url2 = url1[:url1.rfind('/')] + '/tags/' + self.new_tag
101 exec_cmd('svn copy %s %s -m "Tagged for release %s."' % (url1, url2, self.package_version))
102 exec_cmd('git-tag -m "Tagged for release %s." %s' % ( self.package_version, self.new_tag))
108 for co in self.commits:
110 others += '- ' + co.message + '\n'
111 elif co.translation == False:
112 bugs += '- ' + co.summary + '\n'
114 translations += '- ' + co.summary + '\n'
116 news = 'NEW in '+ self.package_version + '\n==============\n'
117 news += others + '\n' + bugs + '\nTranslations:\n' + translations + '\n'
119 f = open ('/tmp/NEWS', 'w')
123 exec_cmd('cat NEWS >> /tmp/NEWS')
124 exec_cmd('mv /tmp/NEWS .')
126 def upload_tarball(self):
127 # This is the tarball we are going to upload
128 tarball = '%s-%s.tar.gz' % (package_name.lower(), package_version)
130 cmd = 'scp %s %s@%s:' % (tarball, username, upload_server)
133 cmd = 'ssh %s@%s install-module %s' % (username, upload_server, tarball)
136 def get_new_tag(self):
137 self.new_tag = self.package_name.upper() + '_' +\
138 self.package_version.replace('.', '_')
141 name = self.package_name
142 version = self.package_version
143 download = self.package_dl_url
144 md5sums = self.md5sums
145 about = self.description
148 footer = '%s\n%s team' % (datetime.date.today().strftime('%d %B %Y'),\
151 t = Template(template)
152 self.notes = text = t.substitute(locals())
155 f = open ('NEWS', 'r')
158 start = s.find ('NEW in '+ self.package_version)
160 start = s.find ('\n', start) + 1
161 start = s.find ('\n', start) + 1
162 end = s.find ('NEW in', start) - 1
163 self.news = s[start:end]
165 def get_md5sums(self):
166 cmd = 'md5sum %s-%s.tar.gz' % (self.package_name.lower(), self.package_version)
167 self.md5sums += exec_cmd(cmd)
169 cmd = 'md5sum %s-%s.tar.bz2' % (self.package_name.lower(), self.package_version)
170 self.md5sums += exec_cmd(cmd)
172 def get_package_info(self):
173 f = open('config.h', 'r')
178 key['package'] = '#define PACKAGE_NAME "'
179 key['version'] = '#define PACKAGE_VERSION "'
180 key['bugreport'] = '#define PACKAGE_BUGREPORT "'
182 for line in s.splitlines(1):
183 if line.startswith(key['package']):
184 p1 = len(key['package'])
186 self.package_name = line[p1:p2]
187 elif line.startswith(key['version']):
188 p1 = len(key['version'])
190 self.package_version = line[p1:p2]
191 elif line.startswith(key['bugreport']):
193 p1 = line.rfind('=') + 1
194 self.package_module = line[p1:p2]
196 first = self.package_version.find('.')
197 second = self.package_version.find('.', first + 1)
198 if first == -1 or second == -1 or first == second:
199 version_dir = self.package_version
201 version_dir = self.package_version[:second]
202 self.package_dl_url = 'http://download.gnome.org/sources/%s/%s/' % (self.package_name.lower(),
205 def get_bugzilla_info(self):
206 query = 'http://bugzilla.gnome.org/browse.cgi?product=%s' % (self.package_module)
207 f = urllib.urlopen(query)
215 end = s.find(s2, i + 1)
216 self.description = s[start:end]
224 end = s.find(s2, start)
225 self.url = s[start:end]
227 def get_commits(self):
230 changes = exec_cmd ("git-log " + prev_tag + "..")
231 for line in changes.splitlines(1):
232 if line.startswith('commit'):
241 self.commits.append(co)
243 co.ref = line[p1:].strip()
244 elif line.startswith('Author:'):
247 co.author = line[p1:p2].strip()
248 elif line.startswith('Date:'):
250 co.date = line[p1:].strip()
251 elif line.startswith(' git-svn-id:'):
253 elif line.startswith('Merge:'):
259 if msg.startswith('*'):
261 msg = msg[p1 + 1:].strip()
262 elif msg.startswith('2007-') or msg.startswith('2008-'):
268 # Bugzilla query to use
269 query = 'http://bugzilla.gnome.org/buglist.cgi?ctype=csv' \
270 '&bug_status=RESOLVED,CLOSED,VERIFIED' \
271 '&resolution=FIXED' \
272 '&bug_id=' + bugs.replace(',', '%2c')
274 f = urllib.urlopen(query)
281 reader = csv.reader(s.splitlines(1))
282 header = reader.next()
288 if col == 'short_short_desc':
293 bug_number = row[col_bug_id]
294 description = row[col_description]
296 for co in self.commits:
297 if co.bug == bug_number:
298 co.summary = 'Fixed #%s, %s (%s)' % (co.bug, description, co.author)