summaryrefslogtreecommitdiff
path: root/patchtracker
diff options
context:
space:
mode:
Diffstat (limited to 'patchtracker')
-rw-r--r--patchtracker/urls.py9
-rw-r--r--patchtracker/views.py58
2 files changed, 67 insertions, 0 deletions
diff --git a/patchtracker/urls.py b/patchtracker/urls.py
index 9738dc5..95376ca 100644
--- a/patchtracker/urls.py
+++ b/patchtracker/urls.py
@@ -12,4 +12,13 @@ urlpatterns = patterns('',
views.download_debianonly_patch),
url(r'^patch/debianonly/view/(?P<package>\w+)/(?P<version>[^/]+)$',
views.view_debianonly_patch),
+ url(r'^patch/nondebian/view/(?P<package>\w+)/(?P<version>[^/]+)$',
+ views.view_nondebian_patch),
+ url(r'^patch/nondebian/dl/(?P<package>\w+)/(?P<version>[^/]+)$',
+ views.download_nondebian_patch),
+ url(r'^patch/misc/view/(?P<package>\w+)/(?P<version>[^/]+)/(?P<patch>.*)$',
+ views.view_misc_patch),
+ url(r'^patch/misc/dl/(?P<package>\w+)/(?P<version>[^/]+)/(?P<patch>.*)$',
+ views.download_misc_patch),
+
)
diff --git a/patchtracker/views.py b/patchtracker/views.py
index 611684b..9f5ff56 100644
--- a/patchtracker/views.py
+++ b/patchtracker/views.py
@@ -78,3 +78,61 @@ def view_debianonly_patch(request, package, version):
extra = { 'pkg':pkg, 'patch':'debian-dir only changes',
'patchContents':patchContents, 'patchType':'series', 'conf':Conf }
return django.shortcuts.render_to_response(tmpl, extra, context_instance=ctx)
+
+def view_nondebian_patch(request, package, version):
+ 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)
+ patchContents = diffhandler.nondebiandir()
+ extra = { 'pkg':pkg, 'patch':'direct (non-packaging) changes',
+ 'patchContents':patchContents, 'patchType':'series', 'conf':Conf }
+ return django.shortcuts.render_to_response(tmpl, extra, context_instance=ctx)
+
+def download_nondebian_patch(request, package, version):
+ 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)
+ patchContents = diffhandler.nondebiandir()
+ return django.http.HttpResponse(patchContents, mimetype="text/plain")
+
+def download_misc_patch(request, package, version, patch):
+ 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)
+ patchContents = diffhandler.filterdiff(include=patch)
+ return django.http.HttpResponse(patchContents, mimetype="text/plain")
+
+def view_misc_patch(request, package, version, patch):
+ 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)
+ patchContents = diffhandler.filterdiff(include=patch)
+ extra = { 'pkg':pkg, 'patch':patch, 'patchContents':patchContents,
+ 'patchType':'series', 'conf':Conf }
+ return django.shortcuts.render_to_response(tmpl, extra, context_instance=ctx)
+
+