summaryrefslogtreecommitdiffstats
path: root/source
diff options
context:
space:
mode:
authorTim Foley <tfoleyNV@users.noreply.github.com>2017-07-17 10:27:52 -0700
committerGitHub <noreply@github.com>2017-07-17 10:27:52 -0700
commit0b4992fb69e359a7e566cca42331a196904556f5 (patch)
tree687ae0e64e7b2cc4624e785f76b6ee8061e3ba20 /source
parentc69060a75c20ee60b891622f0acd9ed598cb468e (diff)
parent782e6f0f675fd858acfdc66e5ea1fa46a646df71 (diff)
Merge pull request #108 from tfoleyNV/gh-105
Don't crash-fail on errors in entry point parameters
Diffstat (limited to 'source')
-rw-r--r--source/slang/emit.cpp26
-rw-r--r--source/slang/parameter-binding.cpp9
-rw-r--r--source/slang/slang-stdlib.cpp2
3 files changed, 30 insertions, 7 deletions
diff --git a/source/slang/emit.cpp b/source/slang/emit.cpp
index 7ffce2acd..8c6a46196 100644
--- a/source/slang/emit.cpp
+++ b/source/slang/emit.cpp
@@ -1495,14 +1495,28 @@ struct EmitVisitor
outerPrec.rightPrecedence = rightPrec;
}
+ void visitGenericAppExpr(GenericAppExpr* expr, ExprEmitArg const& arg)
+ {
+ auto prec = kEOp_Postfix;
+ auto outerPrec = arg.outerPrec;
+ bool needClose = MaybeEmitParens(outerPrec, prec);
-#define UNEXPECTED(NAME) \
- void visit##NAME(NAME*, ExprEmitArg const&) \
- { Emit(#NAME); }
-
- UNEXPECTED(GenericAppExpr);
+ EmitExprWithPrecedence(expr->FunctionExpr, leftSide(outerPrec, prec));
+ Emit("<");
+ bool first = true;
+ for(auto aa : expr->Arguments)
+ {
+ if(!first) Emit(", ");
+ EmitExpr(aa);
+ first = false;
+ }
+ Emit(" >");
-#undef UNEXPECTED
+ if(needClose)
+ {
+ Emit(")");
+ }
+ }
void visitSharedTypeExpr(SharedTypeExpr* expr, ExprEmitArg const&)
{
diff --git a/source/slang/parameter-binding.cpp b/source/slang/parameter-binding.cpp
index 007c023e2..8a8a993cd 100644
--- a/source/slang/parameter-binding.cpp
+++ b/source/slang/parameter-binding.cpp
@@ -994,6 +994,11 @@ static RefPtr<TypeLayout> processEntryPointParameter(
assert(!"unimplemented");
}
}
+ // If we ran into an error in checking the user's code, then skip this parameter
+ else if( auto errorType = type->As<ErrorType>() )
+ {
+ return nullptr;
+ }
else
{
assert(!"unimplemented");
@@ -1090,6 +1095,10 @@ static void collectEntryPointParameters(
state,
paramVarLayout);
+ // Skip parameters for which we could not compute a layout
+ if(!paramTypeLayout)
+ continue;
+
paramVarLayout->typeLayout = paramTypeLayout;
for (auto rr : paramTypeLayout->resourceInfos)
diff --git a/source/slang/slang-stdlib.cpp b/source/slang/slang-stdlib.cpp
index d266c0560..1c1bcceaf 100644
--- a/source/slang/slang-stdlib.cpp
+++ b/source/slang/slang-stdlib.cpp
@@ -264,7 +264,7 @@ __generic<T> __magic_type(HLSLLineStreamType) struct LineStream
void RestartStrip();
};
-__generic<T> __magic_type(HLSLLineStreamType) struct TriangleStream
+__generic<T> __magic_type(HLSLTriangleStreamType) struct TriangleStream
{
void Append(T value);
void RestartStrip();