diff --git a/nmigen/build/plat.py b/nmigen/build/plat.py index 00c147f3..174cda7e 100644 --- a/nmigen/build/plat.py +++ b/nmigen/build/plat.py @@ -50,15 +50,17 @@ def add_file(self, filename, content): if not isinstance(filename, str): raise TypeError("File name must be a string, not {!r}" .format(filename)) - if filename in self.extra_files: - raise ValueError("File {!r} already exists" - .format(filename)) if hasattr(content, "read"): content = content.read() elif not isinstance(content, (str, bytes)): raise TypeError("File contents must be str, bytes, or a file-like object, not {!r}" .format(content)) - self.extra_files[filename] = content + if filename in self.extra_files: + if self.extra_files[filename] != content: + raise ValueError("File {!r} already exists" + .format(filename)) + else: + self.extra_files[filename] = content @property def _toolchain_env_var(self): diff --git a/nmigen/test/test_build_plat.py b/nmigen/test/test_build_plat.py index a974a812..2b2ec62e 100644 --- a/nmigen/test/test_build_plat.py +++ b/nmigen/test/test_build_plat.py @@ -25,6 +25,10 @@ def test_add_file_bytes(self): self.platform.add_file("x.txt", b"foo") self.assertEqual(self.platform.extra_files["x.txt"], b"foo") + def test_add_file_exact_duplicate(self): + self.platform.add_file("x.txt", b"foo") + self.platform.add_file("x.txt", b"foo") + def test_add_file_io(self): with open(__file__) as f: self.platform.add_file("x.txt", f)