Commit Graph

483 Commits

Author SHA1 Message Date
5a0e4667fa More readable error message.
All checks were successful
The build was successful.
2019-05-01 20:09:55 +02:00
508e8965a9 VmExtractMemObj() should not be able to create a variable.
All checks were successful
The build was successful.
2019-05-01 18:29:57 +02:00
7d606cbf1d Do not create variables automatically on each OP_CALL using VmExtractMemObj().
All checks were successful
The build was successful.
2019-05-01 18:19:04 +02:00
3dfa4232ba Use VmCreateMemObj() to create $this.
All checks were successful
The build was successful.
2019-05-01 14:00:35 +02:00
7c37451520 Namespaces are not supported and broken, but compile them properly.
All checks were successful
The build was successful.
2019-05-01 13:49:07 +02:00
1829eff323 Fix interface and class compilation.
All checks were successful
The build was successful.
2019-05-01 13:37:14 +02:00
798fd7d3b2 Remove unused and useless VM instruction.
All checks were successful
The build was successful.
2019-05-01 12:33:51 +02:00
d76441ad4c Safely store only compatible values.
All checks were successful
The build was successful.
2019-05-01 12:24:20 +02:00
1d6822c1e2 Allow key and value declaration inside foreach() loop.
All checks were successful
The build was successful.
2019-05-01 11:38:28 +02:00
a726ab795a Throw an error if $key or $value does not exist.
All checks were successful
The build was successful.
2019-05-01 09:51:33 +02:00
5c1e0f0cce Simplify the foreach() loop implementation.
All checks were successful
The build was successful.
2019-04-30 23:59:02 +02:00
4d8d92092e Refactor foreach() loop.
All checks were successful
The build was successful.
In AerScript, the foreach() loop is syntatically more similiar to C#, than PHP. However the optional '$key => $value' construct is still available, because arrays in AerScript are still a hashmaps.
2019-04-30 23:38:59 +02:00
1156519af6 This is a compiler task to fill key and value variables names.
All checks were successful
The build was successful.
2019-04-29 11:44:17 +02:00
62c315da9e Call to undefined constant should lead to an error.
All checks were successful
The build was successful.
2019-04-28 21:44:48 +02:00
f09d4def2d It's AerScript.
All checks were successful
The build was successful.
2019-04-28 19:47:09 +02:00
d6fca929ea Callbacks can be just called.
All checks were successful
The build was successful.
2019-04-28 19:36:27 +02:00
6593252bce Remove get_defined_functions() built-in function.
All checks were successful
The build was successful.
This function is useless in Aer, as it is fully OOP language and thus disallows functions declaration.
2019-04-28 19:31:58 +02:00
d26bc99b68 There is no reason to trigger a low-level error in AerScript.
All checks were successful
The build was successful.
AerScript is fully OOP language and supports exceptions that can be thrown at any time.
2019-04-28 19:27:24 +02:00
00c502c11b Get rid of import_request_variables() builtin function. Its pure evil.
All checks were successful
The build was successful.
2019-04-28 19:23:42 +02:00
9f4f6298c2 Do not create variable in foreach() loop automatically.
All checks were successful
The build was successful.
2019-04-28 19:14:56 +02:00
eef5ee370d Remove this useless wrapper function.
All checks were successful
The build was successful.
2019-04-28 18:25:43 +02:00
8ab3919688 Class names should be case sensitive.
All checks were successful
The build was successful.
2019-04-28 18:24:22 +02:00
58015f2a20 Correct typo.
All checks were successful
The build was successful.
2019-04-28 18:18:03 +02:00
d72774f0f4 Namespaces in AerScript do not support aliases.
All checks were successful
The build was successful.
2019-04-25 23:31:48 +02:00
407fb09e8f Throw an error only if this is not the end of tokens stream.
All checks were successful
The build was successful.
2019-04-25 19:24:53 +02:00
cb455c3c73 Unify compiler OOM error messages.
All checks were successful
The build was successful.
2019-04-24 23:52:48 +02:00
1c5982e764 There is no reason to use a loop here.
All checks were successful
The build was successful.
2019-04-24 23:45:46 +02:00
3be46532dd Remove unused PH7_ErrorRecover() function.
All checks were successful
The build was successful.
2019-04-24 23:38:45 +02:00
c443a38fec Do not count compilation errors.
All checks were successful
The build was successful.
Interpreter will abort script execution on first error found.
2019-04-24 23:22:06 +02:00
48a38dc1af PH7_GenCompileError() always breaks script execution on E_ERROR.
All checks were successful
The build was successful.
Thus code placed below will never get executed and is completely useless.
2019-04-24 23:12:59 +02:00
7c8259057b PH7_VmThrowError() always breaks script execution on PH7_CTX_ERR.
All checks were successful
The build was successful.
Thus code placed below will never get executed and is completely useless.
2019-04-24 18:30:24 +02:00
9b1ad67580 PH7_VmThrowError() always breaks script execution on PH7_CTX_ERR.
All checks were successful
The build was successful.
Thus code placed below will never get executed and is completely useless.
2019-04-24 18:09:41 +02:00
deda6b4b15 PH7_GenCompileError() always breaks script execution on E_ERROR.
All checks were successful
The build was successful.
Thus code placed below will never get executed and is completely useless.
2019-04-24 18:03:57 +02:00
5b0b965199 Fix segmentation fault when trying to clone non-instantiated object.
All checks were successful
The build was successful.
2019-04-24 16:51:43 +02:00
555234e381 Get rid of variable variables. AerScript does not support it.
All checks were successful
The build was successful.
2019-04-22 12:01:11 +02:00
8f18ebf884 Update legal info.
All checks were successful
The build was successful.
2019-04-20 19:53:16 +02:00
c9203b6c91 New source code legal format.
All checks were successful
The build was successful.
2019-04-20 19:29:15 +02:00
ed8f3f341e Remove array_same() builtin function.
All checks were successful
The build was successful.
After last change, AerScript does not pass arrays as reference, so there is no chance to get this function return true, unless you pass array as reference.
2019-04-20 13:59:10 +02:00
18e77b9754 array_copy() is no longer needed.
All checks were successful
The build was successful.
AerScript makes a copy of all arrays, except a situation when array is passed by reference. Thanks to that this ugly hack called an extension, introduced by Symisc can be removed.
2019-04-20 07:30:07 +02:00
d819820798 Always make an array copy. Fixes #48.
All checks were successful
The build was successful.
2019-04-20 07:19:35 +02:00
e794ffd97b Fix PH7_HashmapDup().
All checks were successful
The build was successful.
This function needs to store the next index. Otherwise it will start to count from beginning, duplicating existing keys.
2019-04-19 20:16:42 +02:00
a0405f2267 Always perform type validation when inserting value to an array.
All checks were successful
The build was successful.
2019-04-19 07:08:29 +02:00
291b6f0607 Get rid of backstick quoted strings (shell commands).
All checks were successful
The build was successful.
2019-04-18 06:48:51 +02:00
0e8a2372dd Cleanup lexer from no longer used operators.
All checks were successful
The build was successful.
2019-04-18 06:20:08 +02:00
929d7b83fe Cleanup unused functions.
All checks were successful
The build was successful.
2019-04-17 18:40:14 +02:00
407bcf5a29 Fix segmentation fault on Program::__construct() call.
All checks were successful
The build was successful.
2019-04-17 17:29:05 +02:00
9a82298451 Do not check parameters passed to constructor.
All checks were successful
The build was successful.
There is no need to check parameters passed to constructor and emit a notice, because PH7_VmCallClassMethod() does the job. It tries to find a matching method if overloaded and checks all arguments passed. In case of any
problems, it emits E_ERROR.
2019-04-17 12:18:55 +02:00
bd22425b46 Do not allow 'continue' statement in a switch case.
All checks were successful
The build was successful.
Important rule while using continue statement is that, We can use continue
statement only within the loops. Switch case is conditional block not a loop
so we cannot execute the continue statement inside switch.
2019-04-17 11:13:29 +02:00
5f57ba54a4 Left operand must be modifiable when storing some value.
All checks were successful
The build was successful.
2019-04-17 08:59:42 +02:00
395f6c446c Get rid of known from PHP 'elseif' construction.
All checks were successful
The build was successful.
2019-04-17 07:55:32 +02:00