Merge "More lint checks." into nyc-dev

This commit is contained in:
Jeff Sharkey
2016-02-29 23:21:28 +00:00
committed by Android (Google) Code Review

View File

@@ -264,6 +264,9 @@ def verify_constants(clazz):
if "static" in f.split and "final" in f.split:
if re.match("[A-Z0-9_]+", f.name) is None:
error(clazz, f, "C2", "Constant field names must be FOO_NAME")
elif f.typ != "java.lang.String":
if f.name.startswith("MIN_") or f.name.startswith("MAX_"):
warn(clazz, f, "C8", "If min/max could change in future, make them dynamic methods")
def verify_enums(clazz):
@@ -417,6 +420,9 @@ def verify_parcelable(clazz):
if len(creator) == 0 or len(write) == 0 or len(describe) == 0:
error(clazz, None, "FW3", "Parcelable requires CREATOR, writeToParcel, and describeContents; missing one")
if " final class " not in clazz.raw:
error(clazz, None, "FW8", "Parcelable classes must be final")
def verify_protected(clazz):
"""Verify that no protected methods or fields are allowed."""
@@ -730,6 +736,13 @@ def verify_exception(clazz):
if "throws java.lang.Exception" in m.raw or "throws java.lang.Throwable" in m.raw or "throws java.lang.Error" in m.raw:
error(clazz, m, "S1", "Methods must not throw generic exceptions")
if "throws android.os.RemoteException" in m.raw:
if clazz.name == "android.content.ContentProviderClient": continue
if clazz.name == "android.os.Binder": continue
if clazz.name == "android.os.IBinder": continue
error(clazz, m, "FW9", "Methods calling into system server should rethrow RemoteException as RuntimeException")
def verify_google(clazz):
"""Verifies that APIs never reference Google."""
@@ -946,6 +959,27 @@ def verify_resource_names(clazz):
error(clazz, f, "C7", "Expected resource name in this class to be FooBar_Baz style")
def verify_files(clazz):
"""Verifies that methods accepting File also accept streams."""
has_file = set()
has_stream = set()
test = []
test.extend(clazz.ctors)
test.extend(clazz.methods)
for m in test:
if "java.io.File" in m.args:
has_file.add(m)
if "java.io.FileDescriptor" in m.args or "android.os.ParcelFileDescriptor" in m.args or "java.io.InputStream" in m.args or "java.io.OutputStream" in m.args:
has_stream.add(m.name)
for m in has_file:
if m.name not in has_stream:
warn(clazz, m, "M10", "Methods accepting File should also accept FileDescriptor or streams")
def examine_clazz(clazz):
"""Find all style issues in the given class."""
if clazz.pkg.name.startswith("java"): return
@@ -954,6 +988,7 @@ def examine_clazz(clazz):
if clazz.pkg.name.startswith("org.xml"): return
if clazz.pkg.name.startswith("org.json"): return
if clazz.pkg.name.startswith("org.w3c"): return
if clazz.pkg.name.startswith("android.icu."): return
verify_constants(clazz)
verify_enums(clazz)
@@ -989,6 +1024,7 @@ def examine_clazz(clazz):
verify_context_first(clazz)
verify_listener_last(clazz)
verify_resource_names(clazz)
verify_files(clazz)
def examine_stream(stream):