Unverified Commit beec2e4a by Malcolm Bechard Committed by GitHub

tweak local_size comparison a bit (#2456)

no longer causes an incorrect error if the current unit has local_size set, but the incoming unit does not
parent fb53f835
...@@ -196,12 +196,14 @@ void TIntermediate::mergeModes(TInfoSink& infoSink, TIntermediate& unit) ...@@ -196,12 +196,14 @@ void TIntermediate::mergeModes(TInfoSink& infoSink, TIntermediate& unit)
MERGE_TRUE(pointMode); MERGE_TRUE(pointMode);
for (int i = 0; i < 3; ++i) { for (int i = 0; i < 3; ++i) {
if (!localSizeNotDefault[i] && unit.localSizeNotDefault[i]) { if (unit.localSizeNotDefault[i]) {
localSize[i] = unit.localSize[i]; if (!localSizeNotDefault[i]) {
localSizeNotDefault[i] = true; localSize[i] = unit.localSize[i];
localSizeNotDefault[i] = true;
}
else if (localSize[i] != unit.localSize[i])
error(infoSink, "Contradictory local size");
} }
else if (localSize[i] != unit.localSize[i])
error(infoSink, "Contradictory local size");
if (localSizeSpecId[i] == TQualifier::layoutNotSet) if (localSizeSpecId[i] == TQualifier::layoutNotSet)
localSizeSpecId[i] = unit.localSizeSpecId[i]; localSizeSpecId[i] = unit.localSizeSpecId[i];
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment