Commit Graph

993 Commits

Author SHA1 Message Date
4d1c246a65
Attempt to fix methods visibility mechanism.
All checks were successful
The build was successful.
2019-05-29 08:17:10 +02:00
1f5afc9d51
Reverse the logic. It does not seem to work actually.
All checks were successful
The build was successful.
2019-05-29 08:10:34 +02:00
675f3596a1
Properly look for method in all classes.
All checks were successful
The build was successful.
2019-05-29 06:12:49 +02:00
26333360b0
Fix similar to a25b163af6.
All checks were successful
The build was successful.
2019-05-28 20:04:23 +02:00
1175219ad4
Temporarily fix test.
All checks were successful
The build was successful.
2019-05-28 13:40:34 +02:00
b319e11c09
Fix build.
All checks were successful
The build was successful.
2019-05-28 11:55:17 +02:00
5c176207e1
Set base class only when $base called.
Some checks reported errors
The build has failed.
2019-05-28 11:51:13 +02:00
5cc4a5e48d
Access privileges to methods should be done in OP_MEMBER.
All checks were successful
The build was successful.
2019-05-23 08:27:56 +02:00
e654e42b07
Store class directly in function container.
All checks were successful
The build was successful.
2019-05-22 08:33:56 +02:00
5b2f300fe4
Implement '$base' construction.
All checks were successful
The build was successful.
2019-05-21 21:41:16 +02:00
d8db20e9bd
Do not use as variable name.
All checks were successful
The build was successful.
2019-05-21 21:36:08 +02:00
1f78547ca2
Convert DOS2UNIX.
All checks were successful
The build was successful.
2019-05-21 21:34:14 +02:00
ddd46a4e80
Quick small cleanup.
All checks were successful
The build was successful.
2019-05-21 19:18:52 +02:00
3cca5faa76
Store variable type in dedicated field.
All checks were successful
The build was successful.
2019-05-21 14:49:36 +02:00
0f4a666b89
Variable type should be separated from control flags.
All checks were successful
The build was successful.
2019-05-21 10:58:34 +02:00
9fd61a207b
Store class pointer in attribute during installation.
All checks were successful
The build was successful.
2019-05-21 08:42:45 +02:00
1acbd21caf
Store a pointer to class container in each method.
All checks were successful
The build was successful.
2019-05-21 08:40:10 +02:00
a25b163af6
Fix another PH7 conceptual bug. Reverse this logic.
All checks were successful
The build was successful.
2019-05-18 13:42:30 +02:00
77c57674e8
Allow private methods redeclaration.
All checks were successful
The build was successful.
2019-05-17 19:54:32 +02:00
4cc7940216
Correctly identify a member.
All checks were successful
The build was successful.
2019-05-17 09:05:17 +02:00
55acf8111f
Assume private visibility for all class members by default.
All checks were successful
The build was successful.
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
48ccd7fef0
Copy all attributes from base classes and emit a warning if redeclared in subclass.
All checks were successful
The build was successful.
2019-05-17 06:52:29 +02:00
e8c675bd8e
Store a pointer to class container to reduce memory usage.
All checks were successful
The build was successful.
2019-05-16 15:41:37 +02:00
7203492763
Store a class name in each attribute.
All checks were successful
The build was successful.
2019-05-16 13:25:06 +02:00
8aed5af238
Correct indentation.
All checks were successful
The build was successful.
2019-05-15 20:15:26 +02:00
f2116a6461
Always use HTTPS when possible.
All checks were successful
The build was successful.
2019-05-15 20:02:39 +02:00
5d9b73ba4e
Use method full name.
All checks were successful
The build was successful.
2019-05-15 19:45:39 +02:00
3cc347f25f
Correct CLI command name.
All checks were successful
The build was successful.
2019-05-14 13:50:52 +02:00
27e3b85b30
This is AerScript interpreter.
All checks were successful
The build was successful.
2019-05-14 13:48:51 +02:00
5256dda922
Attempt to fix '$this' and '$parent' constructs.
All checks were successful
The build was successful.
2019-05-10 23:45:32 +02:00
ea5499f8b3
Private methods should not be accessible from child class.
All checks were successful
The build was successful.
2019-05-09 13:53:22 +02:00
5e7d5957e2
Distinguish methods from attributes.
All checks were successful
The build was successful.
2019-05-09 13:43:01 +02:00
d3d3dff673
Do not allow to call statically a non-static method.
All checks were successful
The build was successful.
2019-05-09 06:18:49 +02:00
c4416ef631
Fix singleton test.
All checks were successful
The build was successful.
2019-05-08 11:05:36 +02:00
76880ae4e2
Extend this test.
All checks were successful
The build was successful.
2019-05-08 09:03:21 +02:00
a2fb0b9ae5
Get rid of 'parent' constant. Use variable instead.
All checks were successful
The build was successful.
2019-05-08 08:38:40 +02:00
07bd3ceec3
Reimplement 'parent' construct as variable $parent.
All checks were successful
The build was successful.
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
0c8ca53f70
Continuous numeration.
All checks were successful
The build was successful.
2019-05-07 09:24:43 +02:00
03c37c58bb
Add constants test.
All checks were successful
The build was successful.
2019-05-07 08:42:42 +02:00
17e0fb4653
Do not try to resolve constants when OP_MEMBER is next instruction on the stack.
All checks were successful
The build was successful.
2019-05-06 18:42:06 +02:00
d3ae1c1bf4
Only identifiers should be allowed as constant name.
All checks were successful
The build was successful.
2019-05-06 18:38:56 +02:00
cedc288f67
Remove static constant.
All checks were successful
The build was successful.
2019-05-06 11:42:19 +02:00
0a6b5a6f42
The 'self' and 'parent' keywords should be resolved at compile time.
All checks were successful
The build was successful.
2019-05-06 11:38:32 +02:00
7b6245572f
Remove constants management builtin functions.
All checks were successful
The build was successful.
2019-05-06 06:54:29 +02:00
9d84c558c4
New test for goto statement.
All checks were successful
The build was successful.
2019-05-06 06:39:36 +02:00
c4b63a3018
Rename OP_LOAD instruction to OP_LOADV.
All checks were successful
The build was successful.
2019-05-05 09:33:06 +02:00
23900f2aed
Remove unused compiler function - PH7_CompileLangConstruct().
All checks were successful
The build was successful.
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
b36510943d
Implement 'define' statement for defining constants globally.
All checks were successful
The build was successful.
2019-05-04 17:08:09 +02:00
ab8bf48485
Make constant declarations local.
All checks were successful
The build was successful.
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
90b2da7c56
Unify constant length.
All checks were successful
The build was successful.
2019-05-03 12:40:47 +02:00