remodel assignment a bit

This commit is contained in:
Torsten Ruger 2016-12-09 13:20:48 +02:00
parent 395fd2d701
commit 1e7093c63f
4 changed files with 48 additions and 39 deletions

View File

@ -1,3 +1,10 @@
class String
def camelize
self.split("_").collect( &:capitalize ).join
end
end
require "register/padding"
require "register/positioned"
require "typed/compiler"
@ -11,6 +18,7 @@ class Fixnum
end
end
require "register/instruction"
require "register/register_value"
require "register/assembler"

View File

@ -1,13 +1,14 @@
module Typed
class Assignment < Statement
attr_accessor :name , :value
def initialize(n = nil , v = nil )
@name , @value = n , v
module Tree
class Assignment < Statement
attr_accessor :name , :value
def initialize(n = nil , v = nil )
@name , @value = n , v
end
end
class FieldDef < Statement
attr_accessor :name , :type , :value
end
end
class FieldDef < Statement
attr_accessor :name , :type , :value
end
end

View File

@ -1,8 +1,10 @@
["call_site", "name_expression"].each do |mod|
require_relative "compiler/" + mod
end
module Typed
CompilerModules = ["assignment" , "call_site", "name_expression"]
CompilerModules.each do |mod|
require_relative "compiler/" + mod
end
# Compiling is the conversion of the AST into 2 things:
# - code (ie sequences of Instructions inside Methods)
# - an object graph containing all the Methods, their classes and Constants
@ -41,8 +43,9 @@ module Typed
end
class Compiler
include NameExpression
include CallSite
CompilerModules.each do |mod|
include Typed.const_get( mod.camelize )
end
def initialize( method = nil )
@regs = []
@ -184,7 +187,6 @@ end
require_relative "ast_helper"
require_relative "ast/code"
require_relative "compiler/assignment"
require_relative "compiler/basic_values"
require_relative "compiler/class_field"
require_relative "compiler/class_statement"

View File

@ -1,33 +1,31 @@
module Typed
Compiler.class_eval do
module Assignment
def on_Assignment statement
def on_Assignment( statement )
# name , value = *statement
reset_regs # statements reset registers, ie have all at their disposal
#puts statement.inspect
# name , value = *statement
name_s = no_space statement.name
v = process(statement.value)
raise "Not register #{v}" unless v.is_a?(Register::RegisterValue)
code = nil
if( index = @method.has_arg(name_s.name))
# TODO, check type @method.arguments[index].type
code = Register.set_slot(statement , v , :message , Parfait::Message.get_indexed(index) )
else # or a local so it is in the frame
index = @method.has_local( name_s.name )
if(index)
# TODO, check type @method.locals[index].type
frame = use_reg(:Frame)
add_code Register.get_slot(statement , :message , :frame , frame )
code = Register.set_slot(statement , v , frame , Parfait::Frame.get_indexed(index) )
end
end
if( code )
#puts "addin code #{code}"
add_code code
else
raise "must define variable #{name} before using it in #{@method.inspect}"
end
code = get_code( statement , name_s )
raise "must define variable #{name} before using it in #{@method.inspect}" unless code
add_code code
end
private
def get_code( statement , name_s )
if( index = @method.has_arg(name_s.name))
# TODO, check type @method.arguments[index].type
return Register.set_slot(statement , v , :message , Parfait::Message.get_indexed(index) )
end
# or a local so it is in the frame
index = @method.has_local( name_s.name )
return nil unless index
# TODO, check type @method.locals[index].type
frame = use_reg(:Frame)
add_code Register.get_slot(statement , :message , :frame , frame )
return Register.set_slot(statement , v , frame , Parfait::Frame.get_indexed(index) )
end
end
end