Commit Graph

160 Commits

Author SHA1 Message Date
dd35b5b8b4
Uncaught exception message.
All checks were successful
The build was successful.
2018-09-03 16:29:50 +02:00
d3d3dcc767
Partially switch to new error reporting.
All checks were successful
The build was successful.
2018-09-03 16:16:32 +02:00
0298299169
Extend SEQ field.
All checks were successful
The build was successful.
2018-09-03 09:36:22 +02:00
9c4eb59b49
Variable list of arguments for PH7_VmGenericError();
All checks were successful
The build was successful.
2018-09-03 09:30:23 +02:00
f176414bce
Release VM and exit automatically, do not rely on VM.
All checks were successful
The build was successful.
2018-09-03 08:40:18 +02:00
eea9eee6e5
Implement PH7_VmGenericError();
All checks were successful
The build was successful.
2018-09-03 08:19:14 +02:00
a2acf64272
VmExtractDebugTrace() provides information about a kind of call.
All checks were successful
The build was successful.
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.
All checks were successful
The build was successful.
2018-09-02 18:53:23 +02:00
ea7955b6ee
Remove useless VmExtractPeekDebugTrace();
All checks were successful
The build was successful.
2018-09-02 18:50:00 +02:00
f89af70ab2
Fix VmExtractDebugTrace();
All checks were successful
The build was successful.
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.
All checks were successful
The build was successful.
2018-09-02 18:45:01 +02:00
da198fcb44
Implement PH7_VmMemoryError();
All checks were successful
The build was successful.
2018-09-02 12:27:32 +02:00
90ab131ce8
Do not append spaces. Instructions names are properly displayed without them.
All checks were successful
The build was successful.
2018-09-01 20:28:16 +02:00
8bfaa83b04
Correct typo.
All checks were successful
The build was successful.
2018-09-01 20:19:10 +02:00
4dae0bcc9e
Always record last instruction.
All checks were successful
The build was successful.
2018-09-01 19:56:36 +02:00
d9db6bbc26
There is no need for global working buffer in VM.
All checks were successful
The build was successful.
2018-08-31 23:34:35 +02:00
67ce98d924
Look for executed OP_CALL.
All checks were successful
The build was successful.
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.
All checks were successful
The build was successful.
2018-08-31 08:25:48 +02:00
3e2a5b3be2
Correct field length.
All checks were successful
The build was successful.
2018-08-30 19:23:06 +02:00
90a02d8fdd
Add operator ID to the debugging information.
All checks were successful
The build was successful.
2018-08-30 16:52:09 +02:00
b6161b0e4b
Fix VM ByteCode debugging.
All checks were successful
The build was successful.
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.
All checks were successful
The build was successful.
2018-08-29 08:04:19 +02:00
8f92782fe2
Fix segmentation fault.
All checks were successful
The build was successful.
2018-08-28 19:07:07 +02:00
d97c0a6634
Fix VmExtractPeekDebugTrace();
All checks were successful
The build was successful.
2018-08-28 11:17:32 +02:00
603672b8e2
PH7 disallows function calls from global scope.
All checks were successful
The build was successful.
2018-08-28 11:16:34 +02:00
37c960e313
Fix uninitialized value leading to segmentation fault.
All checks were successful
The build was successful.
2018-08-27 20:23:08 +02:00
349bbed774
Allow to enable or disable debugging.
Some checks reported errors
The build has failed.
2018-08-27 19:53:24 +02:00
c8e2dccbeb
Assign Program::main() return value as program exit code.
Some checks reported errors
The build has failed.
2018-08-27 19:32:17 +02:00
6d27069590
Add new file for every chunk.
All checks were successful
The build was successful.
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.
All checks were successful
The build was successful.
It makes a use of new VmExtractDebugTrace() function. This probably fixes #45.
2018-08-27 15:47:34 +02:00
ce621cc49c
Implement VmExtractPeekDebugTrace();
All checks were successful
The build was successful.
2018-08-27 12:42:02 +02:00
d0b0a416d0
Allow to dump last frame only.
All checks were successful
The build was successful.
2018-08-27 12:36:21 +02:00
8f7b28d46c
Formatting for VM dump.
All checks were successful
The build was successful.
2018-08-27 12:16:41 +02:00
fb671ec2d7
Implement VmExtractDebugTrace().
All checks were successful
The build was successful.
2018-08-27 11:32:21 +02:00
1403b144d9
Sequence numbers should start from 1.
All checks were successful
The build was successful.
2018-08-27 09:30:51 +02:00
782a4df1cf
Formatting, add information about file and line.
All checks were successful
The build was successful.
2018-08-27 09:17:18 +02:00
b1f71167d9
Unify memory indicator.
All checks were successful
The build was successful.
2018-08-27 08:22:05 +02:00
3f7bac2d85
Associate a filename with VM instructions.
All checks were successful
The build was successful.
2018-08-27 06:45:53 +02:00
f552c54992
Better formatting.
All checks were successful
The build was successful.
2018-08-26 22:10:47 +02:00
a7bbd55d48
Temporarily enable debugging by default.
All checks were successful
The build was successful.
2018-08-26 20:09:30 +02:00
178f3820f6
Enable debugging.
All checks were successful
The build was successful.
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.
All checks were successful
The build was successful.
2018-08-26 18:33:57 +02:00
4197737ddc
Move structure definitions to header.
All checks were successful
The build was successful.
2018-08-23 17:08:10 +02:00
82c18dc109
Do not pop out the processed files.
All checks were successful
The build was successful.
List of procesed files is still needed, as we point to them.
2018-08-23 07:06:33 +02:00
20c1611902
Implement PH7_VmExtractActiveClass().
All checks were successful
The build was successful.
This function extracts an active class with specified depth, #45.
2018-08-22 15:33:16 +02:00
81325b5059
Correct typo.
All checks were successful
The build was successful.
2018-08-18 21:05:46 +02:00
2160747479
Make get_included_files() returning full path.
All checks were successful
The build was successful.
2018-08-18 21:02:23 +02:00
cbb4a0aa5c
get_included_files() should return a list of included, files.
All checks were successful
The build was successful.
2018-08-18 20:42:54 +02:00
4b3279ef01
Correct function description.
All checks were successful
The build was successful.
2018-08-18 19:32:33 +02:00
4dbd3ea412
New memory subsystem.
All checks were successful
The build was successful.
This is a new memory subsystem implementing heap calculations as well as new builtin functions:
 * get_memory_usage()
 * get_memory_peak_usage()
 * get_memory_limit()
It also allows to set an upper memory limit, ensuring that processed script will not be able to allocate more memory from OS.
New subsystem is based on work done in 'memory_limit' branch. Big thanks to devnexen!
This finally fixes #25.
2018-08-18 19:24:38 +02:00
b5fe36c14b
There is no need for include_once() and require_once()
All checks were successful
The build was successful.
Aer is object-oriented language and the code it includes is executed in the global scope. Global scope can contain only classes and namespaces and they cannot be re-declared. Thus every file can be included just once. We can
leave this to programmer, or take care about it on interpreter side. With this commit, include() and require() builtin functions allows to load file just once. Thanks to that, there is no need for include_once() and
require_once(). Done in scope of #30.
2018-08-16 16:12:29 +02:00
039fde099f
Compile Aer code or chunk of code.
All checks were successful
The build was successful.
2018-08-16 09:34:18 +02:00
b94a23d580
Get rid of PH7 ident
All checks were successful
The build was successful.
2018-08-15 20:03:39 +02:00
7c7a837efb
Correct another bunch of typos.
All checks were successful
The build was successful.
2018-08-15 19:06:00 +02:00
71d46e3052
Compiler rework does not allow functions in global scope.
All checks were successful
The build was successful.
These functions will be rewritten in C as a builtin functions in scope of #42.
2018-08-15 18:56:10 +02:00
da0b7eb629
Some useless function
All checks were successful
The build was successful.
2018-08-15 17:34:40 +02:00
af139b3f0a
Reimplement C-like min() and max() functions.
All checks were successful
The build was successful.
These functions should have C-like implementation and take exactly 2 arguments: integer or float.
Finally, C-implementation will be faster than using PH7 builtin library that needs to be compiled and interpreted.
2018-08-15 17:26:26 +02:00
8ab67084a0
It is as easy to instantiate the class as to remove this useless functions.
All checks were successful
The build was successful.
2018-08-15 16:31:28 +02:00
6f491b398a
Always show compilation errors
All checks were successful
The build was successful.
2018-08-15 16:01:09 +02:00
8e87989719
A;ways show compilation errors from evaluated code
All checks were successful
The build was successful.
2018-08-15 15:41:53 +02:00
052649e677
Trust builtin library.
All checks were successful
The build was successful.
The builtin library should compile successfully. Otherwise, we want to know about it.
2018-08-15 14:12:44 +02:00
0e64c7cc6e
Fix builtin library
All checks were successful
The build was successful.
2018-08-15 14:08:59 +02:00
ece036b214
Rework the entry point
All checks were successful
The build was successful.
* some functions were not used and have been removed
 * some parameters seemed to be useless and have been removed
 * code cleanup
2018-08-14 13:45:27 +02:00
7e3c79d3c5
Functions naming cleanup
All checks were successful
The build was successful.
2018-08-13 20:16:37 +02:00
029dd9bfb4
Several changes made:
All checks were successful
The build was successful.
* Do not overload entry point
 * Automatically call Program::__construct()
 * Automatically call Program::main();
 * Fix all tests
2018-08-12 12:52:35 +02:00
8cbfca2bc9
Do not overload entry point
All checks were successful
The build was successful.
2018-08-12 12:27:15 +02:00
3252f54615 Temporarily look for modules in binary/ subdirectory. This will allow us to test modules.
All checks were successful
The build was successful.
Final version should take the full path from configuration.
2018-08-10 08:47:42 +02:00
8936f6529f
Remove duplicate
All checks were successful
The build was successful.
2018-08-09 21:32:00 +02:00
94b29fa238
Remove duplicates
All checks were successful
The build was successful.
2018-08-09 21:27:24 +02:00
8f7fc71027
Consider a method with compiled default value associated as a candidate to call. Fixes #37.
All checks were successful
The build was successful.
2018-08-08 09:00:24 +02:00
e15166d940
Temporary fix for master branch
All checks were successful
The build was successful.
2018-08-08 06:52:15 +02:00
bca4d1a2fa
Always select an appropriate function to call
Some checks reported errors
The build has failed.
It does not matter, if we call function, anonymouss function or method. It is important to select appropriate function to call everytime. Otherwise, if function or method is not overloaded it will call it regardless the number
and type of parameters it takes.
type
2018-08-07 19:48:12 +02:00
34dd052f74
quick typo fix
All checks were successful
The build was successful.
2018-08-07 19:45:34 +02:00
370465fe79
We should use %z to match (SyString *) length and to not display trash.
All checks were successful
The build was successful.
2018-08-07 19:02:28 +02:00
a0fb911d7a Fix #36, unrolling through the frames needed to also reset to the initial frame after 2018-08-07 13:55:13 +00:00
cdc58f2795
Cleanup after 2c37807370 - get rid of global keyword, #29.
All checks were successful
The build was successful.
2018-08-07 12:27:21 +02:00
a4e6962a67
Free dot operator for further usage
All checks were successful
The build was successful.
2018-08-07 08:13:44 +02:00
e4ab5974fa
Let the compiler use OP_ADD instead of OP_CAT
All checks were successful
The build was successful.
2018-08-07 07:47:25 +02:00
9a56751879
Allow addition operator (+) to concatenate strings.
All checks were successful
The build was successful.
2018-08-07 06:54:44 +02:00
4bbdc20174
This commit contains several changes:
All checks were successful
The build was successful.
* print() is now treated as standard function
 * get rid of echo() function
 * fix test suite
and it fixes #26.
2018-08-06 17:18:27 +02:00
7b3e6c5b76
P# introduces virtual classes and virtual methods 2018-07-30 17:08:25 +02:00
159cd76020
No need to duplicate exit() 2018-07-28 22:48:32 +02:00
ef2ea60a60
Treat whole file as P# source code. Fixes #24. 2018-07-28 18:28:19 +02:00
bdf053a205
Implement a fix also for interface. This commit also adds initial and partial support for multiple inheritance. 2018-07-27 23:28:34 +02:00
caf9126f0b
Several changes:
* small code cleanup
 * implement new structure for storing information about class inheritance
 * implement PH7_NewClassInfo()
 * make a use of smaller ph7_class_info instead of ph7_class, to reduce memory usage
2018-07-27 21:05:54 +02:00
e47eef7d97
Fix error reporting 2018-07-27 20:01:45 +02:00
33ab488ace
Removing a debug printf calls and improve error handling. 2018-07-27 18:52:32 +02:00
9e885b3196
Generally speaking ... this is working.
This commit partially fixes #5, however it still needs some work. TODO:
 * remove debugging printf calls,
 * some tuning, to consume less memory,
 * implement similar solution for interfaces
2018-07-27 17:42:12 +02:00
af2c23d3b2
Add some basic checks. At this point, I can say it detects correctly a class declared inside inclueded file. 2018-07-27 17:01:58 +02:00
e70a89fcdb
This is useless. 2018-07-27 08:28:57 +02:00
b040886b97
Test and temporary version of compiler emiting PH7_OP_CLASS_INIT instruction.
However it works on ph7_class and thus passes whole class into the VM, what causes memory overhead,
as finally we have to find this class on the VM's stack. Instead, we could pass some ph7_class_info
structure containing a name of class to look for and information about its inheritances.
2018-07-27 08:24:53 +02:00
09451f4042
Two changes come here:
* do not allow two or more classes / interfaces with the same name
 * fix class_exists() builtin function so that it does not return true if interface is found
2018-07-25 19:00:49 +02:00
63b0f450d3
Move VM initialization into separate step to enable errors reporting earlier. 2018-07-25 18:15:40 +02:00
7bf76c3fa0 Make reported errors more PHP-like 2018-07-25 18:11:53 +02:00
11b4c95c6f
Remove useless duplicated debug functions, they returned some trash information (nothing we don't get via debug_backtrace). 2018-07-24 08:48:10 +02:00
52d9616503
Revert d937d0c825 2018-07-23 19:39:21 +02:00
c28e0dbc88
There are problably still a lot of typos, here and there. 2018-07-23 17:10:48 +02:00
38186c3fda
Correct error messages 2018-07-23 15:23:18 +02:00
17c486d599
Make reported errors more PHP-like 2018-07-23 15:20:46 +02:00
d937d0c825 Merge branch 'fix_file_dir' of PSharp/psharp into master 2018-07-23 07:50:12 +02:00