Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(816)

Side by Side Diff: native_client_sdk/src/build_tools/generate_notice.py

Issue 11074004: [NaCl SDK] Generate NOTICE file automatically. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: feedback Created 8 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « native_client_sdk/src/build_tools/build_sdk.py ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 #!/usr/bin/env python
2 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file.
5
6 """Build the NOTICE file distributed with the NaCl SDK from a set of given
7 license files."""
8
9 import optparse
10 import os
11 import sys
12
13
14 def Trace(msg):
15 if Trace.verbose:
16 print msg
17
18 Trace.verbose = False
19
20
21 def FindFiles(files):
22 found = [f for f in files if os.path.exists(f)]
23
24 if Trace.verbose:
25 for f in sorted(set(files) - set(found)):
26 Trace('Skipping %s. File doesn\'t exist.\n' % (f,))
27
28 return found
29
30
31 def CreateLicenseDict(files):
32 # Many of the license files are duplicates. Create a map of license text to
33 # filename.
34 license_dict = {}
35 for filename in files:
36 license_text = open(filename).read()
37 license_dict.setdefault(license_text, []).append(filename)
38
39 # Flip the dictionary (map tuple of filenames -> license text).
40 return dict((tuple(value), key) for key, value in license_dict.iteritems())
41
42
43 def WriteLicense(output_file, root, license_text, license_filenames):
44 Trace('Writing license for files:\n' + '\n'.join(license_filenames))
45 output_file.write('=' * 70 + '\n')
46 for filename in sorted(license_filenames):
47 filename = os.path.relpath(filename, root)
48 license_dir = os.path.dirname(filename)
49 if not license_dir:
50 license_dir = 'native_client_sdk'
51
52 output_file.write('%s is licensed as follows\n' % (license_dir,))
53 output_file.write(' (Cf. %s):\n' % (filename,))
54 output_file.write('=' * 70 + '\n')
55 output_file.write(license_text)
56 output_file.write('\n\n\n')
57
58
59 def Generate(output_filename, root, files):
60 found_files = FindFiles(files)
61 license_dict = CreateLicenseDict(found_files)
62 with open(output_filename, 'w') as output_file:
63 for license_filenames in sorted(license_dict.iterkeys()):
64 license_text = license_dict[license_filenames]
65 WriteLicense(output_file, root, license_text, license_filenames)
66
67
68 def main(args):
69 parser = optparse.OptionParser()
70 parser.add_option('-v', '--verbose', help='Verbose output.',
71 action='store_true')
72 parser.add_option('-o', '--output', help='Output file')
73 parser.add_option('--root', help='Root for all paths')
74
75 options, args = parser.parse_args(args)
76 Trace.verbose = options.verbose
77
78 if not options.output:
79 parser.error('No output file given. See -o.')
80 if not options.root:
81 parser.error('No root directory given. See --root.')
82
83 Generate(options.output, options.root, args)
84 Trace('Done.')
85
86 return 0
87
88
89 if __name__ == '__main__':
90 sys.exit(main(sys.argv[1:]))
OLDNEW
« no previous file with comments | « native_client_sdk/src/build_tools/build_sdk.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698