1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281
| Type regles VB() As String
js() As String
Nb As Long
End Type
Dim RG As regles
Function ConvertVBAToJS(vbaCode As String) As String
Dim jsCode As String
Dim lignes() As String
Dim i As Long
If vbaCode = "" Then
ConvertVBAToJS = ""
Exit Function
End If
ChargerReglesConversion
lignes = Split(vbaCode, vbCrLf)
jsCode = "class Regles {" & vbCrLf & " constructor() {" & vbCrLf
For i = LBound(lignes) To UBound(lignes)
jsCode = jsCode & IIf(i > LBound(lignes), vbCrLf, "") & " " & ConvertirLigne(lignes(i))
Next i
jsCode = jsCode & vbCrLf & " }" & vbCrLf & "}" & vbCrLf
jsCode = jsCode & "let RG = new Regles();"
ConvertVBAToJS = jsCode
End Function
Sub ChargerReglesConversion()
Dim i As Long
Dim donnees As Variant
donnees = Array( _
Array("Type ", ""), Array("End Type", ""), _
Array("Dim ", ""), Array(" As String", " = []"), Array(" As Integer", " = 0"), _
Array(" As Long", " = 0"), Array(" As Double", " = 0.0"), Array(" As Boolean", " = false"), _
Array("If ", "if ("), Array(" Then", ") {"), Array("End If", "}"), Array("Else", "} else {"), _
Array("ElseIf ", "} else if ("), Array("For ", "for ("), Array(" To ", "; i <= "), Array("Next", "}"), _
Array("While ", "while ("), Array("Wend", "}"), Array("Sub ", "function "), Array("Function ", "function "), _
Array("End Sub", "}"), Array("End Function", "}"), Array("True", "true"), Array("False", "false"), _
Array("Nothing", "null"), Array("vbCrLf", "'\n'"), Array("vbTextCompare", "1"), Array("MsgBox", "alert"), _
Array("InputBox", "prompt"), Array("Len(", ".length"), Array("UBound(", ".length - 1"), _
Array("Split(", ".split("), Array("Trim(", ".trim("), Array("Replace(", ".replace("), _
Array("InStr(", ".indexOf("), Array("Mid(", ".substring("), Array("Left(", ".substring(0, "), _
Array("Right(", ".slice(-"), Array("Exit Function", "return"), Array("Exit Sub", "return"), _
Array(" And ", " && "), Array(" Or ", " || "), Array(" Not ", "!"), Array("<>", "!="), Array(" & ", " + ") _
)
RG.Nb = UBound(donnees) + 1
ReDim RG.VB(1 To RG.Nb)
ReDim RG.js(1 To RG.Nb)
For i = 0 To RG.Nb - 1
RG.VB(i + 1) = donnees(i)(0)
RG.js(i + 1) = donnees(i)(1)
Next i
End Sub
Function ConvertirLigne(ligne As String) As String
Dim resultat As String
Dim i As Long
ligne = Trim(ligne)
If ligne = "" Then
ConvertirLigne = ""
Exit Function
End If
If Left(ligne, 1) = "'" Then
ConvertirLigne = "//" & Mid(ligne, 2)
Exit Function
End If
resultat = ligne
For i = 1 To RG.Nb
resultat = Replace(resultat, RG.VB(i), RG.js(i), 1, -1, vbTextCompare)
Next i
resultat = GererChaines(resultat)
ConvertirLigne = AjouterPointVirgule(resultat)
End Function
Function GererChaines(texte As String) As String
Dim res As String
Dim i As Long
Dim c As String
Dim dansChaine As Boolean
res = ""
dansChaine = False
For i = 1 To Len(texte)
c = Mid(texte, i, 1)
If c = """" Then
res = res & IIf(dansChaine, "\""", """")
dansChaine = Not dansChaine
Else
res = res & c
End If
Next i
GererChaines = res
End Function
Function AjouterPointVirgule(texte As String) As String
If texte = "" Then
AjouterPointVirgule = ""
Exit Function
End If
If InStr(texte, "function") > 0 Or InStr(texte, "if") > 0 Or InStr(texte, "for") > 0 _
Or InStr(texte, "while") > 0 Or InStr(texte, "{") > 0 Or InStr(texte, "}") > 0 Then
AjouterPointVirgule = texte
ElseIf Right(texte, 1) <> ";" Then
AjouterPointVirgule = texte & ";"
Else
AjouterPointVirgule = texte
End If
End Function
Function RegX(code As String) As String
Dim regex As Object
Set regex = CreateObject("VBScript.RegExp")
regex.IgnoreCase = True
regex.Global = True
regex.Pattern = "(function|if|for|while|{)"
Dim result As String, lines() As String, line As String
Dim indentLevel As Integer, i As Integer
lines = Split(code, vbCrLf)
indentLevel = 0
result = ""
For i = 0 To UBound(lines)
line = Trim(lines(i))
If line Like "*}*" Then indentLevel = indentLevel - 1
If indentLevel < 0 Then indentLevel = 0
result = result & String(indentLevel * 4, " ") & line & vbCrLf
If line Like "*{*" Then indentLevel = indentLevel + 1
Next i
RegX = result
End Function
Sub test()
Dim exemple As String
exemple = "Type Regles" & vbCrLf & " VB() As String" & vbCrLf & " JS() As String" & vbCrLf & " Nb As Long" & vbCrLf & "End Type"
Debug.Print RegX(ConvertVBAToJS(TXT))
End Sub
Function TXT() As String
TXT = TXT & "Type regles" & vbCrLf
TXT = TXT & " VB() As String" & vbCrLf
TXT = TXT & " JS() As String" & vbCrLf
TXT = TXT & " Nb As Integer" & vbCrLf
TXT = TXT & "End Type" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & "Dim RG As regles" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & "Function ConvertVBAToJS(vbaCode As String) As String" & vbCrLf
TXT = TXT & " Dim jsCode As String, lignes() As String, i As Integer" & vbCrLf
TXT = TXT & " If vbaCode = """" Then ConvertVBAToJS = """": Exit Function" & vbCrLf
TXT = TXT & " ChargerReglesConversion" & vbCrLf
TXT = TXT & " lignes = Split(vbaCode, vbCrLf)" & vbCrLf
TXT = TXT & " For i = 0 To UBound(lignes)" & vbCrLf
TXT = TXT & " jsCode = jsCode & IIf(i > 0, vbCrLf, """") & ConvertirLigne(lignes(i))" & vbCrLf
TXT = TXT & " Next" & vbCrLf
TXT = TXT & " ConvertVBAToJS = jsCode" & vbCrLf
TXT = TXT & "End Function" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & "Sub ChargerReglesConversion()" & vbCrLf
TXT = TXT & " Dim i As Integer" & vbCrLf
TXT = TXT & " Dim donnees As Variant" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & " donnees = Array( _" & vbCrLf
TXT = TXT & " Array(""Dim "", ""let ""), Array("" As String"", "" = ''""), Array("" As Integer"", "" = 0""), _" & vbCrLf
TXT = TXT & " Array("" As Long"", "" = 0""), Array("" As Double"", "" = 0.0""), Array("" As Boolean"", "" = false""), _" & vbCrLf
TXT = TXT & " Array(""If "", ""if (""), Array("" Then"", "") {""), Array(""End If"", ""}""), Array(""Else"", ""} else {""), _" & vbCrLf
TXT = TXT & " Array(""ElseIf "", ""} else if (""), Array(""For "", ""for (""), Array("" To "", ""; i <= ""), Array(""Next"", ""}""), _" & vbCrLf
TXT = TXT & " Array(""While "", ""while (""), Array(""Wend"", ""}""), Array(""Sub "", ""function ""), Array(""Function "", ""function ""), _" & vbCrLf
TXT = TXT & " Array(""End Sub"", ""}""), Array(""End Function"", ""}""), Array(""True"", ""true""), Array(""False"", ""false""), _" & vbCrLf
TXT = TXT & " Array(""Nothing"", ""null""), Array(""vbCrLf"", ""'\n'""), Array(""vbTextCompare"", ""1""), Array(""MsgBox"", ""alert""), _" & vbCrLf
TXT = TXT & " Array(""InputBox"", ""prompt""), Array(""Len("", "".length""), Array(""UBound("", "".length - 1""), _" & vbCrLf
TXT = TXT & " Array(""Split("", ""vbaCode.split(""), Array(""Trim("", "".trim(""), Array(""Replace("", "".replace(""), _" & vbCrLf
TXT = TXT & " Array(""InStr("", "".indexOf(""), Array(""Mid("", "".substring(""), Array(""Left("", "".substring(0, ""), _" & vbCrLf
TXT = TXT & " Array(""Right("", "".slice(-""), Array(""Exit Function"", ""return""), Array(""Exit Sub"", ""return""), _" & vbCrLf
TXT = TXT & " Array("" And "", "" && ""), Array("" Or "", "" || ""), Array("" Not "", "" !""), Array(""<>"", ""!=""), Array("" & "", "" + "") _" & vbCrLf
TXT = TXT & " )" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & " RG.Nb = UBound(donnees) + 1" & vbCrLf
TXT = TXT & " ReDim RG.VB(1 To RG.Nb)" & vbCrLf
TXT = TXT & " ReDim RG.JS(1 To RG.Nb)" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & " For i = 0 To RG.Nb - 1" & vbCrLf
TXT = TXT & " RG.VB(i + 1) = donnees(i)(0)" & vbCrLf
TXT = TXT & " RG.JS(i + 1) = donnees(i)(1)" & vbCrLf
TXT = TXT & " Next" & vbCrLf
TXT = TXT & "End Sub" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & "Function ConvertirLigne(ligne As String) As String" & vbCrLf
TXT = TXT & " Dim resultat As String, i As Integer" & vbCrLf
TXT = TXT & " ligne = Trim(ligne)" & vbCrLf
TXT = TXT & " If ligne = """" Then ConvertirLigne = """": Exit Function" & vbCrLf
TXT = TXT & " If Left(ligne, 1) = ""'"" Then ConvertirLigne = ""//"" & Mid(ligne, 2): Exit Function" & vbCrLf
TXT = TXT & " resultat = ligne" & vbCrLf
TXT = TXT & " For i = 1 To RG.Nb" & vbCrLf
TXT = TXT & " resultat = Replace(resultat, RG.VB(i), RG.JS(i), , , vbTextCompare)" & vbCrLf
TXT = TXT & " Next" & vbCrLf
TXT = TXT & " resultat = GererChaines(resultat)" & vbCrLf
TXT = TXT & " ConvertirLigne = AjouterPointVirgule(resultat)" & vbCrLf
TXT = TXT & "End Function" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & "Function GererChaines(texte As String) As String" & vbCrLf
TXT = TXT & " Dim res As String, i As Integer, c As String, dansChaine As Boolean" & vbCrLf
TXT = TXT & " For i = 1 To Len(texte)" & vbCrLf
TXT = TXT & " c = Mid(texte, i, 1)" & vbCrLf
TXT = TXT & " If c = """""""" Then" & vbCrLf
TXT = TXT & " res = res & IIf(dansChaine, ""\"""""""""", """""""")" & vbCrLf
TXT = TXT & " dansChaine = Not dansChaine" & vbCrLf
TXT = TXT & " Else" & vbCrLf
TXT = TXT & " res = res & c" & vbCrLf
TXT = TXT & " End If" & vbCrLf
TXT = TXT & " Next" & vbCrLf
TXT = TXT & " GererChaines = res" & vbCrLf
TXT = TXT & "End Function" & vbCrLf
TXT = TXT & "" & vbCrLf
TXT = TXT & "Function AjouterPointVirgule(texte As String) As String" & vbCrLf
TXT = TXT & " If texte = """" Then" & vbCrLf
TXT = TXT & " AjouterPointVirgule = """"" & vbCrLf
TXT = TXT & " Exit Function" & vbCrLf
TXT = TXT & " End If" & vbCrLf
TXT = TXT & " If InStr(texte, ""function"") > 0 Or InStr(texte, ""if"") > 0 Or InStr(texte, ""for"") > 0 _" & vbCrLf
TXT = TXT & " Or InStr(texte, ""while"") > 0 Or InStr(texte, ""{"") > 0 Or InStr(texte, ""}"") > 0 Then" & vbCrLf
TXT = TXT & " AjouterPointVirgule = texte" & vbCrLf
TXT = TXT & " ElseIf Right(texte, 1) <> "";"" Then" & vbCrLf
TXT = TXT & " AjouterPointVirgule = texte & "";""" & vbCrLf
TXT = TXT & " Else" & vbCrLf
TXT = TXT & " AjouterPointVirgule = texte" & vbCrLf
TXT = TXT & " End If" & vbCrLf
TXT = TXT & "End Function" & vbCrLf
TXT = TXT & "" & vbCrLf
'TXT = TXT & "Sub test()" & vbCrLf
'TXT = TXT & " Dim exemple As String" & vbCrLf
'TXT = TXT & " exemple = ""Dim x As Integer"" & vbCrLf & ""x = 10"" & vbCrLf & ""If x > 5 Then"" & vbCrLf & ""MsgBox x"" & vbCrLf & ""End If""" & vbCrLf
'TXT = TXT & " Debug.Print ConvertVBAToJS(TXT)" & vbCrLf
'TXT = TXT & "End Sub" & vbCrLf
'TXT = TXT & "" & vbCrLf
End Function |
Partager