summaryrefslogtreecommitdiff
path: root/source/slang/slang-check-conformance.cpp
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2023-07-18 08:08:11 -0700
committerGitHub <noreply@github.com>2023-07-18 15:08:11 +0000
commit4cb3eeb832b5fb29a61f2934b3daa5e42a3d6cde (patch)
tree89713b5d83b4fee0dad6aa52b72d5ca695f4e8f1 /source/slang/slang-check-conformance.cpp
parent138a44ef272841cb555fa0eb5c49cc889bf1d64a (diff)
Simplify Lookup and improve compiler performance. (#2996)
* Simplify lookup. * Various bug fixes. * Report type dictionary size in perf benchmark. * Remove type duplication. * increase initial dict size. * Bug fix. * Fix bugs. * Fixup. * Revert type legalization looping. * Fix specialization pass. --------- Co-authored-by: Yong He <yhe@nvidia.com>
Diffstat (limited to 'source/slang/slang-check-conformance.cpp')
-rw-r--r--source/slang/slang-check-conformance.cpp15
1 files changed, 12 insertions, 3 deletions
diff --git a/source/slang/slang-check-conformance.cpp b/source/slang/slang-check-conformance.cpp
index 0eb44399d..2696f798d 100644
--- a/source/slang/slang-check-conformance.cpp
+++ b/source/slang/slang-check-conformance.cpp
@@ -50,6 +50,18 @@ namespace Slang
}
SubtypeWitness* SemanticsVisitor::isSubtype(
+ Type* subType,
+ Type* superType)
+ {
+ SubtypeWitness* result = nullptr;
+ if (getShared()->tryGetSubtypeWitness(subType, superType, result))
+ return result;
+ result = checkAndConstructSubtypeWitness(subType, superType);
+ getShared()->cacheSubtypeWitness(subType, superType, result);
+ return result;
+ }
+
+ SubtypeWitness* SemanticsVisitor::checkAndConstructSubtypeWitness(
Type* subType,
Type* superType)
{
@@ -92,9 +104,6 @@ namespace Slang
// For now we are continuing to conflate all the subtype-ish relationships but not
// tangling convertibility into it.
- // TODO: Evaluate whether it is beneficial to memo-cache
- // the results of subtype tests on the `SharedSemanticsContext`.
-
// In the common case, we can use the pre-computed inheritance information for `subType`
// to enumerate all the types it transitively inherits from.
//