| #!/usr/bin/python2.4 |
| # |
| # |
| # Copyright 2008, 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. |
| |
| """Contains utility functions for interacting with the Android build system.""" |
| |
| # Python imports |
| import os |
| import re |
| import subprocess |
| |
| # local imports |
| import errors |
| import logger |
| |
| |
| def GetTop(): |
| """Returns the full pathname of the "top" of the Android development tree. |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| the absolute file path of the Android build root. |
| |
| Raises: |
| AbortError: if Android build root could not be found. |
| """ |
| # TODO: does this need to be reimplemented to be like gettop() in envsetup.sh |
| root_path = os.getenv("ANDROID_BUILD_TOP") |
| if root_path is None: |
| logger.Log("Error: ANDROID_BUILD_TOP not defined. Please run " |
| "envsetup.sh and lunch/choosecombo") |
| raise errors.AbortError |
| return root_path |
| |
| |
| def GetHostOutDir(): |
| """Returns the full pathname of out/host/arch of the Android development tree. |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| the absolute file path of the Android host output directory. |
| Raises: |
| AbortError: if Android host output directory could not be found. |
| """ |
| host_out_path = os.getenv("ANDROID_HOST_OUT") |
| if host_out_path is None: |
| logger.Log("Error: ANDROID_HOST_OUT not defined. Please run " |
| "envsetup.sh and lunch/choosecombo") |
| raise errors.AbortError |
| return host_out_path |
| |
| |
| def GetOutDir(): |
| """Returns the full pathname of the "out" of the Android development tree. |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| the absolute file path of the Android build output directory. |
| """ |
| root_path = os.getenv("OUT_DIR") |
| if root_path is None: |
| root_path = os.path.join(GetTop(), "out") |
| return root_path |
| |
| |
| def GetHostBin(): |
| """Compute the full pathname to the host binary directory. |
| |
| Typically $ANDROID_HOST_OUT/bin. |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| The absolute file path of the Android host binary directory. |
| |
| Raises: |
| AbortError: if Android host binary directory could not be found. |
| """ |
| path = os.path.join(GetHostOutDir(), "bin") |
| if not os.path.exists(path): |
| logger.Log("Error: Host bin path could not be found %s" % path) |
| raise errors.AbortError |
| return path |
| |
| |
| def GetProductOut(): |
| """Returns the full pathname to the target/product directory. |
| |
| Typically the value of the env variable $ANDROID_PRODUCT_OUT. |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| The absolute file path of the Android product directory. |
| |
| Raises: |
| AbortError: if Android product directory could not be found. |
| """ |
| path = os.getenv("ANDROID_PRODUCT_OUT") |
| if path is None: |
| logger.Log("Error: ANDROID_PRODUCT_OUT not defined. Please run " |
| "envsetup.sh and lunch/choosecombo") |
| raise errors.AbortError |
| return path |
| |
| |
| def GetTargetNativeTestPath(): |
| """Returns the full pathname to target/product data/nativetest/ directory. |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| The absolute file path of the Android target native test directory. |
| |
| Raises: |
| AbortError: if Android target native test directory could not be found. |
| """ |
| path = os.path.join(GetProductOut(), "data", "nativetest") |
| if not os.path.exists(path): |
| logger.Log("Error: Target native test path could not be found") |
| raise errors.AbortError |
| return path |
| |
| |
| def GetTargetSystemBin(): |
| """Returns the full pathname to the target/product system/bin directory. |
| |
| Typically the value of the env variable $ANDROID_PRODUCT_OUT/system/bin |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| The absolute file path of the Android target system bin directory. |
| |
| Raises: |
| AbortError: if Android target system bin directory could not be found. |
| """ |
| path = os.path.join(GetProductOut(), "system", "bin") |
| if not os.path.exists(path): |
| logger.Log("Error: Target system bin path could not be found") |
| raise errors.AbortError |
| return path |
| |
| def GetHostLibraryPath(): |
| """Returns the full pathname to the host java library output directory. |
| |
| Typically $ANDROID_HOST_OUT/framework. |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| The absolute file path of the Android host java library directory. |
| |
| Raises: |
| AbortError: if Android host java library directory could not be found. |
| """ |
| path = os.path.join(GetHostOutDir(), "framework") |
| if not os.path.exists(path): |
| logger.Log("Error: Host library path could not be found %s" % path) |
| raise errors.AbortError |
| return path |
| |
| def GetTestAppPath(): |
| """Returns the full pathname to the test app build output directory. |
| |
| Typically $ANDROID_PRODUCT_OUT/data/app |
| |
| Assumes build environment has been properly configured by envsetup & |
| lunch/choosecombo. |
| |
| Returns: |
| The absolute file path of the Android test app build directory. |
| """ |
| return os.path.join(GetProductOut(), "data", "app") |