Comments (4)
I am not like strongly against the cancellation exception. but I would normally expect cancellation exception from the cancellation token I gave in. if I get random cancellation exception, I will be like what did I cancel?
if I get like UnexcpectedDisconnectionException with message saying, someone Closed or Disposed JsonRpc/Underlying Stream while InvokeAsync is active, then it is more clear why the exception happened.
from vs-streamjsonrpc.
@heejaechang has this been a problem for you with Roslyn? Otherwise I may won't fix this.
from vs-streamjsonrpc.
@AArnott is there a specific reason why it chose to throw cancellation exception rather than explicit exception like unexpected disconnection or something like that?
from vs-streamjsonrpc.
A few reasons:
- It was the simplest approach: the only way the code had to interrupt the task we returned earlier is to cancel it.
- Given this is truly an exceptional situation, if we were to throw a novel exception type, we run the risk of the client not expecting to need to catch and deal with it. But it's quite likely they have a catch block around the call.
- Does the client really need to distinguish from all these events? Or ultimately will it handle them all the same? There already is a way for the client connection owner to receive an event about an unexpected connection closure, so that it could (for example) reconnect. But surely you wouldn't want every single outstanding request to receive an exception and each try to reestablish the connection at once.
That said, we do already define a RemoteRpcException
base class, from which we could derive a more specific exception type. The client should (hopefully) already be prepared to catch this base exception type, so throwing a new derived type should have a relatively low risk.
from vs-streamjsonrpc.
Related Issues (20)
- Add support for call-scoped marshaled objects
- StartListening Thread can take 20-30+ seconds to run HOT 1
- We should document and test the case of sending the same RpcMarshalable object across several top-level RPC methods
- Consider using finalizer and weak references to avoid leaks when proxies are abandoned HOT 2
- Parent <-> child communication design.
- StreamJsonRpc + system.text.json throws hasValue exception if using SingleObjectParameterDeserialization and default parameter HOT 2
- Empty array sent instead of empty object when named arguments should be used
- Add TFM to enable reduction in explicit dependencies HOT 2
- Allow `[RpcMarshalable]` interfaces to declare properties with serialized values HOT 4
- JSON Contract resolver needs to be reused HOT 1
- Support MessagePackFormatterAttribute applied to RPC methods
- User-supplied `TypelessObjectResolver` from MessagePack causes `IAsyncEnumerable<T>` to malfunction
- Support System.Text.Json compatible Json Converter for Request ID HOT 4
- Use camelCase for response objects HOT 4
- Intercept a request and modify it before sending to the server HOT 7
- Connection with Java-based JSON-RPC server fails because Content-Length is required HOT 2
- package downgrade caused by v2.17.8 HOT 7
- JoinableTaskFactory bridge fails with multiple JsonRpc instances in a process without JTF HOT 4
- Deserialization of nested objects when using System.Text.Json HOT 2
- IAsyncEnumerable handler can be cleaned up early HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from vs-streamjsonrpc.