Language Design: Combining Gotos and Functions
- by sub
I'm designing and currently rethinking a low-level interpreted programming language with similarities to assembler.
I very soon came across the functions/loops/gotos decision problem and thought that while loops like while and for would be too high-level and unfitting, gotos would be too low level, unmaintainable and generally evil again.
Functions like you know them from most languages that have return values and arguments aren't fitting in the language's concept either.
So I tried to figure out something between a function and a goto which is capable of
Recursion
Efficient loops
After some thinking I came up with the idea of subroutines:
They have a beginning and an end like a function
They have a name but no arguments like a goto
You can go into one with jump and go out of it again before its end with return (doesn't give back  any result, only stops the subroutine)
Handled just like normal code - Global scope like goto
So I wanted to know:
Is the idea above good? What are the (dis)advantages?
Would there be a better combination of function and goto or even a completely new idea?