blob: 7a86dfe90820f2d3d022fb337e16a3e6c7d1cd03 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
#ifndef BAKER_SL_COMPILED_PROGRAM_H
#define BAKER_SL_COMPILED_PROGRAM_H
#include "../core/basic.h"
#include "diagnostics.h"
#include "syntax.h"
#include "type-layout.h"
namespace Slang
{
namespace Compiler
{
#if 0
class ShaderMetaData
{
public:
CoreLib::String ShaderName;
CoreLib::EnumerableDictionary<CoreLib::String, CoreLib::RefPtr<ILModuleParameterSet>> ParameterSets; // bindingName->DescSet
};
class StageSource
{
public:
String MainCode;
List<unsigned char> BinaryCode;
};
class CompiledShaderSource
{
public:
EnumerableDictionary<String, StageSource> Stages;
ShaderMetaData MetaData;
};
#endif
void IndentString(StringBuilder & sb, String src);
struct EntryPointResult
{
String outputSource;
};
struct TranslationUnitResult
{
String outputSource;
List<EntryPointResult> entryPoints;
};
class CompileResult
{
public:
DiagnosticSink* mSink = nullptr;
#if 0
String ScheduleFile;
RefPtr<ILProgram> Program;
EnumerableDictionary<String, CompiledShaderSource> CompiledSource; // shader -> stage -> code
#endif
// Per-translation-unit results
List<TranslationUnitResult> translationUnits;
#if 0
void PrintDiagnostics()
{
for (int i = 0; i < sink.diagnostics.Count(); i++)
{
fprintf(stderr, "%S(%d): %s %d: %S\n",
sink.diagnostics[i].Position.FileName.ToWString(),
sink.diagnostics[i].Position.Line,
getSeverityName(sink.diagnostics[i].severity),
sink.diagnostics[i].ErrorID,
sink.diagnostics[i].Message.ToWString());
}
}
#endif
CompileResult()
{}
~CompileResult()
{
}
DiagnosticSink * GetErrorWriter()
{
return mSink;
}
int GetErrorCount()
{
return mSink->GetErrorCount();
}
};
}
}
#endif
|