171bool Semantic::visit(LiteralExpressionAST *ast)
174 _expr.isConstant =
true;
176 if (ast->value->at(0) == QLatin1Char(
't') && *ast->value == QLatin1String(
"true"))
177 _expr.type = _engine->boolType();
178 else if (ast->value->at(0) == QLatin1Char(
'f') && *ast->value == QLatin1String(
"false"))
179 _expr.type = _engine->boolType();
180 else if (ast->value->endsWith(QLatin1Char(
'u')) || ast->value->endsWith(QLatin1Char(
'U')))
181 _expr.type = _engine->uintType();
182 else if (ast->value->endsWith(QLatin1String(
"lf")) || ast->value->endsWith(QLatin1String(
"LF")))
183 _expr.type = _engine->doubleType();
184 else if (ast->value->endsWith(QLatin1Char(
'f')) || ast->value->endsWith(QLatin1Char(
'F')) || ast->value->contains(QLatin1Char(
'.')))
185 _expr.type = _engine->floatType();
187 _expr.type = _engine->intType();
285bool Semantic::implicitCast(
const Type *type,
const Type *target)
const
287 if (! (type && target)) {
289 }
else if (type->isEqualTo(target)) {
291 }
else if (target->asUIntType() !=
nullptr) {
292 return type->asIntType() !=
nullptr;
293 }
else if (target->asFloatType() !=
nullptr) {
294 return type->asIntType() !=
nullptr ||
295 type->asUIntType() !=
nullptr;
296 }
else if (target->asDoubleType() !=
nullptr) {
297 return type->asIntType() !=
nullptr ||
298 type->asUIntType() !=
nullptr ||
299 type->asFloatType() !=
nullptr;
300 }
else if (
const VectorType *targetVecTy = target->asVectorType()) {
301 if (
const VectorType *vecTy = type->asVectorType()) {
302 if (targetVecTy->dimension() == vecTy->dimension()) {
303 const Type *targetElementType = targetVecTy->elementType();
304 const Type *elementType = vecTy->elementType();
306 if (targetElementType->asUIntType() !=
nullptr) {
308 return elementType->asIntType() !=
nullptr;
309 }
else if (targetElementType->asFloatType() !=
nullptr) {
311 return elementType->asIntType() !=
nullptr ||
312 elementType->asUIntType() !=
nullptr;
313 }
else if (targetElementType->asDoubleType() !=
nullptr) {
315 return elementType->asIntType() !=
nullptr ||
316 elementType->asUIntType() !=
nullptr ||
317 elementType->asFloatType() !=
nullptr;
321 }
else if (
const MatrixType *targetMatTy = target->asMatrixType()) {
322 if (
const MatrixType *matTy = type->asMatrixType()) {
323 if (targetMatTy->columns() == matTy->columns() &&
324 targetMatTy->rows() == matTy->rows()) {
325 const Type *targetElementType = targetMatTy->elementType();
326 const Type *elementType = matTy->elementType();
328 if (targetElementType->asDoubleType() !=
nullptr) {
330 return elementType->asFloatType() !=
nullptr;
339bool Semantic::visit(FunctionCallExpressionAST *ast)
341 ExprResult expr = expression(ast->expr);
342 ExprResult id = functionIdentifier(ast->id);
343 QVector<ExprResult> actuals;
344 for (List<ExpressionAST *> *it = ast->arguments; it; it = it->next) {
345 ExprResult arg = expression(it->value);
349 if (
const Function *funTy = id.type->asFunctionType()) {
350 if (actuals.size() < funTy->argumentCount())
351 _engine->error(ast->lineno, QString::fromLatin1(
"not enough arguments"));
352 else if (actuals.size() > funTy->argumentCount())
353 _engine->error(ast->lineno, QString::fromLatin1(
"too many arguments"));
354 _expr.type = funTy->returnType();
355 }
else if (
const OverloadSet *overloads = id.type->asOverloadSetType()) {
356 QVector<Function *> candidates;
357 const auto functions = overloads->functions();
358 for (Function *f : functions) {
359 if (f->argumentCount() == actuals.size()) {
361 for (; argc < actuals.size(); ++argc) {
362 const Type *actualTy = actuals.at(argc).type;
363 const Type *argumentTy = f->argumentAt(argc)->type();
364 if (! implicitCast(actualTy, argumentTy))
368 if (argc == actuals.size())
369 candidates.append(f);
373 if (candidates.isEmpty()) {
375 Q_ASSERT(!functions.isEmpty());
377 _expr.type = functions.front()->returnType();
379 _expr.type = candidates.constFirst()->returnType();
381 if (candidates.size() != 1) {
387 _expr.type = id.type;
488bool Semantic::visit(BasicTypeAST *ast)
490 switch (ast->token) {
492 _type = _engine->voidType();
496 _type = _engine->boolType();
500 _type = _engine->intType();
504 _type = _engine->uintType();
507 case Parser::T_FLOAT:
508 _type = _engine->floatType();
511 case Parser::T_DOUBLE:
512 _type = _engine->doubleType();
516 case Parser::T_BVEC2:
517 _type = _engine->vectorType(_engine->boolType(), 2);
520 case Parser::T_BVEC3:
521 _type = _engine->vectorType(_engine->boolType(), 3);
524 case Parser::T_BVEC4:
525 _type = _engine->vectorType(_engine->boolType(), 4);
529 case Parser::T_IVEC2:
530 _type = _engine->vectorType(_engine->intType(), 2);
533 case Parser::T_IVEC3:
534 _type = _engine->vectorType(_engine->intType(), 3);
537 case Parser::T_IVEC4:
538 _type = _engine->vectorType(_engine->intType(), 4);
542 case Parser::T_UVEC2:
543 _type = _engine->vectorType(_engine->uintType(), 2);
546 case Parser::T_UVEC3:
547 _type = _engine->vectorType(_engine->uintType(), 3);
550 case Parser::T_UVEC4:
551 _type = _engine->vectorType(_engine->uintType(), 4);
556 _type = _engine->vectorType(_engine->floatType(), 2);
560 _type = _engine->vectorType(_engine->floatType(), 3);
564 _type = _engine->vectorType(_engine->floatType(), 4);
568 case Parser::T_DVEC2:
569 _type = _engine->vectorType(_engine->doubleType(), 2);
572 case Parser::T_DVEC3:
573 _type = _engine->vectorType(_engine->doubleType(), 3);
576 case Parser::T_DVEC4:
577 _type = _engine->vectorType(_engine->doubleType(), 4);
582 case Parser::T_MAT2X2:
583 _type = _engine->matrixType(_engine->floatType(), 2, 2);
586 case Parser::T_MAT2X3:
587 _type = _engine->matrixType(_engine->floatType(), 2, 3);
590 case Parser::T_MAT2X4:
591 _type = _engine->matrixType(_engine->floatType(), 2, 4);
595 case Parser::T_MAT3X2:
596 _type = _engine->matrixType(_engine->floatType(), 3, 2);
600 case Parser::T_MAT3X3:
601 _type = _engine->matrixType(_engine->floatType(), 3, 3);
604 case Parser::T_MAT3X4:
605 _type = _engine->matrixType(_engine->floatType(), 3, 4);
609 case Parser::T_MAT4X2:
610 _type = _engine->matrixType(_engine->floatType(), 4, 2);
613 case Parser::T_MAT4X3:
614 _type = _engine->matrixType(_engine->floatType(), 4, 3);
618 case Parser::T_MAT4X4:
619 _type = _engine->matrixType(_engine->floatType(), 4, 4);
624 case Parser::T_DMAT2:
625 case Parser::T_DMAT2X2:
626 _type = _engine->matrixType(_engine->doubleType(), 2, 2);
629 case Parser::T_DMAT2X3:
630 _type = _engine->matrixType(_engine->doubleType(), 2, 3);
633 case Parser::T_DMAT2X4:
634 _type = _engine->matrixType(_engine->doubleType(), 2, 4);
638 case Parser::T_DMAT3X2:
639 _type = _engine->matrixType(_engine->doubleType(), 3, 2);
642 case Parser::T_DMAT3:
643 case Parser::T_DMAT3X3:
644 _type = _engine->matrixType(_engine->doubleType(), 3, 3);
647 case Parser::T_DMAT3X4:
648 _type = _engine->matrixType(_engine->doubleType(), 3, 4);
652 case Parser::T_DMAT4X2:
653 _type = _engine->matrixType(_engine->doubleType(), 4, 2);
656 case Parser::T_DMAT4X3:
657 _type = _engine->matrixType(_engine->doubleType(), 4, 3);
660 case Parser::T_DMAT4:
661 case Parser::T_DMAT4X4:
662 _type = _engine->matrixType(_engine->doubleType(), 4, 4);
666 case Parser::T_SAMPLER1D:
667 case Parser::T_SAMPLER2D:
668 case Parser::T_SAMPLER3D:
669 case Parser::T_SAMPLERCUBE:
670 case Parser::T_SAMPLER1DSHADOW:
671 case Parser::T_SAMPLER2DSHADOW:
672 case Parser::T_SAMPLERCUBESHADOW:
673 case Parser::T_SAMPLER1DARRAY:
674 case Parser::T_SAMPLER2DARRAY:
675 case Parser::T_SAMPLER1DARRAYSHADOW:
676 case Parser::T_SAMPLER2DARRAYSHADOW:
677 case Parser::T_SAMPLERCUBEARRAY:
678 case Parser::T_SAMPLERCUBEARRAYSHADOW:
679 case Parser::T_SAMPLER2DRECT:
680 case Parser::T_SAMPLER2DRECTSHADOW:
681 case Parser::T_SAMPLERBUFFER:
682 case Parser::T_SAMPLER2DMS:
683 case Parser::T_SAMPLER2DMSARRAY:
684 case Parser::T_ISAMPLER1D:
685 case Parser::T_ISAMPLER2D:
686 case Parser::T_ISAMPLER3D:
687 case Parser::T_ISAMPLERCUBE:
688 case Parser::T_ISAMPLER1DARRAY:
689 case Parser::T_ISAMPLER2DARRAY:
690 case Parser::T_ISAMPLERCUBEARRAY:
691 case Parser::T_ISAMPLER2DRECT:
692 case Parser::T_ISAMPLERBUFFER:
693 case Parser::T_ISAMPLER2DMS:
694 case Parser::T_ISAMPLER2DMSARRAY:
695 case Parser::T_USAMPLER1D:
696 case Parser::T_USAMPLER2D:
697 case Parser::T_USAMPLER3D:
698 case Parser::T_USAMPLERCUBE:
699 case Parser::T_USAMPLER1DARRAY:
700 case Parser::T_USAMPLER2DARRAY:
701 case Parser::T_USAMPLERCUBEARRAY:
702 case Parser::T_USAMPLER2DRECT:
703 case Parser::T_USAMPLERBUFFER:
704 case Parser::T_USAMPLER2DMS:
705 case Parser::T_USAMPLER2DMSARRAY:
706 _type = _engine->samplerType(ast->token);
710 _engine->error(ast->lineno, QString::fromLatin1(
"Unknown type `%1'").arg(QLatin1String(GLSLParserTable::spell[ast->token])));