diff --git a/bin/addons/base/ir/ir.xml b/bin/addons/base/ir/ir.xml index 0f164e637df..8bcb3abfced 100644 --- a/bin/addons/base/ir/ir.xml +++ b/bin/addons/base/ir/ir.xml @@ -750,10 +750,8 @@ - - + + diff --git a/bin/addons/base/ir/ir_model.py b/bin/addons/base/ir/ir_model.py index 05fe09d2b87..105ffece9dc 100644 --- a/bin/addons/base/ir/ir_model.py +++ b/bin/addons/base/ir/ir_model.py @@ -243,9 +243,14 @@ class ir_model_fields(osv.osv): if vals.get('state','base') == 'manual': if not vals['name'].startswith('x_'): raise except_orm(_('Error'), _("Custom fields must have a name that starts with 'x_' !")) - if self.pool.get(vals['model']): - self.pool.get(vals['model']).__init__(self.pool, cr) - self.pool.get(vals['model'])._auto_init(cr, {}) + + model_ids = self.pool.get('ir.model').search(cr, user, [('model','=',vals['relation'])]) + if model_ids: + if self.pool.get(vals['model']): + self.pool.get(vals['model']).__init__(self.pool, cr) + self.pool.get(vals['model'])._auto_init(cr, {}) + else: + raise except_orm(_('Error'), _("Model %s Does not Exist !" % vals['relation'])) return res ir_model_fields() diff --git a/bin/addons/base/ir/ir_ui_menu.py b/bin/addons/base/ir/ir_ui_menu.py index 507934e38e1..5715fc9ac78 100644 --- a/bin/addons/base/ir/ir_ui_menu.py +++ b/bin/addons/base/ir/ir_ui_menu.py @@ -200,7 +200,7 @@ class ir_ui_menu(osv.osv): if values_ids: values_obj.write(cursor, user, values_ids[0], {'value': value}, context=ctx) - else: + elif ctx: values_obj.create(cursor, user, { 'name': 'Menuitem', 'model': self._name,