Skip to content
Snippets Groups Projects
Commit cc2ad1d4 authored by Panos Christeas's avatar Panos Christeas Committed by Olivier Dony
Browse files

[FIX] report_webkit: avoid potential conflict with regular reports + bit of lint cleanup

bzr revid: odo@openerp.com-20101018143342-3uexdknq7lw3ldox
parent f2e519b5
No related branches found
No related tags found
No related merge requests found
...@@ -34,34 +34,34 @@ import netsvc ...@@ -34,34 +34,34 @@ import netsvc
from webkit_report import WebKitParser from webkit_report import WebKitParser
from report.report_sxw import rml_parse from report.report_sxw import rml_parse
def register_report(name, model, tmpl_path, parser): def register_report(name, model, tmpl_path, parser=rml_parse):
"Register the report into the services" "Register the report into the services"
name = 'report.%s' % name name = 'report.%s' % name
if netsvc.Service._services.get(name, False): if netsvc.Service._services.get(name, False):
if hasattr(netsvc.Service._services[name], 'parser'):
parser = netsvc.Service._services[name].parser
del netsvc.Service._services[name] del netsvc.Service._services[name]
WebKitParser(name, model, tmpl_path, parser=parser) WebKitParser(name, model, tmpl_path, parser=parser)
class ReportXML(osv.osv): class ReportXML(osv.osv):
def __init__(self, pool, cr): def __init__(self, pool, cr):
super(ReportXML, self).__init__(pool, cr) super(ReportXML, self).__init__(pool, cr)
def register_all(self,cursor): def register_all(self,cursor):
value = super(ReportXML, self).register_all(cursor) value = super(ReportXML, self).register_all(cursor)
cursor.execute("SELECT * FROM ir_act_report_xml") cursor.execute("SELECT * FROM ir_act_report_xml WHERE report_type = 'webkit'")
records = cursor.dictfetchall() records = cursor.dictfetchall()
for record in records: for record in records:
if record['report_type'] == 'webkit': register_report(record['report_name'], record['model'], record['report_rml'])
parser=rml_parse
register_report(record['report_name'], record['model'], record['report_rml'], parser)
return value return value
def unlink(self, cursor, user, ids, context=None): def unlink(self, cursor, user, ids, context=None):
"""Delete report and unregister it""" """Delete report and unregister it"""
trans_obj = self.pool.get('ir.translation') trans_obj = self.pool.get('ir.translation')
trans_ids = trans_obj.search( trans_ids = trans_obj.search(
cursor, cursor,
user, user,
[('type', '=', 'report'), ('res_id', 'in', ids)] [('type', '=', 'report'), ('res_id', 'in', ids)]
) )
...@@ -72,9 +72,9 @@ class ReportXML(osv.osv): ...@@ -72,9 +72,9 @@ class ReportXML(osv.osv):
# report will fail so it's ok. # report will fail so it's ok.
res = super(ReportXML, self).unlink( res = super(ReportXML, self).unlink(
cursor, cursor,
user, user,
ids, ids,
context context
) )
return res return res
...@@ -82,34 +82,34 @@ class ReportXML(osv.osv): ...@@ -82,34 +82,34 @@ class ReportXML(osv.osv):
def create(self, cursor, user, vals, context=None): def create(self, cursor, user, vals, context=None):
"Create report and register it" "Create report and register it"
res = super(ReportXML, self).create(cursor, user, vals, context) res = super(ReportXML, self).create(cursor, user, vals, context)
parser=rml_parse if vals.get('report_type','') == 'webkit':
register_report( # I really look forward to virtual functions :S
vals['report_name'], register_report(
vals['model'], vals['report_name'],
vals.get('report_rml', False), vals['model'],
parser vals.get('report_rml', False)
) )
return res return res
def write(self, cursor, user, ids, vals, context=None): def write(self, cr, uid, ids, vals, context=None):
"Edit report and manage it registration" "Edit report and manage it registration"
parser=rml_parse if isinstance(ids, (int, long)):
record = self.read(cursor, user, ids) ids = [ids,]
if isinstance(record, list) : for rep in self.browse(cr, uid, ids, context=context):
record = record[0] if rep.report_type != 'webkit':
if vals.get('report_name', False) and \ continue
vals['report_name']!=record['report_name']: if vals.get('report_name', False) and \
report_name = vals['report_name'] vals['report_name'] != rep.report_name:
else: report_name = vals['report_name']
report_name = record['report_name'] else:
report_name = rep.report_name
register_report( register_report(
report_name, report_name,
vals.get('model', record['model']), vals.get('model', rep.model),
vals.get('report_rml', record['report_rml']), vals.get('report_rml', rep.report_rml)
parser
) )
res = super(ReportXML, self).write(cursor, user, ids, vals, context) res = super(ReportXML, self).write(cr, uid, ids, vals, context)
return res return res
_name = 'ir.actions.report.xml' _name = 'ir.actions.report.xml'
...@@ -129,4 +129,4 @@ class ReportXML(osv.osv): ...@@ -129,4 +129,4 @@ class ReportXML(osv.osv):
'report_webkit_data': fields.text('Webkit Template', help="This template will be used if the main report file is not found"), 'report_webkit_data': fields.text('Webkit Template', help="This template will be used if the main report file is not found"),
} }
ReportXML() ReportXML()
\ No newline at end of file
...@@ -205,7 +205,7 @@ class WebKitParser(report_sxw): ...@@ -205,7 +205,7 @@ class WebKitParser(report_sxw):
def create_single_pdf(self, cursor, uid, ids, data, report_xml, context=None): def create_single_pdf(self, cursor, uid, ids, data, report_xml, context=None):
"""generate the PDF""" """generate the PDF"""
if not context: if context is None:
context={} context={}
if report_xml.report_type != 'webkit': if report_xml.report_type != 'webkit':
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment