From f74621876535d80634ecbb734c9aa37b460ebdeb Mon Sep 17 00:00:00 2001 From: Torsten Ruger Date: Sun, 8 Nov 2015 23:58:35 +0200 Subject: [PATCH] reinstate word creation and use for strings so string constants become words, so we can fiddle with them --- lib/register/parfait_adapter.rb | 16 +++++++++++++--- lib/soml/compiler/basic_values.rb | 2 +- test/helper.rb | 11 ----------- 3 files changed, 14 insertions(+), 15 deletions(-) diff --git a/lib/register/parfait_adapter.rb b/lib/register/parfait_adapter.rb index 9fa05029..e38e3c9e 100644 --- a/lib/register/parfait_adapter.rb +++ b/lib/register/parfait_adapter.rb @@ -15,6 +15,15 @@ module Register end list end + # Functions to generate parfait objects + def self.new_word( string ) + string = string.to_s if string.is_a? Symbol + word = Parfait::Word.new( string.length ) + string.codepoints.each_with_index do |code , index | + word.set_char(index + 1 , code) + end + word + end end class Symbol include Positioned @@ -61,8 +70,8 @@ end module Parfait # Objects memory functions. Object memory is 1 based - # but we implement it with ruby array (0 based) and use 0 as type-word - # These are the same functions that Builtin implements at run-time + # but we implement it with ruby array (0 based) and don't use 0 + # These are the same functions that Builtin implements for run-time class Object include Padding include Positioned @@ -80,6 +89,7 @@ module Parfait # 1 -based index def set_internal(index , value) raise "failed init for #{self.class}" unless @memory + raise "Word[#{index}] = " if((self.class == Parfait::Word) and value.nil? ) @memory[index] = value value end @@ -122,7 +132,7 @@ module Parfait def to_string string = "" index = 1 - while( index <= self.length) + while( index <= self.char_length) string[index - 1] = get_char(index).chr index = index + 1 end diff --git a/lib/soml/compiler/basic_values.rb b/lib/soml/compiler/basic_values.rb index 3d5a3750..f138234e 100644 --- a/lib/soml/compiler/basic_values.rb +++ b/lib/soml/compiler/basic_values.rb @@ -36,7 +36,7 @@ module Soml end def on_string expression - value = expression.first.to_sym + value = Register.new_word expression.first.to_sym reg = use_reg :Word Register.machine.constants << value add_code Register::LoadConstant.new( expression, value , reg ) diff --git a/test/helper.rb b/test/helper.rb index 78514bd7..53028bcf 100644 --- a/test/helper.rb +++ b/test/helper.rb @@ -19,17 +19,6 @@ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'test')) require 'salama' -module Register - # Functions to generate parfait objects - def self.new_word( string ) - string = string.to_s if string.is_a? Symbol - word = Parfait::Word.new( string.length ) - string.codepoints.each_with_index do |code , index | - word.set_char(index + 1 , code) - end - word - end -end class Ignored def == other