2021-04-12 18:53:35 +01:00
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
-- the Berry's bytecode file structure (version 1)
|
|
|
|
--
|
|
|
|
-- description
|
|
|
|
--
|
|
|
|
-- a double dash ('--') start a line comment.
|
2021-08-24 21:44:33 +01:00
|
|
|
-- a: b means that the entity 'a' is realized by the 'b' structure.
|
|
|
|
-- a: b c 'b' and 'c' are arranged in a compact order (one byte alignment).
|
2021-04-12 18:53:35 +01:00
|
|
|
-- [a] means that structure 'a' can be repeated 0 to any times.
|
|
|
|
-- [a](b) means that structure 'a' can be repeated 'b' times.
|
|
|
|
-- a | b means that the entity can be implemented by structure 'a' or 'b'.
|
2021-08-24 21:44:33 +01:00
|
|
|
-- N a number indicates the byte count of the field (eg. 'a: 1').
|
|
|
|
-- .N means the number of bits in the field (eg. 'a: .1').
|
2021-04-12 18:53:35 +01:00
|
|
|
-- only the first entity is a file entity (the root).
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
bytecode_file: -- little endian
|
|
|
|
header
|
|
|
|
global_desc
|
|
|
|
main_function
|
|
|
|
|
|
|
|
header: 8
|
|
|
|
magic_number: 3 -- 0xbecdfe (berry code file)
|
2021-08-24 21:44:33 +01:00
|
|
|
version: 2 -- update with file structure definition
|
2021-04-12 18:53:35 +01:00
|
|
|
integer_size: .1
|
|
|
|
float_size: .1
|
|
|
|
-- reserved space
|
|
|
|
|
|
|
|
main_function -> function
|
|
|
|
|
|
|
|
global_desc:
|
|
|
|
builtin_count: 4
|
2021-08-24 21:44:33 +01:00
|
|
|
global_count: 4 -- excluding builtins
|
2021-04-12 18:53:35 +01:00
|
|
|
global_name -> [
|
|
|
|
string
|
|
|
|
](global_count)
|
|
|
|
|
|
|
|
function:
|
|
|
|
information:
|
|
|
|
function_name:
|
|
|
|
string
|
|
|
|
source:
|
|
|
|
string
|
|
|
|
argc: 1 -- arguments count
|
|
|
|
nstack: 1 -- number of stack size by this function
|
2021-08-24 21:44:33 +01:00
|
|
|
varg: 1
|
|
|
|
extra: 1 -- extra data
|
2021-04-12 18:53:35 +01:00
|
|
|
bytecode:
|
|
|
|
code_size: 4
|
|
|
|
code_array -> [ -- bytecode array
|
|
|
|
instruction: 4
|
|
|
|
](code_size)
|
|
|
|
constant_table:
|
|
|
|
constant_count: 4
|
|
|
|
[constant_value](constant_count)
|
|
|
|
proto_table:
|
|
|
|
proto_count: 4
|
|
|
|
[function](proto_count)
|
|
|
|
upval_table:
|
|
|
|
upval_count: 1
|
2021-08-24 21:44:33 +01:00
|
|
|
upvals: [
|
2021-04-12 18:53:35 +01:00
|
|
|
instack: 1
|
|
|
|
index: 1
|
|
|
|
](upval_count)
|
|
|
|
debug_info:
|
|
|
|
-- reserved
|
|
|
|
|
|
|
|
constant_value:
|
|
|
|
type: 1 -- type of value
|
|
|
|
integer | float | string | class
|
|
|
|
|
|
|
|
string:
|
|
|
|
string_size: 2
|
|
|
|
byte_array: string_size
|
|
|
|
|
|
|
|
class:
|
|
|
|
class_name:
|
|
|
|
string
|
|
|
|
member_count: 4 -- number of member variables
|
|
|
|
method_count: 4 -- number of method
|
2021-08-24 21:44:33 +01:00
|
|
|
method_table: [
|
2021-04-12 18:53:35 +01:00
|
|
|
string -- method name
|
2021-09-15 18:36:48 +01:00
|
|
|
function | nil -- method function body or nil (static member) if the first byte is null (which would be an empty func name)
|
2021-04-12 18:53:35 +01:00
|
|
|
](method_count)
|
|
|
|
member_index_table -> [
|
|
|
|
string -- member name
|
|
|
|
](member_count)
|
|
|
|
|
|
|
|
nil: 1
|
|
|
|
boolean: 1
|
2021-08-24 21:44:33 +01:00
|
|
|
integer: 4 | 8
|
|
|
|
float: 4 | 8
|