diff options
| author | pepperpepperpepper <pepper@scannerjammer.com> | 2015-09-30 00:56:49 -0700 |
|---|---|---|
| committer | pepperpepperpepper <pepper@scannerjammer.com> | 2015-09-30 00:56:49 -0700 |
| commit | 5521785e6c52dd4603699d057d62a5797844fd13 (patch) | |
| tree | 3516ba416147ebd00104f3f5fc666371432af0ae /ricky/param/numberrange.py | |
| parent | 20a896ed6a8d54c3e59baa33ce3fce7a26343c20 (diff) | |
huge rename
Diffstat (limited to 'ricky/param/numberrange.py')
| -rw-r--r-- | ricky/param/numberrange.py | 27 |
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 |
