/* * Copyright 2014 NAVER Corp. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.navercorp.pinpoint.rpc; import java.util.concurrent.Executor; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.navercorp.pinpoint.rpc.common.SocketStateCode; /** * @author koo.taejin */ public abstract class ExecutionThreadStateChangeEventHandler<S extends PinpointSocket> implements StateChangeEventListener<S> { private final Logger logger = LoggerFactory.getLogger(this.getClass()); private final StateChangeEventListener handler; private final Executor executor; public ExecutionThreadStateChangeEventHandler(StateChangeEventListener handler, Executor executor) { this.handler = handler; this.executor = executor; } @Override public void eventPerformed(S pinpointSocket, SocketStateCode stateCode) { Execution execution = new Execution(pinpointSocket, stateCode); this.executor.execute(execution); } private class Execution implements Runnable { private final S pinpointSocket; private final SocketStateCode stateCode; public Execution(S pinpointSocket, SocketStateCode stateCode) { this.pinpointSocket = pinpointSocket; this.stateCode = stateCode; } @Override public void run() { try { handler.eventPerformed(pinpointSocket, stateCode); } catch (Exception e) { handler.exceptionCaught(pinpointSocket, stateCode, e); } } } }