Version 3.7 beta/preview
3 posters
Page 1 of 1
Version 3.7 beta/preview
This is a little something for the script nerds. I leave it with that to see what questions pop up.
Version 3.6.1.69 Use download in later post
Last edited by Admin on Wed Dec 06, 2023 3:48 pm; edited 1 time in total
Re: Version 3.7 beta/preview
That's interesting !
I have a background script with the following :
And a buttton with the following code :
but surprisingly the button image and text are not updated when I load the page that contains it.
Attached is a log file.
Any idea ?
I have a background script with the following :
- Code:
[(cc:16,1,0-127){@g_n1:#@e_ccvalue#}]
[(cc:16,2,0-127){@g_n2:#@e_ccvalue#}]
[(cc:16,3,0-127){@g_n3:#@e_ccvalue#}]
[(cc:16,4,0-127){@g_n4:#@e_ccvalue#}]
[(cc:16,5,0-127){@g_n5:#@e_ccvalue#}]
[(cc:16,6,0-127){@g_n6:#@e_ccvalue#}]
[(cc:16,7,0-127){@g_n7:#@e_ccvalue#}]
[(cc:16,8,0-127){@g_n8:#@e_ccvalue#}{@g_nupd:1}]
And a buttton with the following code :
- Code:
[(init){image:%trevligaspel%/Icons/Blank.png}]
[(press){cc:1,1,127}]
[(release){cc:1,1,0}]
[(@g_nupd:1){text:#CONCAT(CHAR(10),CHAR(10),CHAR(@g_n1 ),CHAR(@g_n2 ),CHAR(@g_n3 ),CHAR(@g_n4 ),CHAR(@g_n5 ),CHAR(@g_n6 ),CHAR(@g_n7 ),CHAR(@g_n8 ))#}{@g_nupd:0}]
[(init)(@g_nupd:1){text:#CONCAT(CHAR(10),CHAR(10),CHAR(@g_n1 ),CHAR(@g_n2 ),CHAR(@g_n3 ),CHAR(@g_n4 ),CHAR(@g_n5 ),CHAR(@g_n6 ),CHAR(@g_n7 ),CHAR(@g_n8 ))#}{@g_nupd:0}]
[(cc:3,0,1){image:%trevligaspel%/Icons/TrackMuteSolo-1.png}]
[(cc:3,0,2){image:%trevligaspel%/Icons/TrackMuteSolo-2.png}]
[(cc:3,0,3){image:%trevligaspel%/Icons/TrackMuteSolo-3.png}]
[(cc:3,0,4){image:%trevligaspel%/Icons/TrackMuteSolo-4.png}]
[(cc:3,0,5){image:%trevligaspel%/Icons/TrackMuteSolo-5.png}]
[(init)(cc:3,0,1){image:%trevligaspel%/Icons/TrackMuteSolo-1.png}]
[(init)(cc:3,0,2){image:%trevligaspel%/Icons/TrackMuteSolo-2.png}]
[(init)(cc:3,0,3){image:%trevligaspel%/Icons/TrackMuteSolo-3.png}]
[(init)(cc:3,0,4){image:%trevligaspel%/Icons/TrackMuteSolo-4.png}]
[(init)(cc:3,0,5){image:%trevligaspel%/Icons/TrackMuteSolo-5.png}]
but surprisingly the button image and text are not updated when I load the page that contains it.
Attached is a log file.
Any idea ?
- Attachments
thx538- Posts : 130
Join date : 2023-10-23
Re: Version 3.7 beta/preview
That was interesting. I had to detach the script engine from the script button to have it available for background usage. When doing so, I verified that scripts still ran as expected in the script button, but I failed to verify the (init) commands.
The code is there to handle the (init) commands, but due to an unexpected and interesting chicken-and-egg situation, it didn't work. Fixed in this version; thanks for the report.
Version 3.6.1.74 Use download in later post.
The code is there to handle the (init) commands, but due to an unexpected and interesting chicken-and-egg situation, it didn't work. Fixed in this version; thanks for the report.
Last edited by Admin on Sat Dec 09, 2023 10:16 am; edited 1 time in total
Re: Version 3.7 beta/preview
Thanks ...
It works as expected now.
Background script provides an elegant way to mutualize common midi handling, especially with buttons duplicated on several pages.
It works as expected now.
Background script provides an elegant way to mutualize common midi handling, especially with buttons duplicated on several pages.
thx538- Posts : 130
Join date : 2023-10-23
Re: Version 3.7 beta/preview
But now it raises the question of parallelism in managing global variables.
Suppose I have {@g_nupd:1} set in a background script, and the following in several buttons : [(@g_nupd:1){... do something here ... }{@g_nupd:0}].
What will happen ? Will the "do something" be executed for all buttons or only once ?
Thanks for your support.
Suppose I have {@g_nupd:1} set in a background script, and the following in several buttons : [(@g_nupd:1){... do something here ... }{@g_nupd:0}].
What will happen ? Will the "do something" be executed for all buttons or only once ?
Thanks for your support.
thx538- Posts : 130
Join date : 2023-10-23
Re: Version 3.7 beta/preview
There is no difference between script buttons and background scripts regarding how variables are handled.
When a script sets a variable, it will immediately trigger commands in all other scripts where this variable is referenced. Each script will be triggered with the triggering value (=1) even though other scripts reset it to 0 during the execution.
So, all scripts will "do something".
When a script sets a variable, it will immediately trigger commands in all other scripts where this variable is referenced. Each script will be triggered with the triggering value (=1) even though other scripts reset it to 0 during the execution.
So, all scripts will "do something".
Re: Version 3.7 beta/preview
Thank you for this explanation and sorry to bother you again, but there is something I don't understand.
I have a background script as follows (extract) :
and then a button script with :
Looking at the second line I would have expected this button to send a CC message on channel 14 (13), but is sends a message on channel 13 (12) instead, as confirmed by the attached log file.
Thanks again for your support.
Edit:
Surprisingly, If I change the button script (2nd and 3rd line) to :
it works as expected.
I have a background script as follows (extract) :
- Code:
[(cc:14,0,0-127){@g_p:#@e_ccvalue#}{@g_dupd:1}] Parameters : Global switch Half Bank
and then a button script with :
- Code:
[(config){TriggerOnLocalMidiEvents:Yes}{TriggerOnUnchangedVariables:Yes}]
[(@g_p:0-127)(@g_dupd:1){cc:14,1,#@g_p#}{@g_dupd:0}] Global half bank switch : Trigger local
[(init)(@g_dupd:1)(@g_p:0-127){cc:14,1,#@g_p#}{@g_dupd:0}]
[(cc:14,1,0-127){@l_bp:#@e_ccvalue#}] 1 Local = Parameter only
[(init)(cc:14,1,0-127){@l_bp:#@e_ccvalue#}]
[(press){cc:14,1,#127 - @l_bp#}]
[(@l_bp:0){image:%trevligaspel%/Icons/ParamB1.png}]
[(@l_bp:127){image:%trevligaspel%/Icons/ParamB2.png}]
Looking at the second line I would have expected this button to send a CC message on channel 14 (13), but is sends a message on channel 13 (12) instead, as confirmed by the attached log file.
Thanks again for your support.
Edit:
Surprisingly, If I change the button script (2nd and 3rd line) to :
- Code:
[(@g_dupd:1){cc:14,1,#@g_p#}{@g_dupd:0}] Global half bank switch : Trigger local
[(init)(@g_dupd:1){cc:14,1,#@g_p#}{@g_dupd:0}]
it works as expected.
- Attachments
thx538- Posts : 130
Join date : 2023-10-23
Re: Version 3.7 beta/preview
That was an interesting bug; it's fantastic that you found it. It must have been present for a long time...
It should be fixed in this version.
Version 3.6.1.76 Use downoad in later post.
It should be fixed in this version.
Last edited by Admin on Sun Dec 10, 2023 3:54 pm; edited 1 time in total
Re: Version 3.7 beta/preview
OK, final(?) version. If no more problems are found, I will start to prepare for the publishing.
Unfortunately, there is a breaking change if you have used plugin-internal ports.
I decided to add an input field where you can define the number of available plugin-internal ports, and with that, I changed the internal representation of the ports. If you have used internal ports, you need to re-select the same ports since it will not find the ports with the previous internal names. Sorry.
Version 3.6.1.84
Unfortunately, there is a breaking change if you have used plugin-internal ports.
I decided to add an input field where you can define the number of available plugin-internal ports, and with that, I changed the internal representation of the ports. If you have used internal ports, you need to re-select the same ports since it will not find the ports with the previous internal names. Sorry.
Version 3.6.1.84
Re: Version 3.7 beta/preview
I am not able to get 3.6.1.84 up and running
2023-12-16 14:56:13.0115|INFO|TrevligaSpel|Plugin version: 3.6.1.84
2023-12-16 14:56:13.0115|INFO|TrevligaSpel|Connecting to Stream Deck...
2023-12-16 14:56:13.0115|INFO|TrevligaSpel|RunAsync WebSocketState.Open
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|RunAsync registerEvent
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|RunAsync OnConnected.Invoke
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|Connected to Stream Deck
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|GlobalSettingsManager initialized
2023-12-16 14:56:13.0742 0,00ms INFO 11 Midi plugin version 3.6.1.84, StreamDeck version 6.4.1.19697
Unhandled Exception: System.NullReferenceException: Object reference not set to an instance of an object.
at StreamDeck_Midi.BackgroundScriptController.AreGlobalSettingsChanged() in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Script\BackgroundScriptController.cs:line 49
at StreamDeck_Midi.GlobalSettings.ReceivedGlobalSettings(ReceivedGlobalSettingsPayload payload) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\GlobalSettings.cs:line 799
at StreamDeck_Midi.PluginActionNoteOn.ReceivedGlobalSettings(ReceivedGlobalSettingsPayload payload) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionNoteOn.cs:line 1791
at BarRaider.SdTools.PluginContainer.Connection_OnDidReceiveGlobalSettings(Object sender, SDEventReceivedEventArgs`1 e) in E:\Projects\barraider-sdtools 6.1.1\Backend\PluginContainer.cs:line 254
at System.Threading.Tasks.Task.<>c.<ThrowAsync>b__128_1(Object state)
at System.Threading.ThreadPoolWorkQueue.Dispatch()
at System.Threading.PortableThreadPool.WorkerThread.WorkerThreadStart()
2023-12-16 14:56:13.0115|INFO|TrevligaSpel|Plugin version: 3.6.1.84
2023-12-16 14:56:13.0115|INFO|TrevligaSpel|Connecting to Stream Deck...
2023-12-16 14:56:13.0115|INFO|TrevligaSpel|RunAsync WebSocketState.Open
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|RunAsync registerEvent
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|RunAsync OnConnected.Invoke
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|Connected to Stream Deck
2023-12-16 14:56:13.0351|INFO|TrevligaSpel|GlobalSettingsManager initialized
2023-12-16 14:56:13.0742 0,00ms INFO 11 Midi plugin version 3.6.1.84, StreamDeck version 6.4.1.19697
Unhandled Exception: System.NullReferenceException: Object reference not set to an instance of an object.
at StreamDeck_Midi.BackgroundScriptController.AreGlobalSettingsChanged() in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Script\BackgroundScriptController.cs:line 49
at StreamDeck_Midi.GlobalSettings.ReceivedGlobalSettings(ReceivedGlobalSettingsPayload payload) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\GlobalSettings.cs:line 799
at StreamDeck_Midi.PluginActionNoteOn.ReceivedGlobalSettings(ReceivedGlobalSettingsPayload payload) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionNoteOn.cs:line 1791
at BarRaider.SdTools.PluginContainer.Connection_OnDidReceiveGlobalSettings(Object sender, SDEventReceivedEventArgs`1 e) in E:\Projects\barraider-sdtools 6.1.1\Backend\PluginContainer.cs:line 254
at System.Threading.Tasks.Task.<>c.<ThrowAsync>b__128_1(Object state)
at System.Threading.ThreadPoolWorkQueue.Dispatch()
at System.Threading.PortableThreadPool.WorkerThread.WorkerThreadStart()
Joerg- Posts : 142
Join date : 2021-09-03
Re: Version 3.7 beta/preview
That's a very odd error.
The only way I can imagine this may possibly happen is if you had the published 3.6 version installed and uninstalled that before installing the beta. Is that the case?
Anyhow, try this version:
Version 3.7.0.1
The only way I can imagine this may possibly happen is if you had the published 3.6 version installed and uninstalled that before installing the beta. Is that the case?
Anyhow, try this version:
Version 3.7.0.1
Re: Version 3.7 beta/preview
That is exactly what happend. I always deinstall the official published version before installing the test version because of problems I had in the past.Admin wrote:That's a very odd error.
The only way I can imagine this may possibly happen is if you had the published 3.6 version installed and uninstalled that before installing the beta. Is that the case?
Anyhow, try this version:
Version 3.7.0.1
Joerg- Posts : 142
Join date : 2021-09-03
Re: Version 3.7 beta/preview
I was able to install 3.7.0.1 and everything looks like working as usual.
Then I tried to create an instance of "Backgound Scripts", which isn't working.
2023-12-16 16:57:22.0523|DEBUG|TrevligaSpel|Logger Initialized
2023-12-16 16:57:22.0649|INFO|TrevligaSpel|Plugin [se.trevligaspel.midi] Loading - 12 Actions Found
2023-12-16 16:57:22.2091|INFO|TrevligaSpel|RunAsync Start
2023-12-16 16:57:22.2435|DEBUG|TrevligaSpel|Plugin Loaded: UUID: 2508B48221C21D147A440B826582B330 Device Info: Devices:
[Id: F7FB5408A117D1FD12966C0099CFFE0A Type: StreamDeckMobile Size: Rows: 8 Columns: 8]
[Id: 8C8F4250384A04C2D0BCEB0478841950 Type: StreamDeckPlus Size: Rows: 2 Columns: 4]
[Id: D71A3FD4D97D37F5BBFC61C6F13BCD43 Type: StreamDeckMobile Size: Rows: 8 Columns: 8]
[Id: 40F22F6F89AB0EAAD15FF3FDB40CAC4D Type: StreamDeckMobile Size: Rows: 8 Columns: 8]
[Id: E77015FA9AF980029CA2CA0372321E93 Type: StreamDeckXL Size: Rows: 4 Columns: 8]
[Id: E4081A4570A71A869536C2D711A5D6B4 Type: CorsairGKeys Size: Rows: 1 Columns: 4]
ApplicationInfo: Language: de Platform: windows Version: 6.4.1.19697
PluginInfo: Version: 3.7.0.1
2023-12-16 16:57:22.2435|INFO|TrevligaSpel|Plugin version: 3.7.0.1
2023-12-16 16:57:22.2435|INFO|TrevligaSpel|Connecting to Stream Deck...
2023-12-16 16:57:22.4127|INFO|TrevligaSpel|RunAsync WebSocketState.Open
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|RunAsync registerEvent
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|RunAsync OnConnected.Invoke
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|Connected to Stream Deck
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|GlobalSettingsManager initialized
2023-12-16 16:57:22.4752 0,00ms INFO 11 Midi plugin version 3.7.0.1, StreamDeck version 6.4.1.19697
2023-12-16 17:02:36.1080 313632,78ms ERROR 84 BackgroundScript Constructor [d925ddac46587986affd6d6756d8fdac:Exception:System.ArgumentOutOfRangeException: Index was out of range. Must be non-negative and less than the size of the collection. (Parameter 'index')
at System.Collections.Generic.List`1.get_Item(Int32 index)
at StreamDeck_Midi.PluginActionBackgroundScript.GlobalHasDefaultValues(Int32 idx) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionBackgroundScript.cs:line 464
at StreamDeck_Midi.PluginActionBackgroundScript.GlobalSettingsChanged(Boolean constructorcall) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionBackgroundScript.cs:line 391
at StreamDeck_Midi.PluginActionBackgroundScript..ctor(SDConnection connection, InitialPayload payload) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionBackgroundScript.cs:line 328]
Then I tried to create an instance of "Backgound Scripts", which isn't working.
2023-12-16 16:57:22.0523|DEBUG|TrevligaSpel|Logger Initialized
2023-12-16 16:57:22.0649|INFO|TrevligaSpel|Plugin [se.trevligaspel.midi] Loading - 12 Actions Found
2023-12-16 16:57:22.2091|INFO|TrevligaSpel|RunAsync Start
2023-12-16 16:57:22.2435|DEBUG|TrevligaSpel|Plugin Loaded: UUID: 2508B48221C21D147A440B826582B330 Device Info: Devices:
[Id: F7FB5408A117D1FD12966C0099CFFE0A Type: StreamDeckMobile Size: Rows: 8 Columns: 8]
[Id: 8C8F4250384A04C2D0BCEB0478841950 Type: StreamDeckPlus Size: Rows: 2 Columns: 4]
[Id: D71A3FD4D97D37F5BBFC61C6F13BCD43 Type: StreamDeckMobile Size: Rows: 8 Columns: 8]
[Id: 40F22F6F89AB0EAAD15FF3FDB40CAC4D Type: StreamDeckMobile Size: Rows: 8 Columns: 8]
[Id: E77015FA9AF980029CA2CA0372321E93 Type: StreamDeckXL Size: Rows: 4 Columns: 8]
[Id: E4081A4570A71A869536C2D711A5D6B4 Type: CorsairGKeys Size: Rows: 1 Columns: 4]
ApplicationInfo: Language: de Platform: windows Version: 6.4.1.19697
PluginInfo: Version: 3.7.0.1
2023-12-16 16:57:22.2435|INFO|TrevligaSpel|Plugin version: 3.7.0.1
2023-12-16 16:57:22.2435|INFO|TrevligaSpel|Connecting to Stream Deck...
2023-12-16 16:57:22.4127|INFO|TrevligaSpel|RunAsync WebSocketState.Open
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|RunAsync registerEvent
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|RunAsync OnConnected.Invoke
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|Connected to Stream Deck
2023-12-16 16:57:22.4361|INFO|TrevligaSpel|GlobalSettingsManager initialized
2023-12-16 16:57:22.4752 0,00ms INFO 11 Midi plugin version 3.7.0.1, StreamDeck version 6.4.1.19697
2023-12-16 17:02:36.1080 313632,78ms ERROR 84 BackgroundScript Constructor [d925ddac46587986affd6d6756d8fdac:Exception:System.ArgumentOutOfRangeException: Index was out of range. Must be non-negative and less than the size of the collection. (Parameter 'index')
at System.Collections.Generic.List`1.get_Item(Int32 index)
at StreamDeck_Midi.PluginActionBackgroundScript.GlobalHasDefaultValues(Int32 idx) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionBackgroundScript.cs:line 464
at StreamDeck_Midi.PluginActionBackgroundScript.GlobalSettingsChanged(Boolean constructorcall) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionBackgroundScript.cs:line 391
at StreamDeck_Midi.PluginActionBackgroundScript..ctor(SDConnection connection, InitialPayload payload) in E:\Projects\StreamDeck-Midi - Net 7 3.7\StreamDeck-Midi\Actions\PluginActionBackgroundScript.cs:line 328]
Joerg- Posts : 142
Join date : 2021-09-03
Re: Version 3.7 beta/preview
Please tell me how you installed the updates.
I still claim that the only way I can imagine this may possibly happen is if you had the published 3.6 version installed and uninstalled that before installing the beta. Is that the case?
I still claim that the only way I can imagine this may possibly happen is if you had the published 3.6 version installed and uninstalled that before installing the beta. Is that the case?
Re: Version 3.7 beta/preview
It's important to me to understand how you got to this point. Version 3.7 is already published on MarketPlace, so I need to understand why you get this problem.
Re: Version 3.7 beta/preview
Admin wrote:It's important to me to understand how you got to this point. Version 3.7 is already published on MarketPlace, so I need to understand why you get this problem.
As mentioned above this is exactly what happend.
I uninstalled the official Midi version from the shop and after that I installed your 3.6.xx test version by simply unpacking and clicking on the data file to be installed by StreamDeck. As this Version didn't work out, I uninstalled everything again, closed StreamDeck, restarted StreamDeck and went for another install which didn't work either.
After that I uninstalled everything and installed Version 3.7.xx which is up and running now. The only thing that isn't working is the new "Background scripts" function.
Joerg- Posts : 142
Join date : 2021-09-03
Re: Version 3.7 beta/preview
I can't imagine what the problem is, I can't reproduce it, no matter how brutal I am.
Could you please enable extended logging, restart the Stream Deck software and send me the (whole) log file?
Could you please enable extended logging, restart the Stream Deck software and send me the (whole) log file?
Re: Version 3.7 beta/preview
Yes, that's why I was so eager to learn exactly how you performed the update. These settings are stored in the global settings (not in the profile), And the state of the global settings and from where it is read depends very much on the sequence of actions.
Re: Version 3.7 beta/preview
Version 3.7 is now released; thanks for the help with testing it.
Regarding the update/installation procedure, I recommend always doing an update (not a reinstall) if possible. The only situations where an update isn't possible is if you want to reinstall the same version or downgrade to an earlier version.
When I release new versions (beta or release), the version number is always increased, so an update is possible.
The only difference between an update and a reinstall is, as far as I know, that the global settings are deleted if you perform a reinstall. Global settings keep many settings for the plugin, such as Mackie midi ports, default settings for dials and buttons and the background script configuration.
The plugin tries in various ways to recreate the deleted global settings if you do a reinstall, but depending on the situation, this may be more or less successful. So, if possible, do an update, not a reinstall.
Regarding the update/installation procedure, I recommend always doing an update (not a reinstall) if possible. The only situations where an update isn't possible is if you want to reinstall the same version or downgrade to an earlier version.
When I release new versions (beta or release), the version number is always increased, so an update is possible.
The only difference between an update and a reinstall is, as far as I know, that the global settings are deleted if you perform a reinstall. Global settings keep many settings for the plugin, such as Mackie midi ports, default settings for dials and buttons and the background script configuration.
The plugin tries in various ways to recreate the deleted global settings if you do a reinstall, but depending on the situation, this may be more or less successful. So, if possible, do an update, not a reinstall.
Re: Version 3.7 beta/preview
Hello,
Just out of curiosity, what is "New key images" ?
Just out of curiosity, what is "New key images" ?
thx538- Posts : 130
Join date : 2023-10-23
Similar topics
» Version 3.5.2 preview
» Version 3.5.1 preview
» Version 3.8 beta
» Version 3.6 beta
» Version 3.9 beta
» Version 3.5.1 preview
» Version 3.8 beta
» Version 3.6 beta
» Version 3.9 beta
Page 1 of 1
Permissions in this forum:
You cannot reply to topics in this forum