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

Support setting local variables through info items #86

Open
ralphlange opened this issue Apr 11, 2022 · 8 comments
Open

Support setting local variables through info items #86

ralphlange opened this issue Apr 11, 2022 · 8 comments

Comments

@ralphlange
Copy link
Contributor

ralphlange commented Apr 11, 2022

The % redirection parameter often breaks the layering, as record names are required within the protocol file.

Redirection targets can be set through protocol parameters, but - especially for protocols that return a whole bunch of values - this can make database links completely unreadable.

Idea:
Allow setting local StreamDevice variables (scope: protocol) through info items.
A record in the database could do something like

    info(stream:varLINK1, "myotherrecord.A")
    info(stream:varSTATUS, "mystatusrecord")

and the protocol could

    out "VAL?";
    in "%("$LINK1")f,%("$STATUS")i";

Advantage: all record names stay in the database; the protocol file can use redirections and still be application agnostic.

I am willing to work on this, if we can agree on the general idea and interface.

@dirk-zimoch
Copy link
Member

In all my cases the redirection targets have a common prefix (the "device name"). I usually pass only this prefix as the first protocol parameter and have the "remainder" record names hard coded in the protocol. Modularity is maintained and link length stays within reasonable limits.
For example with two target records $(PREFIX)LINK1 and $(PREFIX)STATUS, the link would use "@file protocol($(PREFIX)) $(PORT)" and a protocol like this: in "%(\$1LINK1)f,%(\$1STATUS)i";
Still I can see the advantage of passing protocol variables through info fields. Nice idea and probably easy to implement. I would generally extend this to any protocol variable. If variables with the same name are defined in the protocol and in info fields, which one should have higher priority? In my opiniton the info field.
I would not incude the quotes in the variable defined by the info field (allowing numbers as well). Thus the syntax would look more like: in "%(\${LINK1})f,%(\${STATUS})i";

@dirk-zimoch
Copy link
Member

dirk-zimoch commented Apr 11, 2022

As we are on it, how about globals through environment variables?

@ralphlange
Copy link
Contributor Author

ralphlange commented Apr 11, 2022

Been there, done that.
But the "remainder" is still part of the record name and doesn't really belong into the protocol.
If it needs to be changed because of different naming conventions between the author and the user of the stream support... see attachment. (Real life example from my desk: Evo.proto.txt)

In that case, the user still needs to change the protocol file, changing the variable setting page.

@dirk-zimoch
Copy link
Member

Great :-P
Next think I wanted to do anyway in the protocol files: include.

@ralphlange
Copy link
Contributor Author

That would be very useful, indeed!

@ralphlange
Copy link
Contributor Author

ralphlange commented Apr 11, 2022

I would not include the quotes in the variable defined by the info field (allowing numbers as well). Thus the syntax would look more like: in "%(\${LINK1})f,%(\${STATUS})i";

??! (Don't understand your statement about numbers. Info items are strings.)
I remember trying also that notation - I don't find it much clearer and it is 50% more overhead (three added characters compared to two "s).

@dirk-zimoch
Copy link
Member

Using "%("$LINK1")f" assumes that LINK1 is a quoted string like $upref"Index" in your example (where $upref is another quoted string. This way, we could not pass for example replyTimeout. .... Minor details.

@ralphlange
Copy link
Contributor Author

Oh. I see.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants