From 86ba9c8bbc676758f8c7af3756d69fb6d5faa891 Mon Sep 17 00:00:00 2001 From: Robert Jordens Date: Mon, 2 Dec 2013 19:32:13 -0700 Subject: [PATCH] migen.fhdl.size: verify fslice for negative values --- migen/fhdl/size.py | 14 +++++++++----- migen/test/test_size.py | 3 +++ 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/migen/fhdl/size.py b/migen/fhdl/size.py index e771cccad..345c9c54d 100644 --- a/migen/fhdl/size.py +++ b/migen/fhdl/size.py @@ -161,16 +161,20 @@ def fslice(v, s): Examples -------- - >>> fslice(Signal(2), 1) #doctest: +ELLIPSIS + >>> fslice(f.Signal(2), 1) #doctest: +ELLIPSIS >>> bin(fslice(0b1101, slice(1, None, 2))) '0b10' + >>> fslice(-1, slice(0, 4)) + 1 + >>> fslice(-7, slice(None)) + 9 """ if isinstance(v, (bool, int)): if isinstance(s, int): s = slice(s) - idx = range(*s.indices(flen(v))) - return sum(((v>>i) & 1) << j for j, i in enumerate(idx)) + idx = range(*s.indices(bits_for(v))) + return sum(((v >> i) & 1) << j for j, i in enumerate(idx)) elif isinstance(v, f.Value): return v[s] else: @@ -190,8 +194,8 @@ def freversed(v): Examples -------- - >>> freversed(Signal(2)) #doctest: +ELLIPSIS - + >>> freversed(f.Signal(2)) #doctest: +ELLIPSIS + >>> bin(freversed(0b1011)) '0b1101' """ diff --git a/migen/test/test_size.py b/migen/test/test_size.py index 07b305247..a55ad4308 100644 --- a/migen/test/test_size.py +++ b/migen/test/test_size.py @@ -32,6 +32,9 @@ class SignalSizeCase(unittest.TestCase): fslice(self.s, sl) self.assertEqual(fslice(self.i, sl), 15) self.assertEqual(fslice(self.j, sl), 8) + self.assertEqual(fslice(-1, 9), 1) + self.assertEqual(fslice(-1, slice(0, 4)), 0b1) + self.assertEqual(fslice(-7, slice(0, None, 1)), 0b1001) def test_fslice_type(self): self.assertRaises(TypeError, fslice, [], 3)