123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- #!/usr/bin/env python
- #===- cindex-includes.py - cindex/Python Inclusion Graph -----*- 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
- #
- #===------------------------------------------------------------------------===#
- """
- A simple command line tool for dumping a Graphviz description (dot) that
- describes include dependencies.
- """
- def main():
- import sys
- from clang.cindex import Index
- from optparse import OptionParser, OptionGroup
- parser = OptionParser("usage: %prog [options] {filename} [clang-args*]")
- parser.disable_interspersed_args()
- (opts, args) = parser.parse_args()
- if len(args) == 0:
- parser.error('invalid number arguments')
- # FIXME: Add an output file option
- out = sys.stdout
- index = Index.create()
- tu = index.parse(None, args)
- if not tu:
- parser.error("unable to load input")
- # A helper function for generating the node name.
- def name(f):
- if f:
- return "\"" + f.name + "\""
- # Generate the include graph
- out.write("digraph G {\n")
- for i in tu.get_includes():
- line = " ";
- if i.is_input_file:
- # Always write the input file as a node just in case it doesn't
- # actually include anything. This would generate a 1 node graph.
- line += name(i.include)
- else:
- line += '%s->%s' % (name(i.source), name(i.include))
- line += "\n";
- out.write(line)
- out.write("}\n")
- if __name__ == '__main__':
- main()
|