summaryrefslogtreecommitdiffstats
path: root/source/core
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2023-04-18 12:36:06 -0400
committerGitHub <noreply@github.com>2023-04-18 12:36:06 -0400
commit181fd1f3c9c4b047c1947096e7b3f8e5bc2314c3 (patch)
tree308cbadae2f68d43ca20f92755b08db08e8b2283 /source/core
parent90a9f43573ec0777c2ae4fa20c8fdc51a4ae7b3a (diff)
On demand SourceMap JSON serialization (#2811)
* #include an absolute path didn't work - because paths were taken to always be relative. * Moved JSON source map writing logic to JSONSourceMapUtil. * Use ArtifactHandler to read/write SourceMaps. Use ObjectCastableAdapter to hold SourceMap Only serialize SourceMap <-> JSON on demand.
Diffstat (limited to 'source/core')
-rw-r--r--source/core/slang-castable.cpp31
-rw-r--r--source/core/slang-castable.h53
2 files changed, 84 insertions, 0 deletions
diff --git a/source/core/slang-castable.cpp b/source/core/slang-castable.cpp
index f3c6541dd..6b7644bf2 100644
--- a/source/core/slang-castable.cpp
+++ b/source/core/slang-castable.cpp
@@ -20,6 +20,37 @@ namespace Slang {
return castable;
}
+/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! ObjectCastableAdapter !!!!!!!!!!!!!!!!!!!!!!!!!!! */
+
+void* ObjectCastableAdapter::castAs(const Guid& guid)
+{
+ if (auto intf = getInterface(guid))
+ {
+ return intf;
+ }
+ return getObject(guid);
+}
+
+void* ObjectCastableAdapter::getInterface(const Guid& guid)
+{
+ if (guid == ISlangUnknown::getTypeGuid() ||
+ guid == ICastable::getTypeGuid() ||
+ guid == IObjectCastableAdapter::getTypeGuid())
+ {
+ return static_cast<IObjectCastableAdapter*>(this);
+ }
+ return nullptr;
+}
+
+void* ObjectCastableAdapter::getObject(const Guid& guid)
+{
+ if (guid == m_containedGuid)
+ {
+ return m_contained;
+ }
+ return nullptr;
+}
+
/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! UnknownCastableAdapter !!!!!!!!!!!!!!!!!!!!!!!!!!! */
void* UnknownCastableAdapter::castAs(const Guid& guid)
diff --git a/source/core/slang-castable.h b/source/core/slang-castable.h
index a72822f05..4f4fdc940 100644
--- a/source/core/slang-castable.h
+++ b/source/core/slang-castable.h
@@ -35,6 +35,58 @@ SLANG_FORCE_INLINE T* as(ICastable* castable)
return nullptr;
}
+/* Adapter interface to make non castable ref counted object usable as ICastable */
+class IObjectCastableAdapter : public ICastable
+{
+ SLANG_COM_INTERFACE(0x8b4aad81, 0x4934, 0x4a67, { 0xb2, 0xe2, 0xe9, 0x17, 0xfc, 0x29, 0x12, 0x54 });
+
+ /// Get the contained object
+ virtual SLANG_NO_THROW RefObject* SLANG_MCALL getContained() = 0;
+ /// Get the guid that represents the contained ref object
+ virtual SLANG_NO_THROW SlangUUID getContainedGuid() = 0;
+};
+
+class ObjectCastableAdapter : public ComBaseObject, public IObjectCastableAdapter
+{
+public:
+ SLANG_COM_BASE_IUNKNOWN_ALL
+
+ // ICastable
+ SLANG_NO_THROW void* SLANG_MCALL castAs(const Guid& guid) SLANG_OVERRIDE;
+
+ // IObjectCastableAdapter
+ virtual SLANG_NO_THROW RefObject* SLANG_MCALL getContained() SLANG_OVERRIDE { return m_contained; }
+ virtual SlangUUID getContainedGuid() SLANG_OVERRIDE { return m_containedGuid; }
+
+ template <typename T>
+ explicit ObjectCastableAdapter(T* ptr)
+ {
+ m_containedGuid = T::getTypeGuid();
+ m_contained = ptr;
+ }
+ template <typename T>
+ explicit ObjectCastableAdapter(const RefPtr<T>& ptr)
+ {
+ m_containedGuid = T::getTypeGuid();
+ m_contained = ptr;
+ }
+
+ ObjectCastableAdapter(RefObject* obj, const Guid& containedGuid) :
+ m_contained(obj),
+ m_containedGuid(containedGuid)
+ {
+ SLANG_ASSERT(obj);
+ }
+
+protected:
+ void* getInterface(const Guid& guid);
+ void* getObject(const Guid& guid);
+
+ RefPtr<RefObject> m_contained;
+ SlangUUID m_containedGuid;
+};
+
+
/* Adapter interface to make a non castable types work as ICastable */
class IUnknownCastableAdapter : public ICastable
{
@@ -44,6 +96,7 @@ class IUnknownCastableAdapter : public ICastable
virtual SLANG_NO_THROW ISlangUnknown* SLANG_MCALL getContained() = 0;
};
+
/* An adapter such that types which aren't derived from ICastable, can be used as such.
With the following caveats.