#!/usr/bin/env python # # Copyright 2018 - 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. from distutils.spawn import find_executable import os import subprocess import sys import setuptools ACLOUD_DIR = os.path.realpath(os.path.dirname(__file__)) try: with open("README.md", "r") as fh: LONG_DESCRIPTION = fh.read() except IOError: LONG_DESCRIPTION = "" # Find the Protocol Compiler. (Taken from protobuf/python/setup.py) if "PROTOC" in os.environ and os.path.exists(os.environ["PROTOC"]): PROTOC = os.environ["PROTOC"] else: PROTOC = find_executable("protoc") def generate_proto(source): """Generate a _pb2.py from a .proto file. Invokes the Protocol Compiler to generate a _pb2.py from the given .proto file. Does nothing if the output already exists and is newer than the input. Args: source: The source proto file that needs to be compiled. """ output = source.replace(".proto", "_pb2.py") if (not os.path.exists(output) or (os.path.exists(source) and os.path.getmtime(source) > os.path.getmtime(output))): print "Generating %s..." % output if not os.path.exists(source): sys.stderr.write("Can't find required file: %s\n" % source) sys.exit(-1) if PROTOC is None: sys.stderr.write( "protoc is not found. Please compile it " "or install the binary package.\n") sys.exit(-1) protoc_command = [PROTOC, "-I%s" % ACLOUD_DIR, "--python_out=.", source] if subprocess.call(protoc_command) != 0: sys.exit(-1) # Generate the protobuf files that we depend on. generate_proto(os.path.join(ACLOUD_DIR, "internal/proto/user_config.proto")) generate_proto(os.path.join(ACLOUD_DIR, "internal/proto/internal_config.proto")) open(os.path.join(ACLOUD_DIR, "internal/proto/__init__.py"), "a").close() setuptools.setup( python_requires=">=2", name="acloud", version="1.0", test_suite="nose.collector", tests_require=["coverage", "mock"], author="Kevin Cheng, Keun Soo Yim", author_email="kevcheng@google.com, yim@google.com", description="Acloud is a command line tool that assists users to " "create an Android Virtual Device (AVD).", long_description=LONG_DESCRIPTION, long_description_content_type="text/markdown", packages=[ "acloud", "acloud.internal", "acloud.public", "acloud.delete", "acloud.create", "acloud.setup", "acloud.metrics", "acloud.internal.lib", "acloud.internal.proto", "acloud.public.data", "acloud.public.acloud_kernel", "acloud.public.actions", "acloud.reconnect", "acloud.list", ], package_dir={ "acloud": ".", "acloud.internal": "internal", "acloud.public": "public", "acloud.delete": "delete", "acloud.create": "create", "acloud.setup": "setup", "acloud.metrics": "metrics", "acloud.internal.lib": "internal/lib", "acloud.internal.proto": "internal/proto", "acloud.public.data": "public/data", "acloud.public.acloud_kernel": "public/acloud_kernel", "acloud.public.actions": "public/actions", "acloud.reconnect": "reconnect", "acloud.list": "list" }, package_data={"acloud.public.data": ["default.config"]}, include_package_data=True, platforms="POSIX", entry_points={ "console_scripts": ["acloud=acloud.public.acloud_main:main"], }, install_requires=[ "google-api-python-client", "oauth2client==3.0.0", "protobuf", "python-dateutil" ], license="Apache License, Version 2.0", classifiers=[ "Programming Language :: Python :: 2", "Programming Language :: Python :: 3", "License :: OSI Approved :: Apache Software License", "Natural Language :: English", "Environment :: Console", "Intended Audience :: Developers", "Topic :: Utilities", ])