Skip to main content

BytecodeProgram

Struct BytecodeProgram 

Source
pub struct BytecodeProgram {
Show 21 fields pub instructions: Vec<Instruction>, pub constants: Vec<Constant>, pub strings: Vec<String>, pub functions: Vec<Function>, pub debug_info: DebugInfo, pub data_schema: Option<DataFrameSchema>, pub module_binding_names: Vec<String>, pub top_level_locals_count: u16, pub top_level_local_storage_hints: Vec<StorageHint>, pub module_binding_storage_hints: Vec<StorageHint>, pub function_local_storage_hints: Vec<Vec<StorageHint>>, pub top_level_frame: Option<FrameDescriptor>, pub type_schema_registry: TypeSchemaRegistry, pub compiled_annotations: HashMap<String, CompiledAnnotation>, pub trait_method_symbols: HashMap<String, String>, pub expanded_function_defs: HashMap<String, FunctionDef>, pub string_index: HashMap<String, u32>, pub foreign_functions: Vec<ForeignFunctionEntry>, pub native_struct_layouts: Vec<NativeStructLayoutEntry>, pub content_addressed: Option<Program>, pub function_blob_hashes: Vec<Option<FunctionHash>>,
}
Expand description

A compiled bytecode program

Fields§

§instructions: Vec<Instruction>

The bytecode instructions

§constants: Vec<Constant>

Constant pool for literals

§strings: Vec<String>

String pool for identifiers and properties

§functions: Vec<Function>

Function table

§debug_info: DebugInfo

Debug information (always present, used for error messages)

§data_schema: Option<DataFrameSchema>

DataFrame schema for column name resolution (required for data access)

§module_binding_names: Vec<String>

ModuleBinding variable names (index -> name mapping for REPL persistence)

§top_level_locals_count: u16

Number of locals used by top-level code. The executor advances sp past this many slots before execution so that expression evaluation doesn’t overlap with local storage.

§top_level_local_storage_hints: Vec<StorageHint>

Storage hints for top-level locals (index -> hint). Used by JIT lowering to preserve native width integer codegen.

§module_binding_storage_hints: Vec<StorageHint>

Storage hints for module bindings (index -> hint).

§function_local_storage_hints: Vec<Vec<StorageHint>>

Per-function local storage hints. function_local_storage_hints[f][local] is the hint for local slot in function f.

§top_level_frame: Option<FrameDescriptor>

Typed frame layout for top-level locals.

When present, supersedes top_level_local_storage_hints for the JIT and VM. None means fall back to the legacy hints vec.

§type_schema_registry: TypeSchemaRegistry

Type schema registry for TypedObject field resolution Used to convert TypedObject back to Object when needed

§compiled_annotations: HashMap<String, CompiledAnnotation>

Compiled annotation definitions Maps annotation name to its compiled handlers

§trait_method_symbols: HashMap<String, String>

Trait method dispatch registry: (trait, type, impl selector, method) -> compiled function symbol name.

This is populated by impl-block compilation and used by runtime dispatch (e.g. print() -> Display::display) without relying on symbol naming heuristics.

§expanded_function_defs: HashMap<String, FunctionDef>

Final function definitions after comptime mutation/specialization.

This is a compile-time inspection artifact for tooling (e.g. shape --expand) and is not serialized into cached bytecode.

§string_index: HashMap<String, u32>

Reverse index for O(1) string dedup during compilation. Maps string content → index in self.strings. Not serialized — rebuilt lazily on first intern_string call after deserialization.

§foreign_functions: Vec<ForeignFunctionEntry>

Foreign function metadata table. Populated by the compiler when fn python ... blocks are compiled. Linked to language runtimes before execution.

§native_struct_layouts: Vec<NativeStructLayoutEntry>

Native type C layout metadata table.

§content_addressed: Option<Program>

Content-addressed program built alongside the flat bytecode.

When present, this contains per-function FunctionBlobs with content hashes. It is produced by the compiler as a dual-output alongside the traditional flat instruction array.

§function_blob_hashes: Vec<Option<FunctionHash>>

Content hash for each function in functions, indexed by function ID.

This provides stable function identity without relying on function names. None entries indicate missing content-addressed metadata.

Implementations§

Source§

impl BytecodeProgram

Source

pub fn new() -> Self

Create a new empty program

Source

pub fn add_constant(&mut self, constant: Constant) -> u16

Add a constant to the pool and return its index

Source

pub fn add_string(&mut self, string: String) -> u16

Add a string to the pool and return its index. Uses the HashMap index for O(1) dedup.

Source

pub fn intern_string(&mut self, s: &str) -> StringId

Intern a string and return a StringId for use in Operand::Name / Operand::MethodCall. Uses the HashMap index for O(1) dedup.

Source

pub fn ensure_string_index(&mut self)

Ensure the string_index HashMap is populated. After deserialization, string_index is empty — rebuild it from the strings Vec.

Source

pub fn resolve_string(&self, id: StringId) -> &str

Resolve a StringId back to a &str.

Panics if the id is out of bounds (indicates a compiler bug).

Source

pub fn emit(&mut self, instruction: Instruction) -> usize

Add an instruction to the program

Source

pub fn current_offset(&self) -> usize

Get the current instruction pointer

Source

pub fn register_trait_method_symbol( &mut self, trait_name: &str, type_name: &str, impl_name: Option<&str>, method_name: &str, function_name: &str, )

Register a trait-method dispatch symbol.

Source

pub fn lookup_trait_method_symbol( &self, trait_name: &str, type_name: &str, impl_name: Option<&str>, method_name: &str, ) -> Option<&str>

Resolve a trait-method dispatch symbol name.

Source

pub fn named_trait_impls_for_method( &self, trait_name: &str, type_name: &str, method_name: &str, ) -> Vec<String>

List named impl selectors for a trait method on a specific type.

Excludes the default selector (__default__) and returns stable sorted names.

Source

pub fn find_default_trait_impl_for_type_method( &self, type_name: &str, method_name: &str, ) -> Option<&str>

Find the default trait impl function for a given type and method (any trait).

Searches trait_method_symbols for any entry whose type and method match, preferring the default selector (__default__). Returns the compiled function symbol name if found.

This is used by method call dispatch to detect when a trait impl method exists for the receiver type, so that builtin functions with the same name don’t shadow it.

Trait Implementations§

Source§

impl Clone for BytecodeProgram

Source§

fn clone(&self) -> BytecodeProgram

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for BytecodeProgram

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for BytecodeProgram

Source§

fn default() -> BytecodeProgram

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for BytecodeProgram

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Serialize for BytecodeProgram

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,