Commit Graph

837 Commits

Author SHA1 Message Date
Rafal Kupiec 5c176207e1
Set base class only when $base called.
The build has failed. Details
2019-05-28 11:51:13 +02:00
Rafal Kupiec 5cc4a5e48d
Access privileges to methods should be done in OP_MEMBER.
The build was successful. Details
2019-05-23 08:27:56 +02:00
Rafal Kupiec e654e42b07
Store class directly in function container.
The build was successful. Details
2019-05-22 08:33:56 +02:00
Rafal Kupiec 5b2f300fe4
Implement '$base' construction.
The build was successful. Details
2019-05-21 21:41:16 +02:00
Rafal Kupiec d8db20e9bd
Do not use as variable name.
The build was successful. Details
2019-05-21 21:36:08 +02:00
Rafal Kupiec 1f78547ca2
Convert DOS2UNIX.
The build was successful. Details
2019-05-21 21:34:14 +02:00
Rafal Kupiec ddd46a4e80
Quick small cleanup.
The build was successful. Details
2019-05-21 19:18:52 +02:00
Rafal Kupiec 3cca5faa76
Store variable type in dedicated field.
The build was successful. Details
2019-05-21 14:49:36 +02:00
Rafal Kupiec 0f4a666b89
Variable type should be separated from control flags.
The build was successful. Details
2019-05-21 10:58:34 +02:00
Rafal Kupiec 9fd61a207b
Store class pointer in attribute during installation.
The build was successful. Details
2019-05-21 08:42:45 +02:00
Rafal Kupiec 1acbd21caf
Store a pointer to class container in each method.
The build was successful. Details
2019-05-21 08:40:10 +02:00
Rafal Kupiec a25b163af6
Fix another PH7 conceptual bug. Reverse this logic.
The build was successful. Details
2019-05-18 13:42:30 +02:00
Rafal Kupiec 77c57674e8
Allow private methods redeclaration.
The build was successful. Details
2019-05-17 19:54:32 +02:00
Rafal Kupiec 4cc7940216
Correctly identify a member.
The build was successful. Details
2019-05-17 09:05:17 +02:00
Rafal Kupiec 55acf8111f
Assume private visibility for all class members by default.
The build was successful. Details
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.
The build was successful. Details
2019-05-17 06:52:29 +02:00
Rafal Kupiec e8c675bd8e
Store a pointer to class container to reduce memory usage.
The build was successful. Details
2019-05-16 15:41:37 +02:00
Rafal Kupiec 7203492763
Store a class name in each attribute.
The build was successful. Details
2019-05-16 13:25:06 +02:00
Rafal Kupiec 8aed5af238
Correct indentation.
The build was successful. Details
2019-05-15 20:15:26 +02:00
Rafal Kupiec f2116a6461
Always use HTTPS when possible.
The build was successful. Details
2019-05-15 20:02:39 +02:00
Rafal Kupiec 5d9b73ba4e
Use method full name.
The build was successful. Details
2019-05-15 19:45:39 +02:00
Rafal Kupiec 3cc347f25f
Correct CLI command name.
The build was successful. Details
2019-05-14 13:50:52 +02:00
Rafal Kupiec 27e3b85b30
This is AerScript interpreter.
The build was successful. Details
2019-05-14 13:48:51 +02:00
Rafal Kupiec 5256dda922
Attempt to fix '$this' and '$parent' constructs.
The build was successful. Details
2019-05-10 23:45:32 +02:00
Rafal Kupiec ea5499f8b3
Private methods should not be accessible from child class.
The build was successful. Details
2019-05-09 13:53:22 +02:00
Rafal Kupiec 5e7d5957e2
Distinguish methods from attributes.
The build was successful. Details
2019-05-09 13:43:01 +02:00
Rafal Kupiec d3d3dff673
Do not allow to call statically a non-static method.
The build was successful. Details
2019-05-09 06:18:49 +02:00
Rafal Kupiec c4416ef631
Fix singleton test.
The build was successful. Details
2019-05-08 11:05:36 +02:00
Rafal Kupiec 76880ae4e2
Extend this test.
The build was successful. Details
2019-05-08 09:03:21 +02:00
Rafal Kupiec a2fb0b9ae5
Get rid of 'parent' constant. Use variable instead.
The build was successful. Details
2019-05-08 08:38:40 +02:00
Rafal Kupiec 07bd3ceec3
Reimplement 'parent' construct as variable $parent.
The build was successful. Details
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.
The build was successful. Details
2019-05-07 09:24:43 +02:00
Rafal Kupiec 03c37c58bb
Add constants test.
The build was successful. Details
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.
The build was successful. Details
2019-05-06 18:42:06 +02:00
Rafal Kupiec d3ae1c1bf4
Only identifiers should be allowed as constant name.
The build was successful. Details
2019-05-06 18:38:56 +02:00
Rafal Kupiec cedc288f67
Remove static constant.
The build was successful. Details
2019-05-06 11:42:19 +02:00
Rafal Kupiec 0a6b5a6f42
The 'self' and 'parent' keywords should be resolved at compile time.
The build was successful. Details
2019-05-06 11:38:32 +02:00
Rafal Kupiec 7b6245572f
Remove constants management builtin functions.
The build was successful. Details
2019-05-06 06:54:29 +02:00
Rafal Kupiec 9d84c558c4
New test for goto statement.
The build was successful. Details
2019-05-06 06:39:36 +02:00
Rafal Kupiec c4b63a3018
Rename OP_LOAD instruction to OP_LOADV.
The build was successful. Details
2019-05-05 09:33:06 +02:00
Rafal Kupiec 23900f2aed
Remove unused compiler function - PH7_CompileLangConstruct().
The build was successful. Details
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.
The build was successful. Details
2019-05-04 17:08:09 +02:00
Rafal Kupiec ab8bf48485
Make constant declarations local.
The build was successful. Details
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.
The build was successful. Details
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.
The build was successful. Details
2019-05-03 10:55:57 +02:00
Rafal Kupiec 03fc167be1
Proper implementation of so hated 'goto' statement.
The build was successful. Details
2019-05-03 10:35:54 +02:00
Rafal Kupiec 2f3ce65289
Correct comment to if/else statements.
The build was successful. Details
2019-05-02 19:03:47 +02:00
Rafal Kupiec 73c1a814f5
Test foreach() loop.
The build was successful. Details
2019-05-02 18:51:12 +02:00
Rafal Kupiec 8f681d1605
Correct PH7_OP_JMPLFE debug name.
The build was successful. Details
2019-05-01 20:24:37 +02:00
Rafal Kupiec 5a0e4667fa
More readable error message.
The build was successful. Details
2019-05-01 20:09:55 +02:00