Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
  * Conditions Of Use
  *
  * This software was developed by employees of the National Institute of
  * Standards and Technology (NIST), an agency of the Federal Government.
  * Pursuant to title 15 Untied States Code Section 105, works of NIST
  * employees are not subject to copyright protection in the United States
  * and are considered to be in the public domain.  As a result, a formal
  * license is not needed to use the software.
 *
 * This software is provided by NIST as a service and is expressly
 * provided "AS IS."  NIST MAKES NO WARRANTY OF ANY KIND, EXPRESS, IMPLIED
 * OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTY OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT
 * AND DATA ACCURACY.  NIST does not warrant or make any representations
 * regarding the use of the software or the results thereof, including but
 * not limited to the correctness, accuracy, reliability or usefulness of
 * the software.
 *
 * Permission to use this software is contingent upon your acceptance
 * of the terms of this agreement
 *
 * .
 *
 */
 package gov.nist.javax.sip.stack.timers;
 
 
Implementation of the SIP Timer based on java.util.concurrent.ScheduledThreadPoolExecutor Seems to perform

Author(s):
jean.deruelle@gmail.com
 
 public class ScheduledExecutorSipTimer implements SipTimer {
 
 	// Counts the number of cancelled tasks
     private volatile int numCancelled = 0;
     
 	}
 	
 	/* (non-Javadoc)
 	 * @see gov.nist.javax.sip.stack.timers.SipTimer#stop()
 	 */
 	public void stop() {
 			.getStackLogger().logInfo("the sip stack timer " + this.getClass().getName() + " has been stopped");
 		}
 	}
 
 	/* (non-Javadoc)
 	 * @see gov.nist.javax.sip.stack.timers.SipTimer#schedule(gov.nist.javax.sip.stack.SIPStackTimerTask, long)
 	 */
 	public boolean schedule(SIPStackTimerTask tasklong delay) {
 			throw new IllegalStateException("The SIP Stack Timer has been stopped, no new tasks can be scheduled !");
 		}
 		task.setSipTimerTask(future);
 		return true;
 	}
 	
 	/*
 	 * (non-Javadoc)
 	 * @see gov.nist.javax.sip.stack.timers.SipTimer#scheduleWithFixedDelay(gov.nist.javax.sip.stack.SIPStackTimerTask, long, long)
 	 */
 	public boolean scheduleWithFixedDelay(SIPStackTimerTask tasklong delay,
 			long period) {
 			throw new IllegalStateException("The SIP Stack Timer has been stopped, no new tasks can be scheduled !");
 		}
 		task.setSipTimerTask(future);
 		return true;
 	}
 
 	/*
 	 * (non-Javadoc)
 	 * @see gov.nist.javax.sip.stack.timers.SipTimer#start(gov.nist.javax.sip.SipStackImpl, java.util.Properties)
 	 */
 	public void start(SipStackImpl sipStackProperties configurationProperties) {
 		sipStack;
 		// TODO have a param in the stack properties to set the number of thread for the timer executor
			.getStackLogger().logInfo("the sip stack timer " + this.getClass().getName() + " has been started");
		}
	}
	/*
	 * (non-Javadoc)
	 * @see gov.nist.javax.sip.stack.timers.SipTimer#cancel(gov.nist.javax.sip.stack.SIPStackTimerTask)
	 */
	public boolean cancel(SIPStackTimerTask task) {
		boolean cancelled = false;
		ScheduledFuture<?> sipTimerTask = (ScheduledFuture<?>) task.getSipTimerTask();
		if(sipTimerTask != null) {
			task.setSipTimerTask(null);
			cancelled = sipTimerTask.cancel(false);
		// Purge is expensive when called frequently, only call it every now and then.
        // We do not sync the numCancelled variable. We dont care about correctness of
        // the number, and we will still call purge rought once on every 100 cancels.
        ++;
        if( % 50 == 0) {
            .purge();
        }
		return cancelled;
	}
	private class ScheduledSipTimerTask implements Runnable {
			this.task;			
		}
		public void run() {
			 try {
				 // task can be null if it has been cancelled
				 if( != null) {
				 }
	        } catch (Throwable e) {
	            ..println("SIP stack timer task failed due to exception:");
	            e.printStackTrace();
	        }
		}				
	}
	/*
	 * (non-Javadoc)
	 * @see gov.nist.javax.sip.stack.timers.SipTimer#isStarted()
	 */
	public boolean isStarted() {
	}
New to GrepCode? Check out our FAQ X