#!/usr/bin/env python3 # # Copyright (C) 2017 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. # # This script generates vhal_consts_x_y.py files for use in vhal_emulator # They are generated from corresponding data in Vehicle HAL types.hal files # To run, invoke at a shell by saying: # $ packages/services/Car/tools/emulator/vhal_const_generate.py # The script will automatically locate itself and the required HAL files and will write next # to itself vhal_consts_x.y.py for any version of Vehicle HAL that it knows about # Those files can then be used with vhal_emulator.py as per that script's documentation from __future__ import print_function import datetime def printHeader(dest): year = datetime.datetime.now().year print("# Copyright (C) %s The Android Open Source Project" % year, file=dest) print("#", file=dest) print("# Licensed under the Apache License, Version 2.0 (the \"License\");", file=dest) print("# you may not use this file except in compliance with the License.", file=dest) print("# You may obtain a copy of the License at", file=dest) print("#", file=dest) print("# http://www.apache.org/licenses/LICENSE-2.0", file=dest) print("#", file=dest) print("# Unless required by applicable law or agreed to in writing, software", file=dest) print("# distributed under the License is distributed on an \"AS IS\" BASIS,", file=dest) print("# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.", file=dest) print("# See the License for the specific language governing permissions and", file=dest) print("# limitations under the License.", file=dest) print("#", file=dest) print("# DO NOT EDIT MANUALLY", file=dest) print("# This file was autogenerated by vhal_const_generate.py", file=dest) def printEnum(doc, name, dest, postprocess=lambda x: x): # Construct a value name prefix from the group name valueNamePrefix = name.upper() + '_' enum_object = doc['enums'][name] print("\n# %s" % name, file=dest) for case in enum_object.cases: print('%s%s = %s' % (valueNamePrefix, case.name, postprocess(case.value.resolve(enum_object, doc))), file=dest) import os, os.path import sys script_directory = os.path.join(os.path.dirname(os.path.abspath(__file__))) parent_location = os.path.abspath(os.path.join(script_directory, '..')) sys.path.append(parent_location) # hidl_parser depends on a custom Python package that requires installation # give user guidance should the import fail try: from hidl_parser import parser except ImportError as e: isPly = False pipTool = "pip%s" % ("3" if sys.version_info > (3,0) else "") if hasattr(e, 'name'): if e.name == 'ply': isPly = True elif hasattr(e, 'message'): if e.message.endswith('ply'): isPly = True if isPly: print('could not import ply.') print('ply is available as part of an Android checkout in external/ply') print('or it can be installed via "sudo %s install ply"' % pipTool) sys.exit(1) else: raise e android_build_top = os.environ.get("ANDROID_BUILD_TOP", None) if android_build_top is not None: vhal_location = os.path.join(android_build_top, 'hardware','interfaces','automotive','vehicle') else: vhal_location = os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)), '..','..','..','..','..','hardware','interfaces','automotive','vehicle' )) if not(os.path.exists(vhal_location) and os.path.isdir(vhal_location)): print("Vehicle HAL was not found at %s. lunch may provide a correct environment, or files moved" % vhal_location) sys.exit(1) def generateHal20(): vhal_20_file = os.path.join(vhal_location, '2.0', 'types.hal') if not(os.path.exists(vhal_20_file)): print("Vehicle HAL was not found at %s. lunch may provide a correct environment, or files moved" % vhal_location) sys.exit(1) print("Generating constants from Vehicle HAL 2.0 (%s)" % (vhal_20_file)) vhal_20_doc = parser.parse(vhal_20_file) vhal_20_file = open(os.path.join(script_directory, 'vhal_consts_2_0.py'), 'w') printHeader(vhal_20_file) for group in vhal_20_doc['enums']: print(group) printEnum(vhal_20_doc, group, vhal_20_file, lambda x : hex(x)) print("\n# Create a container of value_type constants to be used by vhal_emulator", file=vhal_20_file) print("class vhal_types_2_0:", file=vhal_20_file) print(" TYPE_STRING = [VEHICLEPROPERTYTYPE_STRING]", file=vhal_20_file) print(" TYPE_BYTES = [VEHICLEPROPERTYTYPE_BYTES]", file=vhal_20_file) print(" TYPE_INT32 = [VEHICLEPROPERTYTYPE_BOOLEAN,", file=vhal_20_file) print(" VEHICLEPROPERTYTYPE_INT32]", file=vhal_20_file) print(" TYPE_INT64 = [VEHICLEPROPERTYTYPE_INT64]", file=vhal_20_file) print(" TYPE_FLOAT = [VEHICLEPROPERTYTYPE_FLOAT]", file=vhal_20_file) print(" TYPE_INT32S = [VEHICLEPROPERTYTYPE_INT32_VEC]", file=vhal_20_file) print(" TYPE_INT64S = [VEHICLEPROPERTYTYPE_INT64_VEC]", file=vhal_20_file) print(" TYPE_FLOATS = [VEHICLEPROPERTYTYPE_FLOAT_VEC]", file=vhal_20_file) print(" TYPE_MIXED = [VEHICLEPROPERTYTYPE_MIXED]", file=vhal_20_file) generateHal20()