[tryton-debian-vcs] tryton-client branch upstream-2.8 updated. upstream/2.8.8-1-g4d00cc9

Mathias Behrle tryton-debian-vcs at alioth.debian.org
Tue Aug 26 16:41:26 UTC 2014


The following commit has been merged in the upstream-2.8 branch:
https://alioth.debian.org/plugins/scmgit/cgi-bin/gitweb.cgi/?p=tryton/tryton-client.git;a=commitdiff;h=upstream/2.8.8-1-g4d00cc9

commit 4d00cc97dded1893f5a21de6d30adc1e78357df2
Author: Mathias Behrle <mathiasb at m9s.biz>
Date:   Tue Aug 26 14:06:16 2014 +0200

    Adding upstream version 2.8.9.

diff --git a/CHANGELOG b/CHANGELOG
index 6b90ebf..477477a 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,3 +1,6 @@
+Version 2.8.9 - 2014-08-03
+* Bug fixes (see mercurial logs for details)
+
 Version 2.8.8 - 2014-07-02
 * Bug fixes (see mercurial logs for details)
 
diff --git a/PKG-INFO b/PKG-INFO
index e0c7bcb..5419e79 100644
--- a/PKG-INFO
+++ b/PKG-INFO
@@ -1,6 +1,6 @@
 Metadata-Version: 1.1
 Name: tryton
-Version: 2.8.8
+Version: 2.8.9
 Summary: Tryton client
 Home-page: http://www.tryton.org/
 Author: Tryton
diff --git a/tryton.egg-info/PKG-INFO b/tryton.egg-info/PKG-INFO
index e0c7bcb..5419e79 100644
--- a/tryton.egg-info/PKG-INFO
+++ b/tryton.egg-info/PKG-INFO
@@ -1,6 +1,6 @@
 Metadata-Version: 1.1
 Name: tryton
-Version: 2.8.8
+Version: 2.8.9
 Summary: Tryton client
 Home-page: http://www.tryton.org/
 Author: Tryton
diff --git a/tryton/common/domain_inversion.py b/tryton/common/domain_inversion.py
index 4e44010..5841e65 100644
--- a/tryton/common/domain_inversion.py
+++ b/tryton/common/domain_inversion.py
@@ -146,6 +146,8 @@ def simplify(domain):
         return domain
     elif domain in ('OR', 'AND'):
         return domain
+    elif domain in (['OR'], ['AND']):
+        return []
     elif (isinstance(domain, list) and len(domain) == 1
             and not is_leaf(domain[0])):
         return simplify(domain[0])
@@ -413,6 +415,10 @@ def test_simplify():
     assert simplify(domain) == ['OR', [['x', '=', 3]], [['y', '=', 5]]]
     domain = ['OR', ['x', '=', 3], ['AND', ['y', '=', 5]]]
     assert simplify(domain) == ['OR', ['x', '=', 3], [['y', '=', 5]]]
+    domain = ['AND']
+    assert simplify(domain) == []
+    domain = ['OR']
+    assert simplify(domain) == []
 
 
 def test_merge():
diff --git a/tryton/gui/window/view_form/view/form_gtk/many2one.py b/tryton/gui/window/view_form/view/form_gtk/many2one.py
index 0bf12fe..5c11c0d 100644
--- a/tryton/gui/window/view_form/view/form_gtk/many2one.py
+++ b/tryton/gui/window/view_form/view/form_gtk/many2one.py
@@ -32,7 +32,7 @@ class Many2One(WidgetInterface):
         self.wid_text.connect('populate-popup', self._populate_popup)
         self.wid_text.connect('focus-out-event',
             lambda x, y: self._focus_out())
-        self.wid_text.connect_after('changed', self.sig_changed)
+        self.wid_text.connect('changed', self.sig_changed)
         self.changed = True
         self.focus_out = True
 
@@ -305,7 +305,7 @@ class Many2One(WidgetInterface):
         if not self.changed:
             return False
         value = self.field.get(self.record)
-        if self.has_target(value):
+        if self.has_target(value) and self.modified:
             def clean():
                 text = self.wid_text.get_text()
                 position = self.wid_text.get_position()
diff --git a/tryton/gui/window/view_form/view/form_gtk/reference.py b/tryton/gui/window/view_form/view/form_gtk/reference.py
index 367dc5f..0cbecda 100644
--- a/tryton/gui/window/view_form/view/form_gtk/reference.py
+++ b/tryton/gui/window/view_form/view/form_gtk/reference.py
@@ -36,6 +36,12 @@ class Reference(Many2One, SelectionMixin, PopdownMixin):
         res = child.get_text()
         return self._selection.get(res, False)
 
+    def get_empty_value(self):
+        for name, model in self.widget_combo.get_model():
+            if model in (None, ''):
+                return model, name
+        return '', ''
+
     def _readonly_set(self, value):
         super(Reference, self)._readonly_set(value)
         if not value:
@@ -51,7 +57,7 @@ class Reference(Many2One, SelectionMixin, PopdownMixin):
             try:
                 model, name = self.field.get_client(self.record)
             except (ValueError, TypeError):
-                model, name = '', ''
+                model, name = self.get_empty_value()
             return (model != self.get_model()
                 or name != self.wid_text.get_text())
         return False
@@ -104,7 +110,7 @@ class Reference(Many2One, SelectionMixin, PopdownMixin):
             try:
                 model, name = field.get_client(record)
             except (ValueError, TypeError):
-                model, name = '', ''
+                model, name = self.get_empty_value()
             if (model != self.get_model()
                     or name != self.wid_text.get_text()):
                 field.set_client(record, None)
diff --git a/tryton/gui/window/view_form/view/list.py b/tryton/gui/window/view_form/view/list.py
index b9baee6..c490cc7 100644
--- a/tryton/gui/window/view_form/view/list.py
+++ b/tryton/gui/window/view_form/view/list.py
@@ -433,7 +433,9 @@ class ViewList(ParserView):
             if not col.get_visible() or not col.name:
                 continue
             cell = self.widget_tree.cells[col.name]
-            values.append('"' + str(cell.get_textual_value(record)) + '"')
+            values.append('"'
+                + str(cell.get_textual_value(record)).replace('"', '""')
+                + '"')
         data.append('\t'.join(values))
         return
 
diff --git a/tryton/version.py b/tryton/version.py
index becf915..dfdacf1 100644
--- a/tryton/version.py
+++ b/tryton/version.py
@@ -1,6 +1,6 @@
 #This file is part of Tryton.  The COPYRIGHT file at the top level of
 #this repository contains the full copyright notices and license terms.
 PACKAGE = "tryton"
-VERSION = "2.8.8"
+VERSION = "2.8.9"
 LICENSE = "GPL-3"
 WEBSITE = "http://www.tryton.org/"
-- 
tryton-client



More information about the tryton-debian-vcs mailing list