summaryrefslogtreecommitdiff
path: root/patchtracker
diff options
context:
space:
mode:
authorSean Finney <seanius@debian.org>2010-05-13 19:36:31 +0200
committerSean Finney <seanius@debian.org>2010-05-13 19:36:31 +0200
commite3e23ba7197588bb98ea589f693f7fc59cc5eb2a (patch)
treed1df4aa677c085dff078f6e2807a769b736d5eec /patchtracker
parent01e55d8e6ca532ceb1382db529f82941bc7a6bad (diff)
downloadpatch-tracker-e3e23ba7197588bb98ea589f693f7fc59cc5eb2a.tar.gz
commonize all the diffhandler stuff into the SourcePackage model
Diffstat (limited to 'patchtracker')
-rw-r--r--patchtracker/models.py13
-rw-r--r--patchtracker/views.py41
2 files changed, 22 insertions, 32 deletions
diff --git a/patchtracker/models.py b/patchtracker/models.py
index 95a59df..3d4f582 100644
--- a/patchtracker/models.py
+++ b/patchtracker/models.py
@@ -1,5 +1,9 @@
+import os
import re
+import Conf
+import DiffGzHandler, DebTarHandler
+
from django.db import models
from django.contrib import admin
@@ -24,6 +28,15 @@ class SourcePackage (models.Model):
else:
return "Native"
+ def diffhandler( self ):
+ """ Return a diffhandler object too the caller """
+ if self.diffgz_name:
+ dgz = os.sep.join([Conf.archive_root, self.loc, self.diffgz_name])
+ return DiffGzHandler.DiffGzHandler(dgz)
+ elif self.debtar_name:
+ dtar = os.sep.join([Conf.archive_root, self.loc, self.debtar_name])
+ return DebTarHandler.DebTarHandler(dtar)
+
def anchor_name(self):
""" output a version of the package name suitable for use as an
anchor name (i.e. <a name="foo">) """
diff --git a/patchtracker/views.py b/patchtracker/views.py
index 4db3666..e790f3a 100644
--- a/patchtracker/views.py
+++ b/patchtracker/views.py
@@ -5,8 +5,6 @@ import django.shortcuts
import django.template
import ComplexQueries
-import DebTarHandler
-import DiffGzHandler
import Conf
import models
@@ -14,14 +12,7 @@ def package_vers(request, package, version):
pkg = models.SourcePackage.objects.get( name=package, version=version )
ctx = django.template.RequestContext(request)
tmpl = 'package_vers.html'
- diffhandler = None
- if pkg.diffgz_name:
- dgz = os.sep.join([Conf.archive_root, pkg.loc, pkg.diffgz_name])
- diffhandler = DiffGzHandler.DiffGzHandler(dgz)
- elif pkg.debtar_name:
- dtar = os.sep.join([Conf.archive_root, pkg.loc, pkg.debtar_name])
- diffhandler = DebTarHandler.DebTarHandler(dtar)
- extra = { 'pkg':pkg, 'ctx':ctx, 'conf':Conf, 'diffhandler':diffhandler }
+ extra = { 'pkg':pkg, 'ctx':ctx, 'conf':Conf }
return django.shortcuts.render_to_response(tmpl, extra, context_instance=ctx)
def display_toc(request, index):
@@ -35,25 +26,18 @@ def display_patch(request, patchType, package, version, patchName):
pkg = models.SourcePackage.objects.get( name=package, version=version )
ctx = django.template.RequestContext(request)
tmpl = 'patch_view.html'
- diffhandler = None
- if pkg.diffgz_name:
- dgz = os.sep.join([Conf.archive_root, pkg.loc, pkg.diffgz_name])
- diffhandler = DiffGzHandler.DiffGzHandler(dgz)
- elif pkg.debtar_name:
- dtar = os.sep.join([Conf.archive_root, pkg.loc, pkg.debtar_name])
- diffhandler = DebTarHandler.DebTarHandler(dtar)
if patchType == "debianonly":
- patch = diffhandler.debiandir()
+ patch = pkg.diffhandler().debiandir()
patchTitle = "debian-dir only changes"
elif patchType == "misc":
- patch = diffhandler.filterdiff(include=patchName)
+ patch = pkg.diffhandler().filterdiff(include=patchName)
patchTitle = patchName
elif patchType == "nondebian":
- patch = diffhandler.nondebiandir()
+ patch = pkg.diffhandler().nondebiandir()
patchTitle = "direct (non-packaging) changes"
elif patchType == "series":
- patch = diffhandler.series().fetch(patchName)
+ patch = pkg.diffhandler().series().fetch(patchName)
patchTitle = patchName
extra = { 'pkg':pkg, 'patch':patch, 'patchType':patchType, 'conf':Conf,
@@ -62,19 +46,12 @@ def display_patch(request, patchType, package, version, patchName):
def download_patch(request, patchType, package, version, patchName):
pkg = models.SourcePackage.objects.get( name=package, version=version )
- diffhandler = None
- if pkg.diffgz_name:
- dgz = os.sep.join([Conf.archive_root, pkg.loc, pkg.diffgz_name])
- diffhandler = DiffGzHandler.DiffGzHandler(dgz)
- elif pkg.debtar_name:
- dtar = os.sep.join([Conf.archive_root, pkg.loc, pkg.debtar_name])
- diffhandler = DebTarHandler.DebTarHandler(dtar)
if patchType == "debianonly":
- patch = diffhandler.debiandir()
+ patch = pkg.diffhandler().debiandir()
elif patchType == "misc":
- patch = diffhandler.filterdiff(include=patchName)
+ patch = pkg.diffhandler().filterdiff(include=patchName)
elif patchType == "nondebian":
- patch = diffhandler.nondebiandir()
+ patch = pkg.diffhandler().nondebiandir()
elif patchType == "series":
- patch = diffhandler.series().fetch(patchName)
+ patch = pkg.diffhandler().series().fetch(patchName)
return django.http.HttpResponse(patch, mimetype="text/plain")