[tryton-debian-vcs] tryton-modules-product-price-list branch upstream updated. upstream/3.4.1-1-gcdc1d40
Mathias Behrle
tryton-debian-vcs at alioth.debian.org
Thu Apr 23 16:05:07 UTC 2015
The following commit has been merged in the upstream branch:
https://alioth.debian.org/plugins/scmgit/cgi-bin/gitweb.cgi/?p=tryton/tryton-modules-product-price-list.git;a=commitdiff;h=upstream/3.4.1-1-gcdc1d40
commit cdc1d40b7cb8d4a090afa839d50cba54152c59db
Author: Mathias Behrle <mathiasb at m9s.biz>
Date: Thu Apr 23 17:00:02 2015 +0200
Adding upstream version 3.6.0.
Signed-off-by: Mathias Behrle <mathiasb at m9s.biz>
diff --git a/CHANGELOG b/CHANGELOG
index f712fa9..fed4690 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,5 +1,8 @@
-Version 3.4.1 - 2015-02-22
+Version 3.6.0 - 2015-04-20
* Bug fixes (see mercurial logs for details)
+* Add support for PyPy
+* Add tax included option
+* Replace safe_eval by simpleeval
Version 3.4.0 - 2014-10-20
* Bug fixes (see mercurial logs for details)
diff --git a/INSTALL b/INSTALL
index e53d450..f0810af 100644
--- a/INSTALL
+++ b/INSTALL
@@ -5,9 +5,10 @@ Prerequisites
-------------
* Python 2.7 or later (http://www.python.org/)
+ * simpleeval (https://github.com/danthedeckie/simpleeval)
+ * python-sql 0.4 or later (http://code.google.com/p/python-sql/)
* trytond (http://www.tryton.org/)
* trytond_product (http://www.tryton.org/)
- * trytond_party (http://www.tryton.org/)
* trytond_company (http://www.tryton.org/)
Installation
diff --git a/PKG-INFO b/PKG-INFO
index 04ee2d9..fe88413 100644
--- a/PKG-INFO
+++ b/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond_product_price_list
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module with price list
Home-page: http://www.tryton.org/
Author: Tryton
Author-email: issue_tracker at tryton.org
License: GPL-3
-Download-URL: http://downloads.tryton.org/3.4/
+Download-URL: http://downloads.tryton.org/3.6/
Description: trytond_product_price_list
==========================
@@ -64,4 +64,6 @@ Classifier: Natural Language :: Slovenian
Classifier: Natural Language :: Spanish
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: Implementation :: CPython
+Classifier: Programming Language :: Python :: Implementation :: PyPy
Classifier: Topic :: Office/Business
diff --git a/__init__.py b/__init__.py
index 598261a..87d2165 100644
--- a/__init__.py
+++ b/__init__.py
@@ -1,5 +1,5 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from trytond.pool import Pool
from .price_list import *
diff --git a/locale/bg_BG.po b/locale/bg_BG.po
index 9a5bfec..fc13860 100644
--- a/locale/bg_BG.po
+++ b/locale/bg_BG.po
@@ -3,7 +3,9 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
msgstr ""
msgctxt "field:product.price_list,company:"
@@ -34,6 +36,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Име"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr ""
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Променено на"
diff --git a/locale/ca_ES.po b/locale/ca_ES.po
index fe78fbc..36713ed 100644
--- a/locale/ca_ES.po
+++ b/locale/ca_ES.po
@@ -3,8 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
-msgstr "Formula \"%(formula)s\" a línia de tarifa \"%(line)s\" incorrecta."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
+msgstr ""
+"La fórmula \"%(formula)s\" a la línia de tarifa \"%(line)s\" no és correcte "
+"generant l'excepció \"%(exception)s\"."
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -34,6 +38,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Nom"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Impost inclòs"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Data modificació"
diff --git a/locale/cs_CZ.po b/locale/cs_CZ.po
index 96113f8..f8f4506 100644
--- a/locale/cs_CZ.po
+++ b/locale/cs_CZ.po
@@ -3,7 +3,9 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
msgstr ""
msgctxt "field:product.price_list,company:"
@@ -34,6 +36,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr ""
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr ""
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr ""
diff --git a/locale/de_DE.po b/locale/de_DE.po
index 5a598c9..36bc4fc 100644
--- a/locale/de_DE.po
+++ b/locale/de_DE.po
@@ -3,8 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
-msgstr "Ungültige Formel \"%(formula)s\" in Preislistenzeile \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
+msgstr ""
+"Ungültige Formel \"%(formula)s\" in Preislistenzeile \"%(line)s\" mit "
+"Fehlermeldung \"%(exception)s\""
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -34,6 +38,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Name"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Steuer Inklusive"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Zuletzt geändert"
diff --git a/locale/es_AR.po b/locale/es_AR.po
index bef1285..e8d2bd7 100644
--- a/locale/es_AR.po
+++ b/locale/es_AR.po
@@ -3,9 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
msgstr ""
-"Fórmula «%(formula)s» en línea de precio de lista «%(line)s» no es correcta."
+"Fórmula «%(formula)s» incorrecta en línea de precio de lista «%(line)s» con "
+"excepción «%(exception)s»."
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -35,6 +38,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Nombre"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Impuesto incluido"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Fecha modificación"
@@ -81,7 +88,7 @@ msgstr "Secuencia"
msgctxt "field:product.price_list.line,unit_digits:"
msgid "Unit Digits"
-msgstr "Dígitos de unidad"
+msgstr "Decimales de unidad"
msgctxt "field:product.price_list.line,write_date:"
msgid "Write Date"
diff --git a/locale/es_CO.po b/locale/es_CO.po
index 5de9bc8..3424fbf 100644
--- a/locale/es_CO.po
+++ b/locale/es_CO.po
@@ -3,8 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
-msgstr "Fómula inválida \"%(formula)s\" en línea de lista de precios \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
+msgstr ""
+"Frmula inválida \"%s(formula)s\" en línea de lista de precio \"%(line)s\" "
+"con excepción \"%(exception)s\""
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -34,6 +38,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Nombre"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Impuesto Incluido"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Fecha de Modificación"
diff --git a/locale/es_EC.po b/locale/es_EC.po
index b90bf19..bed0ff4 100644
--- a/locale/es_EC.po
+++ b/locale/es_EC.po
@@ -3,10 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
msgstr ""
-"La fórmula \"%(formula)s\" en la línea de lista de precios \"%(line)s\" no "
-"es válida."
+"La fórmula \"%(formula)s\" en la línea de lista de precios \"%(line)s\" con "
+"excepción \"%(exception)s\" no es válida."
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -14,11 +16,11 @@ msgstr "Empresa"
msgctxt "field:product.price_list,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:product.price_list,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:product.price_list,id:"
msgid "ID"
@@ -36,21 +38,25 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Nombre"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Impuesto incluido"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:product.price_list,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "field:product.price_list.line,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:product.price_list.line,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:product.price_list.line,formula:"
msgid "Formula"
@@ -62,7 +68,7 @@ msgstr "ID"
msgctxt "field:product.price_list.line,price_list:"
msgid "Price List"
-msgstr "Lista de Precios"
+msgstr "Lista de precios"
msgctxt "field:product.price_list.line,product:"
msgid "Product"
@@ -82,15 +88,15 @@ msgstr "Secuencia"
msgctxt "field:product.price_list.line,unit_digits:"
msgid "Unit Digits"
-msgstr "Decimales de Unidad"
+msgstr "Decimales de unidad"
msgctxt "field:product.price_list.line,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:product.price_list.line,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "help:product.price_list.line,formula:"
msgid ""
@@ -98,40 +104,40 @@ msgid ""
"- unit_price: the original unit_price"
msgstr ""
"Expresión de Python que se evaluará con:\n"
-"- unit_price: El precio unitario original"
+"- unit_price: el precio unitario original"
msgctxt "model:ir.action,name:act_price_list_form"
msgid "Price Lists"
-msgstr "Listas de Precios"
+msgstr "Listas de precios"
msgctxt "model:ir.ui.menu,name:menu_price_list"
msgid "Price Lists"
-msgstr "Listas de Precios"
+msgstr "Listas de precios"
msgctxt "model:product.price_list,name:"
msgid "Price List"
-msgstr "Lista de Precios"
+msgstr "Lista de precios"
msgctxt "model:product.price_list.line,name:"
msgid "Price List Line"
-msgstr "Línea de Lista de Precios"
+msgstr "Línea de lista de precios"
msgctxt "view:party.party:"
msgid "Price List"
-msgstr "Lista de Precios"
+msgstr "Lista de precios"
msgctxt "view:product.price_list.line:"
msgid "Price List Line"
-msgstr "Línea de Lista de Precios"
+msgstr "Línea de lista de precios"
msgctxt "view:product.price_list.line:"
msgid "Price List Lines"
-msgstr "Líneas de Lista de Precios"
+msgstr "Líneas de lista de precios"
msgctxt "view:product.price_list:"
msgid "Price List"
-msgstr "Lista de Precios"
+msgstr "Lista de precios"
msgctxt "view:product.price_list:"
msgid "Price Lists"
-msgstr "Listas de Precios"
+msgstr "Listas de precios"
diff --git a/locale/es_ES.po b/locale/es_ES.po
index 8e94c01..36b4284 100644
--- a/locale/es_ES.po
+++ b/locale/es_ES.po
@@ -3,8 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
-msgstr "Formula \"%(formula)s\" en línea de tarifa \"%(line)s\" no es correcta."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
+msgstr ""
+"La fórmula \"%(formula)s\" en la línea de tarifa \"%(line)s\" no es correcta"
+" generando la excepción \"%(exception)s\"."
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -34,6 +38,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Nombre"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Impuestos incluidos"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Fecha modificación"
diff --git a/locale/fr_FR.po b/locale/fr_FR.po
index 1a97232..4821c45 100644
--- a/locale/fr_FR.po
+++ b/locale/fr_FR.po
@@ -3,10 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
msgstr ""
-"La formule « %(formula)s » de la ligne de liste de prix « %(line)s » est "
-"invalide."
+"Formule invalide « %(formula)s » sur la ligne de la liste de prix « %(line)s"
+" » avec l'exception « %(exception)s »."
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -36,6 +38,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Nom"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Taxe incluse"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Date de mise à jour"
diff --git a/locale/nl_NL.po b/locale/nl_NL.po
index 9af3e50..742acb0 100644
--- a/locale/nl_NL.po
+++ b/locale/nl_NL.po
@@ -3,7 +3,9 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
msgstr ""
#, fuzzy
@@ -38,6 +40,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Naam bijlage"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr ""
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr ""
diff --git a/locale/ru_RU.po b/locale/ru_RU.po
index ea19633..d724dc8 100644
--- a/locale/ru_RU.po
+++ b/locale/ru_RU.po
@@ -3,7 +3,9 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
msgstr ""
#, fuzzy
@@ -41,6 +43,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Наименование"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr ""
+
#, fuzzy
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
diff --git a/locale/sl_SI.po b/locale/sl_SI.po
index 6355f3b..f54fd19 100644
--- a/locale/sl_SI.po
+++ b/locale/sl_SI.po
@@ -3,8 +3,12 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:product.price_list.line:"
-msgid "Invalid formula \"%(formula)s\" in price list line \"%(line)s\"."
-msgstr "Neveljavna formula \"%(formula)s\" v postavki cenika \"%(line)s\"."
+msgid ""
+"Invalid formula \"%(formula)s\" in price list line \"%(line)s\" with "
+"exception \"%(exception)s\"."
+msgstr ""
+"Neveljavna formula \"%(formula)s\" v postavki cenika \"%(line)s\" z napako "
+"\"%(exception)s\"."
msgctxt "field:product.price_list,company:"
msgid "Company"
@@ -34,6 +38,10 @@ msgctxt "field:product.price_list,rec_name:"
msgid "Name"
msgstr "Ime"
+msgctxt "field:product.price_list,tax_included:"
+msgid "Tax Included"
+msgstr "Davek vključen"
+
msgctxt "field:product.price_list,write_date:"
msgid "Write Date"
msgstr "Zapisano"
diff --git a/price_list.py b/price_list.py
index 36df54a..184f14f 100644
--- a/price_list.py
+++ b/price_list.py
@@ -1,10 +1,12 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from decimal import Decimal
-import tokenize
-from StringIO import StringIO
+
+from sql import Null
+from simpleeval import simple_eval
+
from trytond.model import ModelView, ModelSQL, MatchMixin, fields
-from trytond.tools import safe_eval
+from trytond.tools import decistmt
from trytond.pyson import If, Eval
from trytond.transaction import Transaction
from trytond.pool import Pool
@@ -13,37 +15,6 @@ from trytond import backend
__all__ = ['PriceList', 'PriceListLine']
-# code snippet taken from http://docs.python.org/library/tokenize.html
-def decistmt(s):
- """Substitute Decimals for floats in a string of statements.
-
- >>> from decimal import Decimal
- >>> s = 'print +21.3e-5*-.1234/81.7'
- >>> decistmt(s)
- "print +Decimal ('21.3e-5')*-Decimal ('.1234')/Decimal ('81.7')"
-
- >>> exec(s)
- -3.21716034272e-007
- >>> exec(decistmt(s))
- -3.217160342717258261933904529E-7
- """
- result = []
- # tokenize the string
- g = tokenize.generate_tokens(StringIO(s).readline)
- for toknum, tokval, _, _, _ in g:
- # replace NUMBER tokens
- if toknum == tokenize.NUMBER and '.' in tokval:
- result.extend([
- (tokenize.NAME, 'Decimal'),
- (tokenize.OP, '('),
- (tokenize.STRING, repr(tokval)),
- (tokenize.OP, ')')
- ])
- else:
- result.append((toknum, tokval))
- return tokenize.untokenize(result)
-
-
class PriceList(ModelSQL, ModelView):
'Price List'
__name__ = 'product.price_list'
@@ -54,42 +25,27 @@ class PriceList(ModelSQL, ModelView):
('id', If(Eval('context', {}).contains('company'), '=', '!='),
Eval('context', {}).get('company', -1)),
])
+ tax_included = fields.Boolean('Tax Included')
lines = fields.One2Many('product.price_list.line', 'price_list', 'Lines')
@staticmethod
def default_company():
return Transaction().context.get('company')
- def _get_context_price_list_line(self, party, product, unit_price,
- quantity, uom):
- '''
- Get price list context for unit price
-
- :param party: the BrowseRecord of the party.party
- :param product: the BrowseRecord of the product.product
- :param unit_price: a Decimal for the default unit price in the
- company's currency and default uom of the product
- :param quantity: the quantity of product
- :param uom: the BrowseRecord of the product.uom
- :return: a dictionary
- '''
+ @staticmethod
+ def default_tax_included():
+ return False
+
+ def get_context_formula(self, party, product, unit_price, quantity, uom):
return {
- 'unit_price': unit_price,
- }
+ 'names': {
+ 'unit_price': unit_price,
+ },
+ }
def compute(self, party, product, unit_price, quantity, uom,
pattern=None):
- '''
- Compute price based on price list of party
-
- :param unit_price: a Decimal for the default unit price in the
- company's currency and default uom of the product
- :param quantity: the quantity of product
- :param uom: a instance of the product.uom
- :param pattern: a dictionary with price list field as key
- and match value as value
- :return: the computed unit price
- '''
+ 'Compute price based on price list of party'
Uom = Pool().get('product.uom')
@@ -101,12 +57,11 @@ class PriceList(ModelSQL, ModelView):
pattern['quantity'] = Uom.compute_qty(uom, quantity,
product.default_uom, round=False) if product else quantity
+ context = self.get_context_formula(
+ party, product, unit_price, quantity, uom)
for line in self.lines:
if line.match(pattern):
- with Transaction().set_context(
- self._get_context_price_list_line(party, product,
- unit_price, quantity, uom)):
- return line.get_unit_price()
+ return line.get_unit_price(**context)
return unit_price
@@ -133,7 +88,7 @@ class PriceListLine(ModelSQL, ModelView, MatchMixin):
cls._order.insert(0, ('sequence', 'ASC'))
cls._error_messages.update({
'invalid_formula': ('Invalid formula "%(formula)s" in price '
- 'list line "%(line)s".'),
+ 'list line "%(line)s" with exception "%(exception)s".'),
})
@classmethod
@@ -150,7 +105,7 @@ class PriceListLine(ModelSQL, ModelView, MatchMixin):
@staticmethod
def order_sequence(tables):
table, _ = tables[None]
- return [table.sequence == None, table.sequence]
+ return [table.sequence == Null, table.sequence]
@staticmethod
def default_formula():
@@ -172,23 +127,18 @@ class PriceListLine(ModelSQL, ModelView, MatchMixin):
'''
Check formula
'''
- pool = Pool()
- PriceList = pool.get('product.price_list')
- context = PriceList()._get_context_price_list_line(None, None,
- Decimal('0.0'), 0, None)
-
- with Transaction().set_context(**context):
- try:
- if not isinstance(self.get_unit_price(), Decimal):
- self.raise_user_error('invalid_formula', {
- 'formula': self.formula,
- 'line': self.rec_name,
- })
- except Exception:
- self.raise_user_error('invalid_formula', {
- 'formula': self.formula,
- 'line': self.rec_name,
- })
+ context = self.price_list.get_context_formula(
+ None, None, Decimal('0'), 0, None)
+
+ try:
+ if not isinstance(self.get_unit_price(**context), Decimal):
+ raise ValueError
+ except Exception, exception:
+ self.raise_user_error('invalid_formula', {
+ 'formula': self.formula,
+ 'line': self.rec_name,
+ 'exception': exception,
+ })
def match(self, pattern):
if 'quantity' in pattern:
@@ -197,10 +147,7 @@ class PriceListLine(ModelSQL, ModelView, MatchMixin):
return False
return super(PriceListLine, self).match(pattern)
- def get_unit_price(self):
- '''
- Return unit price (as Decimal)
- '''
- context = Transaction().context.copy()
- context['Decimal'] = Decimal
- return safe_eval(decistmt(self.formula), context)
+ def get_unit_price(self, **context):
+ 'Return unit price (as Decimal)'
+ context.setdefault('functions', {})['Decimal'] = Decimal
+ return simple_eval(decistmt(self.formula), **context)
diff --git a/price_list.xml b/price_list.xml
index 88b3a00..b84fc9d 100644
--- a/price_list.xml
+++ b/price_list.xml
@@ -19,7 +19,8 @@ this repository contains the full copyright notices and license terms. -->
<record model="ir.action.act_window" id="act_price_list_form">
<field name="name">Price Lists</field>
<field name="res_model">product.price_list</field>
- <field name="domain">[('company', '=', Eval('company'))]</field>
+ <field name="domain"
+ eval="[('company', '=', Eval('company'))]" pyson="1"/>
</record>
<record model="ir.action.act_window.view" id="act_price_list_form_view1">
<field name="sequence" eval="10"/>
@@ -56,7 +57,9 @@ this repository contains the full copyright notices and license terms. -->
<field name="global_p" eval="True"/>
</record>
<record model="ir.rule" id="rule_product_list1">
- <field name="domain">[('company', '=', user.company.id if user.company else None)]</field>
+ <field name="domain"
+ eval="[('company', '=', Eval('user', {}).get('company', None))]"
+ pyson="1"/>
<field name="rule_group" ref="rule_group_product_list"/>
</record>
diff --git a/setup.py b/setup.py
index c6d0c97..18f0ce6 100644
--- a/setup.py
+++ b/setup.py
@@ -1,6 +1,6 @@
#!/usr/bin/env python
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from setuptools import setup
import re
@@ -41,7 +41,7 @@ if minor_version % 2:
'hg+http://hg.tryton.org/modules/%s#egg=%s-%s' % (
name[8:], name, version))
-requires = []
+requires = ['simpleeval', 'python-sql >= 0.4']
for dep in info.get('depends', []):
if not re.match(r'(ir|res|webdav)(\W|$)', dep):
requires.append(get_require_version('trytond_%s' % dep))
@@ -85,6 +85,8 @@ setup(name=name,
'Natural Language :: Spanish',
'Operating System :: OS Independent',
'Programming Language :: Python :: 2.7',
+ 'Programming Language :: Python :: Implementation :: CPython',
+ 'Programming Language :: Python :: Implementation :: PyPy',
'Topic :: Office/Business',
],
license='GPL-3',
diff --git a/tests/__init__.py b/tests/__init__.py
index 761c2f5..d4fff33 100644
--- a/tests/__init__.py
+++ b/tests/__init__.py
@@ -1,5 +1,5 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from .test_product_price_list import suite
diff --git a/tests/test_product_price_list.py b/tests/test_product_price_list.py
index abb5c8e..5ab71f8 100644
--- a/tests/test_product_price_list.py
+++ b/tests/test_product_price_list.py
@@ -1,23 +1,13 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
import unittest
import trytond.tests.test_tryton
-from trytond.tests.test_tryton import test_view, test_depends
+from trytond.tests.test_tryton import ModuleTestCase
-class ProductPriceListTestCase(unittest.TestCase):
+class ProductPriceListTestCase(ModuleTestCase):
'Test ProductPriceList module'
-
- def setUp(self):
- trytond.tests.test_tryton.install_module('product_price_list')
-
- def test0005views(self):
- 'Test views'
- test_view('product_price_list')
-
- def test0006depends(self):
- 'Test depends'
- test_depends()
+ module = 'product_price_list'
def suite():
diff --git a/tryton.cfg b/tryton.cfg
index f0fe400..2e941e7 100644
--- a/tryton.cfg
+++ b/tryton.cfg
@@ -1,5 +1,5 @@
[tryton]
-version=3.4.1
+version=3.6.0
depends:
company
ir
diff --git a/trytond_product_price_list.egg-info/PKG-INFO b/trytond_product_price_list.egg-info/PKG-INFO
index 61e9174..bc13153 100644
--- a/trytond_product_price_list.egg-info/PKG-INFO
+++ b/trytond_product_price_list.egg-info/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond-product-price-list
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module with price list
Home-page: http://www.tryton.org/
Author: Tryton
Author-email: issue_tracker at tryton.org
License: GPL-3
-Download-URL: http://downloads.tryton.org/3.4/
+Download-URL: http://downloads.tryton.org/3.6/
Description: trytond_product_price_list
==========================
@@ -64,4 +64,6 @@ Classifier: Natural Language :: Slovenian
Classifier: Natural Language :: Spanish
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: Implementation :: CPython
+Classifier: Programming Language :: Python :: Implementation :: PyPy
Classifier: Topic :: Office/Business
diff --git a/trytond_product_price_list.egg-info/requires.txt b/trytond_product_price_list.egg-info/requires.txt
index a29faeb..49d1daa 100644
--- a/trytond_product_price_list.egg-info/requires.txt
+++ b/trytond_product_price_list.egg-info/requires.txt
@@ -1,3 +1,5 @@
-trytond_company >= 3.4, < 3.5
-trytond_product >= 3.4, < 3.5
-trytond >= 3.4, < 3.5
\ No newline at end of file
+simpleeval
+python-sql >= 0.4
+trytond_company >= 3.6, < 3.7
+trytond_product >= 3.6, < 3.7
+trytond >= 3.6, < 3.7
\ No newline at end of file
diff --git a/view/price_list_form.xml b/view/price_list_form.xml
index 403dc0a..d398f92 100644
--- a/view/price_list_form.xml
+++ b/view/price_list_form.xml
@@ -6,6 +6,12 @@ this repository contains the full copyright notices and license terms. -->
<field name="name"/>
<label name="company"/>
<field name="company"/>
- <field name="lines" colspan="4"
- view_ids="product_price_list.price_list_line_view_tree_sequence"/>
+ <label name="tax_included"/>
+ <field name="tax_included"/>
+ <notebook colspan="4">
+ <page name="lines">
+ <field name="lines" colspan="4"
+ view_ids="product_price_list.price_list_line_view_tree_sequence"/>
+ </page>
+ </notebook>
</form>
diff --git a/view/price_list_tree.xml b/view/price_list_tree.xml
index 9cab295..1c08836 100644
--- a/view/price_list_tree.xml
+++ b/view/price_list_tree.xml
@@ -3,4 +3,5 @@
this repository contains the full copyright notices and license terms. -->
<tree string="Price Lists">
<field name="name"/>
+ <field name="tax_included"/>
</tree>
--
tryton-modules-product-price-list
More information about the tryton-debian-vcs
mailing list