summaryrefslogtreecommitdiff
path: root/ricky/param/numberrange.py
diff options
context:
space:
mode:
authorpepperpepperpepper <pepper@scannerjammer.com>2015-09-30 00:56:49 -0700
committerpepperpepperpepper <pepper@scannerjammer.com>2015-09-30 00:56:49 -0700
commit5521785e6c52dd4603699d057d62a5797844fd13 (patch)
tree3516ba416147ebd00104f3f5fc666371432af0ae /ricky/param/numberrange.py
parent20a896ed6a8d54c3e59baa33ce3fce7a26343c20 (diff)
huge rename
Diffstat (limited to 'ricky/param/numberrange.py')
-rw-r--r--ricky/param/numberrange.py27
1 files changed, 27 insertions, 0 deletions
diff --git a/ricky/param/numberrange.py b/ricky/param/numberrange.py
new file mode 100644
index 0000000..7e01a81
--- /dev/null
+++ b/ricky/param/numberrange.py
@@ -0,0 +1,27 @@
+import sys
+from ricky.param.multiselect import MultiSelect
+import random
+class NumberRange(MultiSelect):
+ def __init__(self, **kwargs):
+ super(NumberRange, self).__init__(**kwargs)
+ self.range_min = kwargs['min']
+ self.range_max = kwargs['max']
+ def randomize(self):
+ weights_total = sum(map(lambda x: x["weight"], self.options())) + self.range_max - self.range_min
+ choice = random.randint(0, weights_total)
+ position = 0
+ for elem in self.options():
+ position += elem["weight"]
+ if position >= choice:
+ self.value = elem["value"]
+ return
+ self.value = random.randint(self.range_min,self.range_max)
+ @property
+ def value(self):
+ return super(MultiSelect, self).get_value()
+ @value.setter
+ def value(self, value):
+ self._value = value
+ if not self._value is None:
+ self.is_ready = 1
+ self.set_by_user = 1