Skip to content

Commit 58e3c82

Browse files
OctaveLaroseHirevo
andcommitted
Applied several suggestions from code review
Co-authored-by: Nicolas Polomack <[email protected]>
1 parent a027ea6 commit 58e3c82

File tree

3 files changed

+29
-25
lines changed

3 files changed

+29
-25
lines changed

som-core/src/bytecode.rs

+22-22
Original file line numberDiff line numberDiff line change
@@ -46,9 +46,9 @@ impl Bytecode {
4646
Self::PushField(_) => "PUSH_FIELD",
4747
Self::PushBlock(_) => "PUSH_BLOCK",
4848
Self::PushConstant(_) => "PUSH_CONSTANT",
49-
Self::PushConstant0 => "PUSH_CONSTANT 0",
50-
Self::PushConstant1 => "PUSH_CONSTANT 1",
51-
Self::PushConstant2 => "PUSH_CONSTANT 2",
49+
Self::PushConstant0 => "PUSH_CONSTANT_0",
50+
Self::PushConstant1 => "PUSH_CONSTANT_1",
51+
Self::PushConstant2 => "PUSH_CONSTANT_2",
5252
Self::PushGlobal(_) => "PUSH_GLOBAL",
5353
Self::Push0 => "PUSH_0",
5454
Self::Push1 => "PUSH_1",
@@ -57,14 +57,14 @@ impl Bytecode {
5757
Self::PopLocal(_, _) => "POP_LOCAL",
5858
Self::PopArgument(_, _) => "POP_ARGUMENT",
5959
Self::PopField(_) => "POP_FIELD",
60-
Self::Send1(_) => "SEND 1",
61-
Self::Send2(_) => "SEND 2",
62-
Self::Send3(_) => "SEND 3",
63-
Self::SendN(_) => "SEND N",
64-
Self::SuperSend1(_) => "SUPER_SEND 1",
65-
Self::SuperSend2(_) => "SUPER_SEND 2",
66-
Self::SuperSend3(_) => "SUPER_SEND 3",
67-
Self::SuperSendN(_) => "SUPER_SEND N",
60+
Self::Send1(_) => "SEND_1",
61+
Self::Send2(_) => "SEND_2",
62+
Self::Send3(_) => "SEND_3",
63+
Self::SendN(_) => "SEND_N",
64+
Self::SuperSend1(_) => "SUPER_SEND_1",
65+
Self::SuperSend2(_) => "SUPER_SEND_2",
66+
Self::SuperSend3(_) => "SUPER_SEND_3",
67+
Self::SuperSendN(_) => "SUPER_SEND_N",
6868
Self::ReturnLocal => "RETURN_LOCAL",
6969
Self::ReturnNonLocal => "RETURN_NON_LOCAL",
7070
}
@@ -82,9 +82,9 @@ impl Bytecode {
8282
Self::PushField(_) => "PUSH_FIELD ",
8383
Self::PushBlock(_) => "PUSH_BLOCK ",
8484
Self::PushConstant(_) => "PUSH_CONSTANT ",
85-
Self::PushConstant0 => "PUSH_CONSTANT 0 ",
86-
Self::PushConstant1 => "PUSH_CONSTANT 1 ",
87-
Self::PushConstant2 => "PUSH_CONSTANT 2 ",
85+
Self::PushConstant0 => "PUSH_CONSTANT_0 ",
86+
Self::PushConstant1 => "PUSH_CONSTANT_1 ",
87+
Self::PushConstant2 => "PUSH_CONSTANT_2 ",
8888
Self::PushGlobal(_) => "PUSH_GLOBAL ",
8989
Self::Push0 => "PUSH_0 ",
9090
Self::Push1 => "PUSH_1 ",
@@ -93,14 +93,14 @@ impl Bytecode {
9393
Self::PopLocal(_, _) => "POP_LOCAL ",
9494
Self::PopArgument(_, _) => "POP_ARGUMENT ",
9595
Self::PopField(_) => "POP_FIELD ",
96-
Self::Send1(_) => "SEND 1 ",
97-
Self::Send2(_) => "SEND 2 ",
98-
Self::Send3(_) => "SEND 3 ",
99-
Self::SendN(_) => "SEND N ",
100-
Self::SuperSend1(_) => "SUPER_SEND 1 ",
101-
Self::SuperSend2(_) => "SUPER_SEND 2 ",
102-
Self::SuperSend3(_) => "SUPER_SEND 3 ",
103-
Self::SuperSendN(_) => "SUPER_SEND N ",
96+
Self::Send1(_) => "SEND_1 ",
97+
Self::Send2(_) => "SEND_2 ",
98+
Self::Send3(_) => "SEND_3 ",
99+
Self::SendN(_) => "SEND_N ",
100+
Self::SuperSend1(_) => "SUPER_SEND_1 ",
101+
Self::SuperSend2(_) => "SUPER_SEND_2 ",
102+
Self::SuperSend3(_) => "SUPER_SEND_3 ",
103+
Self::SuperSendN(_) => "SUPER_SEND_N ",
104104
Self::ReturnLocal => "RETURN_LOCAL ",
105105
Self::ReturnNonLocal => "RETURN_NON_LOCAL",
106106
}

som-interpreter-bc/src/compiler.rs

+6-2
Original file line numberDiff line numberDiff line change
@@ -164,13 +164,17 @@ impl InnerGenCtxt for BlockGenCtxt<'_> {
164164
}
165165

166166
fn remove_dup_popx_pop_sequences(&mut self) {
167-
if self.body.is_none() || self.body.as_ref().unwrap().len() < 3 {
167+
let Some(body) = self.body.as_mut() else {
168+
return;
169+
};
170+
171+
if body.len() < 3 {
168172
return;
169173
}
170174

171175
let mut indices_to_remove: Vec<usize> = vec![];
172176

173-
for (idx, bytecode_win) in self.body.as_ref().unwrap().windows(3).enumerate() {
177+
for (idx, bytecode_win) in body.windows(3).enumerate() {
174178
if matches!(bytecode_win[0], Bytecode::Dup) &&
175179
matches!(bytecode_win[1], Bytecode::PopField(..) | Bytecode::PopLocal(..) | Bytecode::PopArgument(..)) &&
176180
matches!(bytecode_win[2], Bytecode::Pop) {

som-interpreter-bc/src/disassembler.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -66,7 +66,7 @@ fn disassemble_body(
6666
Bytecode::PushConstant0 => 0,
6767
Bytecode::PushConstant1 => 1,
6868
Bytecode::PushConstant2 => 2,
69-
_ => panic!("Obviously unreachable")
69+
_ => unreachable!(),
7070
};
7171

7272
print!(" {idx}");

0 commit comments

Comments
 (0)