summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar t-espave <unknown>2011-08-01 10:56:24 -0700
committerGravatar t-espave <unknown>2011-08-01 10:56:24 -0700
commite98fc054e5398bf55dc98fddcc4f48b626c31301 (patch)
tree5856eb554b61f35a50465dd14cd584ecb25a857c
parent50f0ef2834cd106a61c215c26ac220b58040851a (diff)
generating individual corral queries for page navigation
-rw-r--r--BCT/PhoneControlsExtractor/PhoneBoogieCodeGenerator.py56
1 files changed, 37 insertions, 19 deletions
diff --git a/BCT/PhoneControlsExtractor/PhoneBoogieCodeGenerator.py b/BCT/PhoneControlsExtractor/PhoneBoogieCodeGenerator.py
index c31f50bb..e5c412c0 100644
--- a/BCT/PhoneControlsExtractor/PhoneBoogieCodeGenerator.py
+++ b/BCT/PhoneControlsExtractor/PhoneBoogieCodeGenerator.py
@@ -2,6 +2,7 @@ import sys
import getopt
import os
from xml.dom import minidom
+from itertools import product
import xml.dom
CONTROL_NAMES= ["Button", "CheckBox", "RadioButton"]
@@ -18,6 +19,7 @@ currentNavigationVariable= None
originalPageVars= []
boogiePageVars= []
boogiePageClasses= []
+dummyPageVar= "dummyBoogieStringPageName"
def showUsage():
print "PhoneBoogieCodeGenerator -- create boilerplate code for Boogie verification of Phone apps"
@@ -56,25 +58,41 @@ def outputPageVariables(file):
file.write(pageVar)
def outputMainProcedure(file):
- file.write("procedure __BOOGIE_VERIFICATION_PROCEDURE();\n")
- file.write("implementation __BOOGIE_VERIFICATION_PROCEDURE() {\n")
- file.write("\tvar $doWork: bool;\n")
- file.write("\tvar $activeControl: int;\n")
- file.write("\tvar $isEnabledRef: Ref;\n")
- file.write("\tvar $isEnabled: bool;\n")
- file.write("\tvar $control: Ref;\n\n")
-
- file.write("\tcall " + mainAppClassname + ".#ctor(" + appVarName + ");\n")
- for i in range(0,len(boogiePageVars)):
- file.write("\tcall " + boogiePageClasses[i] + ".#ctor(" + boogiePageVars[i]["name"] + ");\n")
-
- file.write("\t//TODO still need to call Loaded handler on main page.\n")
- file.write("\thavoc $doWork;\n")
- file.write("\twhile ($doWork) {\n")
- file.write("\t\tcall DriveControls();\n")
- file.write("\t\thavoc $doWork;\n")
- file.write("\t}\n")
- file.write("}\n")
+ for i,j in product(range(0, len(boogiePageVars)),repeat=2):
+ if i == j:
+ continue
+ if (boogiePageVars[i]["boogieStringName"] == dummyPageVar):
+ continue
+ if (boogiePageVars[j]["boogieStringName"] == dummyPageVar):
+ continue
+
+ print "continuing with i " + str(i) + ", j " + str(j)
+ print boogiePageVars[i]["boogieStringName"]
+ print boogiePageVars[j]["boogieStringName"]
+ file.write("procedure __BOOGIE_VERIFICATION_PROCEDURE_" + str(i) + "_" + str(j) + "();\n")
+ file.write("implementation __BOOGIE_VERIFICATION_PROCEDURE_" + str(i) + "_" + str(j) + "() {\n")
+ file.write("\tvar $doWork: bool;\n")
+ file.write("\tvar $activeControl: int;\n")
+ file.write("\tvar $isEnabledRef: Ref;\n")
+ file.write("\tvar $isEnabled: bool;\n")
+ file.write("\tvar $control: Ref;\n\n")
+
+ file.write("\tcall " + mainAppClassname + ".#ctor(" + appVarName + ");\n")
+ for k in range(0,len(boogiePageVars)):
+ file.write("\tcall " + boogiePageClasses[k] + ".#ctor(" + boogiePageVars[k]["name"] + ");\n")
+
+ file.write("\t//TODO still need to call Loaded handler on main page.\n")
+ file.write("\thavoc $doWork;\n")
+ file.write("\twhile ($doWork) {\n")
+ file.write("\t\tcall DriveControls();\n")
+ file.write("\t\thavoc $doWork;\n")
+ file.write("\t}\n")
+
+ file.write("\tassume " + currentNavigationVariable + " == " + boogiePageVars[i]["boogieStringName"] + ";\n")
+ file.write("\tcall DriveControls();\n")
+ file.write("\tassume " + currentNavigationVariable + " == " + boogiePageVars[j]["boogieStringName"] + ";\n")
+ file.write("\tassert false;\n");
+ file.write("}\n")
def outputPageControlDriver(file, originalPageName, boogiePageName):
file.write("procedure drive" + boogiePageName + "Controls();\n")