#!/usr/bin/env python # Copyright (c) 2020 Project CHIP Authors # # 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. import optparse import sys TEMPLATE = r'''/* * * Copyright (c) 2020 Project CHIP Authors * All rights reserved. * * 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. */ /** * \@file * This file defines constants and macros for introspecting and * manipulating CHIP versions. * * !!! WARNING !!! WARNING !!! WARNING !!! WARNING !!! * * DO NOT EDIT THIS FILE! This file is automatically-generated by * the '${program}' script. * * The constants and macros defined here may be used to, for , * example, conditionally-compile older, newer, or changed CHIP * APIs based on the CHIP version. For example: * * \@code * #if CHIP_VERSION_CODE >= CHIP_VERSION_CODE_ENCODE(1, 5, 0) * ... * #else * ... * #endif * \@endcode * */ #ifndef CHIP_VERSION_H_ #define CHIP_VERSION_H_ #define _CHIP_VERSION_CODE_MAJOR_WIDTH 8 #define _CHIP_VERSION_CODE_MINOR_WIDTH 8 #define _CHIP_VERSION_CODE_PATCH_WIDTH 8 #define _CHIP_VERSION_CODE_MAJOR_MASK ((1 << _CHIP_VERSION_CODE_MAJOR_WIDTH) - 1) #define _CHIP_VERSION_CODE_MINOR_MASK ((1 << _CHIP_VERSION_CODE_MINOR_WIDTH) - 1) #define _CHIP_VERSION_CODE_PATCH_MASK ((1 << _CHIP_VERSION_CODE_PATCH_WIDTH) - 1) #define _CHIP_VERSION_CODE_MAJOR_SHIFT 24 #define _CHIP_VERSION_CODE_MINOR_SHIFT 16 #define _CHIP_VERSION_CODE_PATCH_SHIFT 8 /** * \@def CHIP_VERSION_CODE_ENCODE(major, minor, patch) * * \@brief * Encode a CHIP version code from its constituent \@a major, \@a minor, and \@a patch * components. * * This macro may be used in conjunction with CHIP_VERSION_CODE to, for * example, conditionally-compile older, newer, or changed CHIP APIs based * on the CHIP version. For example: * * \@code * #if CHIP_VERSION_CODE >= CHIP_VERSION_CODE_ENCODE(1, 5, 0) * ... * #else * ... * #endif * \@endcode * */ #define CHIP_VERSION_CODE_ENCODE(major, minor, patch) \ ((((major) & _CHIP_VERSION_CODE_MAJOR_MASK) << _CHIP_VERSION_CODE_MAJOR_SHIFT) | \ (((minor) & _CHIP_VERSION_CODE_MINOR_MASK) << _CHIP_VERSION_CODE_MINOR_SHIFT) | \ (((patch) & _CHIP_VERSION_CODE_PATCH_MASK) << _CHIP_VERSION_CODE_PATCH_SHIFT)) /** * \@def CHIP_VERSION_CODE_DECODE_MAJOR(code) * * \@brief * Decode a CHIP major version component from a CHIP version \@a code. * */ #define CHIP_VERSION_CODE_DECODE_MAJOR(code) (((code) >> _CHIP_VERSION_CODE_MAJOR_SHIFT) & _CHIP_VERSION_CODE_MAJOR_MASK) /** * \@def CHIP_VERSION_CODE_DECODE_MINOR(code) * * \@brief * Decode a CHIP minor version component from a CHIP version \@a code. * */ #define CHIP_VERSION_CODE_DECODE_MINOR(code) (((code) >> _CHIP_VERSION_CODE_MINOR_SHIFT) & _CHIP_VERSION_CODE_MINOR_MASK) /** * \@def CHIP_VERSION_CODE_DECODE_PATCH(code) * * \@brief * Decode a CHIP patch version component from a CHIP version \@a code. * */ #define CHIP_VERSION_CODE_DECODE_PATCH(code) (((code) >> _CHIP_VERSION_CODE_PATCH_SHIFT) & _CHIP_VERSION_CODE_PATCH_MASK) /** * \@def CHIP_VERSION_MAJOR * * \@brief * The CHIP version major component, as an unsigned integer. * */ #define CHIP_VERSION_MAJOR %(chip_major)d /** * \@def CHIP_VERSION_MINOR * * \@brief * The CHIP version minor component, as an unsigned integer. * */ #define CHIP_VERSION_MINOR %(chip_minor)d /** * \@def CHIP_VERSION_PATCH * * \@brief * The CHIP version patch component, as an unsigned integer. * */ #define CHIP_VERSION_PATCH %(chip_patch)d /** * \@def CHIP_VERSION_EXTRA * * \@brief * The CHIP version extra component, as a quoted C string. * */ #define CHIP_VERSION_EXTRA "%(chip_extra)s" /** * \@def CHIP_VERSION_STRING * * \@brief * The CHIP version, as a quoted C string. * */ #define CHIP_VERSION_STRING "%(chip_version)s" /** * \@def CHIP_VERSION_CODE * * \@brief * The CHIP version, including the major, minor, and patch components, * encoded as an unsigned integer. * * This macro may be used in conjunction with CHIP_VERSION_CODE_ENCODE * to, for example, conditionally-compile older, newer, or changed CHIP * APIs based on the CHIP version. For example: * * \@code * #if CHIP_VERSION_CODE >= CHIP_VERSION_CODE_ENCODE(1, 5, 0) * ... * #else * ... * #endif * \@endcode * */ #define CHIP_VERSION_CODE CHIP_VERSION_CODE_ENCODE( \ CHIP_VERSION_MAJOR, \ CHIP_VERSION_MINOR, \ CHIP_VERSION_PATCH \ ) #endif /* CHIP_VERSION_H_ */ ''' def main(argv): parser = optparse.OptionParser() parser.add_option('--output_file') parser.add_option('--chip_major', type=int, default=0) parser.add_option('--chip_minor', type=int, default=0) parser.add_option('--chip_patch', type=int, default=0) parser.add_option('--chip_extra', type=str, default='') options, _ = parser.parse_args(argv) template_args = { 'chip_major': options.chip_major, 'chip_minor': options.chip_minor, 'chip_patch': options.chip_patch, 'chip_extra': options.chip_extra, } template_args['chip_version'] = '%d.%d.%d%s' % ( options.chip_major, options.chip_minor, options.chip_patch, options.chip_extra) with open(options.output_file, 'w') as chip_version_file: chip_version_file.write(TEMPLATE % template_args) return 0 if __name__ == '__main__': sys.exit(main(sys.argv[1:]))