blob: 70fafecc7a18cc0041d6f6facfbe96ab085eb94d [file] [log] [blame]
#!/usr/bin/env python
import os
import sys
import difflib
import filecmp
import tempfile
from optparse import OptionParser
from subprocess import call
from subprocess import Popen
from subprocess import PIPE
def which(program):
def executable(path):
return os.path.isfile(path) and os.access(path, os.X_OK)
path, file = os.path.split(program)
if path and executable(program):
return program
else:
for path in os.environ["PATH"].split(os.pathsep):
exe = os.path.join(path, program)
if executable(exe):
return exe
return ""
DIFF_TOOLS=["meld", "kdiff3", "xdiff", "diffmerge.sh", "diff"]
PROTO_SRC="./src/com/android/keyguard/"
PROTO_RES="./res/"
TEMP_FILE1="/tmp/tempFile1.txt"
TEMP_FILE2="/tmp/tempFile2.txt"
FW_SRC="../../../../frameworks/base/policy/src/com/android/internal/policy/impl/keyguard/"
FW_RES="../../../../frameworks/base/core/res/res/"
FW_PKG="com.android.internal.policy.impl.keyguard"
PROTO_PKG="com.android.keyguard"
FW_RES_IMPORT="import com.android.internal.R;"
# Find a differ
DIFF_TOOL=""
if ("DIFF_TOOL" in os.environ and len(os.environ["DIFF_TOOL"]) > 0):
DIFF_TOOL=which(os.environ["DIFF_TOOL"])
if len(DIFF_TOOL) == 0:
for differ in DIFF_TOOLS:
DIFF_TOOL=which(differ)
if len(DIFF_TOOL) > 0:
break
print "Using differ", DIFF_TOOL
#Anything file which contains any string in this list as a substring will be ommitted
IGNORE=["LockHotnessActivity.java", "unified_lock_activity.xml", "optionmenu.xml"]
WATCH=[]
def dirCompare(sourceDir, destDir, ext, run_in_reverse):
sourceFiles = getFileList(sourceDir, ext)
destFiles = getFileList(destDir, ext)
for file in sourceFiles:
print file
destFile = destDir + file
sourceFile = sourceDir + file
if (file in destFiles):
if run_in_reverse:
prepareFileForCompare(sourceFile, TEMP_FILE1, FW_RES_IMPORT, FW_PKG, PROTO_PKG)
prepareFileForCompare(destFile, TEMP_FILE2, FW_RES_IMPORT,)
else:
prepareFileForCompare(destFile, TEMP_FILE1, FW_RES_IMPORT, FW_PKG, PROTO_PKG)
prepareFileForCompare(sourceFile, TEMP_FILE2, FW_RES_IMPORT,)
if (filecmp.cmp(TEMP_FILE1, TEMP_FILE2)):
print "File %s is the same in proto and framework" %(file)
else:
print "Running diff for: %s" %(file)
diff(sourceFile, destFile)
else:
print "File %s does not exist in framework" %(file)
if not run_in_reverse:
diff(sourceFile, destFile)
def main(argv):
run_in_reverse = False
if len(argv) > 1:
if argv[1] == '--help' or argv[1] == '-h':
print ('Usage: %s [<commit>]' % argv[0])
print ('\tdiff to framework, ' +
'optionally restricting to files in <commit>')
sys.exit(0)
elif argv[1] == '--reverse':
print "Running in reverse"
run_in_reverse = True
else:
print ("**** Pulling file list from: %s" % argv[1])
pipe = Popen(['git', 'diff', '--name-only', argv[1]], stdout=PIPE).stdout
for line in iter(pipe.readline,''):
path = line.rstrip()
file = path[path.rfind('/') + 1:]
print '**** watching: %s' % file
WATCH.append(file);
pipe.close()
if run_in_reverse:
#dirCompare(FW_RES, PROTO_RES, ".xml", run_in_reverse)
print ("**** Source files:")
dirCompare(FW_SRC, PROTO_SRC, ".java", run_in_reverse)
else:
#dirCompare(PROTO_RES, FW_RES, ".xml", run_in_reverse)
print ("**** Source files:")
dirCompare(PROTO_SRC, FW_SRC, ".java", run_in_reverse)
if (os.path.exists(TEMP_FILE1)):
os.remove(TEMP_FILE1)
if (os.path.exists(TEMP_FILE2)):
os.remove(TEMP_FILE2)
def getFileList(rootdir, extension):
fileList = []
for root, subFolders, files in os.walk(rootdir):
for file in files:
f = os.path.join(root,file)
if (os.path.splitext(f)[1] == extension and (not inIgnore(f))):
fileList.append(f[len(rootdir):])
return fileList
def prepareFileForCompare(inFile, outFile, skip="", replace="", withText=""):
# Delete the outfile, so we're starting with a new file
if (os.path.exists(outFile)):
os.remove(outFile)
fin = open(inFile)
fout = open(outFile, "w")
for line in fin:
# Ignore any lines containing the ignore string ("import com.android.internal.R;) and
# ignore any lines containing only whitespace.
if (line.find(skip) < 0 and len(line.strip(' \t\n\r')) > 0):
# For comparison, for framework files, we replace the fw package with the
# proto package, since these aren't relevant.
if len(replace) > 0:
fout.write(line.replace(replace, withText))
else:
fout.write(line)
fin.close()
fout.close()
def diff(file1, file2):
call([DIFF_TOOL, file1, file2])
def inIgnore(file):
for ignore in IGNORE:
if file.find(ignore) >= 0:
return True
if len(WATCH) > 0:
for watch in WATCH:
if file.find(watch) >= 0:
return False
return True
return False
if __name__=="__main__":
main(sys.argv)