All Downloads are FREE. Search and download functionalities are using the official Maven repository.

dalvik.system.SocketTagger Maven / Gradle / Ivy

/*
 * Copyright (C) 2011 The Android Open Source Project
 *
 * 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 dalvik.system;

import java.io.FileDescriptor;
import java.net.Socket;
import java.net.SocketException;

/**
 * Callbacks for socket assignment and reassignment.
 *
 * @hide
 */
public abstract class SocketTagger {

    private static SocketTagger tagger = new SocketTagger() {
        @Override public void tag(FileDescriptor socketDescriptor) throws SocketException {}
        @Override public void untag(FileDescriptor socketDescriptor) throws SocketException {}
    };

    /**
     * Notified when {@code socketDescriptor} is either assigned to the current
     * thread. The socket is either newly connected or reused from a connection
     * pool. Implementations of this method should be thread-safe.
     */
    public abstract void tag(FileDescriptor socketDescriptor) throws SocketException;

    /**
     * Notified when {@code socketDescriptor} is released from the current
     * thread to a connection pool. Implementations of this method should be
     * thread-safe.
     *
     * 

Note: this method will not be invoked when the socket * is closed. */ public abstract void untag(FileDescriptor socketDescriptor) throws SocketException; public final void tag(Socket socket) throws SocketException { if (!socket.isClosed()) { tag(socket.getFileDescriptor$()); } } public final void untag(Socket socket) throws SocketException { if (!socket.isClosed()) { untag(socket.getFileDescriptor$()); } } /** * Sets this process' socket tagger to {@code tagger}. */ public static synchronized void set(SocketTagger tagger) { if (tagger == null) { throw new NullPointerException("tagger == null"); } SocketTagger.tagger = tagger; } /** * Returns this process socket tagger. */ public static synchronized SocketTagger get() { return tagger; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy