mirror of
https://github.com/irmen/prog8.git
synced 2025-01-14 01:29:55 +00:00
fix compiler errors
This commit is contained in:
parent
b3b2541c1e
commit
08d44ae553
@ -6,6 +6,7 @@ import prog8.ast.Program
|
|||||||
import prog8.ast.base.DataType
|
import prog8.ast.base.DataType
|
||||||
import prog8.ast.expressions.Expression
|
import prog8.ast.expressions.Expression
|
||||||
import prog8.ast.expressions.FunctionCall
|
import prog8.ast.expressions.FunctionCall
|
||||||
|
import prog8.ast.expressions.TypecastExpression
|
||||||
import prog8.ast.statements.*
|
import prog8.ast.statements.*
|
||||||
import prog8.compiler.CompilerException
|
import prog8.compiler.CompilerException
|
||||||
import prog8.functions.BuiltinFunctions
|
import prog8.functions.BuiltinFunctions
|
||||||
@ -60,8 +61,15 @@ class VerifyFunctionArgTypes(val program: Program) : IAstVisitor {
|
|||||||
// multiple return values will NOT work inside an expression.
|
// multiple return values will NOT work inside an expression.
|
||||||
// they MIGHT work in a regular assignment or just a function call statement.
|
// they MIGHT work in a regular assignment or just a function call statement.
|
||||||
val parent = if(call is Statement) call.parent else if(call is Expression) call.parent else null
|
val parent = if(call is Statement) call.parent else if(call is Expression) call.parent else null
|
||||||
if(call !is FunctionCallStatement && parent !is Assignment && parent !is VarDecl) {
|
if (call !is FunctionCallStatement) {
|
||||||
return "can't use subroutine call that returns multiple return values here (try moving it into a separate assignment)"
|
val checkParent =
|
||||||
|
if(parent is TypecastExpression)
|
||||||
|
parent.parent
|
||||||
|
else
|
||||||
|
parent
|
||||||
|
if (checkParent !is Assignment && checkParent !is VarDecl) {
|
||||||
|
return "can't use subroutine call that returns multiple return values here"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ internal class StatementOptimizer(private val program: Program,
|
|||||||
override fun after(subroutine: Subroutine, parent: Node): Iterable<IAstModification> {
|
override fun after(subroutine: Subroutine, parent: Node): Iterable<IAstModification> {
|
||||||
val forceOutput = "force_output" in subroutine.definingBlock().options()
|
val forceOutput = "force_output" in subroutine.definingBlock().options()
|
||||||
if(subroutine.asmAddress==null && !forceOutput) {
|
if(subroutine.asmAddress==null && !forceOutput) {
|
||||||
if(subroutine.containsNoCodeNorVars()) {
|
if(subroutine.containsNoCodeNorVars() && !subroutine.inline) {
|
||||||
errors.warn("removing empty subroutine '${subroutine.name}'", subroutine.position)
|
errors.warn("removing empty subroutine '${subroutine.name}'", subroutine.position)
|
||||||
val removals = callgraph.calledBy.getValue(subroutine).map {
|
val removals = callgraph.calledBy.getValue(subroutine).map {
|
||||||
IAstModification.Remove(it, it.definingScope())
|
IAstModification.Remove(it, it.definingScope())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user