2016-12-09 12:20:48 +01:00
|
|
|
class String
|
2018-04-16 20:24:27 +02:00
|
|
|
def camelise
|
2018-04-06 19:54:27 +02:00
|
|
|
self.split("_").collect{|str| str.capitalize_first }.join
|
|
|
|
end
|
|
|
|
def capitalize_first
|
|
|
|
self[0].capitalize + self[1..-1]
|
|
|
|
end
|
|
|
|
end
|
2018-04-17 19:26:15 +02:00
|
|
|
class Class
|
|
|
|
def short_name
|
|
|
|
self.name.split("::").last
|
|
|
|
end
|
|
|
|
end
|
2016-12-09 12:20:48 +01:00
|
|
|
|
2018-08-24 17:49:44 +02:00
|
|
|
# The Risc Machine, is an abstract machine with registers. Think of it as an arm machine with
|
2018-03-26 13:15:48 +02:00
|
|
|
# normal instruction names. It is not however an abstraction of existing hardware, but only
|
|
|
|
# of that subset that we need.
|
|
|
|
# See risc/Readme
|
|
|
|
module Risc
|
2018-09-02 12:57:19 +02:00
|
|
|
# module method to reset, and init
|
|
|
|
def self.boot!
|
|
|
|
Position.clear_positions
|
|
|
|
Builtin.boot_functions
|
|
|
|
end
|
2018-03-26 13:15:48 +02:00
|
|
|
end
|
|
|
|
|
2018-03-13 12:27:24 +01:00
|
|
|
require_relative "risc/padding"
|
2018-05-31 18:01:10 +02:00
|
|
|
require_relative "risc/position/position"
|
2018-05-12 17:32:10 +02:00
|
|
|
require_relative "risc/platform"
|
2018-07-01 12:45:14 +02:00
|
|
|
require_relative "risc/parfait_boot"
|
2018-08-11 18:17:20 +02:00
|
|
|
require_relative "risc/parfait_adapter"
|
|
|
|
require "parfait"
|
2018-07-01 12:45:14 +02:00
|
|
|
require_relative "risc/linker"
|
2018-07-10 21:02:11 +02:00
|
|
|
require_relative "risc/callable_compiler"
|
2018-06-30 22:26:28 +02:00
|
|
|
require_relative "risc/method_compiler"
|
2018-07-09 15:48:23 +02:00
|
|
|
require_relative "risc/block_compiler"
|
2018-07-01 10:53:18 +02:00
|
|
|
require_relative "risc/assembler"
|
2015-10-22 17:16:29 +02:00
|
|
|
|
|
|
|
class Fixnum
|
|
|
|
def fits_u8?
|
|
|
|
self >= 0 and self <= 255
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-12-09 12:20:48 +01:00
|
|
|
|
2018-03-13 12:27:24 +01:00
|
|
|
require_relative "risc/instruction"
|
2018-06-29 10:39:07 +02:00
|
|
|
require_relative "risc/register_value"
|
2018-03-29 17:17:19 +02:00
|
|
|
require_relative "risc/text_writer"
|
2018-06-29 10:23:26 +02:00
|
|
|
require_relative "risc/builtin"
|
2018-04-06 13:21:38 +02:00
|
|
|
require_relative "risc/builder"
|