From 6036fffef2f8be0afb6b82203a4dd56489dbd178 Mon Sep 17 00:00:00 2001 From: Robert Jordens Date: Sun, 17 Aug 2014 14:56:31 -0600 Subject: [PATCH] Signal.__getitem__: raise TypeError and IndexError when appropriate --- migen/fhdl/structure.py | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/migen/fhdl/structure.py b/migen/fhdl/structure.py index 3edc28608..ba84dd85b 100644 --- a/migen/fhdl/structure.py +++ b/migen/fhdl/structure.py @@ -81,17 +81,20 @@ class Value(HUID): def __getitem__(self, key): from migen.fhdl.bitcontainer import flen + n = flen(self) if isinstance(key, int): + if key >= n: + raise IndexError if key < 0: - key += flen(self) + key += n return _Slice(self, key, key+1) elif isinstance(key, slice): - start, stop, step = key.indices(flen(self)) + start, stop, step = key.indices(n) if step != 1: return Cat(self[i] for i in range(start, stop, step)) return _Slice(self, start, stop) else: - raise KeyError + raise TypeError def eq(self, r): """Assignment