Rafal Kupiec
4dae0bcc9e
Always record last instruction.
2018-09-01 19:56:36 +02:00
Rafal Kupiec
383fe01943
Reserve 10KB for error reporting.
2018-09-01 17:54:45 +02:00
Rafal Kupiec
8fcb3c608a
Remove duplicate of SySetUsed() macro.
2018-08-31 23:45:46 +02:00
Rafal Kupiec
d9db6bbc26
There is no need for global working buffer in VM.
2018-08-31 23:34:35 +02:00
Rafal Kupiec
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
Rafal Kupiec
838842fa02
Add execution marker to each instruction.
2018-08-31 08:25:48 +02:00
Rafal Kupiec
3e2a5b3be2
Correct field length.
2018-08-30 19:23:06 +02:00
Rafal Kupiec
90a02d8fdd
Add operator ID to the debugging information.
2018-08-30 16:52:09 +02:00
Rafal Kupiec
461ee00034
Allow to use PH7_CTX_DEPRECATED.
2018-08-30 13:47:01 +02:00
Rafal Kupiec
fbc725c935
We are tokenizing Aer.
2018-08-30 12:33:38 +02:00
Rafal Kupiec
8215c4e984
Correct comment.
2018-08-30 12:15:48 +02:00
Rafal Kupiec
041c65d63e
Implement SySetGetUsed();
2018-08-30 12:00:02 +02:00
Rafal Kupiec
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
Rafal Kupiec
98d3de2105
Record all instructions in debugging set.
2018-08-29 08:04:19 +02:00
Rafal Kupiec
8f92782fe2
Fix segmentation fault.
2018-08-28 19:07:07 +02:00
Rafal Kupiec
d97c0a6634
Fix VmExtractPeekDebugTrace();
2018-08-28 11:17:32 +02:00
Rafal Kupiec
603672b8e2
PH7 disallows function calls from global scope.
2018-08-28 11:16:34 +02:00
Rafal Kupiec
37c960e313
Fix uninitialized value leading to segmentation fault.
2018-08-27 20:23:08 +02:00
Rafal Kupiec
6a14e88973
Remove unused definition.
2018-08-27 20:22:23 +02:00
Rafal Kupiec
349bbed774
Allow to enable or disable debugging.
2018-08-27 19:53:24 +02:00
Rafal Kupiec
c8e2dccbeb
Assign Program::main() return value as program exit code.
2018-08-27 19:32:17 +02:00
Rafal Kupiec
7a740c0570
Correct typo.
2018-08-27 18:23:12 +02:00
Rafal Kupiec
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
Rafal Kupiec
c9a1971ace
Rewrite debug_backtrace() builtin function.
...
It makes a use of new VmExtractDebugTrace() function. This probably fixes #45 .
2018-08-27 15:47:34 +02:00
Rafal Kupiec
ce621cc49c
Implement VmExtractPeekDebugTrace();
2018-08-27 12:42:02 +02:00
Rafal Kupiec
d0b0a416d0
Allow to dump last frame only.
2018-08-27 12:36:21 +02:00
Rafal Kupiec
8f7b28d46c
Formatting for VM dump.
2018-08-27 12:16:41 +02:00
Rafal Kupiec
fb671ec2d7
Implement VmExtractDebugTrace().
2018-08-27 11:32:21 +02:00
Rafal Kupiec
18222dce8c
Implement VmDebugTrace structure.
2018-08-27 11:22:02 +02:00
Rafal Kupiec
1403b144d9
Sequence numbers should start from 1.
2018-08-27 09:30:51 +02:00
Rafal Kupiec
782a4df1cf
Formatting, add information about file and line.
2018-08-27 09:17:18 +02:00
Rafal Kupiec
b1f71167d9
Unify memory indicator.
2018-08-27 08:22:05 +02:00
Rafal Kupiec
3f7bac2d85
Associate a filename with VM instructions.
2018-08-27 06:45:53 +02:00
Rafal Kupiec
f552c54992
Better formatting.
2018-08-26 22:10:47 +02:00
Rafal Kupiec
e6ad76b031
Dump VM after execution.
...
VM instructions dump should be processed after script execution to follow included files.
2018-08-26 20:29:19 +02:00
Rafal Kupiec
a7bbd55d48
Temporarily enable debugging by default.
2018-08-26 20:09:30 +02:00
Rafal Kupiec
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
Rafal Kupiec
ab5ee94f99
API function rename.
2018-08-26 19:18:33 +02:00
Rafal Kupiec
98ee931a04
Correct instruction length.
2018-08-26 18:33:57 +02:00
Rafal Kupiec
877d19a815
API function rename.
2018-08-26 18:30:21 +02:00
Rafal Kupiec
c8c6208cca
Return script exit code.
2018-08-26 08:37:35 +02:00
Rafal Kupiec
94b213674a
Change the script located in memory indicator.
...
For easier reading with line numbers.
2018-08-23 18:27:14 +02:00
Rafal Kupiec
4197737ddc
Move structure definitions to header.
2018-08-23 17:08:10 +02:00
Rafal Kupiec
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
Rafal Kupiec
20c1611902
Implement PH7_VmExtractActiveClass().
...
This function extracts an active class with specified depth, #45 .
2018-08-22 15:33:16 +02:00
Rafal Kupiec
0ff32e6673
Remove duplicated constants.
2018-08-22 11:24:34 +02:00
Rafal Kupiec
dbe373d537
Resolve __CLASS__ at compile time.
...
Ticket: #45 : __CLASS__ constant must be resolved at compile time, not run time. Otherwise it returns incorrect data.
2018-08-22 09:59:10 +02:00
Rafal Kupiec
3e18a5b8e8
Optimize the code, #45 .
2018-08-22 08:51:45 +02:00
Rafal Kupiec
a0f7949b24
Resolve __DIR__ at compile time.
...
Ticket: #45 : __DIR__ constant must be resolved at compile time, not run time. Otherwise it returns incorrect data.
2018-08-22 06:23:43 +02:00
Rafal Kupiec
02242bb93d
Resolve __FILE__ at compile time.
...
Ticket: #45 : __FILE__ constant must be resolved at compile time, not run time. Otherwise it returns incorrect data.
2018-08-21 20:18:39 +02:00