Commit Graph

426 Commits

Author SHA1 Message Date
03cf969c31
Check for a type of array.
All checks were successful
The build was successful.
2018-10-11 15:15:48 +02:00
b66515516e
First check if array or object.
All checks were successful
The build was successful.
2018-10-01 22:46:35 +02:00
6293b8f5bf
Do not try to dump empty array.
All checks were successful
The build was successful.
2018-10-01 22:43:23 +02:00
c00080e190
Correct comment.
All checks were successful
The build was successful.
2018-09-24 19:20:23 +02:00
b5eb268ce1
Do not allow to set a value of different type to the variable.
All checks were successful
The build was successful.
2018-09-24 19:17:46 +02:00
5f2f9d9c08
Set proper data type for static variables;
All checks were successful
The build was successful.
2018-09-24 19:16:44 +02:00
6e7bc74949
Put comment in right place.
All checks were successful
The build was successful.
2018-09-24 13:39:50 +02:00
f26095658d
Treat empty object as false.
All checks were successful
The build was successful.
2018-09-24 13:38:33 +02:00
2db1954779
Another bunch of fixes for object type.
All checks were successful
The build was successful.
2018-09-24 13:34:22 +02:00
550107235c
Do not try to dump a non-instantiated object.
All checks were successful
The build was successful.
2018-09-24 12:22:58 +02:00
369cadfcda
Tryeing to call a non-instantiated object should result in an error.
All checks were successful
The build was successful.
2018-09-24 12:10:19 +02:00
f72d6c3922
Load data from array/object only if there is anything stored.
All checks were successful
The build was successful.
2018-09-24 11:47:30 +02:00
59fda6d797
Unref hashmap and object only if there is any data stored.
All checks were successful
The build was successful.
2018-09-24 11:29:51 +02:00
dd774be005
Fix for() loop, do not use iP1 for OP_LOAD.
Some checks reported errors
The build has failed.
2018-09-23 17:51:09 +02:00
ae0fde152c
Create a variable only on OP_LOAD.
Some checks reported errors
The build has failed.
2018-09-23 17:40:26 +02:00
28a5fa59ad
Duplicate variable name. Fix variable declaration.
All checks were successful
The build was successful.
2018-09-22 17:54:59 +02:00
514e07c7f3
Fix static variables not containing any value.
All checks were successful
The build was successful.
2018-09-21 22:18:11 +02:00
f927667d85
Strictly check for data type of static variable declaration.
Some checks reported errors
The build has failed.
2018-09-21 22:06:36 +02:00
79e4bac7eb
Remove no longer used PH7_CompileStatic().
All checks were successful
The build was successful.
2018-09-21 00:22:29 +02:00
bd4d146d0a
Initial version of variable definition.
All checks were successful
The build was successful.
2018-09-21 00:21:15 +02:00
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
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
383fe01943
Reserve 10KB for error reporting.
All checks were successful
The build was successful.
2018-09-01 17:54:45 +02:00
8fcb3c608a
Remove duplicate of SySetUsed() macro.
All checks were successful
The build was successful.
2018-08-31 23:45:46 +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
fbc725c935
We are tokenizing Aer.
All checks were successful
The build was successful.
2018-08-30 12:33:38 +02:00
041c65d63e
Implement SySetGetUsed();
All checks were successful
The build was successful.
2018-08-30 12:00:02 +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
877d19a815
API function rename.
All checks were successful
The build was successful.
2018-08-26 18:30:21 +02:00
94b213674a
Change the script located in memory indicator.
All checks were successful
The build was successful.
For easier reading with line numbers.
2018-08-23 18:27:14 +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
0ff32e6673
Remove duplicated constants.
All checks were successful
The build was successful.
2018-08-22 11:24:34 +02:00
dbe373d537
Resolve __CLASS__ at compile time.
All checks were successful
The build was successful.
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
3e18a5b8e8
Optimize the code, #45.
All checks were successful
The build was successful.
2018-08-22 08:51:45 +02:00
a0f7949b24
Resolve __DIR__ at compile time.
All checks were successful
The build was successful.
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
02242bb93d
Resolve __FILE__ at compile time.
All checks were successful
The build was successful.
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
19a504fe11
Enter the class block during compilation, #45.
All checks were successful
The build was successful.
2018-08-21 19:45:50 +02:00
2d99881240
Get rid of manual optimisation technique.
All checks were successful
The build was successful.
This optimisation technique results in non insignificant speed boost on some old x86 architectures. Novadays, we should rely on compiler optimisation.
2018-08-21 06:27:07 +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
00dc23ee4a Get rid of manual optimisation technique resulting in non insignificant speed boost on some old x86 architectures, #38;
All checks were successful
The build was successful.
2018-08-18 19:44:02 +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
08c47b7528
Correct dictionary issues.
All checks were successful
The build was successful.
2018-08-17 09:25:29 +02:00
ab1266ef5d
Rename VFS
All checks were successful
The build was successful.
2018-08-16 22:05:30 +02:00
c83d6e13fc
Removing xExec.
All checks were successful
The build was successful.
First of all, VFS is not a right place for this, finally it was not implemented anyway.
2018-08-16 21:37:34 +02:00
a8a88b4746
Compile closures.
All checks were successful
The build was successful.
2018-08-16 18:40:23 +02:00
f28c671e69
Compile closures.
All checks were successful
The build was successful.
2018-08-16 18:31:12 +02:00
074edd11d3
Add Windows 10 information
All checks were successful
The build was successful.
2018-08-16 18:19:33 +02:00
a8961eb36f
Fix build
All checks were successful
The build was successful.
2018-08-16 17:48:17 +02:00
2c28b63d90
Properly interpret language constructs, fixes #28.
Some checks reported errors
The build has failed.
2018-08-16 17:42:30 +02:00
9100bf0696
Treat 'import' as a special keyword.
All checks were successful
The build was successful.
2018-08-16 16:32:28 +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
510410096b
Aer is OOP language. There is nothing like function.
All checks were successful
The build was successful.
2018-08-16 13:57:35 +02:00
4961922b1d
Unify error with other related to namespace.
All checks were successful
The build was successful.
2018-08-16 13:36:19 +02:00
793b6127d5
Temporarily fix namespace support.
All checks were successful
The build was successful.
The namespace feature is not supported in this version, they are treated same way as global scope.
2018-08-16 12:39:05 +02:00
787f3b5d5f
Synchronize the namespace also with first semicolon.
All checks were successful
The build was successful.
2018-08-16 12:01:36 +02:00
be27532fdf
Unify error level for namespace support.
All checks were successful
The build was successful.
2018-08-16 11:26:47 +02:00
e208e778e0
Compile global scope independently, fixes #40.
All checks were successful
The build was successful.
2018-08-16 11:15:03 +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
f9946e9842
Reimplement filegroup() and fileowner() as builtin function, #42.
All checks were successful
The build was successful.
2018-08-15 21:58:21 +02:00
f33f8d66b4
Correct warning messages.
All checks were successful
The build was successful.
2018-08-15 21:43:17 +02:00
16ea44372f
Dictionary correction.
All checks were successful
The build was successful.
2018-08-15 21:35:44 +02:00
ac1dee48c9
Reimplement fileinode() as builtin function, #42.
All checks were successful
The build was successful.
2018-08-15 21:28:59 +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
89d7aca73a
Correct typo
All checks were successful
The build was successful.
2018-08-15 16:38:33 +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
64b9ac4406
Forward declaration already in compiler.h
All checks were successful
The build was successful.
2018-08-15 11:18:40 +02:00
be454ff7be
Rename PH7_COMPILE_SINGLE_STMT to PH7_COMPILE_STATEMENT
All checks were successful
The build was successful.
2018-08-14 23:48:15 +02:00
26b1675021
API function rename
All checks were successful
The build was successful.
2018-08-14 17:43:43 +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
02fde9c30f
It is not PHP compiler
All checks were successful
The build was successful.
2018-08-13 19:53:08 +02:00
d7f9d8e157
Add missing 'finally' keyword.
All checks were successful
The build was successful.
2018-08-12 22:04:47 +02:00
aa6e00db27
Forward declaration for all functions.
All checks were successful
The build was successful.
2018-08-12 21:58:27 +02:00
59c15caf4e
Use something more human readable
All checks were successful
The build was successful.
2018-08-12 21:16:05 +02:00
6b7591a137
Move common part to compiler.h
All checks were successful
The build was successful.
2018-08-12 21:11:13 +02:00
289af8f9ae
Unify compiler's function naming convenction
All checks were successful
The build was successful.
2018-08-12 20:58:01 +02:00
5ef5cf3e46
Make errors more readable.
All checks were successful
The build was successful.
2018-08-12 19:36:17 +02:00
429c28d0cc
Rework error lovels for AerScript.
All checks were successful
The build was successful.
2018-08-12 19:35:43 +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
c39e627aef
Remove the backtick quoted string.
All checks were successful
The build was successful.
2018-08-12 11:08:09 +02:00
cef0f40820
Compile namespace
All checks were successful
The build was successful.
2018-08-12 11:06:01 +02:00
c298a41eb7
More verbose error messages
All checks were successful
The build was successful.
2018-08-12 10:30:44 +02:00
e866575cb5
More verbose errors
All checks were successful
The build was successful.
2018-08-12 10:18:42 +02:00
c759b1f106
Improove error reporting for method declarations
All checks were successful
The build was successful.
2018-08-12 09:23:21 +02:00
b61fc9d3e6
Rename function to save it from typo
All checks were successful
The build was successful.
2018-08-11 23:21:40 +02:00
576edc6c20
Several changes to virtual class/method. Fixes #41
All checks were successful
The build was successful.
* do not automatically mark class as virtual when at least one virtual method found
 * force non-virtual method to contain body
 * force non-virtual class to implement all methods
2018-08-11 22:50:05 +02:00
3f46f01805
Rename anonymous functions
All checks were successful
The build was successful.
2018-08-11 21:40:05 +02:00
0d8391eaaa
Correct typos
All checks were successful
The build was successful.
2018-08-11 21:22:04 +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
fc4b17434e
Remove duplicated builtin functions
All checks were successful
The build was successful.
2018-08-09 21:34:13 +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