From a6b3d19ab409f6566de000ba0d3ddba4cb08be40 Mon Sep 17 00:00:00 2001 From: Trevor Elliott Date: Thu, 5 Oct 2023 12:04:53 -0700 Subject: [PATCH] wasi-http: Use borrow syntax for borrowed resources (#7161) * Remove `own` and `borrow` annotations from wasi-http * Fix the tests, as borrows are now needed * Don't delete headers that we're borrowing --- .../wasi-http-proxy-tests/src/lib.rs | 2 +- crates/test-programs/wasi-http-tests/src/lib.rs | 2 +- crates/wasi-http/src/types_impl.rs | 1 - .../wasi-http/wit/deps/http/incoming-handler.wit | 4 ++-- .../wasi-http/wit/deps/http/outgoing-handler.wit | 2 +- crates/wasi-http/wit/deps/http/types.wit | 16 ++++++++-------- crates/wasi/wit/deps/http/incoming-handler.wit | 4 ++-- crates/wasi/wit/deps/http/outgoing-handler.wit | 2 +- crates/wasi/wit/deps/http/types.wit | 16 ++++++++-------- 9 files changed, 24 insertions(+), 25 deletions(-) diff --git a/crates/test-programs/wasi-http-proxy-tests/src/lib.rs b/crates/test-programs/wasi-http-proxy-tests/src/lib.rs index 65c7db9168c6..5c25f34ddd3a 100644 --- a/crates/test-programs/wasi-http-proxy-tests/src/lib.rs +++ b/crates/test-programs/wasi-http-proxy-tests/src/lib.rs @@ -17,7 +17,7 @@ struct T; impl bindings::exports::wasi::http::incoming_handler::Guest for T { fn handle(_request: IncomingRequest, outparam: ResponseOutparam) { let hdrs = bindings::wasi::http::types::Headers::new(&[]); - let resp = bindings::wasi::http::types::OutgoingResponse::new(200, hdrs); + let resp = bindings::wasi::http::types::OutgoingResponse::new(200, &hdrs); let body = resp.write().expect("outgoing response"); bindings::wasi::http::types::ResponseOutparam::set(outparam, Ok(resp)); diff --git a/crates/test-programs/wasi-http-tests/src/lib.rs b/crates/test-programs/wasi-http-tests/src/lib.rs index 94b103414340..fd30fda53c4f 100644 --- a/crates/test-programs/wasi-http-tests/src/lib.rs +++ b/crates/test-programs/wasi-http-tests/src/lib.rs @@ -67,7 +67,7 @@ pub fn request( Some(path_with_query), Some(&scheme), Some(authority), - headers, + &headers, ); let outgoing_body = request diff --git a/crates/wasi-http/src/types_impl.rs b/crates/wasi-http/src/types_impl.rs index bc2ae97f4ed5..0cbde9f5cd85 100644 --- a/crates/wasi-http/src/types_impl.rs +++ b/crates/wasi-http/src/types_impl.rs @@ -470,7 +470,6 @@ impl crate::bindings::http::types::HostOutgoingResponse for T { headers: Resource, ) -> wasmtime::Result> { let fields = get_fields_mut(self.table(), &headers)?.clone(); - self.table().delete_resource(headers)?; let id = self.table().push_resource(HostOutgoingResponse { status, diff --git a/crates/wasi-http/wit/deps/http/incoming-handler.wit b/crates/wasi-http/wit/deps/http/incoming-handler.wit index ad8a43f8ccf0..70a6a043a0c7 100644 --- a/crates/wasi-http/wit/deps/http/incoming-handler.wit +++ b/crates/wasi-http/wit/deps/http/incoming-handler.wit @@ -18,7 +18,7 @@ interface incoming-handler { // critical path, since there is no return value, there is no way to report // its success or failure. handle: func( - request: /* own */ incoming-request, - response-out: /* own */ response-outparam + request: incoming-request, + response-out: response-outparam ) } diff --git a/crates/wasi-http/wit/deps/http/outgoing-handler.wit b/crates/wasi-http/wit/deps/http/outgoing-handler.wit index 43bd0035fc06..9b6a73c0cb9b 100644 --- a/crates/wasi-http/wit/deps/http/outgoing-handler.wit +++ b/crates/wasi-http/wit/deps/http/outgoing-handler.wit @@ -14,7 +14,7 @@ interface outgoing-handler { // Consumes the outgoing-request. Gives an error if the outgoing-request // is invalid or cannot be satisfied by this handler. handle: func( - request: /* own */ outgoing-request, + request: outgoing-request, options: option ) -> result } diff --git a/crates/wasi-http/wit/deps/http/types.wit b/crates/wasi-http/wit/deps/http/types.wit index aa486f3c7c7c..edfa2fb8978a 100644 --- a/crates/wasi-http/wit/deps/http/types.wit +++ b/crates/wasi-http/wit/deps/http/types.wit @@ -87,7 +87,7 @@ interface types { // Will return the input-stream child at most once. If called more than // once, subsequent calls will return error. - consume: func() -> result< /* own */ incoming-body> + consume: func() -> result } resource outgoing-request { @@ -96,7 +96,7 @@ interface types { path-with-query: option, scheme: option, authority: option, - headers: /* borrow */ headers + headers: borrow ) // Will return the outgoing-body child at most once. If called more than @@ -127,7 +127,7 @@ interface types { // (the `wasi:http/handler` interface used for both incoming and outgoing can // simply return a `stream`). resource response-outparam { - set: static func(param: /* own */ response-outparam, response: result< /* own */ outgoing-response, error>) + set: static func(param: response-outparam, response: result) } // This type corresponds to the HTTP standard Status Code. @@ -148,7 +148,7 @@ interface types { // May be called at most once. returns error if called additional times. // TODO: make incoming-request-consume work the same way, giving a child // incoming-body. - consume: func() -> result + consume: func() -> result } resource incoming-body { @@ -160,7 +160,7 @@ interface types { // takes ownership of incoming-body. this will trap if the // incoming-body-stream child is still alive! - finish: static func(this: /* own */ incoming-body) -> + finish: static func(this: incoming-body) -> /* transitive child of the incoming-response of incoming-body */ future-trailers } @@ -174,11 +174,11 @@ interface types { } resource outgoing-response { - constructor(status-code: status-code, headers: /* borrow */ headers) + constructor(status-code: status-code, headers: borrow) /// Will give the child outgoing-response at most once. subsequent calls will /// return an error. - write: func() -> result + write: func() -> result } resource outgoing-body { @@ -190,7 +190,7 @@ interface types { /// called to signal that the response is complete. If the `outgoing-body` is /// dropped without calling `outgoing-body-finalize`, the implementation /// should treat the body as corrupted. - finish: static func(this: /* own */ outgoing-body, trailers: /* own */ option) + finish: static func(this: outgoing-body, trailers: option) } /// The following block defines a special resource type used by the diff --git a/crates/wasi/wit/deps/http/incoming-handler.wit b/crates/wasi/wit/deps/http/incoming-handler.wit index ad8a43f8ccf0..70a6a043a0c7 100644 --- a/crates/wasi/wit/deps/http/incoming-handler.wit +++ b/crates/wasi/wit/deps/http/incoming-handler.wit @@ -18,7 +18,7 @@ interface incoming-handler { // critical path, since there is no return value, there is no way to report // its success or failure. handle: func( - request: /* own */ incoming-request, - response-out: /* own */ response-outparam + request: incoming-request, + response-out: response-outparam ) } diff --git a/crates/wasi/wit/deps/http/outgoing-handler.wit b/crates/wasi/wit/deps/http/outgoing-handler.wit index 43bd0035fc06..9b6a73c0cb9b 100644 --- a/crates/wasi/wit/deps/http/outgoing-handler.wit +++ b/crates/wasi/wit/deps/http/outgoing-handler.wit @@ -14,7 +14,7 @@ interface outgoing-handler { // Consumes the outgoing-request. Gives an error if the outgoing-request // is invalid or cannot be satisfied by this handler. handle: func( - request: /* own */ outgoing-request, + request: outgoing-request, options: option ) -> result } diff --git a/crates/wasi/wit/deps/http/types.wit b/crates/wasi/wit/deps/http/types.wit index aa486f3c7c7c..edfa2fb8978a 100644 --- a/crates/wasi/wit/deps/http/types.wit +++ b/crates/wasi/wit/deps/http/types.wit @@ -87,7 +87,7 @@ interface types { // Will return the input-stream child at most once. If called more than // once, subsequent calls will return error. - consume: func() -> result< /* own */ incoming-body> + consume: func() -> result } resource outgoing-request { @@ -96,7 +96,7 @@ interface types { path-with-query: option, scheme: option, authority: option, - headers: /* borrow */ headers + headers: borrow ) // Will return the outgoing-body child at most once. If called more than @@ -127,7 +127,7 @@ interface types { // (the `wasi:http/handler` interface used for both incoming and outgoing can // simply return a `stream`). resource response-outparam { - set: static func(param: /* own */ response-outparam, response: result< /* own */ outgoing-response, error>) + set: static func(param: response-outparam, response: result) } // This type corresponds to the HTTP standard Status Code. @@ -148,7 +148,7 @@ interface types { // May be called at most once. returns error if called additional times. // TODO: make incoming-request-consume work the same way, giving a child // incoming-body. - consume: func() -> result + consume: func() -> result } resource incoming-body { @@ -160,7 +160,7 @@ interface types { // takes ownership of incoming-body. this will trap if the // incoming-body-stream child is still alive! - finish: static func(this: /* own */ incoming-body) -> + finish: static func(this: incoming-body) -> /* transitive child of the incoming-response of incoming-body */ future-trailers } @@ -174,11 +174,11 @@ interface types { } resource outgoing-response { - constructor(status-code: status-code, headers: /* borrow */ headers) + constructor(status-code: status-code, headers: borrow) /// Will give the child outgoing-response at most once. subsequent calls will /// return an error. - write: func() -> result + write: func() -> result } resource outgoing-body { @@ -190,7 +190,7 @@ interface types { /// called to signal that the response is complete. If the `outgoing-body` is /// dropped without calling `outgoing-body-finalize`, the implementation /// should treat the body as corrupted. - finish: static func(this: /* own */ outgoing-body, trailers: /* own */ option) + finish: static func(this: outgoing-body, trailers: option) } /// The following block defines a special resource type used by the