/* license-start
*
* Copyright (C) 2008 - 2013 Crispico, <http://www.crispico.com/>.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation version 3.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details, at <http://www.gnu.org/licenses/>.
*
* Contributors:
* Crispico - Initial API and implementation
*
* license-end
*/
package org.flowerplatform.communication;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
/**
* Keeps a reference to all created <code>ScheduledExecutorService</code>s.
*
* When the server stops it will ensure that these <code>ScheduledExecutorService</code>s
* are also shutdown.
*
* @author Sorin
*/
public class ScheduledExecutorServiceFactory {
private Collection<ScheduledExecutorService> executorServices = Collections.synchronizedList(new ArrayList<ScheduledExecutorService>());
public ScheduledExecutorService createScheduledExecutorService() {
ScheduledExecutorService executorService = Executors.newScheduledThreadPool(1);
executorServices.add(executorService);
return executorService;
}
public void dispose() {
for (ScheduledExecutorService executorService : executorServices) {
executorService.shutdownNow();
}
}
}