Commit Graph

114 Commits

Author SHA1 Message Date
d85a517eb0 Rework trigger_error() builtin function. 2018-09-03 19:27:38 +02:00
0a28e492a7 error_reporting() is useless for Aer.
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.
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.
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. 2018-09-03 16:29:50 +02:00
d3d3dcc767 Partially switch to new error reporting. 2018-09-03 16:16:32 +02:00
0298299169 Extend SEQ field. 2018-09-03 09:36:22 +02:00
9c4eb59b49 Variable list of arguments for PH7_VmGenericError(); 2018-09-03 09:30:23 +02:00
f176414bce Release VM and exit automatically, do not rely on VM. 2018-09-03 08:40:18 +02:00
eea9eee6e5 Implement PH7_VmGenericError(); 2018-09-03 08:19:14 +02:00
a2acf64272 VmExtractDebugTrace() provides information about a kind of call.
Both VmExtractDebugTrace() and VmDebugTrace structure should provide information whether it was object call or a static method call.
2018-09-02 20:15:17 +02:00
d135748bcd Always iterate through all frames. 2018-09-02 18:53:23 +02:00
ea7955b6ee Remove useless VmExtractPeekDebugTrace(); 2018-09-02 18:50:00 +02:00
f89af70ab2 Fix VmExtractDebugTrace();
If there is no information about class in the frame (when closure was called), pClassName should point always to NULL.
2018-09-02 18:46:30 +02:00
3e1d91e909 Add more comments. 2018-09-02 18:45:01 +02:00
da198fcb44 Implement PH7_VmMemoryError(); 2018-09-02 12:27:32 +02:00
90ab131ce8 Do not append spaces. Instructions names are properly displayed without them. 2018-09-01 20:28:16 +02:00
8bfaa83b04 Correct typo. 2018-09-01 20:19:10 +02:00
4dae0bcc9e Always record last instruction. 2018-09-01 19:56:36 +02:00
d9db6bbc26 There is no need for global working buffer in VM. 2018-08-31 23:34:35 +02:00
67ce98d924 Look for executed OP_CALL.
Each function contains a list of all instructions inside, thus we should consider only OP_CALL that has already been executed. As the list is browsed from bottom to top, no more checks are necessary. The first match is what we
are looking for.
2018-08-31 08:30:59 +02:00
838842fa02 Add execution marker to each instruction. 2018-08-31 08:25:48 +02:00
3e2a5b3be2 Correct field length. 2018-08-30 19:23:06 +02:00
90a02d8fdd Add operator ID to the debugging information. 2018-08-30 16:52:09 +02:00
b6161b0e4b Fix VM ByteCode debugging.
Only executed bytecode should be registered for debugging. In this way we do not register all emitted bytecode and save some memory. What is more, this change registers the bytecode in correct executing order including jumps.
Previously all bytecode generated by compiler has been saved what made the bytecode to be saved in compile, not execute order.
2018-08-30 09:46:40 +02:00
98d3de2105 Record all instructions in debugging set. 2018-08-29 08:04:19 +02:00
8f92782fe2 Fix segmentation fault. 2018-08-28 19:07:07 +02:00
d97c0a6634 Fix VmExtractPeekDebugTrace(); 2018-08-28 11:17:32 +02:00
603672b8e2 PH7 disallows function calls from global scope. 2018-08-28 11:16:34 +02:00
37c960e313 Fix uninitialized value leading to segmentation fault. 2018-08-27 20:23:08 +02:00
349bbed774 Allow to enable or disable debugging. 2018-08-27 19:53:24 +02:00
c8e2dccbeb Assign Program::main() return value as program exit code. 2018-08-27 19:32:17 +02:00
6d27069590 Add new file for every chunk.
Every chunk should has its own file associated, even if it is [MEMORY]. Otherwise, some false information can be provided by interpreter to developer.
2018-08-27 18:04:45 +02:00
c9a1971ace Rewrite debug_backtrace() builtin function.
It makes a use of new VmExtractDebugTrace() function. This probably fixes .
2018-08-27 15:47:34 +02:00
ce621cc49c Implement VmExtractPeekDebugTrace(); 2018-08-27 12:42:02 +02:00
d0b0a416d0 Allow to dump last frame only. 2018-08-27 12:36:21 +02:00
8f7b28d46c Formatting for VM dump. 2018-08-27 12:16:41 +02:00
fb671ec2d7 Implement VmExtractDebugTrace(). 2018-08-27 11:32:21 +02:00
1403b144d9 Sequence numbers should start from 1. 2018-08-27 09:30:51 +02:00
782a4df1cf Formatting, add information about file and line. 2018-08-27 09:17:18 +02:00
b1f71167d9 Unify memory indicator. 2018-08-27 08:22:05 +02:00
3f7bac2d85 Associate a filename with VM instructions. 2018-08-27 06:45:53 +02:00
f552c54992 Better formatting. 2018-08-26 22:10:47 +02:00
a7bbd55d48 Temporarily enable debugging by default. 2018-08-26 20:09:30 +02:00
178f3820f6 Enable debugging.
This commit introduces ne debug feature. The PH7 Engine limits the VM dump to the global scope. Since Aer Script is fully object-oriented language the dump option contains only information about last call of OP_DONE. This change,
forces the VM to store all instructions set in a global container when debugging is enabled, thus providing information the dump of whole script parse.
2018-08-26 19:59:17 +02:00
98ee931a04 Correct instruction length. 2018-08-26 18:33:57 +02:00
4197737ddc Move structure definitions to header. 2018-08-23 17:08:10 +02:00
82c18dc109 Do not pop out the processed files.
List of procesed files is still needed, as we point to them.
2018-08-23 07:06:33 +02:00
20c1611902 Implement PH7_VmExtractActiveClass().
This function extracts an active class with specified depth, .
2018-08-22 15:33:16 +02:00
81325b5059 Correct typo. 2018-08-18 21:05:46 +02:00