Skip to content

Commit

Permalink
add rustls and fix free identifier error message
Browse files Browse the repository at this point in the history
  • Loading branch information
mattwparas committed Nov 21, 2024
1 parent 9a2bb2e commit 003f55f
Show file tree
Hide file tree
Showing 9 changed files with 619 additions and 41 deletions.
234 changes: 204 additions & 30 deletions Cargo.lock

Large diffs are not rendered by default.

110 changes: 102 additions & 8 deletions crates/steel-core/src/compiler/compiler.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,10 @@ use crate::{
shadow::RenameShadowedVariables, VisitorMutRefUnit,
},
},
core::{instructions::u24, labels::Expr},
core::{
instructions::{disassemble, u24},

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused import: `disassemble`

Check warning on line 12 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite

unused import: `disassemble`
labels::Expr,
},
parser::{
expand_visitor::{expand_kernel_in_env, expand_kernel_in_env_with_change},
interner::InternedString,
Expand Down Expand Up @@ -62,7 +65,9 @@ use std::time::Instant;
#[derive(Default)]
pub struct DebruijnIndicesInterner {
flat_defines: HashSet<InternedString>,
flat_defines_idx: HashSet<usize>,
second_pass_defines: HashSet<InternedString>,
second_pass_defines_idx: HashSet<usize>,
}

impl DebruijnIndicesInterner {
Expand All @@ -71,6 +76,8 @@ impl DebruijnIndicesInterner {
instructions: &mut [Instruction],
symbol_map: &mut SymbolMap,
) -> Result<()> {
let mut flat_defines_non_closure: HashSet<InternedString> = HashSet::default();

for i in 2..instructions.len() {
match (&instructions[i], &instructions[i - 1], &instructions[i - 2]) {
(
Expand All @@ -93,11 +100,11 @@ impl DebruijnIndicesInterner {
..
},
) => {
// Exiting a definition, clear it
flat_defines_non_closure.clear();

let idx = symbol_map.add(s);
self.flat_defines.insert(s.to_owned());
// if !self.flat_defines.insert(s.to_owned()) {
// stop!(BadSyntax => format!("Cannot redefine define within the same scope: {}", s); *span);
// }

if let Some(x) = instructions.get_mut(i) {
x.payload_size = u24::from_usize(idx);
Expand All @@ -109,23 +116,68 @@ impl DebruijnIndicesInterner {
contents:
Some(Expr::Atom(SyntaxObject {
ty: TokenType::Identifier(s),
// span,
span,
..
})),
..
},
Instruction {
op_code: OpCode::EDEF,
..
},
..,
) => {
let idx = symbol_map.add(s);
self.flat_defines.insert(s.to_owned());
// if !self.flat_defines.insert(s.to_owned()) {
// stop!(BadSyntax => format!("Cannot redefine define within the same scope: {}", s); *span);
// }

if flat_defines_non_closure.contains(s) {
stop!(BadSyntax => format!("Cannot reference identifier before its definition: {}", s.resolve()); *span);
}

flat_defines_non_closure.clear();

// self.flat_defines_idx.insert(idx);
// flat_defines_non_closure.insert(s.to_owned());

if let Some(x) = instructions.get_mut(i) {
x.payload_size = u24::from_usize(idx);
}
}
// (
// Instruction {
// op_code: OpCode::EDEF,
// ..
// },
// ..,
// ) => {
// flat_defines_non_closure.clear();
// }
(
Instruction {
op_code: OpCode::CALLGLOBAL,
contents:
Some(Expr::Atom(SyntaxObject {
ty: TokenType::Identifier(s),
span,

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (macos-latest, aarch64-apple-darwin)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (ubuntu-latest, x86_64-unknown-linux-gnu)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite (sync) (windows-latest, x86_64-pc-windows-msvc)

unused variable: `span`

Check warning on line 161 in crates/steel-core/src/compiler/compiler.rs

View workflow job for this annotation

GitHub Actions / Test Suite

unused variable: `span`
..
})),
..
},
..,
) => {
// We're referencing things within the scope
flat_defines_non_closure.insert(*s);

// let idx = symbol_map.add(s);
// self.flat_defines.insert(s.to_owned());

// self.flat_defines_idx.insert(idx);

// if flat_defines_non_closure.contains(s) {
// println!("{}", disassemble(instructions));
// stop!(BadSyntax => format!("Cannot reference identifier before definition: {}", s.resolve()); *span);
// }
}
_ => {}
}
}
Expand Down Expand Up @@ -181,6 +233,10 @@ impl DebruijnIndicesInterner {
} => {
// Keep track of where the defines actually are in the process
self.second_pass_defines.insert(s.to_owned());

// let idx = symbol_map.get(s).unwrap();

// self.second_pass_defines_idx.insert(idx);
}
Instruction {
op_code: OpCode::PUSH,
Expand Down Expand Up @@ -247,8 +303,46 @@ impl DebruijnIndicesInterner {
stop!(FreeIdentifier => message; *span);
}

if s.resolve() == "client-connection" {
println!(
"Flat defines: {:?}",
self.flat_defines
.iter()
.map(|x| x.resolve())
.collect::<Vec<_>>()
);

println!("Flat defines idx: {:?}", self.flat_defines_idx);

println!(
"Second pass defines: {:?}",
self.second_pass_defines
.iter()
.map(|x| x.resolve())
.collect::<Vec<_>>()
);

println!(
"Second pass defines idx: {:?}",
self.second_pass_defines_idx
);
}

let idx = symbol_map.get(s).map_err(|e| e.set_span(*span))?;

if s.resolve() == "client-connection" {
println!("idx: {} -> {}", idx, s.resolve());
}

// if self.flat_defines.get(s).is_some()
// && self.second_pass_defines.get(s).is_some()
// && self.second_pass_defines_idx.get(&idx).is_some()
// {
// let message =
// format!("Cannot reference an identifier before its definition: {s}");
// stop!(FreeIdentifier => message; *span);
// }

// TODO commenting this for now
if let Some(x) = instructions.get_mut(i) {
x.payload_size = u24::from_usize(idx);
Expand Down
20 changes: 19 additions & 1 deletion crates/steel-core/src/primitives/http.rs
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,23 @@ pub fn headers(value: &SteelVal) -> Result<SteelVal> {
))))
}

#[steel_derive::function(name = "http-response-headers")]
pub fn resp_headers(value: &SteelVal) -> Result<SteelVal> {
let resp = SteelResponse::as_ref(value)?;

Ok(SteelVal::HashMapV(SteelHashMap(Gc::new(
resp.headers
.iter()
.map(|x| {
(
SteelVal::StringV(x.name.clone().into()),
SteelVal::ByteVector(SteelByteVector::new(x.value.clone())),
)
})
.collect::<crate::values::HashMap<_, _>>(),
))))
}

// If not complete, try again?
fn parse_request(buf: &[u8]) -> Result<SteelVal> {
// Pull more bytes from the stream?
Expand Down Expand Up @@ -121,7 +138,7 @@ fn parse_request(buf: &[u8]) -> Result<SteelVal> {

fn parse_response(buf: &[u8]) -> Result<SteelVal> {
// Pull more bytes from the stream?
let mut headers = [httparse::EMPTY_HEADER; 16];
let mut headers = [httparse::EMPTY_HEADER; 64];
let mut req = httparse::Response::new(&mut headers);
let res = req.parse(&buf).unwrap();
if res.is_complete() {
Expand Down Expand Up @@ -171,6 +188,7 @@ pub fn http_module() -> BuiltInModule {
.register_native_fn_definition(PATH_DEFINITION)
.register_native_fn_definition(BODY_OFFSET_DEFINITION)
.register_native_fn_definition(HEADERS_DEFINITION)
.register_native_fn_definition(RESP_HEADERS_DEFINITION)
.register_native_fn_definition(PARSE_HTTP_RESPONSE_DEFINITION);

// module
Expand Down
69 changes: 67 additions & 2 deletions crates/steel-core/src/steel_vm/ffi.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use std::{
borrow::Cow,
io::BufReader,
marker::PhantomData,
sync::{Arc, Mutex},
};
Expand All @@ -14,7 +15,11 @@ use crate::{
as_underlying_type_mut, Custom, CustomType, FutureResult, IntoSteelVal,
MaybeSendSyncStatic, Result, SteelByteVector, SteelHashMap, SteelVal,
},
values::functions::{BoxedDynFunction, StaticOrRcStr},
values::{
functions::{BoxedDynFunction, StaticOrRcStr},
port::SteelPort,
SteelPortRepr,
},
SteelErr,
};

Expand All @@ -23,7 +28,7 @@ use abi_stable::{
std_types::{
RArc, RBoxError, RCowStr, RHashMap, RResult, RSlice, RSliceMut, RStr, RString, RVec, Tuple2,
},
RMut, StableAbi,
DynTrait, RMut, StableAbi,
};
use futures_util::FutureExt;

Expand Down Expand Up @@ -929,6 +934,52 @@ macro_rules! declare_module {
};
}

#[repr(C)]
#[derive(StableAbi)]
#[sabi(impl_InterfaceType(Sync, Send, IoWrite))]
pub struct WriterInterface;

#[repr(C)]
#[derive(StableAbi)]
#[sabi(impl_InterfaceType(Sync, Send, IoRead))]
pub struct ReaderInterface;

#[repr(C)]
#[derive(StableAbi)]
pub struct DynWriter {
pub writer: DynTrait<'static, RBox<()>, WriterInterface>,
}

impl DynWriter {
fn into_port(self) -> SteelPortRepr {
SteelPortRepr::DynWriter(Arc::new(Mutex::new(self.writer)))
}
}

#[repr(C)]
#[derive(StableAbi)]
pub struct DynReader {
pub reader: DynTrait<'static, RBox<()>, ReaderInterface>,
}

impl DynReader {
fn into_port(self) -> SteelPortRepr {
SteelPortRepr::DynReader(BufReader::new(Box::new(self.reader)))
}
}

impl IntoFFIVal for DynWriter {
fn into_ffi_val(self) -> RResult<FFIValue, RBoxError> {
RResult::ROk(FFIValue::DynWriter(self))
}
}

impl IntoFFIVal for DynReader {
fn into_ffi_val(self) -> RResult<FFIValue, RBoxError> {
RResult::ROk(FFIValue::DynReader(self))
}
}

#[repr(C)]
#[derive(StableAbi)]
pub struct MutableString {
Expand All @@ -937,6 +988,8 @@ pub struct MutableString {

impl Custom for MutableString {}

#[repr(C)]
#[derive(StableAbi)]
struct FFIVector {
vec: RVec<FFIValue>,
}
Expand Down Expand Up @@ -1101,6 +1154,8 @@ pub enum FFIValue {
fut: SyncFfiFuture,
},
ByteVector(RVec<u8>),
DynWriter(DynWriter),
DynReader(DynReader),
}

#[repr(C)]
Expand Down Expand Up @@ -1167,6 +1222,8 @@ impl std::fmt::Debug for FFIValue {
FFIValue::HashMap(h) => write!(f, "{:?}", h),
FFIValue::Future { .. } => write!(f, "#<future>"),
FFIValue::ByteVector(b) => write!(f, "{:?}", b),
FFIValue::DynWriter(_) => write!(f, "#<ffi-writer>"),
FFIValue::DynReader(_) => write!(f, "#<ffi-reader>"),
}
}
}
Expand Down Expand Up @@ -1294,6 +1351,14 @@ impl IntoSteelVal for FFIValue {
)))),

Self::ByteVector(b) => Ok(SteelVal::ByteVector(SteelByteVector::new(b.into()))),

Self::DynWriter(d) => Ok(SteelVal::PortV(SteelPort {
port: Gc::new_mut(d.into_port()),
})),

Self::DynReader(d) => Ok(SteelVal::PortV(SteelPort {
port: Gc::new_mut(d.into_port()),
})),
}
}
}
Expand Down
1 change: 1 addition & 0 deletions crates/steel-core/src/values/port.rs
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,7 @@ impl SteelPortRepr {
SteelPortRepr::StdInput(br) => port_read_str_fn!(br, read_to_string),
SteelPortRepr::ChildStdOutput(br) => port_read_str_fn!(br, read_to_string),
SteelPortRepr::ChildStdError(br) => port_read_str_fn!(br, read_to_string),
SteelPortRepr::DynReader(br) => port_read_str_fn!(br, read_to_string),
_x => stop!(Generic => "read-all-str"),
}
}
Expand Down
16 changes: 16 additions & 0 deletions libs/steel-rustls/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
[package]
name = "steel-rustls"
edition = "2021"
version.workspace = true

[lib]
name = "steel_rustls"
crate-type = ["rlib", "cdylib"]

[dependencies]
steel-core = { path = "../../crates/steel-core", version = "0.6.0", features = ["dylibs", "sync"] }
abi_stable = "0.11.1"
rustls = "0.23.17"
webpki-roots = "0.26"


18 changes: 18 additions & 0 deletions libs/steel-rustls/rustls.scm
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
(#%require-dylib "libsteel_rustls" (only-in
client-connection
tcp-connect
tcp-reader
tcp-writer
tls-reader
tls-stream
tls-writer
))
(provide
client-connection
tcp-connect
tcp-reader
tcp-writer
tls-reader
tls-stream
tls-writer
)
Loading

0 comments on commit 003f55f

Please sign in to comment.