readme update

This commit is contained in:
Daniella / Tove 2022-04-16 01:45:17 +02:00
parent 4992213f21
commit 616a8323ef

View file

@ -23,3 +23,26 @@ or
in both languages, this will print 3.
These examples used the print function, which does not exist by default, instead, puts should be used in combination with \_string.
---
## Objects, Functions, and Variables in ISBPL
OOP works like this:
- There are three separate function resolvers:
- Object
- Local
- Global
- They are executed in the order shown above
- The object resolver peeks onto the stack, gets the type of the object, and checks for methods on the type, if it finds one, it executes it
- The local resolver checks for functions defined in the current function, but not in any other function or area
- The global resolver checks for top-level functions, meaning ones that arent in any other function.
- Because variables are native functions under the hood, they are also called by the function resolvers
- Object-local variables are in a Table: `Type?->Instance?->ID?->Value`
### To call a method of an object:
```isbpl
parameter1 parameter2 etc object method
```
as explained above, methods are resolved separately, and it is therefore not required to define them in any other way.