package com.google.common.eventbus; import com.google.common.base.MoreObjects; import com.google.common.base.Preconditions; import com.google.common.util.concurrent.MoreExecutors; import java.lang.reflect.Method; import java.util.Iterator; import java.util.Locale; import java.util.concurrent.Executor; import java.util.logging.Level; import java.util.logging.Logger; @ElementTypesAreNonnullByDefault /* loaded from: classes3.dex */ public class EventBus { private static final Logger logger = Logger.getLogger(EventBus.class.getName()); private final Dispatcher dispatcher; private final SubscriberExceptionHandler exceptionHandler; private final Executor executor; private final String identifier; private final SubscriberRegistry subscribers; /* JADX INFO: Access modifiers changed from: package-private */ public final Executor executor() { return this.executor; } public final String identifier() { return this.identifier; } public EventBus() { this("default"); } public EventBus(String str) { this(str, MoreExecutors.directExecutor(), Dispatcher.perThreadDispatchQueue(), LoggingHandler.INSTANCE); } public EventBus(SubscriberExceptionHandler subscriberExceptionHandler) { this("default", MoreExecutors.directExecutor(), Dispatcher.perThreadDispatchQueue(), subscriberExceptionHandler); } /* JADX INFO: Access modifiers changed from: package-private */ public EventBus(String str, Executor executor, Dispatcher dispatcher, SubscriberExceptionHandler subscriberExceptionHandler) { this.subscribers = new SubscriberRegistry(this); this.identifier = (String) Preconditions.checkNotNull(str); this.executor = (Executor) Preconditions.checkNotNull(executor); this.dispatcher = (Dispatcher) Preconditions.checkNotNull(dispatcher); this.exceptionHandler = (SubscriberExceptionHandler) Preconditions.checkNotNull(subscriberExceptionHandler); } /* JADX INFO: Access modifiers changed from: package-private */ public void handleSubscriberException(Throwable th, SubscriberExceptionContext subscriberExceptionContext) { Preconditions.checkNotNull(th); Preconditions.checkNotNull(subscriberExceptionContext); try { this.exceptionHandler.handleException(th, subscriberExceptionContext); } catch (Throwable th2) { logger.log(Level.SEVERE, String.format(Locale.ROOT, "Exception %s thrown while handling exception: %s", th2, th), th2); } } public void register(Object obj) { this.subscribers.register(obj); } public void unregister(Object obj) { this.subscribers.unregister(obj); } public void post(Object obj) { Iterator subscribers = this.subscribers.getSubscribers(obj); if (subscribers.hasNext()) { this.dispatcher.dispatch(obj, subscribers); } else { if (obj instanceof DeadEvent) { return; } post(new DeadEvent(this, obj)); } } public String toString() { return MoreObjects.toStringHelper(this).addValue(this.identifier).toString(); } /* loaded from: classes3.dex */ static final class LoggingHandler implements SubscriberExceptionHandler { static final LoggingHandler INSTANCE = new LoggingHandler(); LoggingHandler() { } @Override // com.google.common.eventbus.SubscriberExceptionHandler public void handleException(Throwable th, SubscriberExceptionContext subscriberExceptionContext) { Logger logger = logger(subscriberExceptionContext); if (logger.isLoggable(Level.SEVERE)) { logger.log(Level.SEVERE, message(subscriberExceptionContext), th); } } private static Logger logger(SubscriberExceptionContext subscriberExceptionContext) { String name = EventBus.class.getName(); String identifier = subscriberExceptionContext.getEventBus().identifier(); return Logger.getLogger(new StringBuilder(String.valueOf(name).length() + 1 + String.valueOf(identifier).length()).append(name).append(".").append(identifier).toString()); } private static String message(SubscriberExceptionContext subscriberExceptionContext) { Method subscriberMethod = subscriberExceptionContext.getSubscriberMethod(); String name = subscriberMethod.getName(); String name2 = subscriberMethod.getParameterTypes()[0].getName(); String valueOf = String.valueOf(subscriberExceptionContext.getSubscriber()); String valueOf2 = String.valueOf(subscriberExceptionContext.getEvent()); return new StringBuilder(String.valueOf(name).length() + 80 + String.valueOf(name2).length() + String.valueOf(valueOf).length() + String.valueOf(valueOf2).length()).append("Exception thrown by subscriber method ").append(name).append('(').append(name2).append(") on subscriber ").append(valueOf).append(" when dispatching event: ").append(valueOf2).toString(); } } }