summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-mangle.cpp
diff options
context:
space:
mode:
authorTim Foley <tfoleyNV@users.noreply.github.com>2020-02-21 10:39:05 -0800
committerGitHub <noreply@github.com>2020-02-21 10:39:05 -0800
commit830671c2210191f69ddc403cc12f5454bb55b0f0 (patch)
treebc242d34920715c33c827f4071d1ca8a1994a6b6 /source/slang/slang-mangle.cpp
parent433ce869481b72ad44897dcc91d7038b03ba45e2 (diff)
Add surface syntax for "this type" (#1236)
Within the context of an aggregate type (or an `extension` of one), the programmer can use `this` to refer to the "current" instance of the surrounding type, but there is no easy way to utter the name of the type itself. This is especially relevant inside of an `interface`, where the type of `this` isn't actually the `interface` type, but rather a placeholder for the as-yet-unknown concrete type that will implement the interface. This change adds a keyword `This` that works similarly to `this`, but names the current *type* instead of the current instance. It can be used to declare things like binary methods or factory functions in an interface: ``` interface IBasicMathType { This absoluteValue(); This sumWith(This left); } T doSomeMath<T:IBasicMathType>(T value) { return value.sumWith(value.absoluteValue()); } ``` The `This` type is consistent with the type named `Self` in Rust and Swift (where Rust/Swift use `self` instead of `this`). Other names could be considered (e.g., `ThisType`) if we find that users don't like the name in this change.
Diffstat (limited to 'source/slang/slang-mangle.cpp')
-rw-r--r--source/slang/slang-mangle.cpp5
1 files changed, 5 insertions, 0 deletions
diff --git a/source/slang/slang-mangle.cpp b/source/slang/slang-mangle.cpp
index fbeb5c9bf..5d9320f3d 100644
--- a/source/slang/slang-mangle.cpp
+++ b/source/slang/slang-mangle.cpp
@@ -151,6 +151,11 @@ namespace Slang
}
emitRaw(context, "U");
}
+ else if( auto thisType = dynamicCast<ThisType>(type) )
+ {
+ emitRaw(context, "t");
+ emitQualifiedName(context, thisType->interfaceDeclRef);
+ }
else
{
SLANG_UNEXPECTED("unimplemented case in mangling");