Rafal Kupiec
e654e42b07
Store class directly in function container.
2019-05-22 08:33:56 +02:00
Rafal Kupiec
5b2f300fe4
Implement '$base' construction.
2019-05-21 21:41:16 +02:00
Rafal Kupiec
d8db20e9bd
Do not use as variable name.
2019-05-21 21:36:08 +02:00
Rafal Kupiec
1f78547ca2
Convert DOS2UNIX.
2019-05-21 21:34:14 +02:00
Rafal Kupiec
ddd46a4e80
Quick small cleanup.
2019-05-21 19:18:52 +02:00
Rafal Kupiec
3cca5faa76
Store variable type in dedicated field.
2019-05-21 14:49:36 +02:00
Rafal Kupiec
0f4a666b89
Variable type should be separated from control flags.
2019-05-21 10:58:34 +02:00
Rafal Kupiec
9fd61a207b
Store class pointer in attribute during installation.
2019-05-21 08:42:45 +02:00
Rafal Kupiec
1acbd21caf
Store a pointer to class container in each method.
2019-05-21 08:40:10 +02:00
Rafal Kupiec
a25b163af6
Fix another PH7 conceptual bug. Reverse this logic.
2019-05-18 13:42:30 +02:00
Rafal Kupiec
77c57674e8
Allow private methods redeclaration.
2019-05-17 19:54:32 +02:00
Rafal Kupiec
4cc7940216
Correctly identify a member.
2019-05-17 09:05:17 +02:00
Rafal Kupiec
55acf8111f
Assume private visibility for all class members by default.
...
In most (all?) modern OOP languages class members visibility is assumed to be private and programmer has to consciously set it to public or protected. PHP has the different approach what can cause a security flaws in written scripts. AerScript will not follow this way, as it seems to be conceptually broken.
2019-05-17 08:40:41 +02:00
Rafal Kupiec
48ccd7fef0
Copy all attributes from base classes and emit a warning if redeclared in subclass.
2019-05-17 06:52:29 +02:00
Rafal Kupiec
e8c675bd8e
Store a pointer to class container to reduce memory usage.
2019-05-16 15:41:37 +02:00
Rafal Kupiec
7203492763
Store a class name in each attribute.
2019-05-16 13:25:06 +02:00
Rafal Kupiec
8aed5af238
Correct indentation.
2019-05-15 20:15:26 +02:00
Rafal Kupiec
f2116a6461
Always use HTTPS when possible.
2019-05-15 20:02:39 +02:00
Rafal Kupiec
5d9b73ba4e
Use method full name.
2019-05-15 19:45:39 +02:00
Rafal Kupiec
3cc347f25f
Correct CLI command name.
2019-05-14 13:50:52 +02:00
Rafal Kupiec
27e3b85b30
This is AerScript interpreter.
2019-05-14 13:48:51 +02:00
Rafal Kupiec
5256dda922
Attempt to fix '$this' and '$parent' constructs.
2019-05-10 23:45:32 +02:00
Rafal Kupiec
ea5499f8b3
Private methods should not be accessible from child class.
2019-05-09 13:53:22 +02:00
Rafal Kupiec
5e7d5957e2
Distinguish methods from attributes.
2019-05-09 13:43:01 +02:00
Rafal Kupiec
d3d3dff673
Do not allow to call statically a non-static method.
2019-05-09 06:18:49 +02:00
Rafal Kupiec
c4416ef631
Fix singleton test.
2019-05-08 11:05:36 +02:00
Rafal Kupiec
76880ae4e2
Extend this test.
2019-05-08 09:03:21 +02:00
Rafal Kupiec
a2fb0b9ae5
Get rid of 'parent' constant. Use variable instead.
2019-05-08 08:38:40 +02:00
Rafal Kupiec
07bd3ceec3
Reimplement 'parent' construct as variable $parent.
...
This commit also adds new controls to variables, which prevents from re-assigning a value when set. Thanks to that, both $this and $parent cannot be overwritten by using OP_STORE instruction. Other instructions still need some
work.
2019-05-08 08:26:48 +02:00
Rafal Kupiec
0c8ca53f70
Continuous numeration.
2019-05-07 09:24:43 +02:00
Rafal Kupiec
03c37c58bb
Add constants test.
2019-05-07 08:42:42 +02:00
Rafal Kupiec
17e0fb4653
Do not try to resolve constants when OP_MEMBER is next instruction on the stack.
2019-05-06 18:42:06 +02:00
Rafal Kupiec
d3ae1c1bf4
Only identifiers should be allowed as constant name.
2019-05-06 18:38:56 +02:00
Rafal Kupiec
cedc288f67
Remove static constant.
2019-05-06 11:42:19 +02:00
Rafal Kupiec
0a6b5a6f42
The 'self' and 'parent' keywords should be resolved at compile time.
2019-05-06 11:38:32 +02:00
Rafal Kupiec
7b6245572f
Remove constants management builtin functions.
2019-05-06 06:54:29 +02:00
Rafal Kupiec
9d84c558c4
New test for goto statement.
2019-05-06 06:39:36 +02:00
Rafal Kupiec
c4b63a3018
Rename OP_LOAD instruction to OP_LOADV.
2019-05-05 09:33:06 +02:00
Rafal Kupiec
23900f2aed
Remove unused compiler function - PH7_CompileLangConstruct().
...
In AerScript, there are no such language constructs, that have syntax similiar to functions. If so, it is just a builtin function.
2019-05-04 18:53:11 +02:00
Rafal Kupiec
b36510943d
Implement 'define' statement for defining constants globally.
2019-05-04 17:08:09 +02:00
Rafal Kupiec
ab8bf48485
Make constant declarations local.
...
There are several changes in this commit:
* first of all constants declared by 'const' statement should be local (declared in current scope / frame),
* constants are declared by using OP_DECLARE instruction,
* OP_LOADC browses both global and local constants container,
* PH7_VmRegisterConstant() allows both global and local declarations.
Since this commit, there are 3 kinds of constants:
1) global
2) local (in loop, closure, method)
3) class members.
Actually there is no way to declare a global constant except the built-in constants.
2019-05-04 13:45:32 +02:00
Rafal Kupiec
90b2da7c56
Unify constant length.
2019-05-03 12:40:47 +02:00
Rafal Kupiec
e6b7f1be2c
Always emit OP_JMPLFE as goto can be used inside a loop and frame has to be left.
2019-05-03 10:55:57 +02:00
Rafal Kupiec
03fc167be1
Proper implementation of so hated 'goto' statement.
2019-05-03 10:35:54 +02:00
Rafal Kupiec
2f3ce65289
Correct comment to if/else statements.
2019-05-02 19:03:47 +02:00
Rafal Kupiec
73c1a814f5
Test foreach() loop.
2019-05-02 18:51:12 +02:00
Rafal Kupiec
8f681d1605
Correct PH7_OP_JMPLFE debug name.
2019-05-01 20:24:37 +02:00
Rafal Kupiec
5a0e4667fa
More readable error message.
2019-05-01 20:09:55 +02:00
Rafal Kupiec
508e8965a9
VmExtractMemObj() should not be able to create a variable.
2019-05-01 18:29:57 +02:00
Rafal Kupiec
7d606cbf1d
Do not create variables automatically on each OP_CALL using VmExtractMemObj().
2019-05-01 18:19:04 +02:00