02242bb93d
Resolve __FILE__ at compile time. Ticket: #45: __FILE__ constant must be resolved at compile time, not run time. Otherwise it returns incorrect data.belliash2018-08-21 20:18:39 +02:00
19a504fe11
Enter the class block during compilation, #45.belliash2018-08-21 19:45:50 +02:00
33523e4e8a
Block definitions for class and namespace.belliash2018-08-21 19:35:00 +02:00
2d99881240
Get rid of manual optimisation technique. This optimisation technique results in non insignificant speed boost on some old x86 architectures. Novadays, we should rely on compiler optimisation.belliash2018-08-21 06:27:07 +02:00
2160747479
Make get_included_files() returning full path.belliash2018-08-18 21:02:23 +02:00
cbb4a0aa5c
get_included_files() should return a list of included, files.belliash2018-08-18 20:42:54 +02:00
00dc23ee4aGet rid of manual optimisation technique resulting in non insignificant speed boost on some old x86 architectures, #38;belliash2018-08-18 19:43:00 +02:00
4dbd3ea412
New memory subsystem. 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.belliash2018-08-18 19:24:38 +02:00
2c28b63d90
Properly interpret language constructs, fixes#28.belliash2018-08-16 17:42:30 +02:00
9100bf0696
Treat 'import' as a special keyword.belliash2018-08-16 16:32:28 +02:00
b5fe36c14b
There is no need for include_once() and require_once() 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.belliash2018-08-16 16:12:29 +02:00
510410096b
Aer is OOP language. There is nothing like function.belliash2018-08-16 13:57:35 +02:00
4961922b1d
Unify error with other related to namespace.belliash2018-08-16 13:36:19 +02:00
793b6127d5
Temporarily fix namespace support. The namespace feature is not supported in this version, they are treated same way as global scope.belliash2018-08-16 12:39:05 +02:00
787f3b5d5f
Synchronize the namespace also with first semicolon.belliash2018-08-16 12:01:36 +02:00
be27532fdf
Unify error level for namespace support.belliash2018-08-16 11:26:47 +02:00
e208e778e0
Compile global scope independently, fixes#40.belliash2018-08-16 11:15:03 +02:00
039fde099f
Compile Aer code or chunk of code.belliash2018-08-16 09:34:18 +02:00
f9946e9842
Reimplement filegroup() and fileowner() as builtin function, #42.belliash2018-08-15 21:58:21 +02:00
7c7a837efb
Correct another bunch of typos.belliash2018-08-15 19:06:00 +02:00
71d46e3052
Compiler rework does not allow functions in global scope. These functions will be rewritten in C as a builtin functions in scope of #42.belliash2018-08-15 18:56:10 +02:00
af139b3f0a
Reimplement C-like min() and max() functions. 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.belliash2018-08-15 17:26:26 +02:00
8e87989719
A;ways show compilation errors from evaluated codebelliash2018-08-15 15:41:53 +02:00
052649e677
Trust builtin library. The builtin library should compile successfully. Otherwise, we want to know about it.belliash2018-08-15 14:12:44 +02:00
ece036b214
Rework the entry point * some functions were not used and have been removed * some parameters seemed to be useless and have been removed * code cleanupbelliash2018-08-14 13:45:27 +02:00
429c28d0cc
Rework error lovels for AerScript.belliash2018-08-12 19:35:43 +02:00
029dd9bfb4
Several changes made: * Do not overload entry point * Automatically call Program::__construct() * Automatically call Program::main(); * Fix all testsbelliash2018-08-12 12:52:35 +02:00
c759b1f106
Improove error reporting for method declarationsbelliash2018-08-12 09:23:21 +02:00
b61fc9d3e6
Rename function to save it from typobelliash2018-08-11 23:21:40 +02:00
576edc6c20
Several changes to virtual class/method. Fixes#41 * 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 methodsbelliash2018-08-11 22:50:05 +02:00
3252f54615Temporarily look for modules in binary/ subdirectory. This will allow us to test modules. Final version should take the full path from configuration.belliash2018-08-10 08:47:42 +02:00
8f7fc71027
Consider a method with compiled default value associated as a candidate to call. Fixes#37.belliash2018-08-08 09:00:24 +02:00
e15166d940
Temporary fix for master branchbelliash2018-08-08 06:52:15 +02:00
bca4d1a2fa
Always select an appropriate function to call 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. typebelliash2018-08-07 19:48:12 +02:00
a4e6962a67
Free dot operator for further usagebelliash2018-08-07 08:13:44 +02:00
6f0d1ab3ff
Tests should use new string concatenation operatorbelliash2018-08-07 07:53:26 +02:00
e4ab5974fa
Let the compiler use OP_ADD instead of OP_CATbelliash2018-08-07 07:47:25 +02:00
9a56751879
Allow addition operator (+) to concatenate strings.belliash2018-08-07 06:54:44 +02:00
3a994221ce
Add another chapter to the readmebelliash2018-08-06 19:28:03 +02:00
4bbdc20174
This commit contains several changes: * print() is now treated as standard function * get rid of echo() function * fix test suite and it fixes#26.belliash2018-08-06 17:18:27 +02:00
bcde1f446dIt does not matter if it is empty string or not, we want to process it. Empty string should not ever been even considered as a NULL. Fixing #35.
Piotr Likoski
2018-08-06 16:13:49 +02:00
a8259e7dbcEmpty double-quoted string can be served as single-quoted string. Preparing for further changes in scope of #35.
Piotr Likoski
2018-08-06 16:03:22 +02:00
dd239530d8
Test if unicode characters can be used as method / variable namebelliash2018-08-06 08:23:51 +02:00
ff6a7012a4
Another test, converting arab numbers to romanbelliash2018-08-05 22:25:15 +02:00