diff src/memory/params.py @ 1226:72f25d671368

memory (params): use more generic param attribute "constraint" instead of "min" and "max"
author souliane <souliane@mailoo.org>
date Mon, 06 Oct 2014 11:18:37 +0200
parents e6e0ea4dc835
children 4da2e4d58bd0
line wrap: on
line diff
--- a/src/memory/params.py	Sat Oct 04 10:26:10 2014 +0200
+++ b/src/memory/params.py	Mon Oct 06 11:18:37 2014 +0200
@@ -44,17 +44,17 @@
     <individual>
         <category name="General" label="%(category_general)s">
             <param name="Password" value="" type="password" />
-            <param name="%(history_param)s" label="%(label_history)s" value="20" min="0" max="100" type="int" security="0" />
+            <param name="%(history_param)s" label="%(history_label)s" value="20" constraint="0;100" type="int" security="0" />
         </category>
         <category name="Connection" label="%(category_connection)s">
             <param name="JabberID" value="name@example.org/SàT" type="string" />
             <param name="Password" value="" type="password" />
-            <param name="Priority" value="50" type="int" min="-128" max="127"/>
+            <param name="Priority" value="50" type="int" constraint="-128;127"/>
             <param name="%(force_server_param)s" value="" type="string" />
-            <param name="%(force_port_param)s" value="" type="int" min="80" max="65535" />
-            <param name="NewAccount" label="%(label_NewAccount)s" type="button" callback_id="registerNewAccount"/>
-            <param name="autoconnect" label="%(label_autoconnect)s" value="true" type="bool" />
-            <param name="autodisconnect" label="%(label_autodisconnect)s" value="false"  type="bool" />
+            <param name="%(force_port_param)s" value="" type="int" constraint="1;65535" />
+            <param name="NewAccount" label="%(new_account_label)s" type="button" callback_id="registerNewAccount"/>
+            <param name="autoconnect" label="%(autoconnect_label)s" value="true" type="bool" />
+            <param name="autodisconnect" label="%(autodisconnect_label)s" value="false"  type="bool" />
         </category>
         <category name="Misc" label="%(category_misc)s">
             <param name="Watched" value="test@Jabber.goffi.int" type="string" />
@@ -65,13 +65,13 @@
         'category_general': D_("General"),
         'category_connection': D_("Connection"),
         'history_param': C.HISTORY_LIMIT,
-        'label_history': D_('Chat history limit'),
-        'label_NewAccount': D_("Register new account"),
-        'label_autoconnect': D_('Connect on frontend startup'),
-        'label_autodisconnect': D_('Disconnect on frontend closure'),
-        'category_misc': D_("Misc"),
+        'history_label': D_('Chat history limit'),
         'force_server_param': C.FORCE_SERVER_PARAM,
         'force_port_param': C.FORCE_PORT_PARAM,
+        'new_account_label': D_("Register new account"),
+        'autoconnect_label': D_('Connect on frontend startup'),
+        'autodisconnect_label': D_('Disconnect on frontend closure'),
+        'category_misc': D_("Misc"),
     }
 
     def load_default_params(self):
@@ -755,10 +755,13 @@
                     log.debug(_("Trying to set parameter '%(param)s' in category '%(cat)s' with an non-integer value"
                                 % {'param': name, 'cat': category}))
                     return defer.succeed(None)
-                if node[1].hasAttribute("min"):
-                    value = str(max(int(value), int(node[1].getAttribute("min"))))
-                if node[1].hasAttribute("max"):
-                    value = str(min(int(value), int(node[1].getAttribute("max"))))
+                if node[1].hasAttribute("constraint"):
+                    constraint = node[1].getAttribute("constraint")
+                    try:
+                        min_, max_ = [int(limit) for limit in constraint.split(";")]
+                    except ValueError:
+                        raise exceptions.InternalError("Invalid integer parameter constraint: %s" % constraint)
+                    value = str(min(max(int(value), min_), max_))
 
         log.info(_("Setting parameter (%(category)s, %(name)s) = %(value)s") %
                  {'category': category, 'name': name, 'value': value if type_ != 'password' else '********'})