mirror of
https://github.com/fluencelabs/parity-wasm
synced 2025-06-13 23:11:53 +00:00
TableElementType
This commit is contained in:
@ -1,7 +1,7 @@
|
||||
use std::io;
|
||||
use super::{
|
||||
Deserialize, Serialize, Error, VarUint7, VarInt7, VarUint32, VarUint1,
|
||||
ValueType
|
||||
ValueType, TableElementType
|
||||
};
|
||||
|
||||
/// Global definition struct
|
||||
@ -53,7 +53,7 @@ impl Serialize for GlobalType {
|
||||
/// Table entry
|
||||
#[derive(Debug)]
|
||||
pub struct TableType {
|
||||
elem_type: i8,
|
||||
elem_type: TableElementType,
|
||||
limits: ResizableLimits,
|
||||
}
|
||||
|
||||
@ -61,22 +61,26 @@ impl TableType {
|
||||
/// New table definition
|
||||
pub fn new(min: u32, max: Option<u32>) -> Self {
|
||||
TableType {
|
||||
elem_type: 0,
|
||||
elem_type: TableElementType::AnyFunc,
|
||||
limits: ResizableLimits::new(min, max),
|
||||
}
|
||||
}
|
||||
|
||||
/// Table memory specification
|
||||
pub fn limits(&self) -> &ResizableLimits { &self.limits }
|
||||
|
||||
/// Table element type
|
||||
pub fn elem_type(&self) -> TableElementType { self.elem_type }
|
||||
}
|
||||
|
||||
impl Deserialize for TableType {
|
||||
type Error = Error;
|
||||
|
||||
fn deserialize<R: io::Read>(reader: &mut R) -> Result<Self, Self::Error> {
|
||||
let elem_type = VarInt7::deserialize(reader)?;
|
||||
let elem_type = TableElementType::deserialize(reader)?;
|
||||
let limits = ResizableLimits::deserialize(reader)?;
|
||||
Ok(TableType {
|
||||
elem_type: elem_type.into(),
|
||||
elem_type: elem_type,
|
||||
limits: limits,
|
||||
})
|
||||
}
|
||||
@ -86,7 +90,7 @@ impl Serialize for TableType {
|
||||
type Error = Error;
|
||||
|
||||
fn serialize<W: io::Write>(self, writer: &mut W) -> Result<(), Self::Error> {
|
||||
VarInt7::from(self.elem_type).serialize(writer)?;
|
||||
self.elem_type.serialize(writer)?;
|
||||
self.limits.serialize(writer)
|
||||
}
|
||||
}
|
||||
|
@ -26,7 +26,7 @@ pub use self::primitives::{
|
||||
VarUint32, VarUint7, VarUint1, VarInt7, Uint32, VarInt32, VarInt64,
|
||||
Uint64, VarUint64, CountedList, CountedWriter, CountedListWriter,
|
||||
};
|
||||
pub use self::types::{Type, ValueType, BlockType, FunctionType};
|
||||
pub use self::types::{Type, ValueType, BlockType, FunctionType, TableElementType};
|
||||
pub use self::ops::{Opcode, Opcodes, InitExpr};
|
||||
pub use self::func::{Func, FuncBody, Local};
|
||||
pub use self::segment::{ElementSegment, DataSegment};
|
||||
@ -69,6 +69,8 @@ pub enum Error {
|
||||
HeapOther(String),
|
||||
/// Invalid/unknown value type declaration
|
||||
UnknownValueType(i8),
|
||||
/// Invalid/unknown table element type declaration
|
||||
UnknownTableElementType(i8),
|
||||
/// Non-utf8 string
|
||||
NonUtf8String,
|
||||
/// Unknown external kind code
|
||||
|
@ -200,3 +200,35 @@ impl Serialize for FunctionType {
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
/// Table element type.
|
||||
#[derive(Clone, Copy, PartialEq, Debug)]
|
||||
pub enum TableElementType {
|
||||
/// A reference to a function with any signature.
|
||||
AnyFunc,
|
||||
}
|
||||
|
||||
impl Deserialize for TableElementType {
|
||||
type Error = Error;
|
||||
|
||||
fn deserialize<R: io::Read>(reader: &mut R) -> Result<Self, Self::Error> {
|
||||
let val = VarInt7::deserialize(reader)?;
|
||||
|
||||
match val.into() {
|
||||
-0x10 => Ok(TableElementType::AnyFunc),
|
||||
_ => Err(Error::UnknownTableElementType(val.into())),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl Serialize for TableElementType {
|
||||
type Error = Error;
|
||||
|
||||
fn serialize<W: io::Write>(self, writer: &mut W) -> Result<(), Self::Error> {
|
||||
let val: VarInt7 = match self {
|
||||
TableElementType::AnyFunc => 0x70,
|
||||
}.into();
|
||||
val.serialize(writer)?;
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
@ -177,7 +177,7 @@ impl ModuleInstance {
|
||||
let tables = match module.table_section() {
|
||||
Some(table_section) => table_section.entries()
|
||||
.iter()
|
||||
.map(|tt| TableInstance::new(VariableType::AnyFunc, tt)) // TODO: actual table type
|
||||
.map(|tt| TableInstance::new(tt))
|
||||
.collect::<Result<Vec<_>, _>>()?,
|
||||
None => Vec::new(),
|
||||
};
|
||||
|
@ -17,9 +17,10 @@ pub struct TableInstance {
|
||||
|
||||
impl TableInstance {
|
||||
/// New instance of the table
|
||||
pub fn new(variable_type: VariableType, table_type: &TableType) -> Result<Arc<Self>, Error> {
|
||||
pub fn new(table_type: &TableType) -> Result<Arc<Self>, Error> {
|
||||
check_limits(table_type.limits())?;
|
||||
|
||||
let variable_type = table_type.elem_type().into();
|
||||
Ok(Arc::new(TableInstance {
|
||||
variable_type: variable_type,
|
||||
buffer: RwLock::new(
|
||||
|
@ -1,5 +1,5 @@
|
||||
use parking_lot::RwLock;
|
||||
use elements::{GlobalType, ValueType};
|
||||
use elements::{GlobalType, ValueType, TableElementType};
|
||||
use interpreter::Error;
|
||||
use interpreter::value::RuntimeValue;
|
||||
|
||||
@ -98,3 +98,11 @@ impl From<ValueType> for VariableType {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl From<TableElementType> for VariableType {
|
||||
fn from(tt: TableElementType) -> VariableType {
|
||||
match tt {
|
||||
TableElementType::AnyFunc => VariableType::AnyFunc,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user