-
Notifications
You must be signed in to change notification settings - Fork 109
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
API Refactoring #273
API Refactoring #273
Conversation
0fe7b23
to
4f01da2
Compare
motivation: define stable API in preperation 1.0 release changes: * require swift 5.7, remove redundant backwards compatibility code * make LambdaHandler, EventLoopLambdaHandler, and ByteBufferLambdaHandler disjointed protocols to reduce API surface area * create coding wrappers for LambdaHandler and EventLoopLambdaHandler to provide coding bridge * reuse output ByteBuffer to reduce allocationsi * add no-op initializer for simple landa use cases * update callsites and tests
@fabianfett ptal |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great progress! Love the Handlers that don't depend on each other anymore. However we should preserve the types were feasible. And also I don't think we can get rid of the required initializer that easily.
@@ -33,7 +33,7 @@ internal final class LambdaRunner { | |||
/// Run the user provided initializer. This *must* only be called once. | |||
/// | |||
/// - Returns: An `EventLoopFuture<LambdaHandler>` fulfilled with the outcome of the initialization. | |||
func initialize<Handler: ByteBufferLambdaHandler>(logger: Logger, terminator: LambdaTerminator, handlerType: Handler.Type) -> EventLoopFuture<Handler> { | |||
func initialize(handlerType: (some ByteBufferLambdaHandler).Type, logger: Logger, terminator: LambdaTerminator) -> EventLoopFuture<any ByteBufferLambdaHandler> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We must enforce 5.7 if we want to use this syntax. Currently we require 5.6. Also IMO we def. should not return any
here. We should preserve the type.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this PR already changes the requirement to 5.7, unless I missed something?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It only changes this for all the examples. It also drops the 5.4 and 5.5 Package.swift. But the Package.swift without version only requires 5.6.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also I think you are required to use the old generic syntax here, if we don't want to drop the types. Since we need create a connection between the input and the output type.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But the Package.swift without version only requires 5.6.
good catch
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also I think you are required to use the old generic syntax here, if we don't want to drop the types. Since we need create a connection between the input and the output type.
I don't think this can work with the old syntax. the Handler type is stored in LambdaRuntime which needs to loose it old generic signature, so they do not align any more
return Handler.makeHandler(context: context) | ||
|
||
return handlerType.makeHandler(context: context) | ||
.map { $0 as any ByteBufferLambdaHandler } |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
don't drop types here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this was required to make the type system happy. do you have a better way to do this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we don't need to drop here, if we keep the old syntax above.
@@ -58,7 +60,7 @@ internal final class LambdaRunner { | |||
} | |||
} | |||
|
|||
func run<Handler: ByteBufferLambdaHandler>(logger: Logger, handler: Handler) -> EventLoopFuture<Void> { | |||
func run(logger: Logger, handler: any ByteBufferLambdaHandler) -> EventLoopFuture<Void> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
no type dropping here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ditto
@@ -19,34 +19,58 @@ import NIOCore | |||
/// `LambdaRuntime` manages the Lambda process lifecycle. | |||
/// | |||
/// Use this API, if you build a higher level web framework which shall be able to run inside the Lambda environment. | |||
public final class LambdaRuntime<Handler: ByteBufferLambdaHandler> { | |||
public final class LambdaRuntime { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We did we drop the type here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this was required to remove the conformance to ByteBufferLambdaHandler
from the other protocols, as otherwise initializing LambdaRuntime would require it. Do you have a better solution in mind?
Co-authored-by: Yim Lee <yim_lee@apple.com>
* Preserve Types. * Go inline!
@fabianfett now with your changes. thank you |
Hi there. Is there any update on when v1.0 will be released with the Swift async/await support? I am excited to use this in my software! |
hi @benrosen78 we are planning to tag the first 1.0 alpha in the next few weeks. you can use it already by pulling the "main" branch in your dependency |
refactoring the API for 1.0