diff options
author | 2021-01-02 20:29:13 +0000 | |
---|---|---|
committer | 2021-01-02 20:29:13 +0000 | |
commit | 46035553bfdd96e63c94e32da0210227ec2e3cf1 (patch) | |
tree | b191f708fb9a2995ba745b2f31cdeeaee4872b7f /gnu/llvm/libcxx/utils/sym_match.py | |
parent | Move Makefiles for libc++ and libc++abi to gnu/lib in preparation for an (diff) | |
download | wireguard-openbsd-46035553bfdd96e63c94e32da0210227ec2e3cf1.tar.xz wireguard-openbsd-46035553bfdd96e63c94e32da0210227ec2e3cf1.zip |
Import libc++ 10.0.1 release.
Diffstat (limited to 'gnu/llvm/libcxx/utils/sym_match.py')
-rwxr-xr-x | gnu/llvm/libcxx/utils/sym_match.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/gnu/llvm/libcxx/utils/sym_match.py b/gnu/llvm/libcxx/utils/sym_match.py new file mode 100755 index 00000000000..1fd39ca5f83 --- /dev/null +++ b/gnu/llvm/libcxx/utils/sym_match.py @@ -0,0 +1,50 @@ +#!/usr/bin/env python +#===----------------------------------------------------------------------===## +# +# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +# See https://llvm.org/LICENSE.txt for license information. +# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +# +#===----------------------------------------------------------------------===## + +""" +sym_match - Match all symbols in a list against a list of regexes. +""" +from argparse import ArgumentParser +import sys +from libcxx.sym_check import util, match, extract + + +def main(): + parser = ArgumentParser( + description='Extract a list of symbols from a shared library.') + parser.add_argument( + '--blacklist', dest='blacklist', + type=str, action='store', default=None) + parser.add_argument( + 'symbol_list', metavar='symbol_list', type=str, + help='The file containing the old symbol list') + parser.add_argument( + 'regexes', metavar='regexes', default=[], nargs='*', + help='The file containing the new symbol list or a library') + args = parser.parse_args() + + if not args.regexes and args.blacklist is None: + sys.stderr.write('Either a regex or a blacklist must be specified.\n') + sys.exit(1) + if args.blacklist: + search_list = util.read_blacklist(args.blacklist) + else: + search_list = args.regexes + + symbol_list = util.extract_or_load(args.symbol_list) + + matching_count, report = match.find_and_report_matching( + symbol_list, search_list) + sys.stdout.write(report) + if matching_count != 0: + print('%d matching symbols found...' % matching_count) + + +if __name__ == '__main__': + main() |