diff options
author | Treehugger Robot <treehugger-gerrit@google.com> | 2019-03-21 06:04:14 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2019-03-21 06:04:14 +0000 |
commit | 21c81326ff4ee6420e73077ce0f05e3cf5565e29 (patch) | |
tree | c2123bc6124e582a5dc23c51f03c4c1af05825d4 /scripts | |
parent | efd249e62a873bbaab0ca367710f4bbc47220930 (diff) | |
parent | 52818fcde8265fd43ad5f331f57122ecdbe7a6be (diff) | |
download | build_soong-21c81326ff4ee6420e73077ce0f05e3cf5565e29.tar.gz build_soong-21c81326ff4ee6420e73077ce0f05e3cf5565e29.tar.bz2 build_soong-21c81326ff4ee6420e73077ce0f05e3cf5565e29.zip |
Merge "Notice support for APEX"
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/mergenotice.py | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/scripts/mergenotice.py b/scripts/mergenotice.py new file mode 100755 index 00000000..407ae8cc --- /dev/null +++ b/scripts/mergenotice.py @@ -0,0 +1,49 @@ +#!/usr/bin/env python +# +# Copyright (C) 2019 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. +# +""" +Merges input notice files to the output file while ignoring duplicated files +This script shouldn't be confused with build/make/tools/generate-notice-files.py +which is responsible for creating the final notice file for all artifacts +installed. This script has rather limited scope; it is meant to create a merged +notice file for a set of modules that are packaged together, e.g. in an APEX. +The merged notice file does not reveal the individual files in the package. +""" + +import sys +import argparse + +def get_args(): + parser = argparse.ArgumentParser(description='Merge notice files.') + parser.add_argument('--output', help='output file path.') + parser.add_argument('inputs', metavar='INPUT', nargs='+', + help='input notice file') + return parser.parse_args() + +def main(argv): + args = get_args() + + processed = set() + with open(args.output, 'w+') as output: + for input in args.inputs: + with open(input, 'r') as f: + data = f.read().strip() + if data not in processed: + processed.add(data) + output.write('%s\n\n' % data) + +if __name__ == '__main__': + main(sys.argv) |