Commit Graph

606 Commits

Author SHA1 Message Date
241c7d8168 First step to declare a variable with specified data type.
All checks were successful
The build was successful.
2018-09-20 17:06:23 +02:00
e6e59d299e Fix method parameters.
All checks were successful
The build was successful.
2018-09-19 19:27:50 +02:00
9884f8288b Do not allow typecasting to unset a variable.
All checks were successful
The build was successful.
2018-09-18 22:11:57 +02:00
5a6af65cfa Object of wrong type passed as argument should be generate error.
All checks were successful
The build was successful.
2018-09-17 22:06:53 +02:00
82998ffd0f Silently typecast integer value to float.
All checks were successful
The build was successful.
This is a necessary step, to allow passing integer numbers. Otherwise, every float variable would need a floating point value. In other words, "float $x = 5" is allowed construct. Without this simple change, only accepted
construction was "float $x = 5.0".
2018-09-16 20:02:34 +02:00
58103ea5fe Mark method/closure call frame as active.
All checks were successful
The build was successful.
It is impossible to dump the frame during its initialization, as it does not contain all necessary information. Such frame should be skipped. After initialization is done, the frame has to be marked as active just before
evaluating a function body.
2018-09-16 19:52:24 +02:00
3a16eced8a Push error if argument type does not match.
All checks were successful
The build was successful.
2018-09-15 14:13:46 +02:00
5504579566 Passing an object of different type as expected should result in error.
All checks were successful
The build was successful.
2018-09-14 22:27:38 +02:00
faca9b7fb2 Another fix in debug trace.
All checks were successful
The build was successful.
2018-09-14 22:22:37 +02:00
94ae7d187b No data type for argument specified leads to E_ERROR.
All checks were successful
The build was successful.
2018-09-14 21:33:31 +02:00
8b48786f29 Add missing data types.
All checks were successful
The build was successful.
2018-09-14 08:47:16 +02:00
ecebbb6094 Use type hinting in standard library.
Some checks reported errors
The build has failed.
2018-09-14 08:36:00 +02:00
74b1c196f9 Treat invalid type name as error.
All checks were successful
The build was successful.
2018-09-13 18:56:01 +02:00
d4992ff4ba At least try to report correct line number.
All checks were successful
The build was successful.
2018-09-12 19:24:48 +02:00
58b7ceeae9 Get rid of $GLOBALS completely.
All checks were successful
The build was successful.
2018-09-11 17:49:20 +02:00
0804407582 Correct typo.
All checks were successful
The build was successful.
2018-09-11 13:58:03 +02:00
e383536dc4 Do not store script arguments in $GLOBALS.
All checks were successful
The build was successful.
2018-09-11 06:47:48 +02:00
9ebc3dc61a Extract a list of parameters and pass them to Program::main();
All checks were successful
The build was successful.
2018-09-10 23:12:08 +02:00
10d3bfe5e1 Correct comments.
All checks were successful
The build was successful.
2018-09-10 20:17:42 +02:00
7e754db07f Implement SyStrtok();
All checks were successful
The build was successful.
2018-09-10 20:16:46 +02:00
eb79ed500e Store float values in an union.
All checks were successful
The build was successful.
Single variable cannot have many values of different types. This also saves some memory, because union allocates memory just for one of its members.
2018-09-07 12:04:51 +02:00
af1d59dab4 Don't try to get an integer representation of float.
All checks were successful
The build was successful.
2018-09-07 06:49:50 +02:00
ac8b8b0fdb Don't try to get an integer representation of float.
All checks were successful
The build was successful.
2018-09-07 06:43:07 +02:00
9ee0f1954c Do not omit the floating point.
All checks were successful
The build was successful.
Every modern hardware, including embedded devices, should support floating point numbers.
2018-09-07 06:38:32 +02:00
0a9cfce672 Group and add missing keywords.
All checks were successful
The build was successful.
2018-09-06 19:47:06 +02:00
43a36f070c Correct comments.
All checks were successful
The build was successful.
2018-09-06 18:00:34 +02:00
3887aa69a6 Never disable hash functions.
All checks were successful
The build was successful.
2018-09-05 21:46:25 +02:00
c3a4c8de77 Never disable builtin functions.
All checks were successful
The build was successful.
2018-09-05 20:47:07 +02:00
00e1c842d5 Never disable builtin functions.
All checks were successful
The build was successful.
2018-09-05 20:43:39 +02:00
ea4daa9335 Take last instruction being executed, not necessarily OP_CALL.
All checks were successful
The build was successful.
2018-09-05 19:45:38 +02:00
6387026e15 Do not limit the output buffering callbacks.
All checks were successful
The build was successful.
2018-09-05 18:46:42 +02:00
11ba0ce738 No need to store output length in VM.
All checks were successful
The build was successful.
2018-09-05 18:33:53 +02:00
404f5a2688 No need to store unique ID in VM.
All checks were successful
The build was successful.
2018-09-05 18:24:34 +02:00
ae79cb57de No need to store information about line number in ph7_class struct.
All checks were successful
The build was successful.
2018-09-05 17:42:10 +02:00
894dbe47d6 Allow compiler to specify line number, on which instruction has been generated.
All checks were successful
The build was successful.
This also fixes line number on OP_CLASS_INIT and OP_INTERFACE_INIT.
2018-09-05 17:31:06 +02:00
543176a2f4 Switch VM state to PH7_VM_INCL when including new file.
All checks were successful
The build was successful.
2018-09-05 13:28:20 +02:00
d58249cb3f Use debug trace only if VM is really executing some code.
All checks were successful
The build was successful.
2018-09-05 13:16:57 +02:00
c00c91599f Enable unused API functions.
All checks were successful
The build was successful.
2018-09-04 09:33:28 +02:00
19eaaab081 Remove unused code.
All checks were successful
The build was successful.
2018-09-04 09:19:15 +02:00
1643d2ee94 Remove unused code.
All checks were successful
The build was successful.
2018-09-04 09:18:13 +02:00
03e452ea7b Shutdown library properly on error.
All checks were successful
The build was successful.
2018-09-04 09:13:28 +02:00
d793d3ed70 Rename PH7_VmGenericError() to PH7_VmThrowError()
All checks were successful
The build was successful.
2018-09-04 08:54:48 +02:00
758ace0d1a Shutdown library properly on error.
All checks were successful
The build was successful.
2018-09-04 08:49:38 +02:00
dc0a55c8c0 Cleanup old error handler.
All checks were successful
The build was successful.
2018-09-04 08:38:41 +02:00
ac73632cb1 Use new error handler.
All checks were successful
The build was successful.
2018-09-04 08:26:58 +02:00
d85a517eb0 Rework trigger_error() builtin function.
All checks were successful
The build was successful.
2018-09-03 19:27:38 +02:00
0a28e492a7 error_reporting() is useless for Aer.
All checks were successful
The build was successful.
Whole configuration should be done in config file.
2018-09-03 19:11:44 +02:00
fd4206a227 Remove error_log() builtin function and corresponding PH7_VM_CONFIG_ERR_LOG_HANDLER.
All checks were successful
The build was successful.
It was not fully implemented and such feature should be implemented in separate module or on developers own.
2018-09-03 19:03:05 +02:00
109f4e981a Aer does not support custom error handlers.
All checks were successful
The build was successful.
Errors are used only internally to emit notifications about compilation/execution problems. They should not be catched and handled by custom handlers, but properly configured (to be displayed or logged). Instead developers should
use exceptions that can be catched with try-catch block.
2018-09-03 16:43:08 +02:00
dd35b5b8b4 Uncaught exception message.
All checks were successful
The build was successful.
2018-09-03 16:29:50 +02:00