-
Notifications
You must be signed in to change notification settings - Fork 2
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
Error on server compile #27
Comments
I'm looking into it now. |
@DevasiaThomas I have found the problem. The macro did not consider the case where a trait path is specified instead of the trait ident, and I also took the wrong way to extract ident from path. This should be fixed now in version 0.8.2 (macro version 0.6.2), and I have updated Please let me know if this fixes your problem. |
Hi @minghuaw First off, thanks for pushing out a fix at break neck speed - appreciate it :). Unfortunately, the new crate wants my project to switch to rust nightly. It fails to download the macro crate
Is it required for me to switch? I'm on stable right now. |
I just noticed 2021 was released to stable a few days back. Let me update and check again :) |
Sorry I forgot to mention that the edition was also updated. |
@DevasiaThomas I have reverted back to 2018 edition in version 0.8.3. Version 0.8.2 is yanked on crates.io for now. |
Oh, you didn't have to. I already updated my code to move to 2021, I was just writing the client side right now before I responded again. |
I was actually only testing whether the new edition compiles or not, but forgot to change it back and published it. I think edition 2018 would be more friendly for people who haven't upgraded their rust version yet. |
@minghuaw Good news :) It's working as intended. Couple of questions
I have to say @minghuaw your framework had me up and running in a few hours, I spent days on cap'n proto and a few others and just gave up. For now I'll ditch the cross-language support for speed of development. |
The library doesn't have built-in mechanism right now. #5 mentioned a crate called stubborn-io which can be used with
This has not been implemented yet. I am considering adding a context which can be accessed within the server impl in probably version 0.9, and I guess the client network info can be included in that context.
Good point. I haven't thought much about this before in terms of error handling, so right now it would just treat a dropped connection as if the remote peer decided to disconnect. This is clearly a bad design. I will fix this in the next minor update (likely in 0.8.4).
let stream = TcpStream::connect("127.0.0.1:8080").await?;
stream.set_nodelay(true)?;
let client = Client::with_stream(stream); However, it looks like
I didn't implement this because it was originally simply trying to mimic the APIs of go's
Do you have a specific (or some) cross language protocol that you were considering? I was thinking about adding cross language protocol support but wasn't sure which one people need the most. I guess what you need can be a good start point :) |
Nice! I'll definitely give it a shot. In this case you just won't dial I'm assuming
Awesome! I hope the otel part of the context isn't mandatory :)
I just saw stubborn-io, it allows a bunch of callbacks to be registered incase of failure to connect vs drops.. Maybe you can mimc that? stubborn-io only cares about client side though.
I'll raise an issue there to see if they are opening to address this. stubborn feels like something I should use client side now :)
I thought you would come back with this :) . I might transition to this when I finally have the need to push configuration data from upstream to clients.
How would you achieve this? Generate code for those languages? Or have them copy the schema instead and support the serde in that language? As such I don't know the language I have to interact with. I might have to get back to you on this one within a few weeks :) |
I haven't decided the design of the Context yet. I will definitely open an issue to get some feedback before finalizing it.
I am indeed thinking about that, but this will probably be low on the priority list for 0.9.
I am open to such design in the future. Right now I am just not sure about the server side API like how does it know which client it's calling (which I guess client connection info will be necessary), and etc.
I was indeed considering generating code lol, but since I haven't chosen a protocol, I am open to any approach. This is also kind of why I started working on an AMQP1.0 project (which isn't complete and thus not public yet). |
All errors related to connection (read/write) have been unified to |
I'm not sure what I am doing wrong, but I'm getting an error(shared below) while compiling the server and I'm at a loss here. Below is the code. My message was an enum initially - I thought it was related to that but that doesn't seem to be the case. I'm running rust
v1.54.0
. I do acargo publish --dry-run
and point to the packaged version of the service definition project.Service Definition project
Server Implementation project
The text was updated successfully, but these errors were encountered: