making parfait (both) use the new byte functions
This commit is contained in:
parent
dffa3fbf42
commit
ac5a7ac4ca
@ -119,6 +119,8 @@ end
|
|||||||
|
|
||||||
require_relative "instructions/set_slot"
|
require_relative "instructions/set_slot"
|
||||||
require_relative "instructions/get_slot"
|
require_relative "instructions/get_slot"
|
||||||
|
require_relative "instructions/set_byte"
|
||||||
|
require_relative "instructions/get_byte"
|
||||||
require_relative "instructions/load_constant"
|
require_relative "instructions/load_constant"
|
||||||
require_relative "instructions/syscall"
|
require_relative "instructions/syscall"
|
||||||
require_relative "instructions/function_call"
|
require_relative "instructions/function_call"
|
||||||
|
@ -20,7 +20,7 @@ module Parfait
|
|||||||
2 # 2 is the amount of attributes, layout and char_length. the offset after which chars start
|
2 # 2 is the amount of attributes, layout and char_length. the offset after which chars start
|
||||||
end
|
end
|
||||||
def self.get_indexed i
|
def self.get_indexed i
|
||||||
i + get_length_index
|
i + get_length_index * 4
|
||||||
end
|
end
|
||||||
# initialize with length. For now we try to keep all non-parfait (including String) out
|
# initialize with length. For now we try to keep all non-parfait (including String) out
|
||||||
# String will contain spaces for non-zero length
|
# String will contain spaces for non-zero length
|
||||||
@ -89,7 +89,11 @@ module Parfait
|
|||||||
def set_char at , char
|
def set_char at , char
|
||||||
raise "char not fixnum #{char.class}" unless char.kind_of? Fixnum
|
raise "char not fixnum #{char.class}" unless char.kind_of? Fixnum
|
||||||
index = range_correct_index(at)
|
index = range_correct_index(at)
|
||||||
word_index = (index - 1) / 4 + 1 + Word.get_length_index
|
set_internal_byte( index , char)
|
||||||
|
end
|
||||||
|
|
||||||
|
def set_internal_byte index , char
|
||||||
|
word_index = (index - 1) / 4 + 1
|
||||||
rest = ((index - 1) % 4)
|
rest = ((index - 1) % 4)
|
||||||
shifted = char << (rest * 8)
|
shifted = char << (rest * 8)
|
||||||
was = get_internal_word( word_index )
|
was = get_internal_word( word_index )
|
||||||
@ -112,7 +116,12 @@ module Parfait
|
|||||||
#the return "character" is an integer
|
#the return "character" is an integer
|
||||||
def get_char at
|
def get_char at
|
||||||
index = range_correct_index(at)
|
index = range_correct_index(at)
|
||||||
word_index = (index - 1 ) / 4 + 1 + Word.get_length_index
|
get_internal_byte(index)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
def get_internal_byte( index )
|
||||||
|
word_index = (index - 1 ) / 4 + 1
|
||||||
rest = ((index - 1) % 4)
|
rest = ((index - 1) % 4)
|
||||||
char = get_internal_word(word_index)
|
char = get_internal_word(word_index)
|
||||||
char = 0 unless char.is_a?(Numeric)
|
char = 0 unless char.is_a?(Numeric)
|
||||||
@ -130,7 +139,7 @@ module Parfait
|
|||||||
index = self.length + at if at < 0
|
index = self.length + at if at < 0
|
||||||
raise "index must be positive , not #{at}" if (index <= 0)
|
raise "index must be positive , not #{at}" if (index <= 0)
|
||||||
raise "index too large #{at} > #{self.length}" if (index > self.length )
|
raise "index too large #{at} > #{self.length}" if (index > self.length )
|
||||||
return index
|
return index + Word.get_length_index * 4
|
||||||
end
|
end
|
||||||
|
|
||||||
# compare the word to another
|
# compare the word to another
|
||||||
@ -182,7 +191,7 @@ module Parfait
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Word from string
|
# Word from string
|
||||||
def self.new_word( string )
|
def self.new_word( string )
|
||||||
string = string.to_s if string.is_a? Symbol
|
string = string.to_s if string.is_a? Symbol
|
||||||
word = Parfait::Word.new( string.length )
|
word = Parfait::Word.new( string.length )
|
||||||
|
@ -1,16 +1,12 @@
|
|||||||
class Word < Object
|
class Word < Object
|
||||||
|
|
||||||
|
int correct_index(int index)
|
||||||
|
return index + 8
|
||||||
|
end
|
||||||
|
|
||||||
int char_at(int index)
|
int char_at(int index)
|
||||||
int word_index = index - 1
|
index = correct_index(index)
|
||||||
word_index = word_index >> 2
|
return get_internal_byte(index)
|
||||||
word_index = word_index + 3
|
|
||||||
int rest = index - 1
|
|
||||||
rest = rest.mod4()
|
|
||||||
int char = get_internal_word(word_index)
|
|
||||||
int shifted = 8 * rest
|
|
||||||
shifted = char >> shifted
|
|
||||||
int ret = shifted & 255
|
|
||||||
return ret
|
|
||||||
end
|
end
|
||||||
|
|
||||||
int set_length(int i)
|
int set_length(int i)
|
||||||
@ -18,37 +14,16 @@ class Word < Object
|
|||||||
return i
|
return i
|
||||||
end
|
end
|
||||||
|
|
||||||
|
int set_char_at( int index , int val)
|
||||||
|
index = correct_index(index)
|
||||||
|
return set_internal_byte(index , val)
|
||||||
|
end
|
||||||
|
|
||||||
Word push_char(int char)
|
Word push_char(int char)
|
||||||
int index = self.char_length + 1
|
int index = self.char_length + 1
|
||||||
self.set_length(index)
|
self.set_length(index)
|
||||||
|
|
||||||
int word_index = index - 1
|
set_char_at(index , char)
|
||||||
word_index = word_index >> 2
|
|
||||||
word_index = word_index + 3
|
|
||||||
|
|
||||||
int rest = index - 1
|
|
||||||
rest = rest.mod4()
|
|
||||||
|
|
||||||
int shifted = rest * 8
|
|
||||||
shifted = char << shifted
|
|
||||||
|
|
||||||
int was = get_internal_word( word_index )
|
|
||||||
int mask = rest * 8
|
|
||||||
int const = 255 << 8
|
|
||||||
const = const + 255
|
|
||||||
const = const << 8
|
|
||||||
const = const + 255
|
|
||||||
const = const << 8
|
|
||||||
const = const + 255
|
|
||||||
|
|
||||||
mask = 255 << mask
|
|
||||||
mask = const - mask
|
|
||||||
|
|
||||||
int masked = was & mask
|
|
||||||
int put = masked + shifted
|
|
||||||
|
|
||||||
set_internal_word( word_index , put )
|
|
||||||
|
|
||||||
return self
|
return self
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user