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.cpp65
1 files changed, 61 insertions, 4 deletions
diff --git a/source/slang/slang.cpp b/source/slang/slang.cpp
index 8fe08884e..b0adb2025 100644
--- a/source/slang/slang.cpp
+++ b/source/slang/slang.cpp
@@ -13,6 +13,7 @@
#include "../slang/type-layout.h"
#include "slang-file-system.h"
+#include "../core/slang-writer.h"
#include "ir-serialize.h"
@@ -305,6 +306,12 @@ CompileRequest::CompileRequest(Session* session)
sourceManager->initialize(session->getBuiltinSourceManager());
+ // Set all the default writers
+ for (int i = 0; i < int(WriterChannel::CountOf); ++i)
+ {
+ setWriter(WriterChannel(i), nullptr);
+ }
+
// Set up the default file system
SLANG_ASSERT(fileSystem == nullptr);
fileSystemExt = new CacheFileSystem(DefaultFileSystem::getSingleton());
@@ -368,9 +375,38 @@ MatrixLayoutMode TargetRequest::getDefaultMatrixLayoutMode()
}
-
//
+static ISlangWriter* _getDefaultWriter(WriterChannel chan)
+{
+ static FileWriter stdOut(stdout, WriterFlag::IsStatic | WriterFlag::IsUnowned);
+ static FileWriter stdError(stderr, WriterFlag::IsStatic | WriterFlag::IsUnowned);
+ static NullWriter nullWriter(WriterFlag::IsStatic | WriterFlag::IsConsole);
+
+ switch (chan)
+ {
+ case WriterChannel::StdError: return &stdError;
+ case WriterChannel::StdOutput: return &stdOut;
+ case WriterChannel::Diagnostic: return &nullWriter;
+ default:
+ {
+ SLANG_ASSERT(!"Unknown type");
+ return &stdError;
+ }
+ }
+}
+
+void CompileRequest::setWriter(WriterChannel chan, ISlangWriter* writer)
+{
+ writer = writer ? writer : _getDefaultWriter(chan);
+ m_writers[int(chan)] = writer;
+
+ if (chan == WriterChannel::Diagnostic)
+ {
+ mSink.writer = writer;
+ }
+}
+
SlangResult CompileRequest::loadFile(String const& path, ISlangBlob** outBlob)
{
return fileSystemExt->loadFile(path.Buffer(), outBlob);
@@ -1205,7 +1241,6 @@ SLANG_API void spSetFileSystem(
}
}
-
SLANG_API void spSetCompileFlags(
SlangCompileRequest* request,
SlangCompileFlags flags)
@@ -1319,11 +1354,33 @@ SLANG_API void spSetDiagnosticCallback(
SlangDiagnosticCallback callback,
void const* userData)
{
+ using namespace Slang;
+
if(!request) return;
auto req = REQ(request);
- req->mSink.callback = callback;
- req->mSink.callbackUserData = (void*) userData;
+ ComPtr<ISlangWriter> writer(new CallbackWriter(callback, userData, WriterFlag::IsConsole));
+ req->setWriter(WriterChannel::Diagnostic, writer);
+}
+
+SLANG_API void spSetWriter(
+ SlangCompileRequest* request,
+ SlangWriterChannel chan,
+ ISlangWriter* writer)
+{
+ if (!request) return;
+ auto req = REQ(request);
+
+ req->setWriter(Slang::WriterChannel(chan), writer);
+}
+
+SLANG_API ISlangWriter* spGetWriter(
+ SlangCompileRequest* request,
+ SlangWriterChannel chan)
+{
+ if (!request) return nullptr;
+ auto req = REQ(request);
+ return req->getWriter(Slang::WriterChannel(chan));
}
SLANG_API void spAddSearchPath(