mirror of
https://github.com/cc65/cc65.git
synced 2025-01-27 09:33:42 +00:00
Improved checks on function return types.
This commit is contained in:
parent
f381d23001
commit
8e62cbf092
@ -466,11 +466,15 @@ void NewFunc (SymEntry* Func, FuncDesc* D)
|
||||
|
||||
/* Check return type */
|
||||
ReturnType = F_GetReturnType (CurrentFunc);
|
||||
if (IsIncompleteESUType (ReturnType)) {
|
||||
if (!IsTypeArray (ReturnType) && !IsTypeFunc (ReturnType)) {
|
||||
/* There are already diagnostics on returning arrays or functions */
|
||||
if (!IsTypeArray (ReturnType) && !IsTypeFunc (ReturnType)) {
|
||||
if (IsIncompleteESUType (ReturnType)) {
|
||||
Error ("Function has incomplete return type '%s'",
|
||||
GetFullTypeName (ReturnType));
|
||||
} else if (IsPassByRefType (ReturnType)) {
|
||||
/* Handle struct/union specially */
|
||||
Error ("Function return type '%s' of size %u is unsupported",
|
||||
GetFullTypeName (ReturnType), SizeOf (ReturnType));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -311,7 +311,6 @@ static void ReturnStatement (void)
|
||||
/* Handle the 'return' statement */
|
||||
{
|
||||
ExprDesc Expr;
|
||||
const Type* ReturnType;
|
||||
|
||||
ED_Init (&Expr);
|
||||
NextToken ();
|
||||
@ -327,31 +326,19 @@ static void ReturnStatement (void)
|
||||
if (F_HasVoidReturn (CurrentFunc)) {
|
||||
Error ("Returning a value in function with return type 'void'");
|
||||
} else {
|
||||
|
||||
/* Check the return type first */
|
||||
ReturnType = F_GetReturnType (CurrentFunc);
|
||||
if (IsIncompleteESUType (ReturnType)) {
|
||||
/* Avoid excess errors */
|
||||
if (ErrorCount == 0) {
|
||||
Error ("Returning a value in function with incomplete return type");
|
||||
}
|
||||
const Type* ReturnType = F_GetReturnType (CurrentFunc);
|
||||
|
||||
/* Convert the return value to the type of the function result */
|
||||
TypeConversion (&Expr, ReturnType);
|
||||
|
||||
/* Load the value into the primary */
|
||||
if (IsClassStruct (Expr.Type)) {
|
||||
/* Handle struct/union specially */
|
||||
LoadExpr (CG_TypeOf (GetStructReplacementType (ReturnType)), &Expr);
|
||||
} else {
|
||||
/* Convert the return value to the type of the function result */
|
||||
TypeConversion (&Expr, ReturnType);
|
||||
|
||||
/* Load the value into the primary */
|
||||
if (IsClassStruct (Expr.Type)) {
|
||||
/* Handle struct/union specially */
|
||||
ReturnType = GetStructReplacementType (Expr.Type);
|
||||
if (ReturnType == Expr.Type) {
|
||||
Error ("Returning '%s' of this size by value is not supported", GetFullTypeName (Expr.Type));
|
||||
}
|
||||
LoadExpr (CG_TypeOf (ReturnType), &Expr);
|
||||
|
||||
} else {
|
||||
/* Load the value into the primary */
|
||||
LoadExpr (CF_NONE, &Expr);
|
||||
}
|
||||
LoadExpr (CF_NONE, &Expr);
|
||||
}
|
||||
|
||||
/* Append deferred inc/dec at sequence point */
|
||||
|
Loading…
x
Reference in New Issue
Block a user