Mercurial > mozilla > hg > licenser
changeset 27:7e0c931a201d
web licenser now works
author | Jeff Hammel <jhammel@mozilla.com> |
---|---|
date | Fri, 25 Nov 2011 00:57:38 -0800 (2011-11-25) |
parents | 0faf3e7b593a |
children | eb3749dbdbf5 |
files | licenser/licenses.py licenser/web.py |
diffstat | 2 files changed, 66 insertions(+), 20 deletions(-) [+] |
line wrap: on
line diff
--- a/licenser/licenses.py Fri Nov 25 00:08:34 2011 -0800 +++ b/licenser/licenses.py Fri Nov 25 00:57:38 2011 -0800 @@ -56,6 +56,16 @@ def __init__(self, filename): self.filename = filename + def fileobj(self): + """return a file object open for writing""" + if isinstance(self.filename, basestring): + return file(self.filename, 'w') + return self.filename + + def close(self, _file): + if isinstance(self.filename, basestring): + _file.close() + def isempty(self): return not bool(file(self.filename).read().strip) @@ -71,12 +81,12 @@ def __call__(self, license): + lines = self.lines() if self.isempty(): return # you're done - lines = self.lines() # open the file for writing - f = file(self.filename, 'w') + f = self.fileobj() # print the license license_lines = license.splitlines() @@ -93,7 +103,7 @@ # print the rest of the file for line in lines: f.write(line) - f.close() + self.close(f) class HashCommentsFile(CommentedFile): @@ -103,12 +113,12 @@ def __call__(self, license): """interpolate the file""" + lines = self.lines() if self.isempty(): return # you're done - lines = self.lines() # open the file for writing - f = file(self.filename, 'w') + f = self.fileobj() # print shebang if it exists if lines[0].startswith('#!'): @@ -123,7 +133,7 @@ # print the rest of the file for line in lines: f.write(line) - f.close() + self.close(f) def isempty(self): """ @@ -171,7 +181,11 @@ def has_license(self, filename): """does the file already have a license?""" token = self.token() - for line in file(filename).readlines(): + if isinstance(filename, basestring): + f = file(filename) + else: + f = filename + for line in f.readlines(): if token in line: return True return False @@ -183,6 +197,7 @@ def obtain_variables(self, **kw): for var in self.variables: if var not in kw: + import pdb; pdb.set_trace() print 'Enter %s: ' % var, kw[var] = raw_input() self.pre(kw) @@ -210,13 +225,16 @@ return # you're done # get the license - # XXX should be cached - license = self.license() - license = Template(license).substitute(**variables) + license = self.interpolate_license(**variables) # add the license to the file filetype(license) + + def interpolate_license(self, **variables): + license = self.license() + return Template(license).substitute(**variables) + def interpolate(self, directory, variables): for _file in self.files(directory): self.interpolate_file(_file, variables)
--- a/licenser/web.py Fri Nov 25 00:08:34 2011 -0800 +++ b/licenser/web.py Fri Nov 25 00:57:38 2011 -0800 @@ -6,11 +6,12 @@ import licenses import tempfile +from StringIO import StringIO from webob import Request, Response, exc class Handler(object): - required = set(['name', 'email', 'url']) + required = set(['author', 'email', 'url']) template = """<html> <head><title>MPL licenser</title></head> @@ -20,13 +21,14 @@ <div><form method="POST" enctype="multipart/form-data"> <p>Enter a file: <input type="file" name="file"/></p> <p>or a URL: <input type="text" name="url" value="%(url)s"/></p> -<p>And enter your name: <input type="text" name="name" value="%(name)s"/></p> +<p>And enter your name: <input type="text" name="author" value="%(author)s"/></p> <p>and email: <input type="text" name="email" value="%(email)s"/></p> <input type="submit"/> </body> </html>""" def __init__(self, **kw): + self.license = licenses.MPL() self.methods = {'GET': self.GET, 'POST': self.POST} @@ -58,16 +60,42 @@ return Response(content_type='text/html', body=(self.template % variables)) def POST(self, request): - pass + variables = dict([(i, request.params[i]) + for i in self.required + if i in request.params]) + if 'file' in request.POST and hasattr(request.POST['file'], 'filename'): + body = request.POST['file'].file.getvalue() + filename = request.POST['file'].filename + elif 'url' in request.POST: + try: + pass + except: + return self.render(**variables) + if not set(['author', 'email']).issubset(request.params): + return self.render(**variables) + author = request.params['author'] + email = request.params['email'] + retval = self.interpolate(filename, body, author, email) + return Response(content_type='text/plain', body=retval) - def interpolate(self, filename, body, name, email): - fd, tf = tempfile.mkstemp() - try: - os.write(fd, body) - os.close(fd) - finally: - os.remove(tf) + def interpolate(self, filename, body, author, email): + buffer = StringIO() + buffer.write(body) + value = buffer.getvalue().splitlines() + if self.license.has_license(buffer): + return body + filetype = self.license.filetype(filename) + if not filetype: + return body + variables = self.license.obtain_variables(author=author, email=email) + license = self.license.interpolate_license(**variables) + value = [i + '\r\n' for i in value] + filetype._lines = value + buffer = StringIO() + filetype.filename = buffer + filetype(license) + return buffer.getvalue() if __name__ == '__main__': from wsgiref import simple_server