173bool Semantic::visit(LiteralExpressionAST *ast)
176 _expr.isConstant =
true;
178 if (ast->value->at(0) == QLatin1Char(
't') && *ast->value == QLatin1String(
"true"))
179 _expr.type = _engine->boolType();
180 else if (ast->value->at(0) == QLatin1Char(
'f') && *ast->value == QLatin1String(
"false"))
181 _expr.type = _engine->boolType();
182 else if (ast->value->endsWith(QLatin1Char(
'u')) || ast->value->endsWith(QLatin1Char(
'U')))
183 _expr.type = _engine->uintType();
184 else if (ast->value->endsWith(QLatin1String(
"lf")) || ast->value->endsWith(QLatin1String(
"LF")))
185 _expr.type = _engine->doubleType();
186 else if (ast->value->endsWith(QLatin1Char(
'f')) || ast->value->endsWith(QLatin1Char(
'F')) || ast->value->contains(QLatin1Char(
'.')))
187 _expr.type = _engine->floatType();
189 _expr.type = _engine->intType();
287bool Semantic::implicitCast(
const Type *type,
const Type *target)
const
289 if (! (type && target)) {
291 }
else if (type->isEqualTo(target)) {
293 }
else if (target->asUIntType() !=
nullptr) {
294 return type->asIntType() !=
nullptr;
295 }
else if (target->asFloatType() !=
nullptr) {
296 return type->asIntType() !=
nullptr ||
297 type->asUIntType() !=
nullptr;
298 }
else if (target->asDoubleType() !=
nullptr) {
299 return type->asIntType() !=
nullptr ||
300 type->asUIntType() !=
nullptr ||
301 type->asFloatType() !=
nullptr;
302 }
else if (
const VectorType *targetVecTy = target->asVectorType()) {
303 if (
const VectorType *vecTy = type->asVectorType()) {
304 if (targetVecTy->dimension() == vecTy->dimension()) {
305 const Type *targetElementType = targetVecTy->elementType();
306 const Type *elementType = vecTy->elementType();
308 if (targetElementType->asUIntType() !=
nullptr) {
310 return elementType->asIntType() !=
nullptr;
311 }
else if (targetElementType->asFloatType() !=
nullptr) {
313 return elementType->asIntType() !=
nullptr ||
314 elementType->asUIntType() !=
nullptr;
315 }
else if (targetElementType->asDoubleType() !=
nullptr) {
317 return elementType->asIntType() !=
nullptr ||
318 elementType->asUIntType() !=
nullptr ||
319 elementType->asFloatType() !=
nullptr;
323 }
else if (
const MatrixType *targetMatTy = target->asMatrixType()) {
324 if (
const MatrixType *matTy = type->asMatrixType()) {
325 if (targetMatTy->columns() == matTy->columns() &&
326 targetMatTy->rows() == matTy->rows()) {
327 const Type *targetElementType = targetMatTy->elementType();
328 const Type *elementType = matTy->elementType();
330 if (targetElementType->asDoubleType() !=
nullptr) {
332 return elementType->asFloatType() !=
nullptr;
341bool Semantic::visit(FunctionCallExpressionAST *ast)
343 ExprResult expr = expression(ast->expr);
344 ExprResult id = functionIdentifier(ast->id);
345 QVector<ExprResult> actuals;
346 for (List<ExpressionAST *> *it = ast->arguments; it; it = it->next) {
347 ExprResult arg = expression(it->value);
351 if (
const Function *funTy = id.type->asFunctionType()) {
352 if (actuals.size() < funTy->argumentCount())
353 _engine->error(ast->lineno, QString::fromLatin1(
"not enough arguments"));
354 else if (actuals.size() > funTy->argumentCount())
355 _engine->error(ast->lineno, QString::fromLatin1(
"too many arguments"));
356 _expr.type = funTy->returnType();
357 }
else if (
const OverloadSet *overloads = id.type->asOverloadSetType()) {
358 QVector<Function *> candidates;
359 const auto functions = overloads->functions();
360 for (Function *f : functions) {
361 if (f->argumentCount() == actuals.size()) {
363 for (; argc < actuals.size(); ++argc) {
364 const Type *actualTy = actuals.at(argc).type;
365 const Type *argumentTy = f->argumentAt(argc)->type();
366 if (! implicitCast(actualTy, argumentTy))
370 if (argc == actuals.size())
371 candidates.append(f);
375 if (candidates.isEmpty()) {
377 Q_ASSERT(!functions.isEmpty());
379 _expr.type = functions.front()->returnType();
381 _expr.type = candidates.constFirst()->returnType();
383 if (candidates.size() != 1) {
389 _expr.type = id.type;
490bool Semantic::visit(BasicTypeAST *ast)
492 switch (ast->token) {
494 _type = _engine->voidType();
498 _type = _engine->boolType();
502 _type = _engine->intType();
506 _type = _engine->uintType();
509 case Parser::T_FLOAT:
510 _type = _engine->floatType();
513 case Parser::T_DOUBLE:
514 _type = _engine->doubleType();
518 case Parser::T_BVEC2:
519 _type = _engine->vectorType(_engine->boolType(), 2);
522 case Parser::T_BVEC3:
523 _type = _engine->vectorType(_engine->boolType(), 3);
526 case Parser::T_BVEC4:
527 _type = _engine->vectorType(_engine->boolType(), 4);
531 case Parser::T_IVEC2:
532 _type = _engine->vectorType(_engine->intType(), 2);
535 case Parser::T_IVEC3:
536 _type = _engine->vectorType(_engine->intType(), 3);
539 case Parser::T_IVEC4:
540 _type = _engine->vectorType(_engine->intType(), 4);
544 case Parser::T_UVEC2:
545 _type = _engine->vectorType(_engine->uintType(), 2);
548 case Parser::T_UVEC3:
549 _type = _engine->vectorType(_engine->uintType(), 3);
552 case Parser::T_UVEC4:
553 _type = _engine->vectorType(_engine->uintType(), 4);
558 _type = _engine->vectorType(_engine->floatType(), 2);
562 _type = _engine->vectorType(_engine->floatType(), 3);
566 _type = _engine->vectorType(_engine->floatType(), 4);
570 case Parser::T_DVEC2:
571 _type = _engine->vectorType(_engine->doubleType(), 2);
574 case Parser::T_DVEC3:
575 _type = _engine->vectorType(_engine->doubleType(), 3);
578 case Parser::T_DVEC4:
579 _type = _engine->vectorType(_engine->doubleType(), 4);
584 case Parser::T_MAT2X2:
585 _type = _engine->matrixType(_engine->floatType(), 2, 2);
588 case Parser::T_MAT2X3:
589 _type = _engine->matrixType(_engine->floatType(), 2, 3);
592 case Parser::T_MAT2X4:
593 _type = _engine->matrixType(_engine->floatType(), 2, 4);
597 case Parser::T_MAT3X2:
598 _type = _engine->matrixType(_engine->floatType(), 3, 2);
602 case Parser::T_MAT3X3:
603 _type = _engine->matrixType(_engine->floatType(), 3, 3);
606 case Parser::T_MAT3X4:
607 _type = _engine->matrixType(_engine->floatType(), 3, 4);
611 case Parser::T_MAT4X2:
612 _type = _engine->matrixType(_engine->floatType(), 4, 2);
615 case Parser::T_MAT4X3:
616 _type = _engine->matrixType(_engine->floatType(), 4, 3);
620 case Parser::T_MAT4X4:
621 _type = _engine->matrixType(_engine->floatType(), 4, 4);
626 case Parser::T_DMAT2:
627 case Parser::T_DMAT2X2:
628 _type = _engine->matrixType(_engine->doubleType(), 2, 2);
631 case Parser::T_DMAT2X3:
632 _type = _engine->matrixType(_engine->doubleType(), 2, 3);
635 case Parser::T_DMAT2X4:
636 _type = _engine->matrixType(_engine->doubleType(), 2, 4);
640 case Parser::T_DMAT3X2:
641 _type = _engine->matrixType(_engine->doubleType(), 3, 2);
644 case Parser::T_DMAT3:
645 case Parser::T_DMAT3X3:
646 _type = _engine->matrixType(_engine->doubleType(), 3, 3);
649 case Parser::T_DMAT3X4:
650 _type = _engine->matrixType(_engine->doubleType(), 3, 4);
654 case Parser::T_DMAT4X2:
655 _type = _engine->matrixType(_engine->doubleType(), 4, 2);
658 case Parser::T_DMAT4X3:
659 _type = _engine->matrixType(_engine->doubleType(), 4, 3);
662 case Parser::T_DMAT4:
663 case Parser::T_DMAT4X4:
664 _type = _engine->matrixType(_engine->doubleType(), 4, 4);
668 case Parser::T_SAMPLER1D:
669 case Parser::T_SAMPLER2D:
670 case Parser::T_SAMPLER3D:
671 case Parser::T_SAMPLERCUBE:
672 case Parser::T_SAMPLER1DSHADOW:
673 case Parser::T_SAMPLER2DSHADOW:
674 case Parser::T_SAMPLERCUBESHADOW:
675 case Parser::T_SAMPLER1DARRAY:
676 case Parser::T_SAMPLER2DARRAY:
677 case Parser::T_SAMPLER1DARRAYSHADOW:
678 case Parser::T_SAMPLER2DARRAYSHADOW:
679 case Parser::T_SAMPLERCUBEARRAY:
680 case Parser::T_SAMPLERCUBEARRAYSHADOW:
681 case Parser::T_SAMPLER2DRECT:
682 case Parser::T_SAMPLER2DRECTSHADOW:
683 case Parser::T_SAMPLERBUFFER:
684 case Parser::T_SAMPLER2DMS:
685 case Parser::T_SAMPLER2DMSARRAY:
686 case Parser::T_ISAMPLER1D:
687 case Parser::T_ISAMPLER2D:
688 case Parser::T_ISAMPLER3D:
689 case Parser::T_ISAMPLERCUBE:
690 case Parser::T_ISAMPLER1DARRAY:
691 case Parser::T_ISAMPLER2DARRAY:
692 case Parser::T_ISAMPLERCUBEARRAY:
693 case Parser::T_ISAMPLER2DRECT:
694 case Parser::T_ISAMPLERBUFFER:
695 case Parser::T_ISAMPLER2DMS:
696 case Parser::T_ISAMPLER2DMSARRAY:
697 case Parser::T_USAMPLER1D:
698 case Parser::T_USAMPLER2D:
699 case Parser::T_USAMPLER3D:
700 case Parser::T_USAMPLERCUBE:
701 case Parser::T_USAMPLER1DARRAY:
702 case Parser::T_USAMPLER2DARRAY:
703 case Parser::T_USAMPLERCUBEARRAY:
704 case Parser::T_USAMPLER2DRECT:
705 case Parser::T_USAMPLERBUFFER:
706 case Parser::T_USAMPLER2DMS:
707 case Parser::T_USAMPLER2DMSARRAY:
708 _type = _engine->samplerType(ast->token);
712 _engine->error(ast->lineno, QString::fromLatin1(
"Unknown type `%1'").arg(QLatin1String(GLSLParserTable::spell[ast->token])));