package androidx.emoji2.text; import android.content.Context; import android.os.Bundle; import android.os.Handler; import android.os.Looper; import android.text.Editable; import android.view.KeyEvent; import android.view.inputmethod.EditorInfo; import android.view.inputmethod.InputConnection; import androidx.annotation.AnyThread; import androidx.annotation.CheckResult; import androidx.annotation.ColorInt; import androidx.annotation.GuardedBy; import androidx.annotation.IntRange; import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.annotation.RequiresApi; import androidx.annotation.RestrictTo; import androidx.collection.ArraySet; import androidx.core.util.Preconditions; import androidx.emoji2.text.DefaultEmojiCompatConfig; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.Iterator; import java.util.List; import java.util.Set; import java.util.concurrent.locks.ReadWriteLock; import java.util.concurrent.locks.ReentrantReadWriteLock; @AnyThread /* loaded from: classes.dex */ public class EmojiCompat { public static final String EDITOR_INFO_METAVERSION_KEY = "android.support.text.emoji.emojiCompat_metadataVersion"; public static final String EDITOR_INFO_REPLACE_ALL_KEY = "android.support.text.emoji.emojiCompat_replaceAll"; @RestrictTo({RestrictTo.Scope.LIBRARY}) static final int EMOJI_COUNT_UNLIMITED = Integer.MAX_VALUE; public static final int EMOJI_FALLBACK = 2; public static final int EMOJI_SUPPORTED = 1; public static final int EMOJI_UNSUPPORTED = 0; public static final int LOAD_STATE_DEFAULT = 3; public static final int LOAD_STATE_FAILED = 2; public static final int LOAD_STATE_LOADING = 0; public static final int LOAD_STATE_SUCCEEDED = 1; public static final int LOAD_STRATEGY_DEFAULT = 0; public static final int LOAD_STRATEGY_MANUAL = 1; private static final String NOT_INITIALIZED_ERROR_TEXT = "EmojiCompat is not initialized.\n\nYou must initialize EmojiCompat prior to referencing the EmojiCompat instance.\n\nThe most likely cause of this error is disabling the EmojiCompatInitializer\neither explicitly in AndroidManifest.xml, or by including\nandroidx.emoji2:emoji2-bundled.\n\nAutomatic initialization is typically performed by EmojiCompatInitializer. If\nyou are not expecting to initialize EmojiCompat manually in your application,\nplease check to ensure it has not been removed from your APK's manifest. You can\ndo this in Android Studio using Build > Analyze APK.\n\nIn the APK Analyzer, ensure that the startup entry for\nEmojiCompatInitializer and InitializationProvider is present in\n AndroidManifest.xml. If it is missing or contains tools:node=\"remove\", and you\nintend to use automatic configuration, verify:\n\n 1. Your application does not include emoji2-bundled\n 2. All modules do not contain an exclusion manifest rule for\n EmojiCompatInitializer or InitializationProvider. For more information\n about manifest exclusions see the documentation for the androidx startup\n library.\n\nIf you intend to use emoji2-bundled, please call EmojiCompat.init. You can\nlearn more in the documentation for BundledEmojiCompatConfig.\n\nIf you intended to perform manual configuration, it is recommended that you call\nEmojiCompat.init immediately on application startup.\n\nIf you still cannot resolve this issue, please open a bug with your specific\nconfiguration to help improve error message."; public static final int REPLACE_STRATEGY_ALL = 1; public static final int REPLACE_STRATEGY_DEFAULT = 0; public static final int REPLACE_STRATEGY_NON_EXISTENT = 2; @GuardedBy("CONFIG_LOCK") private static volatile boolean sHasDoneDefaultConfigLookup; @Nullable @GuardedBy("INSTANCE_LOCK") private static volatile EmojiCompat sInstance; @Nullable final int[] mEmojiAsDefaultStyleExceptions; private final int mEmojiSpanIndicatorColor; private final boolean mEmojiSpanIndicatorEnabled; private final GlyphChecker mGlyphChecker; @NonNull private final CompatInternal mHelper; @NonNull @GuardedBy("mInitLock") private final Set mInitCallbacks; @NonNull private final ReadWriteLock mInitLock = new ReentrantReadWriteLock(); @GuardedBy("mInitLock") private volatile int mLoadState = 3; @NonNull private final Handler mMainHandler = new Handler(Looper.getMainLooper()); private final int mMetadataLoadStrategy; @NonNull final MetadataRepoLoader mMetadataLoader; final boolean mReplaceAll; @NonNull private final SpanFactory mSpanFactory; final boolean mUseEmojiAsDefaultStyle; private static final Object INSTANCE_LOCK = new Object(); private static final Object CONFIG_LOCK = new Object(); @Retention(RetentionPolicy.SOURCE) @RestrictTo({RestrictTo.Scope.LIBRARY}) public @interface CodepointSequenceMatchResult { } public interface GlyphChecker { boolean hasGlyph(@NonNull CharSequence charSequence, @IntRange(from = 0) int i, @IntRange(from = 0) int i2, @IntRange(from = 0) int i3); } public static abstract class InitCallback { public void onFailed(@Nullable Throwable th) { } public void onInitialized() { } } @Retention(RetentionPolicy.SOURCE) @RestrictTo({RestrictTo.Scope.LIBRARY}) public @interface LoadStrategy { } public interface MetadataRepoLoader { void load(@NonNull MetadataRepoLoaderCallback metadataRepoLoaderCallback); } public static abstract class MetadataRepoLoaderCallback { public abstract void onFailed(@Nullable Throwable th); public abstract void onLoaded(@NonNull MetadataRepo metadataRepo); } @Retention(RetentionPolicy.SOURCE) @RestrictTo({RestrictTo.Scope.LIBRARY}) public @interface ReplaceStrategy { } public interface SpanFactory { @NonNull @RequiresApi(19) EmojiSpan createSpan(@NonNull TypefaceEmojiRasterizer typefaceEmojiRasterizer); } public static boolean isConfigured() { return sInstance != null; } @ColorInt @RestrictTo({RestrictTo.Scope.LIBRARY_GROUP}) public int getEmojiSpanIndicatorColor() { return this.mEmojiSpanIndicatorColor; } @RestrictTo({RestrictTo.Scope.LIBRARY_GROUP}) public boolean isEmojiSpanIndicatorEnabled() { return this.mEmojiSpanIndicatorEnabled; } private EmojiCompat(@NonNull Config config) { this.mReplaceAll = config.mReplaceAll; this.mUseEmojiAsDefaultStyle = config.mUseEmojiAsDefaultStyle; this.mEmojiAsDefaultStyleExceptions = config.mEmojiAsDefaultStyleExceptions; this.mEmojiSpanIndicatorEnabled = config.mEmojiSpanIndicatorEnabled; this.mEmojiSpanIndicatorColor = config.mEmojiSpanIndicatorColor; this.mMetadataLoader = config.mMetadataLoader; this.mMetadataLoadStrategy = config.mMetadataLoadStrategy; this.mGlyphChecker = config.mGlyphChecker; ArraySet arraySet = new ArraySet(); this.mInitCallbacks = arraySet; SpanFactory spanFactory = config.mSpanFactory; this.mSpanFactory = spanFactory == null ? new DefaultSpanFactory() : spanFactory; Set set = config.mInitCallbacks; if (set != null && !set.isEmpty()) { arraySet.addAll(config.mInitCallbacks); } this.mHelper = new CompatInternal19(this); loadMetadata(); } @Nullable public static EmojiCompat init(@NonNull Context context) { return init(context, null); } @Nullable @RestrictTo({RestrictTo.Scope.LIBRARY}) public static EmojiCompat init(@NonNull Context context, @Nullable DefaultEmojiCompatConfig.DefaultEmojiCompatConfigFactory defaultEmojiCompatConfigFactory) { EmojiCompat emojiCompat; if (sHasDoneDefaultConfigLookup) { return sInstance; } if (defaultEmojiCompatConfigFactory == null) { defaultEmojiCompatConfigFactory = new DefaultEmojiCompatConfig.DefaultEmojiCompatConfigFactory(null); } Config create = defaultEmojiCompatConfigFactory.create(context); synchronized (CONFIG_LOCK) { try { if (!sHasDoneDefaultConfigLookup) { if (create != null) { init(create); } sHasDoneDefaultConfigLookup = true; } emojiCompat = sInstance; } catch (Throwable th) { throw th; } } return emojiCompat; } @NonNull public static EmojiCompat init(@NonNull Config config) { EmojiCompat emojiCompat = sInstance; if (emojiCompat == null) { synchronized (INSTANCE_LOCK) { try { emojiCompat = sInstance; if (emojiCompat == null) { emojiCompat = new EmojiCompat(config); sInstance = emojiCompat; } } finally { } } } return emojiCompat; } @NonNull public static EmojiCompat reset(@NonNull Config config) { EmojiCompat emojiCompat; synchronized (INSTANCE_LOCK) { emojiCompat = new EmojiCompat(config); sInstance = emojiCompat; } return emojiCompat; } @Nullable @RestrictTo({RestrictTo.Scope.TESTS}) public static EmojiCompat reset(@Nullable EmojiCompat emojiCompat) { EmojiCompat emojiCompat2; synchronized (INSTANCE_LOCK) { sInstance = emojiCompat; emojiCompat2 = sInstance; } return emojiCompat2; } @RestrictTo({RestrictTo.Scope.TESTS}) public static void skipDefaultConfigurationLookup(boolean z) { synchronized (CONFIG_LOCK) { sHasDoneDefaultConfigLookup = z; } } @NonNull public static EmojiCompat get() { EmojiCompat emojiCompat; synchronized (INSTANCE_LOCK) { emojiCompat = sInstance; Preconditions.checkState(emojiCompat != null, NOT_INITIALIZED_ERROR_TEXT); } return emojiCompat; } public void load() { Preconditions.checkState(this.mMetadataLoadStrategy == 1, "Set metadataLoadStrategy to LOAD_STRATEGY_MANUAL to execute manual loading"); if (isInitialized()) { return; } this.mInitLock.writeLock().lock(); try { if (this.mLoadState == 0) { return; } this.mLoadState = 0; this.mInitLock.writeLock().unlock(); this.mHelper.loadMetadata(); } finally { this.mInitLock.writeLock().unlock(); } } private void loadMetadata() { this.mInitLock.writeLock().lock(); try { if (this.mMetadataLoadStrategy == 0) { this.mLoadState = 0; } this.mInitLock.writeLock().unlock(); if (getLoadState() == 0) { this.mHelper.loadMetadata(); } } catch (Throwable th) { this.mInitLock.writeLock().unlock(); throw th; } } public void onMetadataLoadSuccess() { ArrayList arrayList = new ArrayList(); this.mInitLock.writeLock().lock(); try { this.mLoadState = 1; arrayList.addAll(this.mInitCallbacks); this.mInitCallbacks.clear(); this.mInitLock.writeLock().unlock(); this.mMainHandler.post(new ListenerDispatcher(arrayList, this.mLoadState)); } catch (Throwable th) { this.mInitLock.writeLock().unlock(); throw th; } } public void onMetadataLoadFailed(@Nullable Throwable th) { ArrayList arrayList = new ArrayList(); this.mInitLock.writeLock().lock(); try { this.mLoadState = 2; arrayList.addAll(this.mInitCallbacks); this.mInitCallbacks.clear(); this.mInitLock.writeLock().unlock(); this.mMainHandler.post(new ListenerDispatcher(arrayList, this.mLoadState, th)); } catch (Throwable th2) { this.mInitLock.writeLock().unlock(); throw th2; } } public void registerInitCallback(@NonNull InitCallback initCallback) { Preconditions.checkNotNull(initCallback, "initCallback cannot be null"); this.mInitLock.writeLock().lock(); try { if (this.mLoadState != 1 && this.mLoadState != 2) { this.mInitCallbacks.add(initCallback); this.mInitLock.writeLock().unlock(); } this.mMainHandler.post(new ListenerDispatcher(initCallback, this.mLoadState)); this.mInitLock.writeLock().unlock(); } catch (Throwable th) { this.mInitLock.writeLock().unlock(); throw th; } } public void unregisterInitCallback(@NonNull InitCallback initCallback) { Preconditions.checkNotNull(initCallback, "initCallback cannot be null"); this.mInitLock.writeLock().lock(); try { this.mInitCallbacks.remove(initCallback); } finally { this.mInitLock.writeLock().unlock(); } } public int getLoadState() { this.mInitLock.readLock().lock(); try { return this.mLoadState; } finally { this.mInitLock.readLock().unlock(); } } private boolean isInitialized() { return getLoadState() == 1; } public int getEmojiStart(@NonNull CharSequence charSequence, @IntRange(from = 0) int i) { return this.mHelper.getEmojiStart(charSequence, i); } public int getEmojiEnd(@NonNull CharSequence charSequence, @IntRange(from = 0) int i) { return this.mHelper.getEmojiEnd(charSequence, i); } public static boolean handleOnKeyDown(@NonNull Editable editable, int i, @NonNull KeyEvent keyEvent) { return EmojiProcessor.handleOnKeyDown(editable, i, keyEvent); } public static boolean handleDeleteSurroundingText(@NonNull InputConnection inputConnection, @NonNull Editable editable, @IntRange(from = 0) int i, @IntRange(from = 0) int i2, boolean z) { return EmojiProcessor.handleDeleteSurroundingText(inputConnection, editable, i, i2, z); } @Deprecated public boolean hasEmojiGlyph(@NonNull CharSequence charSequence) { Preconditions.checkState(isInitialized(), "Not initialized yet"); Preconditions.checkNotNull(charSequence, "sequence cannot be null"); return this.mHelper.hasEmojiGlyph(charSequence); } @Deprecated public boolean hasEmojiGlyph(@NonNull CharSequence charSequence, @IntRange(from = 0) int i) { Preconditions.checkState(isInitialized(), "Not initialized yet"); Preconditions.checkNotNull(charSequence, "sequence cannot be null"); return this.mHelper.hasEmojiGlyph(charSequence, i); } public int getEmojiMatch(@NonNull CharSequence charSequence, @IntRange(from = 0) int i) { Preconditions.checkState(isInitialized(), "Not initialized yet"); Preconditions.checkNotNull(charSequence, "sequence cannot be null"); return this.mHelper.getEmojiMatch(charSequence, i); } @Nullable @CheckResult public CharSequence process(@Nullable CharSequence charSequence) { return process(charSequence, 0, charSequence == null ? 0 : charSequence.length()); } @Nullable @CheckResult public CharSequence process(@Nullable CharSequence charSequence, @IntRange(from = 0) int i, @IntRange(from = 0) int i2) { return process(charSequence, i, i2, Integer.MAX_VALUE); } @Nullable @CheckResult public CharSequence process(@Nullable CharSequence charSequence, @IntRange(from = 0) int i, @IntRange(from = 0) int i2, @IntRange(from = 0) int i3) { return process(charSequence, i, i2, i3, 0); } @Nullable @CheckResult public CharSequence process(@Nullable CharSequence charSequence, @IntRange(from = 0) int i, @IntRange(from = 0) int i2, @IntRange(from = 0) int i3, int i4) { boolean z; Preconditions.checkState(isInitialized(), "Not initialized yet"); Preconditions.checkArgumentNonnegative(i, "start cannot be negative"); Preconditions.checkArgumentNonnegative(i2, "end cannot be negative"); Preconditions.checkArgumentNonnegative(i3, "maxEmojiCount cannot be negative"); Preconditions.checkArgument(i <= i2, "start should be <= than end"); if (charSequence == null) { return null; } Preconditions.checkArgument(i <= charSequence.length(), "start should be < than charSequence length"); Preconditions.checkArgument(i2 <= charSequence.length(), "end should be < than charSequence length"); if (charSequence.length() == 0 || i == i2) { return charSequence; } if (i4 != 1) { z = i4 != 2 ? this.mReplaceAll : false; } else { z = true; } return this.mHelper.process(charSequence, i, i2, i3, z); } @NonNull public String getAssetSignature() { Preconditions.checkState(isInitialized(), "Not initialized yet"); return this.mHelper.getAssetSignature(); } public void updateEditorInfo(@NonNull EditorInfo editorInfo) { if (!isInitialized() || editorInfo == null) { return; } if (editorInfo.extras == null) { editorInfo.extras = new Bundle(); } this.mHelper.updateEditorInfoAttrs(editorInfo); } @RestrictTo({RestrictTo.Scope.LIBRARY}) public static class DefaultSpanFactory implements SpanFactory { @Override // androidx.emoji2.text.EmojiCompat.SpanFactory @NonNull @RequiresApi(19) public EmojiSpan createSpan(@NonNull TypefaceEmojiRasterizer typefaceEmojiRasterizer) { return new TypefaceEmojiSpan(typefaceEmojiRasterizer); } } public static abstract class Config { @Nullable int[] mEmojiAsDefaultStyleExceptions; boolean mEmojiSpanIndicatorEnabled; @Nullable Set mInitCallbacks; @NonNull final MetadataRepoLoader mMetadataLoader; boolean mReplaceAll; SpanFactory mSpanFactory; boolean mUseEmojiAsDefaultStyle; int mEmojiSpanIndicatorColor = -16711936; int mMetadataLoadStrategy = 0; @NonNull GlyphChecker mGlyphChecker = new DefaultGlyphChecker(); @NonNull public final MetadataRepoLoader getMetadataRepoLoader() { return this.mMetadataLoader; } @NonNull public Config setEmojiSpanIndicatorColor(@ColorInt int i) { this.mEmojiSpanIndicatorColor = i; return this; } @NonNull public Config setEmojiSpanIndicatorEnabled(boolean z) { this.mEmojiSpanIndicatorEnabled = z; return this; } @NonNull public Config setMetadataLoadStrategy(int i) { this.mMetadataLoadStrategy = i; return this; } @NonNull public Config setReplaceAll(boolean z) { this.mReplaceAll = z; return this; } @NonNull public Config setSpanFactory(@NonNull SpanFactory spanFactory) { this.mSpanFactory = spanFactory; return this; } public Config(@NonNull MetadataRepoLoader metadataRepoLoader) { Preconditions.checkNotNull(metadataRepoLoader, "metadataLoader cannot be null."); this.mMetadataLoader = metadataRepoLoader; } @NonNull public Config registerInitCallback(@NonNull InitCallback initCallback) { Preconditions.checkNotNull(initCallback, "initCallback cannot be null"); if (this.mInitCallbacks == null) { this.mInitCallbacks = new ArraySet(); } this.mInitCallbacks.add(initCallback); return this; } @NonNull public Config unregisterInitCallback(@NonNull InitCallback initCallback) { Preconditions.checkNotNull(initCallback, "initCallback cannot be null"); Set set = this.mInitCallbacks; if (set != null) { set.remove(initCallback); } return this; } @NonNull public Config setUseEmojiAsDefaultStyle(boolean z) { return setUseEmojiAsDefaultStyle(z, null); } @NonNull public Config setUseEmojiAsDefaultStyle(boolean z, @Nullable List list) { this.mUseEmojiAsDefaultStyle = z; if (!z || list == null) { this.mEmojiAsDefaultStyleExceptions = null; } else { this.mEmojiAsDefaultStyleExceptions = new int[list.size()]; Iterator it = list.iterator(); int i = 0; while (it.hasNext()) { this.mEmojiAsDefaultStyleExceptions[i] = it.next().intValue(); i++; } Arrays.sort(this.mEmojiAsDefaultStyleExceptions); } return this; } @NonNull public Config setGlyphChecker(@NonNull GlyphChecker glyphChecker) { Preconditions.checkNotNull(glyphChecker, "GlyphChecker cannot be null"); this.mGlyphChecker = glyphChecker; return this; } } public static class ListenerDispatcher implements Runnable { private final List mInitCallbacks; private final int mLoadState; private final Throwable mThrowable; public ListenerDispatcher(@NonNull InitCallback initCallback, int i) { this(Arrays.asList((InitCallback) Preconditions.checkNotNull(initCallback, "initCallback cannot be null")), i, null); } public ListenerDispatcher(@NonNull Collection collection, int i) { this(collection, i, null); } public ListenerDispatcher(@NonNull Collection collection, int i, @Nullable Throwable th) { Preconditions.checkNotNull(collection, "initCallbacks cannot be null"); this.mInitCallbacks = new ArrayList(collection); this.mLoadState = i; this.mThrowable = th; } @Override // java.lang.Runnable public void run() { int size = this.mInitCallbacks.size(); int i = 0; if (this.mLoadState != 1) { while (i < size) { this.mInitCallbacks.get(i).onFailed(this.mThrowable); i++; } } else { while (i < size) { this.mInitCallbacks.get(i).onInitialized(); i++; } } } } public static class CompatInternal { final EmojiCompat mEmojiCompat; public String getAssetSignature() { return ""; } public int getEmojiEnd(@NonNull CharSequence charSequence, @IntRange(from = 0) int i) { return -1; } public int getEmojiMatch(CharSequence charSequence, int i) { return 0; } public int getEmojiStart(@NonNull CharSequence charSequence, @IntRange(from = 0) int i) { return -1; } public boolean hasEmojiGlyph(@NonNull CharSequence charSequence) { return false; } public boolean hasEmojiGlyph(@NonNull CharSequence charSequence, int i) { return false; } public CharSequence process(@NonNull CharSequence charSequence, @IntRange(from = 0) int i, @IntRange(from = 0) int i2, @IntRange(from = 0) int i3, boolean z) { return charSequence; } public void updateEditorInfoAttrs(@NonNull EditorInfo editorInfo) { } public CompatInternal(EmojiCompat emojiCompat) { this.mEmojiCompat = emojiCompat; } public void loadMetadata() { this.mEmojiCompat.onMetadataLoadSuccess(); } } @RequiresApi(19) public static final class CompatInternal19 extends CompatInternal { private volatile MetadataRepo mMetadataRepo; private volatile EmojiProcessor mProcessor; public CompatInternal19(EmojiCompat emojiCompat) { super(emojiCompat); } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public void loadMetadata() { try { this.mEmojiCompat.mMetadataLoader.load(new MetadataRepoLoaderCallback() { // from class: androidx.emoji2.text.EmojiCompat.CompatInternal19.1 @Override // androidx.emoji2.text.EmojiCompat.MetadataRepoLoaderCallback public void onLoaded(@NonNull MetadataRepo metadataRepo) { CompatInternal19.this.onMetadataLoadSuccess(metadataRepo); } @Override // androidx.emoji2.text.EmojiCompat.MetadataRepoLoaderCallback public void onFailed(@Nullable Throwable th) { CompatInternal19.this.mEmojiCompat.onMetadataLoadFailed(th); } }); } catch (Throwable th) { this.mEmojiCompat.onMetadataLoadFailed(th); } } public void onMetadataLoadSuccess(@NonNull MetadataRepo metadataRepo) { if (metadataRepo != null) { this.mMetadataRepo = metadataRepo; MetadataRepo metadataRepo2 = this.mMetadataRepo; SpanFactory spanFactory = this.mEmojiCompat.mSpanFactory; GlyphChecker glyphChecker = this.mEmojiCompat.mGlyphChecker; EmojiCompat emojiCompat = this.mEmojiCompat; this.mProcessor = new EmojiProcessor(metadataRepo2, spanFactory, glyphChecker, emojiCompat.mUseEmojiAsDefaultStyle, emojiCompat.mEmojiAsDefaultStyleExceptions, EmojiExclusions.getEmojiExclusions()); this.mEmojiCompat.onMetadataLoadSuccess(); return; } this.mEmojiCompat.onMetadataLoadFailed(new IllegalArgumentException("metadataRepo cannot be null")); } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public boolean hasEmojiGlyph(@NonNull CharSequence charSequence) { return this.mProcessor.getEmojiMatch(charSequence) == 1; } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public boolean hasEmojiGlyph(@NonNull CharSequence charSequence, int i) { return this.mProcessor.getEmojiMatch(charSequence, i) == 1; } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public int getEmojiMatch(CharSequence charSequence, int i) { return this.mProcessor.getEmojiMatch(charSequence, i); } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public int getEmojiStart(@NonNull CharSequence charSequence, int i) { return this.mProcessor.getEmojiStart(charSequence, i); } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public int getEmojiEnd(@NonNull CharSequence charSequence, int i) { return this.mProcessor.getEmojiEnd(charSequence, i); } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public CharSequence process(@NonNull CharSequence charSequence, int i, int i2, int i3, boolean z) { return this.mProcessor.process(charSequence, i, i2, i3, z); } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public void updateEditorInfoAttrs(@NonNull EditorInfo editorInfo) { editorInfo.extras.putInt(EmojiCompat.EDITOR_INFO_METAVERSION_KEY, this.mMetadataRepo.getMetadataVersion()); editorInfo.extras.putBoolean(EmojiCompat.EDITOR_INFO_REPLACE_ALL_KEY, this.mEmojiCompat.mReplaceAll); } @Override // androidx.emoji2.text.EmojiCompat.CompatInternal public String getAssetSignature() { String sourceSha = this.mMetadataRepo.getMetadataList().sourceSha(); return sourceSha == null ? "" : sourceSha; } } }