If we replace the project directories with symlinks to the actual directories, everything should build fine. Unfortunately, without this fix, it does not. Change-Id: Id19fef9696d0f599a7b3a14b6a8fc10ae857f9c7
		
			
				
	
	
		
			99 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python
 | |
| #
 | |
| # Copyright (C) 2009 The Android Open Source Project
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #      http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| #
 | |
| 
 | |
| #
 | |
| # Finds files with the specified name under a particular directory, stopping
 | |
| # the search in a given subdirectory when the file is found.
 | |
| #
 | |
| 
 | |
| import os
 | |
| import sys
 | |
| 
 | |
| def perform_find(mindepth, prune, dirlist, filename):
 | |
|   result = []
 | |
|   pruneleaves = set(map(lambda x: os.path.split(x)[1], prune))
 | |
|   for rootdir in dirlist:
 | |
|     rootdepth = rootdir.count("/")
 | |
|     for root, dirs, files in os.walk(rootdir, followlinks=True):
 | |
|       # prune
 | |
|       check_prune = False
 | |
|       for d in dirs:
 | |
|         if d in pruneleaves:
 | |
|           check_prune = True
 | |
|           break
 | |
|       if check_prune:
 | |
|         i = 0
 | |
|         while i < len(dirs):
 | |
|           if dirs[i] in prune:
 | |
|             del dirs[i]
 | |
|           else:
 | |
|             i += 1
 | |
|       # mindepth
 | |
|       if mindepth > 0:
 | |
|         depth = 1 + root.count("/") - rootdepth
 | |
|         if depth < mindepth:
 | |
|           continue
 | |
|       # match
 | |
|       if filename in files:
 | |
|         result.append(os.path.join(root, filename))
 | |
|         del dirs[:]
 | |
|   return result
 | |
| 
 | |
| def usage():
 | |
|   sys.stderr.write("""Usage: %(progName)s [<options>] <dirlist> <filename>
 | |
| Options:
 | |
|    --mindepth=<mindepth>
 | |
|        Both behave in the same way as their find(1) equivalents.
 | |
|    --prune=<dirname>
 | |
|        Avoids returning results from inside any directory called <dirname>
 | |
|        (e.g., "*/out/*"). May be used multiple times.
 | |
| """ % {
 | |
|       "progName": os.path.split(sys.argv[0])[1],
 | |
|     })
 | |
|   sys.exit(1)
 | |
| 
 | |
| def main(argv):
 | |
|   mindepth = -1
 | |
|   prune = []
 | |
|   i=1
 | |
|   while i<len(argv) and len(argv[i])>2 and argv[i][0:2] == "--":
 | |
|     arg = argv[i]
 | |
|     if arg.startswith("--mindepth="):
 | |
|       try:
 | |
|         mindepth = int(arg[len("--mindepth="):])
 | |
|       except ValueError:
 | |
|         usage()
 | |
|     elif arg.startswith("--prune="):
 | |
|       p = arg[len("--prune="):]
 | |
|       if len(p) == 0:
 | |
|         usage()
 | |
|       prune.append(p)
 | |
|     else:
 | |
|       usage()
 | |
|     i += 1
 | |
|   if len(argv)-i < 2: # need both <dirlist> and <filename>
 | |
|     usage()
 | |
|   dirlist = argv[i:-1]
 | |
|   filename = argv[-1]
 | |
|   results = list(set(perform_find(mindepth, prune, dirlist, filename)))
 | |
|   results.sort()
 | |
|   for r in results:
 | |
|     print r
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|   main(sys.argv)
 |