================ @@ -15978,6 +15988,24 @@ Decl *Sema::ActOnFinishFunctionBody(Decl *dcl, Stmt *Body, CheckCoroutineWrapper(FD); } + // Diagnose invalid SYCL kernel entry point function declarations. + if (FD && !FD->isInvalidDecl() && !FD->isTemplated() && + FD->hasAttr<SYCLKernelEntryPointAttr>()) { + if (FD->isDeleted()) { + Diag(FD->getAttr<SYCLKernelEntryPointAttr>()->getLocation(), + diag::err_sycl_entry_point_invalid) + << /*deleted function*/ 2; + } else if (FD->isDefaulted()) { + Diag(FD->getAttr<SYCLKernelEntryPointAttr>()->getLocation(), + diag::err_sycl_entry_point_invalid) + << /*defaulted function*/ 3; + } else if (FSI->isCoroutine()) { + Diag(FD->getAttr<SYCLKernelEntryPointAttr>()->getLocation(), + diag::err_sycl_entry_point_invalid) + << /*coroutine*/ 7; ---------------- erichkeane wrote:
I still disagree strongly. Any time where there are more than 2-3 options, and are used in more than 1 or 2 places, it vastly improves readability and prevents bugs of printing the wrong thing. We can have a second opinion from Aaron, but this is something pretty important to me as code-owner. https://github.com/llvm/llvm-project/pull/120327 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits