/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright (c) 1997-2015 Oracle and/or its affiliates. All rights reserved. * * The contents of this file are subject to the terms of either the GNU * General Public License Version 2 only ("GPL") or the Common Development * and Distribution License("CDDL") (collectively, the "License"). You * may not use this file except in compliance with the License. You can * obtain a copy of the License at * http://glassfish.java.net/public/CDDL+GPL_1_1.html * or packager/legal/LICENSE.txt. See the License for the specific * language governing permissions and limitations under the License. * * When distributing the software, include this License Header Notice in each * file and include the License file at packager/legal/LICENSE.txt. * * GPL Classpath Exception: * Oracle designates this particular file as subject to the "Classpath" * exception as provided by Oracle in the GPL Version 2 section of the License * file that accompanied this code. * * Modifications: * If applicable, add the following below the License Header, with the fields * enclosed by brackets [] replaced by your own identifying information: * "Portions Copyright [year] [name of copyright owner]" * * Contributor(s): * If you wish your version of this file to be governed by only the CDDL or * only the GPL Version 2, indicate your decision by adding "[Contributor] * elects to include this software in this distribution under the [CDDL or GPL * Version 2] license." If you don't indicate a single choice of license, a * recipient has the option to distribute your version of this file under * either the CDDL, the GPL Version 2 or to extend the choice of license to * its licensees as provided above. However, if you add GPL Version 2 code * and therefore, elected the GPL Version 2 license, then the option applies * only if the new code is made subject to such option by the copyright * holder. */ package com.sun.xml.ws.api.pipe; import java.util.concurrent.Executor; import java.util.concurrent.Executors; import java.util.concurrent.ThreadFactory; import java.util.concurrent.atomic.AtomicInteger; import com.sun.xml.ws.api.message.Packet; import com.sun.xml.ws.api.server.Container; import com.sun.xml.ws.api.server.ContainerResolver; /** * Collection of {@link Fiber}s. * Owns an {@link Executor} to run them. * * @author Kohsuke Kawaguchi * @author Jitendra Kotamraju */ public class Engine { private volatile Executor threadPool; public final String id; private final Container container; String getId() { return id; } Container getContainer() { return container; } Executor getExecutor() { return threadPool; } public Engine(String id, Executor threadPool) { this(id, ContainerResolver.getDefault().getContainer(), threadPool); } public Engine(String id, Container container, Executor threadPool) { this(id, container); this.threadPool = threadPool != null ? wrap(threadPool) : null; } public Engine(String id) { this(id, ContainerResolver.getDefault().getContainer()); } public Engine(String id, Container container) { this.id = id; this.container = container; } public void setExecutor(Executor threadPool) { this.threadPool = threadPool != null ? wrap(threadPool) : null; } void addRunnable(Fiber fiber) { if(threadPool==null) { synchronized(this) { threadPool = wrap(Executors.newCachedThreadPool(new DaemonThreadFactory())); } } threadPool.execute(fiber); } private Executor wrap(Executor ex) { return ContainerResolver.getDefault().wrapExecutor(container, ex); } /** * Creates a new fiber in a suspended state. * * <p> * To start the returned fiber, call {@link Fiber#start(Tube,Packet,Fiber.CompletionCallback)}. * It will start executing the given {@link Tube} with the given {@link Packet}. * * @return new Fiber */ public Fiber createFiber() { return new Fiber(this); } private static class DaemonThreadFactory implements ThreadFactory { static final AtomicInteger poolNumber = new AtomicInteger(1); final AtomicInteger threadNumber = new AtomicInteger(1); final String namePrefix; DaemonThreadFactory() { namePrefix = "jaxws-engine-" + poolNumber.getAndIncrement() + "-thread-"; } public Thread newThread(Runnable r) { Thread t = ThreadHelper.createNewThread(r); t.setName(namePrefix + threadNumber.getAndIncrement()); if (!t.isDaemon()) { t.setDaemon(true); } if (t.getPriority() != Thread.NORM_PRIORITY) { t.setPriority(Thread.NORM_PRIORITY); } return t; } } }