Commit 65749cf
authored
Diagnose if extension declares new interface requirements (#9276)
## Summary
This PR adds a diagnostic for missing symbol definitions during the IR
linking phase. When `cloneGlobalValueWithLinkage` selects the "best
value" for a symbol, it now validates that the value is actually
usable—meaning it must either:
- Have a function body (a concrete definition)
- Be marked as a target intrinsic (via appropriate decoration)
- Be marked as an imported symbol (e.g., `DLLImport` decoration)
- Have SPIRV instruction or autodiff decorations
If none of these conditions are met, the compiler now emits a linker
error indicating the symbol lacks a definition, along with note
diagnostics listing all candidate values that were considered.
## Background
Previously, declaring a method signature in an extension without
providing a body would silently proceed through compilation until
hitting an internal error during code emission ("unexpected IR opcode").
This made it difficult to diagnose issues where users accidentally
declared interface-like requirements in extensions—something that isn't
semantically valid since extensions cannot add new requirements to
existing types.
## Changes
- **`source/slang/slang-ir-link.cpp`**: Added validation in
`cloneGlobalValueWithLinkage` to check that the selected best value has
a valid definition. Added helper function `isFunctionDefinedOrImported`
to perform the check. Emits a clear diagnostic when a symbol is
referenced but has no definition.
- **`tests/diagnostics/extension-interface-requirement.slang`**: Added
test case covering the scenario where an extension declares a method
without a body.
Closes #91981 parent 72761cc commit 65749cf
File tree
2 files changed
+140
-0
lines changed- source/slang
- tests/diagnostics
2 files changed
+140
-0
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
60 | 60 | | |
61 | 61 | | |
62 | 62 | | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
63 | 66 | | |
64 | 67 | | |
65 | 68 | | |
| 69 | + | |
66 | 70 | | |
67 | 71 | | |
68 | 72 | | |
| |||
1553 | 1557 | | |
1554 | 1558 | | |
1555 | 1559 | | |
| 1560 | + | |
| 1561 | + | |
| 1562 | + | |
| 1563 | + | |
| 1564 | + | |
| 1565 | + | |
| 1566 | + | |
| 1567 | + | |
| 1568 | + | |
| 1569 | + | |
| 1570 | + | |
| 1571 | + | |
| 1572 | + | |
| 1573 | + | |
| 1574 | + | |
| 1575 | + | |
| 1576 | + | |
| 1577 | + | |
| 1578 | + | |
| 1579 | + | |
| 1580 | + | |
1556 | 1581 | | |
1557 | 1582 | | |
1558 | 1583 | | |
| |||
1697 | 1722 | | |
1698 | 1723 | | |
1699 | 1724 | | |
| 1725 | + | |
| 1726 | + | |
| 1727 | + | |
| 1728 | + | |
| 1729 | + | |
| 1730 | + | |
| 1731 | + | |
| 1732 | + | |
| 1733 | + | |
| 1734 | + | |
| 1735 | + | |
| 1736 | + | |
| 1737 | + | |
| 1738 | + | |
| 1739 | + | |
| 1740 | + | |
| 1741 | + | |
| 1742 | + | |
| 1743 | + | |
| 1744 | + | |
| 1745 | + | |
| 1746 | + | |
| 1747 | + | |
| 1748 | + | |
| 1749 | + | |
| 1750 | + | |
| 1751 | + | |
| 1752 | + | |
| 1753 | + | |
| 1754 | + | |
| 1755 | + | |
| 1756 | + | |
| 1757 | + | |
| 1758 | + | |
| 1759 | + | |
| 1760 | + | |
| 1761 | + | |
| 1762 | + | |
| 1763 | + | |
| 1764 | + | |
| 1765 | + | |
| 1766 | + | |
| 1767 | + | |
| 1768 | + | |
| 1769 | + | |
| 1770 | + | |
| 1771 | + | |
| 1772 | + | |
| 1773 | + | |
| 1774 | + | |
| 1775 | + | |
| 1776 | + | |
| 1777 | + | |
| 1778 | + | |
1700 | 1779 | | |
1701 | 1780 | | |
1702 | 1781 | | |
| |||
2065 | 2144 | | |
2066 | 2145 | | |
2067 | 2146 | | |
| 2147 | + | |
2068 | 2148 | | |
2069 | 2149 | | |
2070 | 2150 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
0 commit comments