Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(interface-types) Implement the record instructions #1331

Merged
merged 44 commits into from
Apr 6, 2020
Merged
Changes from 1 commit
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
bbb4f1f
feat(interface-types) Introduce the record type.
Hywan Mar 24, 2020
734795c
test(interface-types) Test `Type::Record`.
Hywan Mar 26, 2020
3c02c50
chore(interface-types) Move the `instruction.rs` module in `instructi…
Hywan Mar 26, 2020
bd9226e
feat(interface-types) Introduce `RecordType` for `InterfaceType` and …
Hywan Mar 26, 2020
a99ae6b
feat(interface-types) Add the `Record` WIT value.
Hywan Mar 30, 2020
154dcba
feat(interface-types) Implement Serde deserializing for WIT records t…
Hywan Mar 30, 2020
c87c2ef
feat(interface-values) Improve the `TypeMismatch` error.
Hywan Mar 31, 2020
ee57b47
feat(interface-types) Improve the `Deserializer` API.
Hywan Mar 31, 2020
3655ef8
chore(interface-types) Reorganize the serde module.
Hywan Mar 31, 2020
0af1076
feat(interface-types) Encodes/decodes the `record.lift` instruction.
Hywan Mar 31, 2020
02b7e21
feat(interface-types) Implement the `record.lift` instruction.
Hywan Mar 31, 2020
1a17cbb
test(interface-types) Deserialize WIT record to Rust struct.
Hywan Mar 31, 2020
5ba6fda
chore(interface-types) Improve code readibility of `string` instructi…
Hywan Apr 2, 2020
3411ac7
feat(interface-types) Move `serde::InterfaceTypeIterator` into `value…
Hywan Apr 2, 2020
aab82c1
feat(interface-types) Implement `From<&Vec<InterfaceValue>>` for `Rec…
Hywan Apr 2, 2020
a1551b5
test(interface-types) Rename a test case.
Hywan Apr 2, 2020
b8ef82d
test(interface-types) Rename test cases.
Hywan Apr 2, 2020
11687c5
feat(interface-types) Encodes/decodes the `record.lower` instruction.
Hywan Apr 2, 2020
0023eea
feat(interface-types) Implement the `record.lower` instruction.
Hywan Apr 2, 2020
8f8c5f1
chore(interface-types) Improve code readabilit of the `record.lift` i…
Hywan Apr 2, 2020
bac56a6
Merge branch 'master' into feat-interface-types-record-instructions
Hywan Apr 2, 2020
f850753
fix(interface-types) Fix a `git-merge` issue.
Hywan Apr 2, 2020
7b18241
feat(interface-types) Make `serde` optional behind a feature flag.
Hywan Apr 2, 2020
8868d64
feat(interface-types) Rename `from_values` to `from_interface_values`.
Hywan Apr 2, 2020
f9832fe
feat(interface-types) Implement a serializer for WIT values.
Hywan Apr 2, 2020
d6f7e3f
doc(interface-types) Describe `to_interface_value`.
Hywan Apr 2, 2020
ee0596d
feat(interface-types) Restrict supported type in the `Deserializer`.
Hywan Apr 2, 2020
b0af014
doc(interface-types) Update an example.
Hywan Apr 2, 2020
e385bf6
feat(interface-types) Make `unwrap`s safe by introducing more errors.
Hywan Apr 2, 2020
010b10d
chore(cargo) Update `Cargo.lock`.
Hywan Apr 2, 2020
be66ac8
doc(interface-types) Improve `serde` module documentation.
Hywan Apr 2, 2020
2011fda
chore(interface-types) Split the `serde` module…
Hywan Apr 2, 2020
6cef1c2
doc(interface-types) Fix typos.
Hywan Apr 3, 2020
3159da5
feat(interface-types) Add the `Vec1` type to represent a non-empty ve…
Hywan Apr 3, 2020
d186142
doc(interface-types) Fix a typo.
Hywan Apr 3, 2020
e160feb
fix(interface-types) Use lazy evaluation in the deserializer.
Hywan Apr 3, 2020
398d791
fix(interface-types) Also apply another lazy evaluation in the deseri…
Hywan Apr 3, 2020
e4921bd
feat(interface-types) Use `Vec::last_mut` to simplify code.
Hywan Apr 3, 2020
5119b6a
feat(interface-types) Simplify `FlattenInterfaceValueIterator` with `…
Hywan Apr 3, 2020
4ad3d7f
doc(interface-types) Explain a part of an algorithm.
Hywan Apr 4, 2020
4faf827
feat(interface-types) Avoid clones by using owned items in an iterator.
Hywan Apr 6, 2020
c2b1b87
feat(interface-types) Use `VecDeque` to remove unsafe code.
Hywan Apr 6, 2020
27053d5
doc(interface-types) Rewrite `record_lift_` documentation.
Hywan Apr 6, 2020
9f10b7a
doc(interface-types) Update `from_interface_values`'s doc.
Hywan Apr 6, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat(interface-types) Encodes/decodes the record.lift instruction.
  • Loading branch information
Hywan committed Mar 31, 2020

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
commit 0af1076eee219a9f943ac7797332181b11f3f07d
18 changes: 17 additions & 1 deletion lib/interface-types/src/decoders/binary.rs
Original file line number Diff line number Diff line change
@@ -173,6 +173,7 @@ fn instruction<'input, E: ParseError<&'input [u8]>>(
Ok(match opcode {
0x00 => {
consume!((input, argument_0) = uleb(input)?);

(
input,
Instruction::ArgumentGet {
@@ -183,6 +184,7 @@ fn instruction<'input, E: ParseError<&'input [u8]>>(

0x01 => {
consume!((input, argument_0) = uleb(input)?);

(
input,
Instruction::CallCore {
@@ -228,6 +230,7 @@ fn instruction<'input, E: ParseError<&'input [u8]>>(

0x23 => {
consume!((input, argument_0) = uleb(input)?);

(
input,
Instruction::StringLowerMemory {
@@ -238,6 +241,17 @@ fn instruction<'input, E: ParseError<&'input [u8]>>(

0x24 => (input, Instruction::StringSize),

0x25 => {
consume!((input, argument_0) = uleb(input)?);

(
input,
Instruction::RecordLift {
type_index: argument_0 as u32,
},
)
}

_ => return Err(Err::Error(make_error(input, ErrorKind::ParseTo))),
})
}
@@ -701,7 +715,7 @@ mod tests {
#[test]
fn test_instructions() {
let input = &[
0x25, // list of 37 items
0x26, // list of 38 items
0x00, 0x01, // ArgumentGet { index: 1 }
0x01, 0x01, // CallCore { function_index: 1 }
0x02, // S8FromI32
@@ -739,6 +753,7 @@ mod tests {
0x22, // StringLiftMemory
0x23, 0x01, // StringLowerMemory { allocator_index: 1 }
0x24, // StringSize
0x25, 0x01, // RecordLift { type_index: 1 },
0x0a,
];
let output = Ok((
@@ -781,6 +796,7 @@ mod tests {
Instruction::StringLiftMemory,
Instruction::StringLowerMemory { allocator_index: 1 },
Instruction::StringSize,
Instruction::RecordLift { type_index: 1 },
],
));

9 changes: 9 additions & 0 deletions lib/interface-types/src/decoders/wat.rs
Original file line number Diff line number Diff line change
@@ -65,6 +65,7 @@ mod keyword {
custom_keyword!(string_lift_memory = "string.lift_memory");
custom_keyword!(string_lower_memory = "string.lower_memory");
custom_keyword!(string_size = "string.size");
custom_keyword!(record_lift = "record.lift");
}

impl Parse<'_> for InterfaceType {
@@ -312,6 +313,12 @@ impl<'a> Parse<'a> for Instruction {
parser.parse::<keyword::string_size>()?;

Ok(Instruction::StringSize)
} else if lookahead.peek::<keyword::record_lift>() {
parser.parse::<keyword::record_lift>()?;

Ok(Instruction::RecordLift {
type_index: parser.parse()?,
})
} else {
Err(lookahead.error())
}
@@ -756,6 +763,7 @@ mod tests {
"string.lift_memory",
"string.lower_memory 42",
"string.size",
"record.lift 42",
];
let outputs = vec![
Instruction::ArgumentGet { index: 7 },
@@ -797,6 +805,7 @@ mod tests {
allocator_index: 42,
},
Instruction::StringSize,
Instruction::RecordLift { type_index: 42 },
];

assert_eq!(inputs.len(), outputs.len());
9 changes: 8 additions & 1 deletion lib/interface-types/src/encoders/binary.rs
Original file line number Diff line number Diff line change
@@ -338,6 +338,11 @@ where
}

Instruction::StringSize => 0x24_u8.to_bytes(writer)?,

Instruction::RecordLift { type_index } => {
0x25_u8.to_bytes(writer)?;
(*type_index as u64).to_bytes(writer)?
}
}

Ok(())
@@ -683,9 +688,10 @@ mod tests {
Instruction::StringLiftMemory,
Instruction::StringLowerMemory { allocator_index: 1 },
Instruction::StringSize,
Instruction::RecordLift { type_index: 1 },
],
&[
0x25, // list of 37 items
0x26, // list of 38 items
0x00, 0x01, // ArgumentGet { index: 1 }
0x01, 0x01, // CallCore { function_index: 1 }
0x02, // S8FromI32
@@ -723,6 +729,7 @@ mod tests {
0x22, // StringLiftMemory
0x23, 0x01, // StringLowerMemory { allocator_index: 1 }
0x24, // StringSize
0x025, 0x01, // RecordLift { type_index: 1 }
]
);
}
5 changes: 4 additions & 1 deletion lib/interface-types/src/encoders/wat.rs
Original file line number Diff line number Diff line change
@@ -136,9 +136,10 @@ impl ToString for &Instruction {
Instruction::I64FromU64 => "i64.from_u64".into(),
Instruction::StringLiftMemory => "string.lift_memory".into(),
Instruction::StringLowerMemory { allocator_index } => {
format!(r#"string.lower_memory {}"#, allocator_index)
format!("string.lower_memory {}", allocator_index)
}
Instruction::StringSize => "string.size".into(),
Instruction::RecordLift { type_index } => format!("record.lift {}", type_index),
}
}
}
@@ -465,6 +466,7 @@ mod tests {
})
.to_string(),
(&Instruction::StringSize).to_string(),
(&Instruction::RecordLift { type_index: 42 }).to_string(),
];
let outputs = vec![
"arg.get 7",
@@ -504,6 +506,7 @@ mod tests {
"string.lift_memory",
"string.lower_memory 42",
"string.size",
"record.lift 42",
];

assert_eq!(inputs, outputs);
6 changes: 6 additions & 0 deletions lib/interface-types/src/interpreter/instructions/mod.rs
Original file line number Diff line number Diff line change
@@ -135,6 +135,12 @@ pub enum Instruction {

/// The `string.size` instruction.
StringSize,

/// The `record.lift` instruction.
RecordLift {
/// The type index of the record.
type_index: u32,
},
}

/// Just a short helper to map the error of a cast from an
2 changes: 2 additions & 0 deletions lib/interface-types/src/interpreter/mod.rs
Original file line number Diff line number Diff line change
@@ -234,6 +234,8 @@ where
instructions::string_lower_memory(*allocator_index, *instruction)
}
Instruction::StringSize => instructions::string_size(*instruction),

Instruction::RecordLift { type_index: _ } => todo!(),
})
.collect();