Loading mime/Android.bp +65 −5 Original line number Original line Diff line number Diff line Loading @@ -12,24 +12,84 @@ // See the License for the specific language governing permissions and // See the License for the specific language governing permissions and // limitations under the License. // limitations under the License. java_defaults { name: "mimemap-defaults", srcs: [ "java/android/content/type/DefaultMimeMapFactory.java", ], sdk_version: "core_platform", } java_library { java_library { name: "mimemap", name: "mimemap", defaults: ["mimemap-defaults"], static_libs: ["mimemap-res.jar"], visibility: [ "//frameworks/base:__subpackages__", ], } java_library { name: "mimemap-testing", defaults: ["mimemap-defaults"], static_libs: ["mimemap-testing-res.jar"], jarjar_rules: "jarjar-rules.txt", visibility: [ visibility: [ "//cts/tests/tests/mimemap:__subpackages__", "//cts/tests/tests/mimemap:__subpackages__", "//frameworks/base:__subpackages__", "//frameworks/base:__subpackages__", ], ], } // The mimemap-res.jar and mimemap-testing-res.jar genrules produce a .jar that // has the resource file in a subdirectory res/ and testres/, respectively. // Those paths need to They need to be in different paths because one of them // ends up on a bootclasspath jar whereas the other one ends up in a test jar. // Bootclasspath resources hide test or application resources under the same // path because ClassLoader.getResource(String) consults the parent ClassLoader // first. // // Further notes: // - the "cp" command will flatten any directory paths that occur in $(in), // but here they happen to already be in the root directory. If we needed // to preserve sub paths then we might want to zip the files first and then // unzip them below the new parent directory. // - the path names "res/" and "testres/" and duplicated in .java source files // (DefaultMimeMapFactory.java and MimeMapTest.java, as of October 2019). java_genrule { name: "mimemap-res.jar", tools: [ "soong_zip", ], srcs: [":mime.types"], out: ["mimemap-res.jar"], cmd: "mkdir $(genDir)/res/ && cp $(in) $(genDir)/res/ && $(location soong_zip) -C $(genDir) -o $(out) -D $(genDir)/res/", } srcs: [ // The same as mimemap-res.jar except that the resources are placed in a different directory. "java/android/content/type/DefaultMimeMapFactory.java", // They get bundled with CTS so that CTS can compare a device's MimeMap implementation vs. // the stock Android one from when CTS was built. java_genrule { name: "mimemap-testing-res.jar", tools: [ "soong_zip", ], ], srcs: [":mime.types"], out: ["mimemap-testing-res.jar"], cmd: "mkdir $(genDir)/testres/ && cp $(in) $(genDir)/testres/ && $(location soong_zip) -C $(genDir) -o $(out) -D $(genDir)/testres/", } java_resources: [ // Combination of all *mime.types resources. filegroup { name: "mime.types", visibility: [ "//visibility:private", ], srcs: [ ":debian.mime.types", ":debian.mime.types", ":android.mime.types", ":android.mime.types", ":vendor.mime.types", ":vendor.mime.types", ], ], sdk_version: "core_platform", } } filegroup { filegroup { Loading mime/jarjar-rules.txt 0 → 100644 +1 −0 Original line number Original line Diff line number Diff line rule android.content.type.DefaultMimeMapFactory android.content.type.cts.StockAndroidMimeMapFactory No newline at end of file mime/java/android/content/type/DefaultMimeMapFactory.java +25 −10 Original line number Original line Diff line number Diff line Loading @@ -20,10 +20,13 @@ import libcore.net.MimeMap; import java.io.BufferedReader; import java.io.BufferedReader; import java.io.IOException; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.ArrayList; import java.util.Arrays; import java.util.Arrays; import java.util.List; import java.util.List; import java.util.Objects; import java.util.function.Function; import java.util.regex.Pattern; import java.util.regex.Pattern; /** /** Loading @@ -45,21 +48,33 @@ public class DefaultMimeMapFactory { * Android's default mapping between MIME types and extensions. * Android's default mapping between MIME types and extensions. */ */ public static MimeMap create() { public static MimeMap create() { MimeMap.Builder builder = MimeMap.builder(); Class c = DefaultMimeMapFactory.class; parseTypes(builder, true, "/mime.types"); // The resources are placed into the res/ path by the "mimemap-res.jar" genrule. parseTypes(builder, true, "/android.mime.types"); return create(resourceName -> c.getResourceAsStream("/res/" + resourceName)); parseTypes(builder, false, "/vendor.mime.types"); return builder.build(); } } private static final Pattern SPLIT_PATTERN = Pattern.compile("\\s+"); private static final Pattern SPLIT_PATTERN = Pattern.compile("\\s+"); /** * Creates a {@link MimeMap} instance whose resources are loaded from the * InputStreams looked up in {@code resourceSupplier}. * * @hide */ public static MimeMap create(Function<String, InputStream> resourceSupplier) { MimeMap.Builder builder = MimeMap.builder(); parseTypes(builder, true, resourceSupplier, "mime.types"); parseTypes(builder, true, resourceSupplier, "android.mime.types"); parseTypes(builder, false, resourceSupplier, "vendor.mime.types"); return builder.build(); } private static void parseTypes(MimeMap.Builder builder, boolean allowOverwrite, private static void parseTypes(MimeMap.Builder builder, boolean allowOverwrite, String resource) { Function<String, InputStream> resourceSupplier, String resourceName) { try (BufferedReader r = new BufferedReader( try (InputStream inputStream = Objects.requireNonNull(resourceSupplier.apply(resourceName)); new InputStreamReader(DefaultMimeMapFactory.class.getResourceAsStream(resource)))) { BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream))) { String line; String line; while ((line = r.readLine()) != null) { while ((line = reader.readLine()) != null) { int commentPos = line.indexOf('#'); int commentPos = line.indexOf('#'); if (commentPos >= 0) { if (commentPos >= 0) { line = line.substring(0, commentPos); line = line.substring(0, commentPos); Loading @@ -78,7 +93,7 @@ public class DefaultMimeMapFactory { builder.put(specs.get(0), specs.subList(1, specs.size())); builder.put(specs.get(0), specs.subList(1, specs.size())); } } } catch (IOException | RuntimeException e) { } catch (IOException | RuntimeException e) { throw new RuntimeException("Failed to parse " + resource, e); throw new RuntimeException("Failed to parse " + resourceName, e); } } } } Loading Loading
mime/Android.bp +65 −5 Original line number Original line Diff line number Diff line Loading @@ -12,24 +12,84 @@ // See the License for the specific language governing permissions and // See the License for the specific language governing permissions and // limitations under the License. // limitations under the License. java_defaults { name: "mimemap-defaults", srcs: [ "java/android/content/type/DefaultMimeMapFactory.java", ], sdk_version: "core_platform", } java_library { java_library { name: "mimemap", name: "mimemap", defaults: ["mimemap-defaults"], static_libs: ["mimemap-res.jar"], visibility: [ "//frameworks/base:__subpackages__", ], } java_library { name: "mimemap-testing", defaults: ["mimemap-defaults"], static_libs: ["mimemap-testing-res.jar"], jarjar_rules: "jarjar-rules.txt", visibility: [ visibility: [ "//cts/tests/tests/mimemap:__subpackages__", "//cts/tests/tests/mimemap:__subpackages__", "//frameworks/base:__subpackages__", "//frameworks/base:__subpackages__", ], ], } // The mimemap-res.jar and mimemap-testing-res.jar genrules produce a .jar that // has the resource file in a subdirectory res/ and testres/, respectively. // Those paths need to They need to be in different paths because one of them // ends up on a bootclasspath jar whereas the other one ends up in a test jar. // Bootclasspath resources hide test or application resources under the same // path because ClassLoader.getResource(String) consults the parent ClassLoader // first. // // Further notes: // - the "cp" command will flatten any directory paths that occur in $(in), // but here they happen to already be in the root directory. If we needed // to preserve sub paths then we might want to zip the files first and then // unzip them below the new parent directory. // - the path names "res/" and "testres/" and duplicated in .java source files // (DefaultMimeMapFactory.java and MimeMapTest.java, as of October 2019). java_genrule { name: "mimemap-res.jar", tools: [ "soong_zip", ], srcs: [":mime.types"], out: ["mimemap-res.jar"], cmd: "mkdir $(genDir)/res/ && cp $(in) $(genDir)/res/ && $(location soong_zip) -C $(genDir) -o $(out) -D $(genDir)/res/", } srcs: [ // The same as mimemap-res.jar except that the resources are placed in a different directory. "java/android/content/type/DefaultMimeMapFactory.java", // They get bundled with CTS so that CTS can compare a device's MimeMap implementation vs. // the stock Android one from when CTS was built. java_genrule { name: "mimemap-testing-res.jar", tools: [ "soong_zip", ], ], srcs: [":mime.types"], out: ["mimemap-testing-res.jar"], cmd: "mkdir $(genDir)/testres/ && cp $(in) $(genDir)/testres/ && $(location soong_zip) -C $(genDir) -o $(out) -D $(genDir)/testres/", } java_resources: [ // Combination of all *mime.types resources. filegroup { name: "mime.types", visibility: [ "//visibility:private", ], srcs: [ ":debian.mime.types", ":debian.mime.types", ":android.mime.types", ":android.mime.types", ":vendor.mime.types", ":vendor.mime.types", ], ], sdk_version: "core_platform", } } filegroup { filegroup { Loading
mime/jarjar-rules.txt 0 → 100644 +1 −0 Original line number Original line Diff line number Diff line rule android.content.type.DefaultMimeMapFactory android.content.type.cts.StockAndroidMimeMapFactory No newline at end of file
mime/java/android/content/type/DefaultMimeMapFactory.java +25 −10 Original line number Original line Diff line number Diff line Loading @@ -20,10 +20,13 @@ import libcore.net.MimeMap; import java.io.BufferedReader; import java.io.BufferedReader; import java.io.IOException; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.ArrayList; import java.util.Arrays; import java.util.Arrays; import java.util.List; import java.util.List; import java.util.Objects; import java.util.function.Function; import java.util.regex.Pattern; import java.util.regex.Pattern; /** /** Loading @@ -45,21 +48,33 @@ public class DefaultMimeMapFactory { * Android's default mapping between MIME types and extensions. * Android's default mapping between MIME types and extensions. */ */ public static MimeMap create() { public static MimeMap create() { MimeMap.Builder builder = MimeMap.builder(); Class c = DefaultMimeMapFactory.class; parseTypes(builder, true, "/mime.types"); // The resources are placed into the res/ path by the "mimemap-res.jar" genrule. parseTypes(builder, true, "/android.mime.types"); return create(resourceName -> c.getResourceAsStream("/res/" + resourceName)); parseTypes(builder, false, "/vendor.mime.types"); return builder.build(); } } private static final Pattern SPLIT_PATTERN = Pattern.compile("\\s+"); private static final Pattern SPLIT_PATTERN = Pattern.compile("\\s+"); /** * Creates a {@link MimeMap} instance whose resources are loaded from the * InputStreams looked up in {@code resourceSupplier}. * * @hide */ public static MimeMap create(Function<String, InputStream> resourceSupplier) { MimeMap.Builder builder = MimeMap.builder(); parseTypes(builder, true, resourceSupplier, "mime.types"); parseTypes(builder, true, resourceSupplier, "android.mime.types"); parseTypes(builder, false, resourceSupplier, "vendor.mime.types"); return builder.build(); } private static void parseTypes(MimeMap.Builder builder, boolean allowOverwrite, private static void parseTypes(MimeMap.Builder builder, boolean allowOverwrite, String resource) { Function<String, InputStream> resourceSupplier, String resourceName) { try (BufferedReader r = new BufferedReader( try (InputStream inputStream = Objects.requireNonNull(resourceSupplier.apply(resourceName)); new InputStreamReader(DefaultMimeMapFactory.class.getResourceAsStream(resource)))) { BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream))) { String line; String line; while ((line = r.readLine()) != null) { while ((line = reader.readLine()) != null) { int commentPos = line.indexOf('#'); int commentPos = line.indexOf('#'); if (commentPos >= 0) { if (commentPos >= 0) { line = line.substring(0, commentPos); line = line.substring(0, commentPos); Loading @@ -78,7 +93,7 @@ public class DefaultMimeMapFactory { builder.put(specs.get(0), specs.subList(1, specs.size())); builder.put(specs.get(0), specs.subList(1, specs.size())); } } } catch (IOException | RuntimeException e) { } catch (IOException | RuntimeException e) { throw new RuntimeException("Failed to parse " + resource, e); throw new RuntimeException("Failed to parse " + resourceName, e); } } } } Loading