Home | History | Annotate | Download | only in utils
      1 #!/usr/bin/env python
      2 #
      3 # Copyright (C) 2014 The Android Open Source Project
      4 #
      5 # Licensed under the Apache License, Version 2.0 (the 'License');
      6 # you may not use this file except in compliance with the License.
      7 # You may obtain a copy of the License at
      8 #
      9 #      http://www.apache.org/licenses/LICENSE-2.0
     10 #
     11 # Unless required by applicable law or agreed to in writing, software
     12 # distributed under the License is distributed on an 'AS IS' BASIS,
     13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     14 # See the License for the specific language governing permissions and
     15 # limitations under the License.
     16 #
     17 import hashlib
     18 import os
     19 import subprocess
     20 import sys
     21 
     22 densities = [
     23     "ldpi",
     24     "mdpi",
     25     "tvdpi",
     26     "hdpi",
     27     "xhdpi",
     28     "400dpi",
     29     "xxhdpi",
     30     "xxxhdpi"
     31 ]
     32 
     33 # A script to find holo images which are duplicated in the landscape and
     34 # portrait folder. The landscape images will then be deleted as Android will
     35 # look up landscape resources in the portrait folder if it doesn't exist in the
     36 # landscape folder. This will reduce the size of the Holo test case.
     37 def main(argv):
     38   run(True)
     39   run(False)
     40 
     41 def run(sw):
     42   for density in densities:
     43     portDir = getDirName(density, sw, False)
     44     landDir = getDirName(density, sw, True)
     45     portrait = getAllHashes(portDir)
     46     landscape = getAllHashes(landDir)
     47     for f in portrait:
     48       if f in landscape and landscape[f] == portrait[f]:
     49         subprocess.call(["rm", landDir + "/" + f])
     50 
     51 def getAllHashes(dirName):
     52   files = {}
     53   for f in os.listdir(dirName):
     54     if f.endswith(".png"):
     55       files[f] = getHash(open(dirName + "/" + f, 'rb'))
     56   return files
     57 
     58 def getHash(f):
     59   return hashlib.sha1(f.read()).hexdigest()
     60 
     61 def getDirName(density, sw, land):
     62   name = "drawable-"
     63   if sw:
     64     name += "sw600dp-"
     65   if land:
     66     name += "land-"
     67   return name + density
     68 
     69 if __name__ == '__main__':
     70   main(sys.argv)
     71