Title: JSP Tag Libraries
ISBN: 193011009X
US Price: $35.96
Publication Date: May 2001
Pages: 656
© 2001 Manning Publications Co.

Reviews : Java Books :
JSP Tag Libraries : Chapter 10: Iterating with Tags

10. 2. 2 IterationTagSupport

Let's look at the basic iteration tag class, IterationTagSupport, and how it uses IterationSupport. Before taking a look into the implementation of IterationTagSupport as presented in listing 10. 5, let's consider how we would like it to work.

What should IterationTagSupport do?

Most emphatically, the generic iteration tag class should automatically take care of iteration-related issues such as flow control, as well as exporting default iterator variables. In addition, it must be able to:

  • Create an IterationSupport object out of the elements provided as a tag attribute. This can be accomplished by defining a method that our specialized iteration tags can override and that IterationTagSupport will call during its doStartTag(). By specialized tag we mean the special version of the tag that is custom built to handle a particular iterator type and a particular type of object in that iterator.
  • Export a different set of JSP variables. Whenever IterationTagSupport wants to export its iterator value, it should call yet another method that can be overridden by the specialized tag (but the default implementation of the variable exportation method should export only a single iterator).

IterationTagSupport's implementation

IterationTagSupport was created with a few methods that may be overridden by specialized iteration tags.

Listing 10. 5 Source code for the generic iteration tag handler

package book.iteration; 

import book.util.LocalStrings; 
import book.util. ExBodyTagSupport; 
import javax.servlet.jsp.JspException; 

public abstract class IterationTagSupport 
	extends ExBodyTagSupport { 

	static LocalStrings ls = 
		LocalStrings.getLocalStrings( IterationTagSupport. class); 
	
	IterationSupport elementsList = null; 
	
	public int doStartTag() 
		throws JspException 
	{ 
		fetchIterationSupport(); 
		if( elementsList.hasNext()) { 
			return EVAL_BODY_TAG; 
		} 
		return SKIP_BODY; 
	} 

	public void doInitBody() 
		throws JspException 
	{ 
		exportVariables(); 
	} 
	
	public int doAfterBody() 
		throws JspException 
	{ 
		try { 
			getBodyContent().writeOut( getPreviousOut()); 
			getBodyContent().clear(); 

		} catch( java.io.IOException ioe) { 
			// User probably disconnected ... 
			// Log and throw a JspTagException 
		} 
	
		if( elementsList.hasNext()) { 
			exportVariables(); 
			return EVAL_BODY_TAG; 
		} 
	
		return SKIP_BODY; 
	} 
	
	protected abstract void fetchIterationSupport()  
		throws JspException; 

	protected void exportVariables()  
		throws JspException 
	{ 
		pageContext.setAttribute( id, elementsList. getNext()); 
	} 

	protected void clearProperties()  
	{ 
		id = null; 
		super.clearProperties(); 
	} 
	
	protected void clearServiceState()  
	{ 
		elementsList = null; 
	} 
}

First override point. The specialized tag must implement this method to create and set an IterationSupport object The first method that tags can and must override is fetchIterationSupport(). This abstract method is the location wherein the overriding tag should implement the creating and setting of the IterationSupport object and any specialized iteration tag must provide such objects to make the generic infrastruc-ture work. If problems rise within fetchIterationSupport(), it can throw a JspException that the generic implementation will pass to the JSP runtime.

Second override point. The specialized tag may want to export additional objects The second method that can be overridden is exportVariables(), which is where the generic iteration tag exports the iterator (based in the id attribute). An overriding tag may override this method to add more variables. For example, a certain tag iterates a hash table and wants to export both the key to the table and the value itself. In this case you would like to add the exportation of the value variable along with the default iterator.

Override if you have additional attributes in the specialized tag (you probably do).

Override if you have additional service state in the specialized tag.

Listing 10.5 shows that the general structure of IterationTagSupport is very similar to the one presented in SimpleForeachTag. The tag is merely a generic iteration infrastructure with several methods to override as explained in the annotations. Note also that IterationTagSupport extends our now familiar ExBodyTagSupport, and therefore inherits its functionality.

How to Add Java Applets to Your Site

New on the Java Boutique:

New Review:

Time Management Made Easy with the Quartz Enterprise Job Scheduler
Why not just use the Java timer API? This open source scheduling API boasts simplicity, ease-of-integration, a well-rounded feature set, and it's free!

New Applet:

Reverse Complement
Reverse Complement is a simple applet that converts DNA or RNA sequences into three useful formats.

Elsewhere on internet.com:

WebDeveloper Java
Lots of Java information on webdeveloper.com

WDVL Java
Thorough Java resource at the Web Developer's Virtual Library.

ScriptSearch Java
Hundreds of free Java code files to download.

jGuru: Your View of the Java Universe
Customizable portal with online training, FAQs, regular news updates, and tutorials.