Fix #1981
Copy over incoming units localSize if it's set, and this->localSize is not set Also fix overwritting localSizeSpecId if it's already been set.
This commit is contained in:
parent
38b4db48f9
commit
dd9e570db6
@ -192,12 +192,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 (localSize[i] > 1)
|
if (!localSizeNotDefault[i] && unit.localSizeNotDefault[i]) {
|
||||||
localSize[i] = unit.localSize[i];
|
localSize[i] = unit.localSize[i];
|
||||||
|
localSizeNotDefault[i] = true;
|
||||||
|
}
|
||||||
else if (localSize[i] != unit.localSize[i])
|
else if (localSize[i] != unit.localSize[i])
|
||||||
error(infoSink, "Contradictory local size");
|
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];
|
||||||
else if (localSizeSpecId[i] != unit.localSizeSpecId[i])
|
else if (localSizeSpecId[i] != unit.localSizeSpecId[i])
|
||||||
error(infoSink, "Contradictory local size specialization ids");
|
error(infoSink, "Contradictory local size specialization ids");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user