From 6f5ec50992e64b5b9dbd714ec1dd8b33a2c6a48a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20M=C3=BChlegger?= Date: Fri, 23 Aug 2024 15:30:56 +0200 Subject: [PATCH] Fix S7 offline blocks with comments can't generate AWL Code --- .../Step7V5/BlocksOfflineFolder.cs | 36 +++++++++---------- 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/LibNoDaveConnectionLibrary/DataTypes/Projectfolders/Step7V5/BlocksOfflineFolder.cs b/LibNoDaveConnectionLibrary/DataTypes/Projectfolders/Step7V5/BlocksOfflineFolder.cs index e0e24293..063dafa2 100644 --- a/LibNoDaveConnectionLibrary/DataTypes/Projectfolders/Step7V5/BlocksOfflineFolder.cs +++ b/LibNoDaveConnectionLibrary/DataTypes/Projectfolders/Step7V5/BlocksOfflineFolder.cs @@ -668,6 +668,24 @@ public Block GetBlock(ProjectBlockInfo blkInfo, S7ConvertingOptions myConvOpt) FBStaticAccessConverter.ReplaceStaticAccess(retVal, prgFld, myConvOpt); + for (int i = 0; i < retVal.AWLCode.Count - 1; i++) + { + S7FunctionBlockRow akRw = (S7FunctionBlockRow)retVal.AWLCode[i]; + + if (akRw.CombineDBAccess) + { + S7FunctionBlockRow nRw = (S7FunctionBlockRow)retVal.AWLCode[i + 1]; + if (!nRw.Parameter.Contains("[")) + { + nRw.Parameter = akRw.Parameter + "." + nRw.Parameter; + nRw.MC7 = Helper.CombineByteArray(akRw.MC7, nRw.MC7); + nRw.Label = akRw.Label ?? nRw.Label; + retVal.AWLCode.RemoveAt(i + 1); + retVal.AWLCode[i] = nRw; + } + } + } + #region UseComments from Block if (myConvOpt.UseComments) { @@ -800,24 +818,6 @@ public Block GetBlock(ProjectBlockInfo blkInfo, S7ConvertingOptions myConvOpt) retVal.AWLCode = newAwlCode; } #endregion - - for (int i = 0; i < retVal.AWLCode.Count - 1; i++) - { - S7FunctionBlockRow akRw = (S7FunctionBlockRow)retVal.AWLCode[i]; - - if (akRw.CombineDBAccess) - { - S7FunctionBlockRow nRw = (S7FunctionBlockRow)retVal.AWLCode[i + 1]; - if (!nRw.Parameter.Contains("[")) - { - nRw.Parameter = akRw.Parameter + "." + nRw.Parameter; - nRw.MC7 = Helper.CombineByteArray(akRw.MC7, nRw.MC7); - nRw.Label = akRw.Label ?? nRw.Label; - retVal.AWLCode.RemoveAt(i + 1); - retVal.AWLCode[i] = nRw; - } - } - } } retVal.Networks = NetWork.GetNetworksList(retVal);