Skip to content
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

Find better Place for OMC.Connect #78

Open
manuEbg opened this issue Jun 29, 2021 · 4 comments
Open

Find better Place for OMC.Connect #78

manuEbg opened this issue Jun 29, 2021 · 4 comments
Assignees
Labels
enhancement New feature or request

Comments

@manuEbg
Copy link
Contributor

manuEbg commented Jun 29, 2021

We need to find a better place for this Line .

Reasons:

Propsal:
Create new RPC-Method connectCompiler, which obviously connects to the compiler, and maybe sets some kind of variable that allows other functions like checkModel to report an error if compiler is not connected instead of failing....

@manuEbg manuEbg added the enhancement New feature or request label Jun 29, 2021
@manuEbg manuEbg self-assigned this Jun 29, 2021
@CSchoel
Copy link
Contributor

CSchoel commented Jul 2, 2021

Objection! 🗣️ 👉

Please think about your users, in this case the developers that have to implement the client. Everything you do inside the LSP framework comes almost free of cost at the client side, because you can use standard LSP libraries. Custom JSON RPC commands, however, require custom code at the client side. Therefore, there should be a very good justification for each JSON RPC call. The whole point of using LSP is to make the implementation of clients as easy as possible.

In this case, I see no justification at all for a custom call. When the client asks the server to initialize, it is reasonable to expect that the server will do everything required to be able to receive any other command. If this causes issues with multiple clients, you have to a) start a separate OMC instance for each client or b) check whether the OMC is already running and only issue a new connection if this is not the case.

Also as a side note I think your link leads to the wrong line of code. In the title you talk about OMC:connect, but the link shows the line associated with #74 .

@manuEbg
Copy link
Contributor Author

manuEbg commented Jul 2, 2021

Correct the Link was wrong... not sure how this happened:) Thanks for pointing this out!

I see the Problem you pointed out regarding another RPC command... But i thought it might be useful to allow a client to trigger a "reconnect" to the compiler.

Also I thought that the InitializeMethod intended to be more kind of a handshake and capability exchange than "Initialization".

@CSchoel
Copy link
Contributor

CSchoel commented Jul 2, 2021

I think the idea of the initialize method is twofold: The first part is a handshake, exactly as you said, and the second part why it is useful is that it provides a time window where client and server know about each other, but do not actively send messages. That time window is exactly what we need to connect to the OMC. Otherwise, as you have already noted, you would have to implement error handling procedures for virtually any other request that can be made by the client, because it would fail if the OMC is not connected.

Nothing stops you from implementing a separate reset/reconnect command, but again: Think from the user's point of view. If you have the option, do you want to send two commands to the server in order to start working on your project, or rather just one? KISS.

@manuEbg
Copy link
Contributor Author

manuEbg commented Jul 3, 2021

Nothing stops you from implementing a separate reset/reconnect command, but again: Think from the user's point of view. If you have the option, do you want to send two commands to the server in order to start working on your project, or rather just one?

I don't want to send two commands 😊

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants