From 06f0effb848c6b938e03da8a61e44b3d032380e8 Mon Sep 17 00:00:00 2001 From: Tim Foley Date: Fri, 26 Jan 2018 15:30:23 -0800 Subject: Fix handling of errors in imported modules (#387) * Fix handling of errors in imported modules - If a semantic error is detected in an imported module, then don't try to generate IR code for it - Also, if a module (transitively) imports itself, then report that as an error - The way I'm checking for this is a bit hacky (I'm adding the module to the map of loaded modules, but in an "unfinished" state, and then using that unfinished state to detect the import of a module already being imported). This isn't a 100% complete solution for any of the related problems, but it improves the user experience for the common case. * Remove #import test. The feature is slated to be removed, so it isn't worth fixing up this test case. --- tests/diagnostics/recursive-import.slang.expected | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 tests/diagnostics/recursive-import.slang.expected (limited to 'tests/diagnostics/recursive-import.slang.expected') diff --git a/tests/diagnostics/recursive-import.slang.expected b/tests/diagnostics/recursive-import.slang.expected new file mode 100644 index 000000000..ad5cf1975 --- /dev/null +++ b/tests/diagnostics/recursive-import.slang.expected @@ -0,0 +1,6 @@ +result code = -1 +standard error = { +tests/diagnostics/recursive-import.slang(6): error 38200: module `recursive_import_extra` recursively imports itself +} +standard output = { +} -- cgit v1.2.3