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

Unified Diff: build/android/javac.py

Issue 12853002: Convert java library javac/jar to python (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « build/android/jar.py ('k') | build/android/pylib/build_utils.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/android/javac.py
diff --git a/build/android/javac.py b/build/android/javac.py
new file mode 100755
index 0000000000000000000000000000000000000000..1ba5d064f8d18a5ee86c12aa1b5e996b41ddc52f
--- /dev/null
+++ b/build/android/javac.py
@@ -0,0 +1,79 @@
+#!/usr/bin/env python
+#
+# Copyright 2013 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+import fnmatch
+import optparse
+import os
+import subprocess
+import sys
+
+from pylib import build_utils
+
+def DoJavac(options):
+ output_dir = options.output_dir
+
+ src_dirs = build_utils.ParseGypList(options.src_dirs)
+ java_files = build_utils.FindInDirectories(src_dirs, '*.java')
+ if options.javac_includes:
+ javac_includes = build_utils.ParseGypList(options.javac_includes)
+ filtered_java_files = []
+ for f in java_files:
+ for include in javac_includes:
+ if fnmatch.fnmatch(f, include):
+ filtered_java_files.append(f)
+ break
+ java_files = filtered_java_files
+
+ # Compiling guava with certain orderings of input files causes a compiler
+ # crash... Sorted order works, so use that.
+ # See https://code.google.com/p/guava-libraries/issues/detail?id=950
+ java_files.sort()
+
+ classpath = build_utils.ParseGypList(options.classpath)
+
+ # Delete the classes directory. This ensures that all .class files in the
+ # output are actually from the input .java files. For example, if a .java
+ # file is deleted or an inner class is removed, the classes directory should
+ # not contain the corresponding old .class file after running this action.
+ build_utils.DeleteDirectory(output_dir)
+ build_utils.MakeDirectory(output_dir)
+
+ subprocess.check_call([
+ 'javac',
+ '-g',
+ '-Xlint:unchecked',
+ '-source', '1.5',
+ '-target', '1.5',
+ '-classpath', ':'.join(classpath),
+ '-d', output_dir] +
+ java_files)
+
+
+def main(argv):
+ parser = optparse.OptionParser()
+ parser.add_option('--src-dirs', help='Directories containing java files.')
+ parser.add_option('--javac-includes',
+ help='A list of file patterns. If provided, only java files that match' +
+ 'one of the patterns will be compiled.')
+ parser.add_option('--classpath', help='Classpath for javac.')
+ parser.add_option('--output-dir', help='Directory for javac output.')
+ parser.add_option('--stamp', help='Path to touch on success.')
+
+ # TODO(newt): remove this once http://crbug.com/177552 is fixed in ninja.
+ parser.add_option('--ignore', help='Ignored.')
+
+ options, _ = parser.parse_args()
+
+ DoJavac(options)
+
+ if options.stamp:
+ build_utils.Touch(options.stamp)
+
+
+if __name__ == '__main__':
+ sys.exit(main(sys.argv))
+
+
« no previous file with comments | « build/android/jar.py ('k') | build/android/pylib/build_utils.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698