summaryrefslogtreecommitdiff
path: root/graphics/java/android
diff options
context:
space:
mode:
author TreeHugger Robot <treehugger-gerrit@google.com> 2019-03-13 01:05:39 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2019-03-13 01:05:39 +0000
commitc91fa25bee9bacb27d3a9e3d60fd9c7ee5c7abb9 (patch)
tree43490ab436e29e6543e69ea1c9ea121c5c0faef5 /graphics/java/android
parentf525cf00390dc67945ffbd6f9ff0c63fdd12b992 (diff)
parent96e93959fb8cb27db1829b28113558cc8136c858 (diff)
Merge "Always suppress font error during resource loading"
Diffstat (limited to 'graphics/java/android')
-rw-r--r--graphics/java/android/graphics/Typeface.java30
-rw-r--r--graphics/java/android/graphics/fonts/Font.java4
2 files changed, 24 insertions, 10 deletions
diff --git a/graphics/java/android/graphics/Typeface.java b/graphics/java/android/graphics/Typeface.java
index 95187149b985..86f658b4a48e 100644
--- a/graphics/java/android/graphics/Typeface.java
+++ b/graphics/java/android/graphics/Typeface.java
@@ -33,12 +33,12 @@ import android.graphics.fonts.FontStyle;
import android.graphics.fonts.FontVariationAxis;
import android.graphics.fonts.SystemFonts;
import android.os.Build;
-import android.os.Build.VERSION_CODES;
import android.os.ParcelFileDescriptor;
import android.provider.FontRequest;
import android.provider.FontsContract;
import android.text.FontConfig;
import android.util.Base64;
+import android.util.Log;
import android.util.LongSparseArray;
import android.util.LruCache;
import android.util.SparseArray;
@@ -48,7 +48,6 @@ import com.android.internal.annotations.VisibleForTesting;
import com.android.internal.util.Preconditions;
import dalvik.annotation.optimization.CriticalNative;
-import dalvik.system.VMRuntime;
import libcore.util.NativeAllocationRegistry;
@@ -262,18 +261,29 @@ public class Typeface {
? FontStyle.FONT_SLANT_ITALIC : FontStyle.FONT_SLANT_UPRIGHT);
}
+ Font font = null;
+ try {
+ font = fontBuilder.build();
+ } catch (IllegalArgumentException e) {
+ // The exception happens if the unsupported font is passed. We suppress this
+ // exception and just ignore this font here since there is no way of
+ // resolving this issue by users during inflating layout.
+ Log.w(TAG, "Ignoring font file since failed to create font object."
+ + " The font file is not supported on this platform.");
+ continue;
+ }
if (familyBuilder == null) {
- familyBuilder = new FontFamily.Builder(fontBuilder.build());
+ familyBuilder = new FontFamily.Builder(font);
} else {
try {
- familyBuilder.addFont(fontBuilder.build());
+ familyBuilder.addFont(font);
} catch (IllegalArgumentException e) {
- if (VMRuntime.getRuntime().getTargetSdkVersion() <= VERSION_CODES.P) {
- // Surpress the IllegalArgumentException for keeping the backward
- // compatibility.
- continue;
- }
- throw e;
+ // The exception happens if the same style is added to the family.
+ // We suppress this exception and just ignore this font here since there is
+ // no way of resolving this issue by users during inflating layout.
+ Log.w(TAG,
+ "Ignoring font file since the same style font is already added.");
+ continue;
}
}
}
diff --git a/graphics/java/android/graphics/fonts/Font.java b/graphics/java/android/graphics/fonts/Font.java
index f715f43344d3..f92802f5b574 100644
--- a/graphics/java/android/graphics/fonts/Font.java
+++ b/graphics/java/android/graphics/fonts/Font.java
@@ -354,6 +354,10 @@ public final class Font {
/**
* Creates the font based on the configured values.
+ *
+ * If the font is not supported by the platform, this function will fail with
+ * {@link IllegalArgumentException}.
+ *
* @return the Font object
*/
public @Nullable Font build() throws IOException {