Commit Graph

2254 Commits

Author SHA1 Message Date
f1cfd3c379 change calling convention
Message carries arrays for arguments and locals
This means an extra load for any access
Also fix silly bug: using the wrong method (the one we’re in, not the
one we’re calling)
2016-12-27 20:37:53 +02:00
3c3dedadd1 remove indexed_length from NamedList 2016-12-27 20:34:47 +02:00
aaa94f0743 small fixes 2016-12-27 20:34:11 +02:00
a5946cb644 same renames for bytes (set/get_byte) 2016-12-25 18:11:58 +02:00
f648bf7bd5 rename also get_slot, to slot_to_reg
makes source and target clear
2016-12-25 18:05:39 +02:00
35adf9a5e6 rename set_slot
set_slot was clear about the target, but not the source.
Better with reg_to_slot (and soon it’s inverse slot_to_reg)
2016-12-25 18:02:39 +02:00
1b8d6149dd adding to_s to code for debugging 2016-12-23 21:31:31 +02:00
6c9bd7e476 remove unused code
also just came through opal
2016-12-22 21:16:56 +02:00
3b888b203d crude rework of the hashing to work in opal 2016-12-22 21:16:36 +02:00
2adec3226c opal gods require explicit requires 2016-12-22 21:15:20 +02:00
c3c52d36b8 seperate args from message (just like frame) 2016-12-21 22:35:36 +02:00
ed12108425 rename locals from type to role in message 2016-12-21 19:01:42 +02:00
0e99ff33ae use frame type rather than the indexed construct 2016-12-21 18:59:07 +02:00
93ba5543b3 more renaming of frame 2016-12-21 18:51:22 +02:00
0040baae28 rename frame to named_list to be shared soon 2016-12-21 18:45:18 +02:00
b242f9e223 bringing the locals into the ruby method 2016-12-21 11:30:35 +02:00
9ec9ccb9b6 start on collector for local variables 2016-12-21 11:20:36 +02:00
8b05951883 extracting processor comonality before adding a third 2016-12-21 10:51:33 +02:00
8507bef08b extracting methods for the compiler to handle 2016-12-20 20:02:52 +02:00
a70d20d63e add a ruby method
including source ast and args, later locals
2016-12-20 20:02:20 +02:00
9e89306733 rename to get guard matches 2016-12-20 20:01:28 +02:00
aa6685a0cb test collector for ivar assignment 2016-12-20 15:46:23 +02:00
aa5f48e3c6 remove instance_names from class again
and use types names instead. For now assuming Object class
2016-12-19 14:20:47 +02:00
af9fed863f small rename 2016-12-19 14:16:10 +02:00
107e3e6d58 pick up instance variables from the class
Crude first set to creating types
2016-12-18 20:05:11 +02:00
e77298f4b1 Give the class a list of ivars
Which is redundant with the type’s names, so let’s see
2016-12-18 20:04:40 +02:00
af9987659f create and test derived classes too 2016-12-18 17:17:58 +02:00
170d453a36 start with melon and tests
First step, create a basic class
2016-12-18 17:02:55 +02:00
756cb52a98 renames compiler to method_compiler 2016-12-18 14:15:19 +02:00
272f99daf7 the cop struck again 2016-12-17 20:09:17 +02:00
48af14f5c9 removes class statements
classes have to be created in melon, a level up
2016-12-17 18:31:26 +02:00
ffb69a2c55 remove function statements
functions need to be defined a level up
2016-12-17 18:28:42 +02:00
8845b91529 remove FieldDef
and on_field_def , :field_def and fixed all related tests
local variables will have to be determined outside the typed layer
2016-12-17 13:12:49 +02:00
c12f11fba5 try both ree and cop 2016-12-17 09:44:21 +02:00
782627ae79 small rename
to avoid confusion with type.create_method
2016-12-17 00:21:12 +02:00
5c34835ae3 type converts method args if needed 2016-12-17 00:17:54 +02:00
681b53cc4c make compiler default to compiling Space.main 2016-12-17 00:17:35 +02:00
f8cefcde3c retiring ClassField and class_field from typed layer
Creating classes is the responsibility of melon
2016-12-16 19:05:49 +02:00
dd6dede6ef refactor object file somewhat 2016-12-16 16:18:14 +02:00
e10fc3eedd some reek assited coding on assembler 2016-12-16 15:41:26 +02:00
5cd05f6135 refactor memory instruction (needs better tests) 2016-12-16 15:40:52 +02:00
190a0ffa47 adds set_byte interpreter test 2016-12-16 01:43:54 +02:00
b2579a2b82 dead code removal 2016-12-16 01:31:38 +02:00
6f9955a726 more auto guard rules
and related renaming of files
2016-12-16 01:14:09 +02:00
516bbd10b7 little fat of meta class
meta is firmly in the ruby world, not implemented in type world
2016-12-16 00:57:10 +02:00
f7e01ff05e remove the value class
more of an idea, had no impact on implementation
2016-12-16 00:56:25 +02:00
fd519314cb strip down compare instruction
not really used, using conditional branches instead.
(in arm any instruction can execute conditionally)
2016-12-16 00:41:37 +02:00
ed0900df7f extracting to_s from getter and setter 2016-12-16 00:30:26 +02:00
bc22c40101 Get Byte interpreter test 2016-12-15 22:15:58 +02:00
886220d388 remove unused variable class 2016-12-15 19:43:53 +02:00