Gráfico de commits

977 Commits

Autor SHA1 Mensagem Data
1acbd21caf Store a pointer to class container in each method.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-21 08:40:10 +02:00
a25b163af6 Fix another PH7 conceptual bug. Reverse this logic.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-18 13:42:30 +02:00
77c57674e8 Allow private methods redeclaration.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-17 19:54:32 +02:00
4cc7940216 Correctly identify a member.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-17 09:05:17 +02:00
55acf8111f Assume private visibility for all class members by default.
Todas as verificações foram bem sucedidas
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.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-17 06:52:29 +02:00
e8c675bd8e Store a pointer to class container to reduce memory usage.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-16 15:41:37 +02:00
7203492763 Store a class name in each attribute.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-16 13:25:06 +02:00
8aed5af238 Correct indentation.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-15 20:15:26 +02:00
f2116a6461 Always use HTTPS when possible.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-15 20:02:39 +02:00
5d9b73ba4e Use method full name.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-15 19:45:39 +02:00
3cc347f25f Correct CLI command name.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-14 13:50:52 +02:00
27e3b85b30 This is AerScript interpreter.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-14 13:48:51 +02:00
5256dda922 Attempt to fix '$this' and '$parent' constructs.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-10 23:45:32 +02:00
ea5499f8b3 Private methods should not be accessible from child class.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-09 13:53:22 +02:00
5e7d5957e2 Distinguish methods from attributes.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-09 13:43:01 +02:00
d3d3dff673 Do not allow to call statically a non-static method.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-09 06:18:49 +02:00
c4416ef631 Fix singleton test.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-08 11:05:36 +02:00
76880ae4e2 Extend this test.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-08 09:03:21 +02:00
a2fb0b9ae5 Get rid of 'parent' constant. Use variable instead.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-08 08:38:40 +02:00
07bd3ceec3 Reimplement 'parent' construct as variable $parent.
Todas as verificações foram bem sucedidas
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.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-07 09:24:43 +02:00
03c37c58bb Add constants test.
Todas as verificações foram bem sucedidas
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.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-06 18:42:06 +02:00
d3ae1c1bf4 Only identifiers should be allowed as constant name.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-06 18:38:56 +02:00
cedc288f67 Remove static constant.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-06 11:42:19 +02:00
0a6b5a6f42 The 'self' and 'parent' keywords should be resolved at compile time.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-06 11:38:32 +02:00
7b6245572f Remove constants management builtin functions.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-06 06:54:29 +02:00
9d84c558c4 New test for goto statement.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-06 06:39:36 +02:00
c4b63a3018 Rename OP_LOAD instruction to OP_LOADV.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-05 09:33:06 +02:00
23900f2aed Remove unused compiler function - PH7_CompileLangConstruct().
Todas as verificações foram bem sucedidas
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.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-04 17:08:09 +02:00
ab8bf48485 Make constant declarations local.
Todas as verificações foram bem sucedidas
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.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-03 12:40:47 +02:00
e6b7f1be2c Always emit OP_JMPLFE as goto can be used inside a loop and frame has to be left.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-03 10:55:57 +02:00
03fc167be1 Proper implementation of so hated 'goto' statement.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-03 10:35:54 +02:00
2f3ce65289 Correct comment to if/else statements.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-02 19:03:47 +02:00
73c1a814f5 Test foreach() loop.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-02 18:51:12 +02:00
8f681d1605 Correct PH7_OP_JMPLFE debug name.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 20:24:37 +02:00
5a0e4667fa More readable error message.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 20:09:55 +02:00
508e8965a9 VmExtractMemObj() should not be able to create a variable.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 18:29:57 +02:00
7d606cbf1d Do not create variables automatically on each OP_CALL using VmExtractMemObj().
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 18:19:04 +02:00
3dfa4232ba Use VmCreateMemObj() to create $this.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 14:00:35 +02:00
7c37451520 Namespaces are not supported and broken, but compile them properly.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 13:49:07 +02:00
1829eff323 Fix interface and class compilation.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 13:37:14 +02:00
798fd7d3b2 Remove unused and useless VM instruction.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 12:33:51 +02:00
70676cb0d5 Correct comment.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 12:27:40 +02:00
d76441ad4c Safely store only compatible values.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 12:24:20 +02:00
186e5887f6 We can now declare key and value variables inside a loop.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 11:51:08 +02:00
bbcd99789d Fix test.
Todas as verificações foram bem sucedidas
The build was successful.
2019-05-01 11:48:57 +02:00