summaryrefslogtreecommitdiffstats
path: root/source/slang/slang.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang.cpp')
-rw-r--r--source/slang/slang.cpp22
1 files changed, 18 insertions, 4 deletions
diff --git a/source/slang/slang.cpp b/source/slang/slang.cpp
index 6b2814ca7..637b22090 100644
--- a/source/slang/slang.cpp
+++ b/source/slang/slang.cpp
@@ -4887,8 +4887,16 @@ SlangResult _addLibraryReference(EndToEndCompileRequest* req, IArtifact* artifac
auto sourceMap = asBoxValue<SourceMap>(castable);
SLANG_ASSERT(sourceMap);
- // I guess we add to all ir modules?
-
+ // TODO(JS):
+ // There is perhaps (?) a risk here that we might copy the obfuscated map
+ // into some output container. Currently that only happens for source maps
+ // that are from translation units.
+ //
+ // On the other hand using "import" is a way that such source maps *would* be
+ // copied into the output, and that is something that could be a vector
+ // for leaking.
+ //
+ // That isn't a risk from -r though because, it doesn't create a translation unit(s).
for (auto irModule : library->m_modules)
{
irModule->setObfuscatedSourceMap(sourceMap);
@@ -5316,9 +5324,15 @@ ISlangMutableFileSystem* EndToEndCompileRequest::getCompileRequestResultAsFileSy
if (m_containerArtifact)
{
ComPtr<ISlangMutableFileSystem> fileSystem(new MemoryFileSystem);
- if (SLANG_SUCCEEDED(ArtifactContainerUtil::writeContainer(m_containerArtifact, "", fileSystem)))
+
+ // Filter the containerArtifact into things that can be written
+ ComPtr<IArtifact> writeArtifact;
+ if (SLANG_SUCCEEDED(ArtifactContainerUtil::filter(m_containerArtifact, writeArtifact)))
{
- m_containerFileSystem.swap(fileSystem);
+ if (SLANG_SUCCEEDED(ArtifactContainerUtil::writeContainer(writeArtifact, "", fileSystem)))
+ {
+ m_containerFileSystem.swap(fileSystem);
+ }
}
}
}