You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@roller.apache.org by sn...@apache.org on 2005/10/21 23:46:28 UTC

svn commit: r327589 [66/72] - in /incubator/roller/branches/roller_1.x: ./ contrib/ contrib/lib/ contrib/plugins/ contrib/plugins/src/ contrib/plugins/src/org/ contrib/plugins/src/org/roller/ contrib/plugins/src/org/roller/presentation/ contrib/plugins...

Added: incubator/roller/branches/roller_1.x/web/theme/scripts/overlib.js
URL: http://svn.apache.org/viewcvs/incubator/roller/branches/roller_1.x/web/theme/scripts/overlib.js?rev=327589&view=auto
==============================================================================
--- incubator/roller/branches/roller_1.x/web/theme/scripts/overlib.js (added)
+++ incubator/roller/branches/roller_1.x/web/theme/scripts/overlib.js Fri Oct 21 14:27:36 2005
@@ -0,0 +1,1315 @@
+//\/////
+//\  overLIB 4.00 - You may not remove or change this notice.
+//\  Copyright Erik Bosrup 1998-2004. All rights reserved.
+//\
+//\  Contributors are listed on the homepage.
+//\  This file might be old, always check for the latest version at:
+//\  http://www.bosrup.com/web/overlib/
+//\
+//\  Please read the license agreement (available through the link above)
+//\  before using overLIB. Direct any licensing questions to erik@bosrup.com.
+//\
+//\  Do not sell this as your own work or remove this copyright notice. 
+//\  For full details on copying or changing this script please read the
+//\  license agreement at the link above. Please give credit on sites that
+//\  use overLIB and submit changes of the script so other people can use
+//\  them as well.
+//   $Revision: 1.1 $                $Date: 2004/07/14 01:43:11 $
+//\/////
+//\mini
+
+////////
+// PRE-INIT
+// Ignore these lines, configuration is below.
+////////
+var olLoaded = 0;var pmStart = 10000000; var pmUpper = 10001000; var pmCount = pmStart+1;  var pms = new Array(); var olInfo = new Info('4.00', 1);
+var FREPLACE = 0; var FBEFORE = 1; var FAFTER = 2; var FALTERNATE = 3;
+var olHideForm=0;  // parameter for hiding SELECT and ActiveX elements in IE5.5+ 
+registerCommands('donothing,inarray,caparray,sticky,background,noclose,caption,left,right,center,offsetx,offsety,fgcolor,bgcolor,textcolor,capcolor,closecolor,width,border,cellpad,status,autostatus,autostatuscap,height,closetext,snapx,snapy,fixx,fixy,relx,rely,fgbackground,bgbackground,padx,pady,fullhtml,above,below,capicon,textfont,captionfont,closefont,textsize,captionsize,closesize,timeout,function,delay,hauto,vauto,closeclick,wrap,followmouse,mouseoff,closetitle,cssoff,cssclass,fgclass,bgclass,textfontclass,captionfontclass,closefontclass');
+
+////////
+// DEFAULT CONFIGURATION
+// Settings you want everywhere are set here. All of this can also be
+// changed on your html page or through an overLIB call.
+////////
+if (typeof ol_fgcolor=='undefined') var ol_fgcolor="#CCCCFF";
+if (typeof ol_bgcolor=='undefined') var ol_bgcolor="#333399";
+if (typeof ol_textcolor=='undefined') var ol_textcolor="#000000";
+if (typeof ol_capcolor=='undefined') var ol_capcolor="#FFFFFF";
+if (typeof ol_closecolor=='undefined') var ol_closecolor="#9999FF";
+if (typeof ol_textfont=='undefined') var ol_textfont="Verdana,Arial,Helvetica";
+if (typeof ol_captionfont=='undefined') var ol_captionfont="Verdana,Arial,Helvetica";
+if (typeof ol_closefont=='undefined') var ol_closefont="Verdana,Arial,Helvetica";
+if (typeof ol_textsize=='undefined') var ol_textsize="1";
+if (typeof ol_captionsize=='undefined') var ol_captionsize="1";
+if (typeof ol_closesize=='undefined') var ol_closesize="1";
+if (typeof ol_width=='undefined') var ol_width="200";
+if (typeof ol_border=='undefined') var ol_border="1";
+if (typeof ol_cellpad=='undefined') var ol_cellpad=2;
+if (typeof ol_offsetx=='undefined') var ol_offsetx=10;
+if (typeof ol_offsety=='undefined') var ol_offsety=10;
+if (typeof ol_text=='undefined') var ol_text="Default Text";
+if (typeof ol_cap=='undefined') var ol_cap="";
+if (typeof ol_sticky=='undefined') var ol_sticky=0;
+if (typeof ol_background=='undefined') var ol_background="";
+if (typeof ol_close=='undefined') var ol_close="Close";
+if (typeof ol_hpos=='undefined') var ol_hpos=RIGHT;
+if (typeof ol_status=='undefined') var ol_status="";
+if (typeof ol_autostatus=='undefined') var ol_autostatus=0;
+if (typeof ol_height=='undefined') var ol_height=-1;
+if (typeof ol_snapx=='undefined') var ol_snapx=0;
+if (typeof ol_snapy=='undefined') var ol_snapy=0;
+if (typeof ol_fixx=='undefined') var ol_fixx=-1;
+if (typeof ol_fixy=='undefined') var ol_fixy=-1;
+if (typeof ol_relx=='undefined') var ol_relx=null;
+if (typeof ol_rely=='undefined') var ol_rely=null;
+if (typeof ol_fgbackground=='undefined') var ol_fgbackground="";
+if (typeof ol_bgbackground=='undefined') var ol_bgbackground="";
+if (typeof ol_padxl=='undefined') var ol_padxl=1;
+if (typeof ol_padxr=='undefined') var ol_padxr=1;
+if (typeof ol_padyt=='undefined') var ol_padyt=1;
+if (typeof ol_padyb=='undefined') var ol_padyb=1;
+if (typeof ol_fullhtml=='undefined') var ol_fullhtml=0;
+if (typeof ol_vpos=='undefined') var ol_vpos=BELOW;
+if (typeof ol_aboveheight=='undefined') var ol_aboveheight=0;
+if (typeof ol_capicon=='undefined') var ol_capicon="";
+if (typeof ol_frame=='undefined') var ol_frame=self;
+if (typeof ol_timeout=='undefined') var ol_timeout=0;
+if (typeof ol_function=='undefined') var ol_function=null;
+if (typeof ol_delay=='undefined') var ol_delay=0;
+if (typeof ol_hauto=='undefined') var ol_hauto=0;
+if (typeof ol_vauto=='undefined') var ol_vauto=0;
+if (typeof ol_closeclick=='undefined') var ol_closeclick=0;
+if (typeof ol_wrap=='undefined') var ol_wrap=0;
+if (typeof ol_followmouse=='undefined') var ol_followmouse=1;
+if (typeof ol_mouseoff=='undefined') var ol_mouseoff=0;
+if (typeof ol_closetitle=='undefined') var ol_closetitle='Close';
+if (typeof ol_css=='undefined') var ol_css=CSSOFF;
+if (typeof ol_fgclass=='undefined') var ol_fgclass="";
+if (typeof ol_bgclass=='undefined') var ol_bgclass="";
+if (typeof ol_textfontclass=='undefined') var ol_textfontclass="";
+if (typeof ol_captionfontclass=='undefined') var ol_captionfontclass="";
+if (typeof ol_closefontclass=='undefined') var ol_closefontclass="";
+
+////////
+// ARRAY CONFIGURATION
+////////
+
+// You can use these arrays to store popup text here instead of in the html.
+if (typeof ol_texts=='undefined') var ol_texts = new Array("Text 0", "Text 1");
+if (typeof ol_caps=='undefined') var ol_caps = new Array("Caption 0", "Caption 1");
+
+////////
+// END OF CONFIGURATION
+// Don't change anything below this line, all configuration is above.
+////////
+
+
+
+
+
+////////
+// INIT
+////////
+// Runtime variables init. Don't change for config!
+var o3_text="";
+var o3_cap="";
+var o3_sticky=0;
+var o3_background="";
+var o3_close="Close";
+var o3_hpos=RIGHT;
+var o3_offsetx=2;
+var o3_offsety=2;
+var o3_fgcolor="";
+var o3_bgcolor="";
+var o3_textcolor="";
+var o3_capcolor="";
+var o3_closecolor="";
+var o3_width=100;
+var o3_border=1;
+var o3_cellpad=2;
+var o3_status="";
+var o3_autostatus=0;
+var o3_height=-1;
+var o3_snapx=0;
+var o3_snapy=0;
+var o3_fixx=-1;
+var o3_fixy=-1;
+var o3_relx=null;
+var o3_rely=null;
+var o3_fgbackground="";
+var o3_bgbackground="";
+var o3_padxl=0;
+var o3_padxr=0;
+var o3_padyt=0;
+var o3_padyb=0;
+var o3_fullhtml=0;
+var o3_vpos=BELOW;
+var o3_aboveheight=0;
+var o3_capicon="";
+var o3_textfont="Verdana,Arial,Helvetica";
+var o3_captionfont="Verdana,Arial,Helvetica";
+var o3_closefont="Verdana,Arial,Helvetica";
+var o3_textsize="1";
+var o3_captionsize="1";
+var o3_closesize="1";
+var o3_frame=self;
+var o3_timeout=0;
+var o3_timerid=0;
+var o3_allowmove=0;
+var o3_function=null; 
+var o3_delay=0;
+var o3_delayid=0;
+var o3_hauto=0;
+var o3_vauto=0;
+var o3_closeclick=0;
+var o3_wrap=0;
+var o3_followmouse=1;
+var o3_mouseoff=0;
+var o3_closetitle='';
+var o3_css=CSSOFF;
+var o3_fgclass="";
+var o3_bgclass="";
+var o3_textfontclass="";
+var o3_captionfontclass="";
+var o3_closefontclass="";
+
+// Display state variables
+var o3_x = 0;
+var o3_y = 0;
+var o3_showingsticky = 0;
+var o3_removecounter = 0;
+
+// Our layer
+var over = null;
+var fnRef, hoveringSwitch = false;
+
+// Decide browser version
+var isMac = (navigator.userAgent.indexOf("Mac") != -1);
+var olOp = (navigator.userAgent.toLowerCase().indexOf('opera 7.') > -1);
+var olNs4 = (navigator.appName=='Netscape' && parseInt(navigator.appVersion) == 4);
+var olNs6 = (document.getElementById) ? true : false;
+var olIe4 = (document.all) ? true : false;
+var olIe5 = false; 
+var olIe55 = false; // Added additional variable to identify IE5.5+
+var docRoot = 'document.body';
+
+// Resize fix for NS4.x to keep track of layer
+if (olNs4) {
+	var oW = window.innerWidth;
+	var oH = window.innerHeight;
+	window.onresize = function() { if (oW != window.innerWidth || oH != window.innerHeight) location.reload(); }
+}
+
+// Microsoft Stupidity Check(tm).
+if (olIe4) {
+	var versNum=parseFloat(navigator.userAgent.match(/MSIE (\d\.\d+)\.*/i)[1]);
+	if (versNum >= 5){
+		olIe5=true;
+		olIe55=(versNum>=5.5&&!olOp) ? true : false;
+		if (olNs6) olNs6=false;
+	}
+	if (olNs6) olIe4 = false;
+}
+
+// Check for compatability mode.
+if (document.compatMode && document.compatMode == 'CSS1Compat') {
+	docRoot= ((olIe4 && !olOp) ? 'document.documentElement' : docRoot);
+}
+
+// Add window onload handlers to indicate when all modules have been loaded
+// For Netscape 6+ and Mozilla, uses addEventListener method on the window object
+// For IE it uses the attachEvent method of the window object and for Netscape 4.x
+// it sets the window.onload handler to the OLonload_handler function
+if(window.addEventListener) window.addEventListener("load",OLonLoad_handler,true);
+else if (window.attachEvent) window.attachEvent("onload",OLonLoad_handler);
+else window.onload=OLonLoad_handler;
+
+// Capture events, alt. diffuses the overlib function.
+var olCheckMouseCapture = true;
+if ((olNs4 || olNs6 || olIe4)) {
+	olMouseCapture();
+} else {
+	overlib = no_overlib;
+	nd = no_overlib;
+	ver3fix = true;
+}
+
+
+////////
+// PUBLIC FUNCTIONS
+////////
+
+// overlib(arg0,...,argN)
+// Loads parameters into global runtime variables.
+function overlib() {
+	if (!olLoaded || isExclusive(overlib.arguments)) return true;
+	if (olCheckMouseCapture) olMouseCapture();
+	if (over) cClick();
+
+	// Load defaults to runtime.
+	o3_text=ol_text;
+	o3_cap=ol_cap;
+	o3_sticky=ol_sticky;
+	o3_background=ol_background;
+	o3_close=ol_close;
+	o3_hpos=ol_hpos;
+	o3_offsetx=ol_offsetx;
+	o3_offsety=ol_offsety;
+	o3_fgcolor=ol_fgcolor;
+	o3_bgcolor=ol_bgcolor;
+	o3_textcolor=ol_textcolor;
+	o3_capcolor=ol_capcolor;
+	o3_closecolor=ol_closecolor;
+	o3_width=ol_width;
+	o3_border=ol_border;
+	o3_cellpad=ol_cellpad;
+	o3_status=ol_status;
+	o3_autostatus=ol_autostatus;
+	o3_height=ol_height;
+	o3_snapx=ol_snapx;
+	o3_snapy=ol_snapy;
+	o3_fixx=ol_fixx;
+	o3_fixy=ol_fixy;
+	o3_relx=ol_relx;
+	o3_rely=ol_rely;
+	o3_fgbackground=ol_fgbackground;
+	o3_bgbackground=ol_bgbackground;
+	o3_padxl=ol_padxl;
+	o3_padxr=ol_padxr;
+	o3_padyt=ol_padyt;
+	o3_padyb=ol_padyb;
+	o3_fullhtml=ol_fullhtml;
+	o3_vpos=ol_vpos;
+	o3_aboveheight=ol_aboveheight;
+	o3_capicon=ol_capicon;
+	o3_textfont=ol_textfont;
+	o3_captionfont=ol_captionfont;
+	o3_closefont=ol_closefont;
+	o3_textsize=ol_textsize;
+	o3_captionsize=ol_captionsize;
+	o3_closesize=ol_closesize;
+	o3_timeout=ol_timeout;
+	o3_function=ol_function;
+	o3_delay=ol_delay;
+	o3_hauto=ol_hauto;
+	o3_vauto=ol_vauto;
+	o3_closeclick=ol_closeclick;
+	o3_wrap=ol_wrap;	
+	o3_followmouse=ol_followmouse;
+	o3_mouseoff=ol_mouseoff;
+	o3_closetitle=ol_closetitle;
+	o3_css=ol_css;
+	o3_fgclass=ol_fgclass;
+	o3_bgclass=ol_bgclass;
+	o3_textfontclass=ol_textfontclass;
+	o3_captionfontclass=ol_captionfontclass;
+	o3_closefontclass=ol_closefontclass;
+	
+	setRunTimeVariables();
+	
+	fnRef = '';
+	
+	// Special for frame support, over must be reset...
+	o3_frame = ol_frame;
+	
+	if (olNs4) {
+		over = o3_frame.document.layers['overDiv'];
+	} else if (document.all) {
+		over = o3_frame.document.all['overDiv'];
+	} else if (document.getElementById) {
+		over = o3_frame.document.getElementById("overDiv");
+	}
+
+	parseTokens('o3_', overlib.arguments);
+	if (!postParseChecks()) return false;
+
+	if (o3_delay == 0) {
+		return runHook("olMain", FREPLACE);
+ 	} else {
+		o3_delayid = setTimeout("runHook('olMain', FREPLACE)", o3_delay);
+		return false;
+	}
+}
+
+// Clears popups if appropriate
+function nd(time) {
+	if (olLoaded && !isExclusive()) {
+		if (time && !o3_delay) {
+			if (o3_timerid > 0) clearTimeout(o3_timerid);
+			
+			o3_timerid = setTimeout("cClick()",(o3_timeout = time));
+		}
+		if (o3_removecounter >= 1) { o3_showingsticky = 0 };
+		
+		if (o3_showingsticky == 0) {
+			o3_allowmove = 0;
+			if (over != null && o3_timerid == 0) runHook("hideObject", FREPLACE, over);
+		} else {
+			o3_removecounter++;
+		}
+	}
+	
+	return true;
+}
+
+// The Close onMouseOver function for stickies
+function cClick() {
+	if (olLoaded) {
+		runHook("hideObject", FREPLACE, over);
+		o3_showingsticky = 0;	
+	}	
+	return false;
+}
+
+// Method for setting page specific defaults.
+function overlib_pagedefaults() {
+	parseTokens('ol_', overlib_pagedefaults.arguments);
+}
+
+
+////////
+// OVERLIB MAIN FUNCTION
+////////
+
+// This function decides what it is we want to display and how we want it done.
+function olMain() {
+	var layerhtml, styleType;
+ 	runHook("olMain", FBEFORE);
+ 	
+	if (o3_background!="" || o3_fullhtml) {
+		// Use background instead of box.
+		layerhtml = runHook('ol_content_background', FALTERNATE, o3_css, o3_text, o3_background, o3_fullhtml);
+	} else {
+		// They want a popup box.
+		styleType = (pms[o3_css-1-pmStart] == "cssoff" || pms[o3_css-1-pmStart] == "cssclass");
+
+		// Prepare popup background
+		if (o3_fgbackground != "") o3_fgbackground = "background=\""+o3_fgbackground+"\"";
+		if (o3_bgbackground != "") o3_bgbackground = (styleType ? "background=\""+o3_bgbackground+"\"" : o3_bgbackground);
+
+		// Prepare popup colors
+		if (o3_fgcolor != "") o3_fgcolor = (styleType ? "bgcolor=\""+o3_fgcolor+"\"" : o3_fgcolor);
+		if (o3_bgcolor != "") o3_bgcolor = (styleType ? "bgcolor=\""+o3_bgcolor+"\"" : o3_bgcolor);
+
+		// Prepare popup height
+		if (o3_height > 0) o3_height = (styleType ? "height=\""+o3_height+"\"" : o3_height);
+		else o3_height = "";
+
+		// Decide which kinda box.
+		if (o3_cap=="") {
+			// Plain
+			layerhtml = runHook('ol_content_simple', FALTERNATE, o3_css, o3_text);
+		} else {
+			// With caption
+			if (o3_sticky) {
+				// Show close text
+				layerhtml = runHook('ol_content_caption', FALTERNATE, o3_css, o3_text, o3_cap, o3_close);
+			} else {
+				// No close text
+				layerhtml = runHook('ol_content_caption', FALTERNATE, o3_css, o3_text, o3_cap, "");
+			}
+		}
+	}	
+
+	// We want it to stick!
+	if (o3_sticky) {
+		if (o3_timerid > 0) {
+			clearTimeout(o3_timerid);
+			o3_timerid = 0;
+		}
+		o3_showingsticky = 1;
+		o3_removecounter = 0;
+	}
+
+	// Created a separate routine to generate the popup to make it easier
+	// to implement a plugin capability
+	if (!runHook("createPopup", FREPLACE, layerhtml)) return false;
+
+	// Prepare status bar
+	if (o3_autostatus > 0) {
+		o3_status = o3_text;
+		if (o3_autostatus > 1) o3_status = o3_cap;
+	}
+
+	// When placing the layer the first time, even stickies may be moved.
+	o3_allowmove = 0;
+
+	// Initiate a timer for timeout
+	if (o3_timeout > 0) {          
+		if (o3_timerid > 0) clearTimeout(o3_timerid);
+		o3_timerid = setTimeout("cClick()", o3_timeout);
+	}
+
+	// Show layer
+	runHook("disp", FREPLACE, o3_status);
+	runHook("olMain", FAFTER);
+
+	if (o3_status != '') {
+		return true;
+	} else {
+		return;
+	}
+}
+
+////////
+// LAYER GENERATION FUNCTIONS
+////////
+// These functions just handle popup content with tags that should adhere to the W3C standards specification.
+
+// Makes simple table without caption
+function ol_content_simple(text) {
+	txt='<table width="'+o3_width+ '" border="0" cellpadding="'+o3_border+'" cellspacing="0" '+(o3_bgclass ? 'class="'+o3_bgclass+'"' : o3_bgcolor+' '+o3_height)+'><tr><td><table width="100%" border="0" cellpadding="' + o3_cellpad + '" cellspacing="0" '+(o3_fgclass ? 'class="'+o3_fgclass+'"' : o3_fgcolor+' '+o3_fgbackground+' '+o3_height)+'><tr><td valign="TOP"'+(o3_textfontclass ? ' class="'+o3_textfontclass+'">' : '>')+(o3_textfontclass ? '' : wrapStr(0,o3_textsize,'text'))+text+(o3_textfontclass ? '' : wrapStr(1,o3_textsize))+'</td></tr></table></td></tr></table>';
+
+	set_background("");
+	return txt;
+}
+
+// Makes table with caption and optional close link
+function ol_content_caption(text,title,close) {
+	var nameId;
+	closing="";
+	closeevent="onmouseover";
+	if (o3_closeclick==1) closeevent= (o3_closetitle ? "title='" + o3_closetitle +"'" : "") + " onclick";
+	if (o3_capicon!="") {
+		nameId=' hspace=\"5\"'+' align=\"middle\" alt=\"\"';
+		if (typeof o3_dragimg!='undefined'&&o3_dragimg) nameId=' hspace=\"5\"'+' name=\"'+o3_dragimg+'\" id=\"'+o3_dragimg+'\" align=\"middle\" alt=\"Drag Enabled\" title=\"Drag Enabled\"';
+		o3_capicon='<img src=\"'+o3_capicon+'\"'+nameId+' />';
+	}
+
+	if (close != "") closing='<td '+(o3_closefontclass ? 'class="'+o3_closefontclass : 'align="RIGHT')+'"><a href="javascript:return '+fnRef+'cClick();" '+closeevent+'="return '+fnRef+'cClick();">'+(o3_closefontclass ? '' : wrapStr(0,o3_closesize,'close'))+close+(o3_closefontclass ? '' : wrapStr(1,o3_closesize,'close'))+'</a></td>';
+	txt='<table width="'+o3_width+ '" border="0" cellpadding="'+o3_border+'" cellspacing="0" '+(o3_bgclass ? 'class="'+o3_bgclass+'"' : o3_bgcolor+' '+o3_bgbackground+' '+o3_height)+'><tr><td><table width="100%" border="0" cellpadding="0" cellspacing="0"><tr><td'+(o3_captionfontclass ? ' class="'+o3_captionfontclass+'">' : '>')+(o3_captionfontclass ? '' : '<b>'+wrapStr(0,o3_captionsize,'caption'))+o3_capicon+title+(o3_captionfontclass ? '' : wrapStr(1,o3_captionsize)+'</b>')+'</td>'+closing+'</tr></table><table width="100%" border="0" cellpadding="' + o3_cellpad + '" cellspacing="0" '+(o3_fgclass ? 'class="'+o3_fgclass+'"' : o3_fgcolor+' '+o3_fgbackground+' '+o3_height)+'><tr><td valign="TOP"'+(o3_textfontclass ? ' class="'+o3_textfontclass+'">' :'>')+(o3_textfontclass ? '' : wrapStr(0,o3_textsize,'text'))+text+(o3_textfontclass ? '' : wrapStr(1,o3_textsize)) + '</td></tr></table></td></tr></table>';
+
+	set_background("");
+	return txt;
+}
+
+// Sets the background picture,padding and lots more. :)
+function ol_content_background(text,picture,hasfullhtml) {
+	if (hasfullhtml) {
+		txt=text;
+	} else {
+		txt='<table width="'+o3_width+'" border="0" cellpadding="0" cellspacing="0" height="'+o3_height+'"><tr><td colspan="3" height="'+o3_padyt+'"></td></tr><tr><td width="'+o3_padxl+'"></td><td valign="TOP" width="'+(o3_width-o3_padxl-o3_padxr)+'">'+wrapStr(0,o3_textsize,'text')+text+wrapStr(1,o3_textsize)+'</td><td width="'+o3_padxr+'"></td></tr><tr><td colspan="3" height="'+o3_padyb+'"></td></tr></table>';
+	}
+
+	set_background(picture);
+	return txt;
+}
+
+// Loads a picture into the div.
+function set_background(pic) {
+	if (pic == "") {
+		if (olNs4) {
+			over.background.src = null; 
+		} else if (over.style) {
+			over.style.backgroundImage = "none";
+		}
+	} else {
+		if (olNs4) {
+			over.background.src = pic;
+		} else if (over.style) {
+			over.style.backgroundImage = "url("+pic+")";
+		}
+	}
+}
+
+////////
+// HANDLING FUNCTIONS
+////////
+
+// Displays the popup
+function disp(statustext) {
+	runHook("disp", FBEFORE);
+	
+	if (o3_allowmove == 0) {
+		runHook("placeLayer", FREPLACE);
+		runHook("showObject", FREPLACE, over);
+		o3_allowmove = (o3_sticky || o3_followmouse==0) ? 0 : 1;
+	}
+	
+	runHook("disp", FAFTER);
+
+	if (statustext != "") self.status = statustext;
+}
+
+// Creates the actual popup structure
+function createPopup(lyrContent){
+	runHook("createPopup", FBEFORE);
+	
+	if (o3_wrap && !(olNs4 || olOp)) {
+		if (olIe4) {
+			over.style.pixelWidth = 0;
+		} else if (olNs6) {
+			repositionTo(over, 0, -over.offsetHeight);
+		}
+	}
+
+	layerWrite(lyrContent);
+	
+	// Have to set o3_width for placeLayer() routine if o3_wrap is turned on
+	if (o3_wrap) o3_width=(olNs4 ? over.clip.width : over.offsetWidth);
+	
+	runHook("createPopup", FAFTER, lyrContent);
+
+	return true;
+}
+
+// Decides where we want the popup.
+function placeLayer() {
+	var placeX, placeY, widthFix = 0;
+	
+	// HORIZONTAL PLACEMENT
+	if (eval('o3_frame.'+docRoot) && eval("typeof o3_frame."+docRoot+".clientWidth=='number'") && eval('o3_frame.'+docRoot+'.clientWidth')) {
+		iwidth = eval('o3_frame.'+docRoot+'.clientWidth');
+	} else if (typeof(o3_frame.innerWidth) == 'number') {
+		widthFix = Math.ceil(1.2*(o3_frame.outerWidth - o3_frame.innerWidth));
+		iwidth = o3_frame.innerWidth;
+	}
+
+	// Horizontal scroll offset
+	winoffset=(olIe4) ? eval('o3_frame.'+docRoot+'.scrollLeft') : o3_frame.pageXOffset;
+	var parsedWidth = parseInt(o3_width);
+
+	if (o3_fixx > -1 || o3_relx != null) {
+		// Fixed position
+		placeX=(o3_relx != null ? ( o3_relx < 0 ? winoffset +o3_relx+ iwidth - parsedWidth - widthFix : winoffset+o3_relx) : o3_fixx);
+	} else {  
+		// If HAUTO, decide what to use.
+		if (o3_hauto == 1) {
+			if ((o3_x - winoffset) > (iwidth / 2)) {
+				o3_hpos = LEFT;
+			} else {
+				o3_hpos = RIGHT;
+			}
+		}  		
+
+		// From mouse
+		if (o3_hpos == CENTER) { // Center
+			placeX = o3_x+o3_offsetx-(parsedWidth/2);
+
+			if (placeX < winoffset) placeX = winoffset;
+		}
+
+		if (o3_hpos == RIGHT) { // Right
+			placeX = o3_x+o3_offsetx;
+
+			if ((placeX+parsedWidth) > (winoffset+iwidth - widthFix)) {
+				placeX = iwidth+winoffset - parsedWidth - widthFix;
+				if (placeX < 0) placeX = 0;
+			}
+		}
+		if (o3_hpos == LEFT) { // Left
+			placeX = o3_x-o3_offsetx-parsedWidth;
+			if (placeX < winoffset) placeX = winoffset;
+		}  	
+
+		// Snapping!
+		if (o3_snapx > 1) {
+			var snapping = placeX % o3_snapx;
+
+			if (o3_hpos == LEFT) {
+				placeX = placeX - (o3_snapx+snapping);
+			} else {
+				// CENTER and RIGHT
+				placeX = placeX+(o3_snapx - snapping);
+			}
+
+			if (placeX < winoffset) placeX = winoffset;
+		}
+	}	
+
+	// VERTICAL PLACEMENT
+	if (eval('o3_frame.'+docRoot) && eval("typeof o3_frame."+docRoot+".clientHeight=='number'") && eval('o3_frame.'+docRoot+'.clientHeight')) {
+		iheight = eval('o3_frame.'+docRoot+'.clientHeight');
+	} else if (typeof(o3_frame.innerHeight)=='number') {
+		iheight = o3_frame.innerHeight;
+	}
+
+	// Vertical scroll offset
+	scrolloffset=(olIe4) ? eval('o3_frame.'+docRoot+'.scrollTop') : o3_frame.pageYOffset;
+	var parsedHeight=(o3_aboveheight ? parseInt(o3_aboveheight) : (olNs4 ? over.clip.height : over.offsetHeight));
+
+	if (o3_fixy > -1 || o3_rely != null) {
+		// Fixed position
+		placeY=(o3_rely != null ? (o3_rely < 0 ? scrolloffset+o3_rely+iheight - parsedHeight : scrolloffset+o3_rely) : o3_fixy);
+	} else {
+		// If VAUTO, decide what to use.
+		if (o3_vauto == 1) {  
+			if ((o3_y - scrolloffset) > (iheight/2)) {
+				o3_vpos = ABOVE;
+			} else {
+				o3_vpos = BELOW;
+			}
+		}
+
+		// From mouse
+		if (o3_vpos == ABOVE) {
+			if (o3_aboveheight == 0) o3_aboveheight = parsedHeight; 
+
+			placeY = o3_y - (o3_aboveheight+o3_offsety);
+			if (placeY < scrolloffset) placeY = scrolloffset;
+		} else {
+			// BELOW
+			placeY = o3_y+o3_offsety;
+		} 
+
+		// Snapping!
+		if (o3_snapy > 1) {
+			var snapping = placeY % o3_snapy;  			
+
+			if (o3_aboveheight > 0 && o3_vpos == ABOVE) {
+				placeY = placeY - (o3_snapy+snapping);
+			} else {
+				placeY = placeY+(o3_snapy - snapping);
+			} 			
+
+			if (placeY < scrolloffset) placeY = scrolloffset;
+		}
+	}
+
+	// Actually move the object.
+	repositionTo(over, placeX, placeY);
+}
+
+// Moves the layer
+function olMouseMove(e) {
+	var e = (e) ? e : event;
+
+	if (e.pageX) {
+		o3_x = e.pageX;
+		o3_y = e.pageY;
+	} else if (e.clientX) {
+		o3_x = eval('e.clientX+o3_frame.'+docRoot+'.scrollLeft');
+		o3_y = eval('e.clientY+o3_frame.'+docRoot+'.scrollTop');
+	}
+	
+	if (o3_allowmove == 1) runHook("placeLayer", FREPLACE);
+
+	// MouseOut handler
+	if (hoveringSwitch && !olNs4 && runHook("cursorOff", FREPLACE)) {
+		cClick();
+		hoveringSwitch = !hoveringSwitch;
+	}
+}
+
+// Fake function for 3.0 users.
+function no_overlib() { return ver3fix; }
+
+// Capture the mouse and chain other scripts.
+function olMouseCapture() {
+	capExtent = document;
+	var fN, mseHandler = olMouseMove;
+	var re = /function[ ]+(\w+)\(/;
+	
+	if (document.onmousemove || (!olIe4 && window.onmousemove)) {
+		if (window.onmousemove) capExtent = window;
+		fN = capExtent.onmousemove.toString().match(re);
+
+		if (fN[1] == 'anonymous' || fN[1] == 'olMouseMove') {
+			olCheckMouseCapture = false;
+			return;
+		}
+		var str = fN[1]+'(e); ' + 'olMouseMove(e); ';
+		mseHandler = new Function('e', str);
+	}
+
+	capExtent.onmousemove = mseHandler;
+	if (olNs4) capExtent.captureEvents(Event.MOUSEMOVE);
+}
+
+
+////////
+// PARSING FUNCTIONS
+////////
+
+// Does the actual command parsing.
+function parseTokens(pf, ar) {
+	// What the next argument is expected to be.
+	var v, mode=-1, par = (pf != 'ol_');	
+	var fnMark = (par && !ar.length ? 1 : 0);
+
+	for (i = 0; i < ar.length; i++) {
+		if (mode < 0) {
+			// Arg is maintext,unless its a number between pmStart and pmUpper
+			// then its a command.
+			if (typeof ar[i] == 'number' && ar[i] > pmStart && ar[i] < pmUpper) {
+				fnMark = (par ? 1 : 0);
+				i--;   // backup one so that the next block can parse it
+			} else {
+				switch(pf) {
+					case 'ol_':
+						ol_text = ar[i].toString();
+						break;
+					default:
+						o3_text=ar[i].toString();  
+				}
+			}
+			mode = 0;
+		} else {
+			// Note: NS4 doesn't like switch cases with vars.
+			if (ar[i] >= pmCount || ar[i]==DONOTHING) { continue; }
+			if (ar[i]==INARRAY) { fnMark = 0; eval(pf+'text=ol_texts['+ar[++i]+'].toString()'); continue; }
+			if (ar[i]==CAPARRAY) { eval(pf+'cap=ol_caps['+ar[++i]+'].toString()'); continue; }
+			if (ar[i]==STICKY) { if (pf!='ol_') eval(pf+'sticky=1'); continue; }
+			if (ar[i]==BACKGROUND) { eval(pf+'background="'+ar[++i]+'"'); continue; }
+			if (ar[i]==NOCLOSE) { if (pf!='ol_') opt_NOCLOSE(); continue; }
+			if (ar[i]==CAPTION) { eval(pf+"cap='"+escSglQuote(ar[++i])+"'"); continue; }
+			if (ar[i]==CENTER || ar[i]==LEFT || ar[i]==RIGHT) { eval(pf+'hpos='+ar[i]); continue; }
+			if (ar[i]==OFFSETX) { eval(pf+'offsetx='+ar[++i]); continue; }
+			if (ar[i]==OFFSETY) { eval(pf+'offsety='+ar[++i]); continue; }
+			if (ar[i]==FGCOLOR) { eval(pf+'fgcolor="'+ar[++i]+'"'); continue; }
+			if (ar[i]==BGCOLOR) { eval(pf+'bgcolor="'+ar[++i]+'"'); continue; }
+			if (ar[i]==TEXTCOLOR) { eval(pf+'textcolor="'+ar[++i]+'"'); continue; }
+			if (ar[i]==CAPCOLOR) { eval(pf+'capcolor="'+ar[++i]+'"'); continue; }
+			if (ar[i]==CLOSECOLOR) { eval(pf+'closecolor="'+ar[++i]+'"'); continue; }
+			if (ar[i]==WIDTH) { eval(pf+'width='+ar[++i]); continue; }
+			if (ar[i]==BORDER) { eval(pf+'border='+ar[++i]); continue; }
+			if (ar[i]==CELLPAD) { i=opt_MULTIPLEARGS(++i,ar,(pf+'cellpad')); continue; }
+			if (ar[i]==STATUS) { eval(pf+"status='"+escSglQuote(ar[++i])+"'"); continue; }
+			if (ar[i]==AUTOSTATUS) { eval(pf +'autostatus=('+pf+'autostatus == 1) ? 0 : 1'); continue; }
+			if (ar[i]==AUTOSTATUSCAP) { eval(pf +'autostatus=('+pf+'autostatus == 2) ? 0 : 2'); continue; }
+			if (ar[i]==HEIGHT) { eval(pf+'height='+pf+'aboveheight='+ar[++i]); continue; } // Same param again.
+			if (ar[i]==CLOSETEXT) { eval(pf+"close='"+escSglQuote(ar[++i])+"'"); continue; }
+			if (ar[i]==SNAPX) { eval(pf+'snapx='+ar[++i]); continue; }
+			if (ar[i]==SNAPY) { eval(pf+'snapy='+ar[++i]); continue; }
+			if (ar[i]==FIXX) { eval(pf+'fixx='+ar[++i]); continue; }
+			if (ar[i]==FIXY) { eval(pf+'fixy='+ar[++i]); continue; }
+			if (ar[i]==RELX) { eval(pf+'relx='+ar[++i]); continue; }
+			if (ar[i]==RELY) { eval(pf+'rely='+ar[++i]); continue; }
+			if (ar[i]==FGBACKGROUND) { eval(pf+'fgbackground="'+ar[++i]+'"'); continue; }
+			if (ar[i]==BGBACKGROUND) { eval(pf+'bgbackground="'+ar[++i]+'"'); continue; }
+			if (ar[i]==PADX) { eval(pf+'padxl='+ar[++i]); eval(pf+'padxr='+ar[++i]); continue; }
+			if (ar[i]==PADY) { eval(pf+'padyt='+ar[++i]); eval(pf+'padyb='+ar[++i]); continue; }
+			if (ar[i]==FULLHTML) { if (pf!='ol_') eval(pf+'fullhtml=1'); continue; }
+			if (ar[i]==BELOW || ar[i]==ABOVE) { eval(pf+'vpos='+ar[i]); continue; }
+			if (ar[i]==CAPICON) { eval(pf+'capicon="'+ar[++i]+'"'); continue; }
+			if (ar[i]==TEXTFONT) { eval(pf+"textfont='"+escSglQuote(ar[++i])+"'"); continue; }
+			if (ar[i]==CAPTIONFONT) { eval(pf+"captionfont='"+escSglQuote(ar[++i])+"'"); continue; }
+			if (ar[i]==CLOSEFONT) { eval(pf+"closefont='"+escSglQuote(ar[++i])+"'"); continue; }
+			if (ar[i]==TEXTSIZE) { eval(pf+'textsize="'+ar[++i]+'"'); continue; }
+			if (ar[i]==CAPTIONSIZE) { eval(pf+'captionsize="'+ar[++i]+'"'); continue; }
+			if (ar[i]==CLOSESIZE) { eval(pf+'closesize="'+ar[++i]+'"'); continue; }
+			if (ar[i]==TIMEOUT) { eval(pf+'timeout='+ar[++i]); continue; }
+			if (ar[i]==FUNCTION) { if (pf=='ol_') { if (typeof ar[i+1]!='number') { v=ar[++i]; ol_function=(typeof v=='function' ? v : null); }} else {fnMark = 0; v = null; if (typeof ar[i+1]!='number') v = ar[++i];  opt_FUNCTION(v); } continue; }
+			if (ar[i]==DELAY) { eval(pf+'delay='+ar[++i]); continue; }
+			if (ar[i]==HAUTO) { eval(pf+'hauto=('+pf+'hauto == 0) ? 1 : 0'); continue; }
+			if (ar[i]==VAUTO) { eval(pf+'vauto=('+pf+'vauto == 0) ? 1 : 0'); continue; }
+			if (ar[i]==CLOSECLICK) { eval(pf +'closeclick=('+pf+'closeclick == 0) ? 1 : 0'); continue; }
+			if (ar[i]==WRAP) { eval(pf +'wrap=('+pf+'wrap == 0) ? 1 : 0'); continue; }
+			if (ar[i]==FOLLOWMOUSE) { eval(pf +'followmouse=('+pf+'followmouse == 1) ? 0 : 1'); continue; }
+			if (ar[i]==MOUSEOFF) { eval(pf +'mouseoff=('+pf+'mouseoff == 0) ? 1 : 0'); continue; }
+			if (ar[i]==CLOSETITLE) { eval(pf+"closetitle='"+escSglQuote(ar[++i])+"'"); continue; }
+			if (ar[i]==CSSOFF||ar[i]==CSSCLASS) { eval(pf+'css='+ar[i]); continue; }
+			if (ar[i]==FGCLASS) { eval(pf+'fgclass="'+ar[++i]+'"'); continue; }
+			if (ar[i]==BGCLASS) { eval(pf+'bgclass="'+ar[++i]+'"'); continue; }
+			if (ar[i]==TEXTFONTCLASS) { eval(pf+'textfontclass="'+ar[++i]+'"'); continue; }
+			if (ar[i]==CAPTIONFONTCLASS) { eval(pf+'captionfontclass="'+ar[++i]+'"'); continue; }
+			if (ar[i]==CLOSEFONTCLASS) { eval(pf+'closefontclass="'+ar[++i]+'"'); continue; }
+			i = parseCmdLine(pf, i, ar);
+		}
+	}
+
+	if (fnMark && o3_function) o3_text = o3_function();
+	
+	if ((pf == 'o3_') && o3_wrap) {
+		o3_width = 0;
+		
+		if (olOp || (olIe4 && isMac)) {
+			var tReg=/<.*\n*>/ig;
+			if (!tReg.test(o3_text)) o3_text = o3_text.replace(/[ ]+/g, '&nbsp;');
+			if (!tReg.test(o3_cap))o3_cap = o3_cap.replace(/[ ]+/g, '&nbsp;');
+		}
+	}
+	if ((pf == 'o3_') && o3_sticky) {
+		if (!o3_close && (o3_frame != ol_frame)) o3_close = ol_close;
+		if (o3_mouseoff && (o3_frame == ol_frame)) opt_NOCLOSE(' ');
+	}
+}
+
+
+////////
+// LAYER FUNCTIONS
+////////
+
+// Writes to a layer
+function layerWrite(txt) {
+	txt += "\n";
+	if (olNs4) {
+		var lyr = o3_frame.document.overDiv.document
+		lyr.write(txt)
+		lyr.close()
+	} else if (typeof over.innerHTML != 'undefined') {
+		if (olIe5 && isMac) over.innerHTML = '';
+		over.innerHTML = txt;
+	} else {
+		range = o3_frame.document.createRange();
+		range.setStartAfter(over);
+		domfrag = range.createContextualFragment(txt);
+		
+		while (over.hasChildNodes()) {
+			over.removeChild(over.lastChild);
+		}
+		
+		over.appendChild(domfrag);
+	}
+}
+
+// Make an object visible
+function showObject(obj) {
+	runHook("showObject", FBEFORE);
+
+	var theObj=(olNs4 ? obj : obj.style);
+	theObj.visibility = 'visible';
+
+	runHook("showObject", FAFTER);
+}
+
+// Hides an object
+function hideObject(obj) {
+	runHook("hideObject", FBEFORE);
+
+	var theObj=(olNs4 ? obj : obj.style);
+	theObj.visibility = 'hidden';
+
+	if (o3_timerid > 0) clearTimeout(o3_timerid);
+	if (o3_delayid > 0) clearTimeout(o3_delayid);
+
+	o3_timerid = 0;
+	o3_delayid = 0;
+	self.status = "";
+
+	if (over.onmouseout || over.onmouseover) {
+		if (olNs4) over.releaseEvents(Event.MOUSEOUT || Event.MOUSEOVER);
+		over.onmouseout = over.onmouseover = null;
+	}
+
+	runHook("hideObject", FAFTER);
+}
+
+// Move a layer
+function repositionTo(obj, xL, yL) {
+	var theObj=(olNs4 ? obj : obj.style);
+	theObj.left = xL + (!olNs4 ? 'px' : 0);
+	theObj.top = yL + (!olNs4 ? 'px' : 0);
+}
+
+// Check position of cursor relative to overDiv DIVision; mouseOut function
+function cursorOff() {
+	var left = parseInt(over.style.left);
+	var top = parseInt(over.style.top);
+	var right = left+over.offsetWidth;
+	var bottom = top+ over.offsetHeight;
+
+	if (o3_x < left || o3_x > right || o3_y < top || o3_y > bottom) return true;
+
+	return false;
+}
+
+
+////////
+// COMMAND FUNCTIONS
+////////
+
+// Calls callme or the default function.
+function opt_FUNCTION(callme) {
+	o3_text = (callme ? (typeof callme=='string' ? (/.+\(.*\)/.test(callme) ? eval(callme) : callme) : callme()) : (o3_function ? o3_function() : 'No Function'));
+
+	return 0;
+}
+
+// Handle hovering
+function opt_NOCLOSE(unused) {
+	if (!unused) o3_close = "";
+
+	if (olNs4) {
+		over.captureEvents(Event.MOUSEOUT || Event.MOUSEOVER);
+		over.onmouseover = function () { if (o3_timerid > 0) { clearTimeout(o3_timerid); o3_timerid = 0; } }
+		over.onmouseout = cClick;
+	} else {
+		over.onmouseover = function () {hoveringSwitch = true; if (o3_timerid > 0) { clearTimeout(o3_timerid); o3_timerid =0; } }
+	}
+
+	return 0;
+}
+
+// Function to scan command line arguments for multiples
+function opt_MULTIPLEARGS(i, args, parameter) {
+  var k = i, l, re, pV, str = '';
+
+  for(k=i; k<args.length; k++) {
+		str += args[k] + ',';
+		if(typeof args[k] == 'number'&&args[k]>pmStart) break;
+	}
+  if(k >= args.length) l = str.length-1;
+  else {
+    re = eval('/,' + args[k] + '/');
+    l = str.search(re);
+  }
+
+	k--;  // reduce by one so the for loop this is in works correctly
+	str = str.substring(0, l);
+	pV = (olNs4&&/cellpad/i.test(parameter)) ? str.split(',')[0] : str;
+	eval(parameter + '="' + pV + '"');
+
+	return k;
+}
+
+// Remove &nbsp; in texts when done.
+function nbspCleanup() {
+	if (o3_wrap && (olOp || (olIe4 && isMac))) {
+		o3_text = o3_text.replace(/\&nbsp;/g, ' ');
+		o3_cap = o3_cap.replace(/\&nbsp;/g, ' ');
+	}
+}
+
+// Escape embedded single quotes in text strings
+function escSglQuote(str) {
+  return str.toString().replace(/'/g,"\\'");
+}
+
+// Onload handler for window onload event
+function OLonLoad_handler(e) {
+	if (!olLoaded) olLoaded=1;  // indicates that all modules have loaded now
+
+	// remove the OLonload_handler for Ns6+, Mozilla based browsers, and IE
+	if (window.removeEventListener) window.removeEventListener("load",OLonLoad_handler,true);
+	else if (window.detachEvent) window.detachEvent("onload",OLonLoad_handler);
+	
+	// Route the event to the normal handler in Nx4.x
+	if (olNs4) routeEvent(e);
+}
+
+// Wraps strings in Layer Generation Functions with the correct tags
+//    endWrap true(if end tag) or false if start tag
+//    fontSizeStr - font size string such as '1' or '10px'
+//    whichString is being wrapped -- 'text', 'caption', or 'close'
+function wrapStr(endWrap,fontSizeStr,whichString) {
+	var fontStr, fontColor, isClose=((whichString=='close') ? 1 : 0), hasDims=/[%\-a-z]+$/.test(fontSizeStr);
+	fontSizeStr = (olNs4) ? (!hasDims ? fontSizeStr : '1') : fontSizeStr;
+	if (endWrap) return (hasDims&&!olNs4) ? (isClose ? '</span>' : '</div>') : '</font>';
+	else {
+		fontStr='o3_'+whichString+'font';
+		fontColor='o3_'+((whichString=='caption')? 'cap' : whichString)+'color';
+		return (hasDims&&!olNs4) ? (isClose ? '<span style="font-family: '+quoteMultiNameFonts(eval(fontStr))+'; color: '+eval(fontColor)+'; font-size: '+fontSizeStr+';">' : '<div style="font-family: '+quoteMultiNameFonts(eval(fontStr))+'; color: '+eval(fontColor)+'; font-size: '+fontSizeStr+';">') : '<font face="'+eval(fontStr)+'" color="'+eval(fontColor)+'" size="'+(parseInt(fontSizeStr)>7 ? '7' : fontSizeStr)+'">';
+	}
+}
+
+// Quotes Multi word font names; needed for CSS Standards adherence in font-family
+function quoteMultiNameFonts(theFont) {
+	var v, pM=theFont.split(',');
+	for (var i=0; i<pM.length; i++) {
+		v=pM[i];
+		v=v.replace(/^\s+/,'').replace(/\s+$/,'');
+		if(/\s/.test(v) && !/['"]/.test(v)) {
+			v="\'"+v+"\'";
+			pM[i]=v;
+		}
+	}
+	return pM.join();
+}
+
+// dummy function which will be overridden 
+function isExclusive(args) {
+	return false;
+}
+////////
+//  PLUGIN ACTIVATION FUNCTIONS
+////////
+
+// Runs plugin functions to set runtime variables.
+function setRunTimeVariables(){
+	if (typeof runTime != 'undefined' && runTime.length) {
+		for (var k = 0; k < runTime.length; k++) {
+			runTime[k]();
+		}
+	}
+}
+
+// Runs plugin functions to parse commands.
+function parseCmdLine(pf, i, args) {
+	if (typeof cmdLine != 'undefined' && cmdLine.length) { 
+		for (var k = 0; k < cmdLine.length; k++) { 
+			var j = cmdLine[k](pf, i, args);
+			if (j >- 1) {
+				i = j;
+				break;
+			}
+		}
+	}
+
+	return i;
+}
+
+// Runs plugin functions to do things after parse.
+function postParseChecks(){
+	if (typeof postParse != 'undefined' && postParse.length) {
+		for (var k = 0; k < postParse.length; k++) {
+			if (postParse[k]()) continue;
+			return false;  // end now since have an error
+		}
+	}
+	return true;
+}
+
+
+////////
+//  PLUGIN REGISTRATION FUNCTIONS
+////////
+
+// Registers commands and creates constants.
+function registerCommands(cmdStr) {
+	if (typeof cmdStr!='string') return;
+
+	var pM = cmdStr.split(',');
+	pms = pms.concat(pM);
+
+	for (var i = 0; i< pM.length; i++) {
+		eval(pM[i].toUpperCase()+'='+pmCount++);
+	}
+}
+
+// Register a function to hook at a certain point.
+function registerHook(fnHookTo, fnRef, hookType, optPm) {
+	var hookPt, last = typeof optPm;
+	
+	if (fnHookTo == 'plgIn'||fnHookTo == 'postParse') return;
+	if (typeof hookPts == 'undefined') hookPts = new Array();
+	if (typeof hookPts[fnHookTo] == 'undefined') hookPts[fnHookTo] = new FunctionReference();
+
+	hookPt = hookPts[fnHookTo];
+
+	if (hookType != null) {
+		if (hookType == FREPLACE) {
+			hookPt.ovload = fnRef;  // replace normal overlib routine
+			if (fnHookTo.indexOf('ol_content_') > -1) hookPt.alt[pms[CSSOFF-1-pmStart]]=fnRef; 
+
+		} else if (hookType == FBEFORE || hookType == FAFTER) {
+			var hookPt=(hookType == 1 ? hookPt.before : hookPt.after);
+
+			if (typeof fnRef == 'object') {
+				hookPt = hookPt.concat(fnRef);
+			} else {
+				hookPt[hookPt.length++] = fnRef;
+			}
+
+			if (optPm) hookPt = reOrder(hookPt, fnRef, optPm);
+
+		} else if (hookType == FALTERNATE) {
+			if (last=='number') hookPt.alt[pms[optPm-1-pmStart]] = fnRef;
+		}
+
+		return;
+	}
+}
+
+// Register a function that will set runtime variables.
+function registerRunTimeFunction(fn) {
+	if (isFunction(fn)) {
+		if (typeof runTime == 'undefined') runTime = new Array();
+		if (typeof fn == 'object') {
+			runTime = runTime.concat(fn);
+		} else {
+			runTime[runTime.length++] = fn;
+		}
+	}
+}
+
+// Register a function that will handle command parsing.
+function registerCmdLineFunction(fn){
+	if (isFunction(fn)) {
+		if (typeof cmdLine == 'undefined') cmdLine = new Array();
+		if (typeof fn == 'object') {
+			cmdLine = cmdLine.concat(fn);
+		} else {
+			cmdLine[cmdLine.length++] = fn;
+		}
+	}
+}
+
+// Register a function that does things after command parsing. 
+function registerPostParseFunction(fn){
+	if (isFunction(fn)) {
+		if (typeof postParse == 'undefined') postParse = new Array();
+		if (typeof fn == 'object') {
+			postParse = postParse.concat(fn);
+		} else {
+			postParse[postParse.length++] = fn;
+		}
+	}
+}
+
+////////
+//  PLUGIN REGISTRATION FUNCTIONS
+////////
+
+// Runs any hooks registered.
+function runHook(fnHookTo, hookType) {
+	var l = hookPts[fnHookTo], optPm, arS, ar = runHook.arguments;
+
+	if (hookType == FREPLACE) {
+		arS = argToString(ar, 2);
+
+		if (typeof l == 'undefined' || !(l = l.ovload)) return eval(fnHookTo+'('+arS+')');
+		else return eval('l('+arS+')');
+
+	} else if (hookType == FBEFORE || hookType == FAFTER) {
+		if (typeof l == 'undefined') return;
+		l=(hookType == 1 ? l.before : l.after);
+
+		if (!l.length) return;
+
+		arS = argToString(ar, 2);
+		for (var k = 0; k < l.length; k++) eval('l[k]('+arS+')'); 
+
+	} else if (hookType == FALTERNATE) {
+		optPm = ar[2];
+		arS = argToString(ar, 3);
+
+		if (typeof l == 'undefined' || (l = l.alt[pms[optPm-1-pmStart]]) == 'undefined') {
+			return eval(fnHookTo+'('+arS+')');
+		} else {
+			return eval('l('+arS+')');
+		}
+	}
+}
+
+////////
+//  UTILITY FUNCTIONS
+////////
+
+// Checks if something is a function.
+function isFunction(fnRef) {
+	var rtn = true;
+
+	if (typeof fnRef == 'object') {
+		for (var i = 0; i < fnRef.length; i++) {
+			if (typeof fnRef[i]=='function') continue;
+			rtn = false;
+			break;
+		}
+	} else if (typeof fnRef != 'function') {
+		rtn = false;
+	}
+	
+	return rtn;
+}
+
+// Converts an array into an argument string for use in eval.
+function argToString(array, strtInd, argName) {
+	var jS = strtInd, aS = '', ar = array;
+	argName=(argName ? argName : 'ar');
+	
+	if (ar.length > jS) {
+		for (var k = jS; k < ar.length; k++) aS += argName+'['+k+'], ';
+		aS = aS.substring(0, aS.length-2);
+	}
+	
+	return aS;
+}
+
+// Places a hook in the correct position in a hook point.
+function reOrder(hookPt, fnRef, order) {
+	if (!order || typeof order == 'undefined' || typeof order == 'number') return;
+	
+	var newPt = new Array(), match;
+
+	if (typeof order=='function') {
+		if (typeof fnRef=='object') {
+			newPt = newPt.concat(fnRef);
+		} else {
+			newPt[newPt.length++]=fnRef;
+		}
+		
+		for (var i = 0; i < hookPt.length; i++) {
+			match = false;
+			if (typeof fnRef == 'function' && hookPt[i] == fnRef) {
+				continue;
+			} else {
+				for(var j = 0; j < fnRef.length; j++) if (hookPt[i] == fnRef[j]) {
+					match = true;
+					break;
+				}
+			}
+			if (!match) newPt[newPt.length++] = hookPt[i];
+		}
+
+		newPt[newPt.length++] = order;
+
+	} else if (typeof order == 'object') {
+		if (typeof fnRef == 'object') {
+			newPt = newPt.concat(fnRef);
+		} else {
+			newPt[newPt.length++] = fnRef;
+		}
+		
+		for (var j = 0; j < hookPt.length; j++) {
+			match = false;
+			if (typeof fnRef == 'function' && hookPt[j] == fnRef) {
+				continue;
+			} else {
+				for (var i = 0; i < fnRef.length; i++) if (hookPt[j] == fnRef[i]) {
+					match = true;
+					break;
+				}
+			}
+			if (!match) newPt[newPt.length++]=hookPt[j];
+		}
+
+		for (i = 0; i < newPt.length; i++) hookPt[i] = newPt[i];
+		newPt.length = 0;
+		
+		for (var j = 0; j < hookPt.length; j++) {
+			match = false;
+			for (var i = 0; i < order.length; i++) {
+				if (hookPt[j] == order[i]) {
+					match = true;
+					break;
+				}
+			}
+			if (!match) newPt[newPt.length++] = hookPt[j];
+		}
+		newPt = newPt.concat(order);
+	}
+
+	for(i = 0; i < newPt.length; i++) hookPt[i] = newPt[i];
+
+	return hookPt;
+}
+
+////////
+// OBJECT CONSTRUCTORS
+////////
+
+// Object for handling hooks.
+function FunctionReference() {
+	this.ovload = null;
+	this.before = new Array();
+	this.after = new Array();
+	this.alt = new Array();
+}
+
+// Object for simple access to the overLIB version used.
+// Examples: simpleversion:351 major:3 minor:5 revision:1
+function Info(version, prerelease) {
+	this.version = version;
+	this.prerelease = prerelease;
+
+	this.simpleversion = parseInt(this.version*100);
+	this.major = parseInt(this.simpleversion / 100);
+	this.minor = parseInt(this.simpleversion / 10) - this.major * 10;
+	this.revision = parseInt(this.simpleversion) - this.major * 100 - this.minor * 10;
+}
+
+
+
+////////
+// STANDARD REGISTRATIONS
+////////
+registerHook("ol_content_simple", ol_content_simple, FALTERNATE, CSSOFF);
+registerHook("ol_content_caption", ol_content_caption, FALTERNATE, CSSOFF);
+registerHook("ol_content_background", ol_content_background, FALTERNATE, CSSOFF);
+registerHook("ol_content_simple", ol_content_simple, FALTERNATE, CSSCLASS);
+registerHook("ol_content_caption", ol_content_caption, FALTERNATE, CSSCLASS);
+registerHook("ol_content_background", ol_content_background, FALTERNATE, CSSCLASS);
+registerHook("hideObject", nbspCleanup, FAFTER);
+

Added: incubator/roller/branches/roller_1.x/web/theme/scripts/roller.js
URL: http://svn.apache.org/viewcvs/incubator/roller/branches/roller_1.x/web/theme/scripts/roller.js?rev=327589&view=auto
==============================================================================
--- incubator/roller/branches/roller_1.x/web/theme/scripts/roller.js (added)
+++ incubator/roller/branches/roller_1.x/web/theme/scripts/roller.js Fri Oct 21 14:27:36 2005
@@ -0,0 +1,158 @@
+/* This function is used to set cookies */
+function setCookie(name,value,expires,path,domain,secure) {
+  document.cookie = name + "=" + escape (value) +
+    ((expires) ? "; expires=" + expires.toGMTString() : "") +
+    ((path) ? "; path=" + path : "") +
+    ((domain) ? "; domain=" + domain : "") + ((secure) ? "; secure" : "");
+}
+
+/* This function is used to get cookies */
+function getCookie(name) {
+	var prefix = name + "=" 
+	var start = document.cookie.indexOf(prefix) 
+
+	if (start==-1) {
+		return null;
+	}
+	
+	var end = document.cookie.indexOf(";", start+prefix.length) 
+	if (end==-1) {
+		end=document.cookie.length;
+	}
+
+	var value=document.cookie.substring(start+prefix.length, end) 
+	return unescape(value);
+}
+
+/* This function is used to delete cookies */
+function deleteCookie(name,path,domain) {
+  if (getCookie(name)) {
+    document.cookie = name + "=" +
+      ((path) ? "; path=" + path : "") +
+      ((domain) ? "; domain=" + domain : "") +
+      "; expires=Thu, 01-Jan-70 00:00:01 GMT";
+  }
+}
+
+function rememberUser(theForm) {
+    var expires = new Date();
+    expires.setTime(expires.getTime() + 24 * 365 * 60 * 60 * 1000); // sets it for approx 365 days.
+    // sets it for entire domain, so freeroller will remember for all users
+    setCookie("commentAuthor",theForm.name.value,expires,"/"); 
+    setCookie("commentEmail",theForm.email.value,expires,"/");
+    setCookie("commentUrl",theForm.url.value,expires,"/");
+}
+
+function forgetUser(theForm) {
+    deleteCookie("commentAuthor","/");
+    deleteCookie("commentEmail","/");
+    deleteCookie("commentUrl","/");
+}
+
+/* This function is used to show/hide elements with a display:none style attribute */ 
+function toggle(targetId) {
+    if (document.getElementById) {
+        target = document.getElementById(targetId);
+    	if (target.style.display == "none") {
+    		target.style.display = "";            
+    	} else {
+    		target.style.display = "none";
+    	}
+    }
+}
+
+/* The toggleFolder and togglePlusMinus functions are for expanding/contracting folders */
+function toggleFolder(targetId) {
+    var expanded;
+    if (document.getElementById) {
+        target = document.getElementById(targetId);
+    	if (target.style.display == "none") {
+    		target.style.display = "";    
+            expanded = true;        
+    	} else {
+    		target.style.display = "none";
+            expanded = false;
+    	}
+        togglePlusMinus("i" + targetId);
+        
+        // set a cookie to remember this preference
+        var expires = new Date();
+        expires.setTime(expires.getTime() + 24 * 365 * 60 * 60 * 1000); // sets it for approx 365 days.
+        setCookie("rfolder-"+targetId,expanded,expires,"/");
+    }
+}
+
+function togglePlusMinus(targetId) {
+    if (document.getElementById) {
+        target = document.getElementById(targetId);
+    	if (target.innerHTML == "+") {
+    		target.innerHTML = "-";
+    	} else {
+    		target.innerHTML = "+";
+    	}
+    }
+}
+
+/* This function is to set folders to expand/contract based on a user's preference */
+function folderPreference(folderId) {
+    var folderCookie = getCookie("rfolder-"+folderId);
+    if (folderCookie != null) { // we have user's last setting
+        folder = document.getElementById(folderId);
+        plusMinus = document.getElementById("i"+folderId);
+        if (folderCookie == "true") { // show
+            folder.style.display = "";
+            plusMinus.innerHTML = "-";
+        } else { // hide
+            folder.style.display = "none";
+            plusMinus.innerHTML = "+"; 
+        }
+    }
+}
+
+function toggleNextRow(e) {
+    if (e.type == "checkbox") {
+        var checked = e.checked;
+    } else if (e.type == "radio") {
+        var v = e.value;
+        var checked = (v == "1" || v == "y" || v == "true") ? true : false;
+    }
+    // var nextRow = e.parentNode.parentNode.nextSibling;
+    // the above doesn't work on Mozilla since it treats white space as nodes
+    var thisRow = e.parentNode.parentNode;
+    var tableBody = thisRow.parentNode;
+    var nextRow = tableBody.getElementsByTagName("tr")[thisRow.rowIndex+1];
+    
+    if (checked == true) {
+        nextRow.style.display = "";
+    } else {
+        nextRow.style.display = "none";
+    }
+}
+
+function toggleControl(toggleId, targetId) {
+    var expanded;
+    if (document.getElementById) {
+        target = document.getElementById(targetId);
+        toggle = document.getElementById(toggleId);
+    	if (target.style.display == "none") {
+    		target.style.display = "";  
+    		toggle.style.background = "#e7e7ff";  
+            expanded = true;  
+                  
+    	} else {
+    		target.style.display = "none";
+    		toggle.style.background = "#f0f0f0";  
+            expanded = false;
+    	}
+        togglePlusMinus("i" + targetId);
+        
+        // set a cookie to remember this preference
+        var expires = new Date();
+        expires.setTime(expires.getTime() + 24 * 365 * 60 * 60 * 1000); // sets it for approx 365 days.
+        setCookie("control-"+targetId,expanded,expires,"/");
+    }
+}
+
+
+// Show the document's title on the status bar
+window.defaultStatus=document.title;
\ No newline at end of file

Added: incubator/roller/branches/roller_1.x/web/theme/scripts/searchhi.js
URL: http://svn.apache.org/viewcvs/incubator/roller/branches/roller_1.x/web/theme/scripts/searchhi.js?rev=327589&view=auto
==============================================================================
--- incubator/roller/branches/roller_1.x/web/theme/scripts/searchhi.js (added)
+++ incubator/roller/branches/roller_1.x/web/theme/scripts/searchhi.js Fri Oct 21 14:27:36 2005
@@ -0,0 +1,69 @@
+/* http://www.kryogenix.org/code/browser/searchhi/ */
+/* Modified 20021006 to fix query string parsing and add case insensitivity */
+function highlightWord(node,word) {
+	// Iterate into this nodes childNodes
+	if (node.hasChildNodes) {
+		var hi_cn;
+		for (hi_cn=0;hi_cn<node.childNodes.length;hi_cn++) {
+			highlightWord(node.childNodes[hi_cn],word);
+		}
+	}
+	
+	// And do this node itself
+	if (node.nodeType == 3) { // text node
+		tempNodeVal = node.nodeValue.toLowerCase();
+		tempWordVal = word.toLowerCase();
+		if (tempNodeVal.indexOf(tempWordVal) != -1) {
+			pn = node.parentNode;
+			if (pn.className != "searchword") {
+				// word has not already been highlighted!
+				nv = node.nodeValue;
+				ni = tempNodeVal.indexOf(tempWordVal);
+				// Create a load of replacement nodes
+				before = document.createTextNode(nv.substr(0,ni));
+				docWordVal = nv.substr(ni,word.length);
+				after = document.createTextNode(nv.substr(ni+word.length));
+				hiwordtext = document.createTextNode(docWordVal);
+				hiword = document.createElement("span");
+				hiword.className = "searchword";
+				hiword.appendChild(hiwordtext);
+				pn.insertBefore(before,node);
+				pn.insertBefore(hiword,node);
+				pn.insertBefore(after,node);
+				pn.removeChild(node);
+			}
+		}
+	}
+}
+
+function googleSearchHighlight() {
+	if (!document.createElement) return;
+	ref = document.referrer;
+	if (ref.indexOf('?') == -1) return;
+	qs = ref.substr(ref.indexOf('?')+1);
+	qsa = qs.split('&');
+	for (i=0;i<qsa.length;i++) {
+		qsip = qsa[i].split('=');
+        if (qsip.length == 1) continue;
+        if (qsip[0] == 'q' || qsip[0] == 'p') { // q= for Google, p= for Yahoo
+            words = unescape(qsip[1].replace(/\+/g,' ')).split(/\s+/);
+            for (w=0;w<words.length;w++) {
+                highlightWord(document.getElementsByTagName("body")[0],words[w]);
+            }
+        }
+	}
+}
+
+function highlightTerm() {
+    if (!document.createElement) return;
+    // ensure this only executes when showing search results
+    if (document.getElementById("searchAgain")) {
+        var searchTerm = document.getElementById("q").value;
+        words = unescape(searchTerm.replace(/\+/g,' ')).split(/\s+/);
+        for (w=0;w<words.length;w++) {
+            highlightWord(document.getElementsByTagName("body")[0],words[w]);
+        }
+    }
+}
+
+window.onload = highlightTerm;

Added: incubator/roller/branches/roller_1.x/web/theme/scripts/xmlp.js
URL: http://svn.apache.org/viewcvs/incubator/roller/branches/roller_1.x/web/theme/scripts/xmlp.js?rev=327589&view=auto
==============================================================================
--- incubator/roller/branches/roller_1.x/web/theme/scripts/xmlp.js (added)
+++ incubator/roller/branches/roller_1.x/web/theme/scripts/xmlp.js Fri Oct 21 14:27:36 2005
@@ -0,0 +1,1179 @@
+/*
+ * xmlp.js, version 1.0
+ * An XML parser in JavaScript
+ *
+ * Revision history:
+ *    1.0, 23 Nov 2001 : Initial version
+ *
+ * Copyright (C) 2001 David A. Lindquist (dave@gazingus.org)
+ *
+ * This library is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License as published by
+ * the Free Software Foundation; either version 2.1 of the License, or
+ * (at your option) any later version.
+ * 
+ * This library 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 Lesser General Public License for more details.
+ * 
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ */
+
+/// Node ///////////////////////////////////////////////////////////////////////
+
+Node.ELEMENT_NODE                =  1;
+Node.ATTRIBUTE_NODE              =  2;
+Node.TEXT_NODE                   =  3;
+Node.CDATA_SECTION_NODE          =  4;
+Node.ENTITY_REFERENCE_NODE       =  5;
+Node.ENTITY_NODE                 =  6; // not used
+Node.PROCESSING_INSTRUCTION_NODE =  7;
+Node.COMMENT_NODE                =  8;
+Node.DOCUMENT_NODE               =  9;
+Node.DOCUMENT_TYPE_NODE          = 10;
+Node.DOCUMENT_FRAGMENT_NODE      = 11;
+Node.NOTATION_NODE               = 12; // not used
+
+function Node() {
+  this.attributes = null;
+  this.childNodes = new NodeList();
+  this.firstChild = null
+  this.lastChild = null;
+  this.nextSibling = null;
+  this.nodeName = null;
+  this.nodeType = null;
+  this.nodeValue = null;
+  this.ownerDocument = null;
+  this.parentNode = null;
+  this.previousSibling = null;
+}
+
+Node.prototype.getAttributes = function() { return this.attributes; }
+Node.prototype.getChildNodes = function() { return this.childNodes; }
+Node.prototype.getFirstChild = function() { return this.firstChild; }
+Node.prototype.getLastChild = function() { return this.lastChild; }
+Node.prototype.getNextSibling = function() { return this.nextSibling; }
+Node.prototype.getNodeName = function() { return this.nodeName; }
+Node.prototype.getNodeType = function() { return this.nodeType; }
+Node.prototype.getNodeValue = function() { return this.nodeValue; }
+Node.prototype.getOwnerDocument = function() { return this.ownerDocument; }
+Node.prototype.getParentNode = function() { return this.parentNode; }
+Node.prototype.getPreviousSibling = function() { return this.previousSibling; }
+
+Node.prototype.setNodeValue =
+function() {
+  // Default behavior is to do nothing;
+  // overridden in some subclasses
+}
+
+Node.prototype.appendChild =
+function( childNode ) {
+  if ( this.nodeType == Node.ELEMENT_NODE ||
+       this.nodeType == Node.ATTRIBUTE_NODE ||
+       this.nodeType == Node.DOCUMENT_NODE ||
+       this.nodeType == Node.DOCUMENT_FRAGMENT_NODE ) {
+    this.childNodes.add( childNode );
+  }
+  else {
+    // :REVISIT: change to DOMException
+    throw new ParseError( "Cannot append child node" );
+  }
+
+  if ( this.ownerDocument != childNode.ownerDocument ) {
+    // :REVISIT: change to DOMException
+    throw new ParseError( "Cannot append child to this document" );
+  }
+  
+  if ( this.childNodes.length == 1 ) {
+    this.firstChild = childNode;
+  }
+
+  this.lastChild = childNode;
+  childNode.parentNode = this;
+  
+  var prevSibling = this.childNodes.item( -2 );
+  childNode.previousSibling = prevSibling;
+  
+  if ( prevSibling != null ) {
+    prevSibling.nextSibling = childNode;
+  }
+}
+
+Node.prototype.cloneNode =
+function( deep ) {
+  // :REVISIT: change to DOMException
+  throw new ParseError( "Not implemented" );
+}
+
+Node.prototype.hasChildNodes =
+function() {
+  return ( this.childNodes.length > 0 );
+}
+
+Node.prototype.insertBefore =
+function( newChild, refChild ) {
+  var currentChildren = this.childNodes;
+  this.childNodes = new NodeList();
+  for ( var i = 0; i < currentChildren.length; ) {
+    var child = currentChildren.item(i);
+    if ( child == refChild && refChild != null ) {
+      this.appendChild( newChild );
+      refChild = null;
+    }
+    else {
+      this.appendChild( child );
+      i++;
+    }
+  }
+}
+
+Node.prototype.removeChild =
+function( oldChild ) {
+  var currentChildren = this.childNodes;
+  this.childNodes = new NodeList();
+  for ( var i = 0; i < currentChildren.length; i++ ) {
+    var child = currentChildren.item(i)
+    if ( child != oldChild ) {
+      this.appendChild( child );
+    }
+  }
+}
+
+Node.prototype.replaceChild =
+function( newChild, oldChild ) {
+  var oldChildren = this.childNodes;
+  this.childNodes = new NodeList();
+  for ( var i = 0; i < oldChildren.length; i++ ) {
+    if ( oldChildren.item(i) == oldChild ) {
+      this.appendChild( newChild );
+    }
+    else {
+      this.appendChild( oldChild );
+    }
+  }
+}
+
+/// Element ////////////////////////////////////////////////////////////////////
+
+Element.prototype = new Node();
+Element.prototype.constructor = Element;
+  // Element : Node
+
+function Element( ownerDoc, name ) {
+  this.tagName = name;
+  
+  // inherited from Node
+  this.attributes = new NamedNodeMap();
+  this.childNodes = new NodeList();
+  this.nodeType = Node.ELEMENT_NODE;
+  this.nodeName = name;
+  this.ownerDocument = ownerDoc;
+}
+
+Element.prototype.getAttribute =
+function( name ) {
+  var attr = this.attributes.getNamedItem( name );
+  return ( attr == null ) ? "" : attr.getValue();
+}
+
+Element.prototype.getAttributeNode =
+function( name ) {
+  return this.attributes.getNamedItem( name );
+}
+
+Element.prototype.getElementsByTagName =
+function( tagName ) {
+  return new DeepNodeList( this, tagName );
+}
+
+Element.prototype.getTagName =
+function() {
+  return this.tagName;
+}
+
+Element.prototype.normalize =
+function() {
+  var child, next;
+  for ( child = this.getFirstChild(); child != null; child = next ) {
+    next = child.getNextSibling();
+    if ( child.getNodeType() == Node.TEXT_NODE ) {
+      if ( next != null && next.getNodeType() == Node.TEXT_NODE ) {
+        child.appendData( next.getNodeValue() );
+        this.removeChild( next );
+        next = child;
+      }
+      else {
+        if ( child.getNodeValue().length == 0 ) {
+          this.removeChild( child );
+        }
+      }
+    }
+    else if ( child.getNodeType() == Node.ELEMENT_NODE ) {
+      child.normalize();
+    }
+  }
+}
+
+Element.prototype.removeAttribute = 
+function( name ) {
+  this.attributes.removeNamedItem( name );
+}
+
+Element.prototype.removeAttributeNode =
+function( attr ) {
+  return this.attributes.removeNamedItem( attr.nodeName );
+}
+
+Element.prototype.setAttribute =
+function( name, value ) {
+  var attr = this.ownerDocument.createAttribute( name );
+  arrt.setValue( value );
+  this.attributes.setNamedItem( attr );
+}
+
+Element.prototype.setAttributeNode =
+function( attr ) {
+  return this.attributes.setNamedItem( attr );
+}
+
+/// Attr ///////////////////////////////////////////////////////////////////////
+
+Attr.prototype = new Node();
+Attr.prototype.constructor = Attr;
+  // Attr : Node
+
+function Attr( ownerDoc, name ) {
+  this.name = name;
+  this.specified = true;
+  this.value = null;
+  
+  // inherited from Node
+  this.childNodes = new NodeList();
+  this.nodeName = name;
+  this.nodeType = Node.ATTRIBUTE_NODE;
+  this.nodeValue = null;
+  this.ownerDocument = ownerDoc;
+}
+
+Attr.prototype.getName =
+function() {
+  return this.name;
+}
+
+Attr.prototype.getNodeValue =
+function() {
+  return this.getValue();
+}
+
+Attr.prototype.getSpecified =
+function() {
+  return this.specified;
+}
+
+Attr.prototype.getValue =
+function() {
+  // :REVISIT:
+  var value = "";
+  for ( var i = 0; i < this.childNodes.length; i++ ) {
+    value += this.childNodes.item(i).getNodeValue();
+  }
+  return value;
+}
+
+Attr.prototype.setValue =
+function( value ) {
+  // :REVISIT:
+  this.childNodes = new NodeList();
+  this.firstChild = null;
+  this.lastChild = null;
+  
+  if ( value != null ) {
+    this.appendChild( this.ownerDocument.createTextNode( value ) );
+  }
+}
+
+/// CharacterData //////////////////////////////////////////////////////////////
+
+CharacterData.prototype = new Node();
+CharacterData.prototype.constructor = CharacterData;
+  // CharacterData : Node
+
+function CharacterData( data ) {
+  this.data = data;
+  
+  // inherited from Node
+  this.nodeValue = data;
+}
+
+CharacterData.prototype.appendData =
+function( data ) {
+  this.setData( this.getData() + data );
+}
+
+CharacterData.prototype.deleteData =
+function( offset, count ) {
+  var begin = this.getData().substring( 0, offset );
+  var end = this.getData().substring( offset + count );
+  this.setData( begin + end );
+}
+
+CharacterData.prototype.getData =
+function() {
+  return this.data;
+}
+
+CharacterData.prototype.getLength =
+function() {
+  return ( this.data ) ? this.data.length : 0;
+}
+
+CharacterData.prototype.insetData =
+function( offset, data ) {
+  var begin = this.getData().substring( 0, offset );
+  var end = this.getData().substring( offset, this.getLength );
+  this.setData( begin + data + end );
+}
+
+CharacterData.prototype.replaceData =
+function( offset, count, data ) {
+  this.deleteData( offset, count );
+  this.insertData( offset, data );
+}
+
+CharacterData.prototype.setData =
+function( data ) {
+  this.setNodeValue( data );
+}
+
+CharacterData.prototype.setNodeValue =
+function( value ) {
+  this.data = value;
+  this.nodeValue = value;
+}
+
+CharacterData.prototype.substringData =
+function( offset, count ) {
+  return this.getData().substring( offset, offset + count );
+}
+
+/// Text ///////////////////////////////////////////////////////////////////////
+
+Text.prototype = new CharacterData();
+Text.prototype.constructor = Text;
+  // Text : CharacterData
+
+function Text( ownerDoc, data ) {
+  // inherited from CharacterData
+  this.data = data;
+  
+  // inherited from CharacterData : Node
+  this.nodeName = "#text";
+  this.nodeType = Node.TEXT_NODE;
+  this.nodeValue = data;
+  this.ownerDocument = ownerDoc;
+}
+
+Text.prototype.splitText =
+function( offset ) {
+  // :REVISIT:
+  // check for index out of bounds condition
+  
+  var newText =
+    this.getOwnerDocument().createTextNode( this.data.substring( offset ) );
+  
+  var parentNode = this.getParentNode();
+  if ( parentNode != null ) {
+    parentNode.insetBefore( newText, this.nextSibling );
+  }
+  
+  return newText;
+}
+
+/// CDATASection ///////////////////////////////////////////////////////////////
+
+CDATASection.prototype = new Text();
+CDATASection.prototype.constructor = CDATASection;
+  // CDATASection : Text
+
+function CDATASection( ownerDoc, data ) {
+  
+  // inherited from Text : CharacterData
+  this.data = data;
+  
+  // inherited from Text : CharacterData : Node
+  this.nodeName = "#cdata-section";
+  this.nodeType = Node.CDATA_SECTION_NODE;
+  this.nodeValue = data;
+  this.ownerDocument = ownerDoc;
+}
+
+/// EntityReference ////////////////////////////////////////////////////////////
+
+EntityReference.prototype = new Node();
+EntityReference.prototype.constructor = EntityReference;
+  // EntityReference : Node
+
+function EntityReference( ownerDoc, name ) {
+  
+  // inherited from Node
+  this.nodeName = name;
+  this.nodeType = Node.ENTITY_REFERENCE_NODE;
+  this.ownerDocument = ownerDoc;
+}
+
+/// ProcessingInstruction //////////////////////////////////////////////////////
+
+ProcessingInstruction.prototype = new Node();
+ProcessingInstruction.prototype.constructor = ProcessingInstruction;
+  // ProcessingInstruction : Node
+
+function ProcessingInstruction( ownerDoc, target, data ) {
+  this.target = target;
+  this.data = data;
+  
+  // inherited from Node
+  this.nodeName = target;
+  this.nodeType = Node.PROCESSING_INSTRUCTION_NODE;
+  this.nodeValue = data;
+  this.ownerDocument = ownerDoc;
+}
+
+ProcessingInstruction.prototype.getData =
+function() {
+  return this.data;
+}
+
+ProcessingInstruction.prototype.getTarget =
+function() {
+  return this.target;
+}
+
+ProcessingInstruction.prototype.setData =
+function( data ) {
+  this.setNodeValue( data );
+}
+
+ProcessingInstruction.prototype.setNodeValue =
+function( value ) {
+  this.data = data;
+  this.nodeValue = data;
+}
+
+/// Comment ////////////////////////////////////////////////////////////////////
+
+Comment.prototype = new CharacterData();
+Comment.prototype.constructor = Comment;
+  // Comment : CharacterData
+
+function Comment( ownerDoc, data ) {
+  // inherited from CharacterData
+  this.data = data;
+  
+  // inherited from CharacterData : Node
+  this.nodeName = "#comment";
+  this.nodeType = Node.COMMENT_NODE;
+  this.nodeValue = data;
+  this.ownerDocument = ownerDoc;
+}
+
+/// Document ///////////////////////////////////////////////////////////////////
+
+Document.prototype = new Node();
+Document.prototype.constructor = Document;
+  // Document : Node
+
+function Document() {
+  this.doctype = null;
+  this.implementation = null;
+  this.documentElement = null;
+
+  // inherited from Node
+  this.childNodes = new NodeList();
+  this.nodeName = "#document";
+  this.nodeType = Node.DOCUMENT_NODE;
+  this.ownerDocument = this;
+}
+
+Document.prototype.createAttribute =
+function( name, value ) {
+  return new Attr( this, name, value );
+}
+
+Document.prototype.createCDATASection =
+function( data ) {
+  return new CDATASection( this, data );
+}
+
+Document.prototype.createComment =
+function( data ) {
+  return new Comment( this, data );
+}
+
+Document.prototype.createDocumentFragment =
+function() {
+  return new DocumentFragment( this );
+}
+
+Document.prototype.createElement =
+function( tagName ) {
+  return new Element( this, tagName );
+}
+
+Document.prototype.createEntityReference =
+function( name ) {
+  return new EntityReference( this, name );
+}
+
+Document.prototype.createProcessingInstruction =
+function( target, data ) {
+  return new ProcessingInstruction( this, target, data );
+}
+
+Document.prototype.createTextNode =
+function( data ) {
+  return new Text( this, data );
+}
+
+Document.prototype.getDoctype =
+function() {
+  return this.doctype;
+}
+
+Document.prototype.getDocumentElement =
+function() {
+  return this.documentElement;
+}
+
+Document.prototype.getElementsByTagName =
+function( tagName ) {
+  return new DeepNodeList( this, tagName );
+}
+
+Document.prototype.getImplementation =
+function() {
+  // :REVISIT:
+  return this.implementation;
+}
+
+/// DocumentType ///////////////////////////////////////////////////////////////
+
+DocumentType.prototype = new Node();
+DocumentType.prototype.constructor = DocumentType;
+  // DocumentType : Node
+
+function DocumentType( ownderDoc, name ) {
+  this.name = name;
+  this.entities = null;
+  this.notations = null;
+  
+  // inherited from Node
+  this.nodeName = name;
+  this.nodeType = Node.DOCUMENT_TYPE_NODE;
+  this.ownerDocument = ownderDoc;
+}
+
+DocumentType.prototype.getEntities = 
+function() {
+  // :REVISIT: change to DOMException
+  throw new ParseError( "Not implemented" );
+}
+
+DocumentType.prototype.getName = 
+function() {
+  return this.name;
+}
+
+DocumentType.prototype.getNotations = 
+function() {
+  // :REVISIT: change to DOMException
+  throw new ParseError( "Not implemented" );
+}
+
+/// DocumentFragment ///////////////////////////////////////////////////////////
+
+DocumentFragment.prototype = new Node();
+DocumentFragment.prototype.constructor = DocumentFragment;
+  // DocumentFragment : Node
+
+function DocumentFragment( ownerDoc ) {
+  
+  // inherited from Node
+  this.childNodes = new NodeList();
+  this.nodeName = "#document-fragment";
+  this.nodeType = Node.DOCUMENT_FRAGMENT_NODE;
+  this.ownerDocument = ownerDoc;
+}
+
+/// NodeList ///////////////////////////////////////////////////////////////////
+
+function NodeList() {
+  this.length = 0;
+}
+
+NodeList.prototype.getLength =
+function() {
+  return this.length;
+}
+
+NodeList.prototype.item =
+function( index ) {
+  var item;
+  item = ( index < 0 ) ? this[ this.length + index ]
+                       : this[ index ];
+  return ( item || null );
+}
+
+NodeList.prototype.add =
+function( node ) {
+  this[ this.length++ ] = node;
+}
+
+/// DeepNodeList ///////////////////////////////////////////////////////////////
+
+DeepNodeList.prototype = new NodeList();
+DeepNodeList.prototype.constructor = DeepNodeList;
+  // DeepNodeList : NodeList
+
+function DeepNodeList( rootNode, tagName ) {
+  this.rootNode = rootNode;
+  this.tagName = tagName;
+  this.getElementsByTagName( rootNode );
+}
+
+DeepNodeList.prototype.getElementsByTagName =
+function( contextNode ) {
+  var nextNode;
+  while ( contextNode != null ) {
+    if ( contextNode.hasChildNodes() ) {
+      contextNode = contextNode.firstChild;
+    }
+    else if ( contextNode != this.rootNode &&
+              null != ( next = contextNode.nextSibling ) ) {
+      contextNode = next;
+    }
+    else {
+      next = null;
+      for ( ; contextNode != this.rootNode;
+           contextNode = contextNode.parentNode ) {
+        next = contextNode.nextSibling;
+        if ( next != null ) {
+          break;
+        }
+      }
+      contextNode = next;
+    }
+    if ( contextNode != this.rootNode &&
+         contextNode != null &&
+         contextNode.nodeType == Node.ELEMENT_NODE ) {
+      if ( this.tagName == "*" || contextNode.tagName == this.tagName ) {
+        this.add( contextNode );
+      }
+    }
+  }
+  return null;
+}
+
+/// NamedNodeMap ///////////////////////////////////////////////////////////////
+
+function NamedNodeMap() {
+  this.length = 0;
+}
+
+NamedNodeMap.prototype.getLength =
+function() {
+  return this.length;
+}
+
+NamedNodeMap.prototype.getNamedItem =
+function( name ) {
+  return ( this[ name ] || null );
+}
+
+NamedNodeMap.prototype.item =
+function( index ) {
+  var item;
+  item = ( index < 0 ) ? this[ this.length + index ]
+                       : this[ index ];
+  return ( item || null );
+}
+
+NamedNodeMap.prototype.removeNamedItem =
+function( name ) {
+  var removed = this[ name ];
+
+  if ( !removed ) {
+    return null;
+  }
+
+  delete this[ name ];
+  for ( var i = 0; i < this.length - 1; i++ ) {
+    if ( !this[i] ) {
+      this[i] = this[ i + 1 ];
+      delete this[ i + 1 ];
+    }
+  }
+  this.length--;
+  return removed;
+}
+
+NamedNodeMap.prototype.setNamedItem =
+function( node ) {
+  var nodeName = node.getNodeName();
+  var item = this.getNamedItem( nodeName );
+  this[ nodeName ] = node;
+  
+  if ( item == null ) {
+    this[ this.length++ ] = node;
+  }
+  
+  return item;
+}
+
+/// ParseError /////////////////////////////////////////////////////////////////
+
+ParseError.prototype = new Error();
+ParseError.prototype.constructor = ParseError;
+  // ParseError : Error
+
+function ParseError( message ) {
+  this.message = message;
+}
+
+/// DOMException ///////////////////////////////////////////////////////////////
+
+// :REVISIT:
+// not currently used
+
+DOMException.prototype = new Error();
+DOMException.prototype.constructor = DOMException;
+  // DOMException : Error
+
+DOMException.INDEX_SIZE_ERR              = 1;
+DOMException.DOMSTRING_SIZE_ERR          = 2;
+DOMException.HIERARCHY_REQUEST_ERR       = 3;
+DOMException.WRONG_DOCUMENT_ERR          = 4;
+DOMException.INVALID_CHARACTER_ERR       = 5;
+DOMException.NO_DATA_ALLOWED_ERR         = 6;
+DOMException.NO_MODIFICATION_ALLOWED_ERR = 7;
+DOMException.NOT_FOUND_ERR               = 8;
+DOMException.NOT_SUPPORTED_ERR           = 9;
+DOMException.INUSE_ATTRIBUTE_ERR         = 10;
+
+function DOMException( code, message ) {
+  this.code = code;
+  this.message = message;
+}
+
+/// XMLParser //////////////////////////////////////////////////////////////////
+
+XMLParser.VERSION = 1.0;
+
+function XMLParser() {
+  this.doc = new Document();
+  this.xml = null;
+
+  this.openedTags = new Array();
+  this.contextNodes = new Array( this.doc );
+}
+
+XMLParser.prototype.parse =
+function( xml ) {
+  this.xml = xml.trim();
+  this.processProlog();
+  this.processRootElement();
+  this.processMisc();
+
+  if ( this.xml.length != 0 ) {
+    throw( new ParseError( "Illegal construct in XML document" ) );
+  }
+}
+
+XMLParser.prototype.processProlog =
+function() {
+  this.processXmlDecl();
+  this.processMisc();
+  this.processDoctypeDecl();
+  this.processMisc();
+}
+
+XMLParser.prototype.processRootElement =
+function() {
+  var matches;
+  
+  if ( matches = this.xml.match( RegExp.$STag ) ) {
+    this.processSTag( matches );
+    this.xml = this.xml.substring( matches[0].length );
+    this.processContent();
+  }
+  else if ( matches = this.xml.match( RegExp.$EmptyElemTag ) ) {
+    this.processEmptyElemTag( matches );
+    this.xml = this.xml.substring( matches[0].length );
+  }
+  else {
+    throw( new ParseError( "Root element not found" ) );
+  }
+}
+
+XMLParser.prototype.processMisc =
+function() {
+  var matches;
+  
+  while ( RegExp.$Misc.test( this.xml ) ) {
+    
+      // white space
+    if ( matches = this.xml.match( RegExp.$S ) ) {
+      ;
+    }
+      // comment
+    else if ( matches = this.xml.match( RegExp.$Comment ) ) {
+      var comment = this.doc.createComment( matches[1] );
+      
+      this.doc.appendChild( comment );
+    }
+      // processing instruction
+    else if ( matches = this.xml.match( RegExp.$PI ) ) {
+      var target = matches[1];
+      var data = matches[3];
+      var pi = this.doc.createProcessingInstruction( target, data );
+      
+      this.doc.appendChild( pi );
+    }
+      // unknown construct
+    else {
+      throw( new ParseError( "Illegal construct in XML document" ) );
+    }
+    
+    this.xml = this.xml.substring( matches[0].length );
+  }
+}
+
+XMLParser.prototype.processContent =
+function() {
+  var matches;
+
+  while ( this.openedTags.length != 0  ) {
+
+      // start tag
+    if ( matches = this.xml.match( RegExp.$STag ) ) {
+      this.processSTag( matches );
+    }
+      // end tag
+    else if ( matches = this.xml.match( RegExp.$ETag ) ) {
+      this.processETag( matches );
+    }
+      // empty element
+    else if ( matches = this.xml.match( RegExp.$EmptyElemTag ) ) {
+      this.processEmptyElemTag( matches );
+    }
+      // character data
+    else if ( matches = this.xml.match( RegExp.$CharData ) ) {
+      this.processCharData( matches );
+    }
+      // entity reference
+    else if ( matches = this.xml.match( RegExp.$Reference ) ) {
+      this.processReference( matches );
+    }
+      // CDATA section
+    else if ( matches = this.xml.match( RegExp.$CDSect ) ) {
+      this.processCDSect( matches );
+    }
+      // processing instruction
+    else if ( matches = this.xml.match( RegExp.$PI ) ) {
+      this.processPI( matches );
+    }
+      // comment
+    else if ( matches = this.xml.match( RegExp.$Comment ) ) {
+      this.processComment( matches );
+    }
+      // unknown construct
+    else {
+      throw( new ParseError( "Illegal construct in XML document" ) );
+    }
+
+    this.xml = this.xml.substring( matches[0].length );
+  }
+}
+
+XMLParser.prototype.processAttributes =
+function( attString ) {
+  var matches;
+
+  while ( matches = attString.match( RegExp.$Attribute ) ) {
+    var name = matches[1];
+    var value = matches[2].removeQuotes();
+    var attr = this.doc.createAttribute( name );
+    var currentContext = this.contextNodes.lastItem();
+
+    attr.setValue( value );
+    
+    attString = attString.substring( matches[0].length ).trim();
+    currentContext.attributes.setNamedItem( attr );
+  }
+}
+
+XMLParser.prototype.processXmlDecl =
+function() {
+  var matches;
+
+  if ( matches = this.xml.match( RegExp.$XMLDecl ) ) {
+    this.xml = this.xml.substring( matches[0].length );
+  }
+}
+
+XMLParser.prototype.processDoctypeDecl =
+function() {
+  var matches;
+  
+  if ( matches = this.xml.match( RegExp.$doctypedecl ) ) {
+    var name = matches[1];
+    
+    var doctype = new DocumentType( this.doc, name );
+    this.doc.appendChild( doctype );
+    this.doc.doctype = doctype;
+    
+    this.xml = this.xml.substring( matches[0].length );
+  }
+}
+
+XMLParser.prototype.processSTag =
+function( matches ) {
+  var element = this.doc.createElement( matches[1] );
+  var attString = matches[2];
+  
+  this.openedTags.push( matches[1] );
+  this.addNode( element );
+  
+  if ( attString ) {
+    this.processAttributes( attString.trim() );
+  }
+}
+
+XMLParser.prototype.processETag =
+function( matches ) {
+  this.contextNodes.pop();
+  
+  if ( this.openedTags.pop() != matches[1] ) {
+    throw( new ParseError( "End tag does not match opening tag" ) );
+  }
+}
+
+XMLParser.prototype.processEmptyElemTag =
+function( matches ) {
+  var element = this.doc.createElement( matches[1] );
+  var attString = matches[2];
+  
+  this.addNode( element );
+  
+  if ( attString ) {
+    this.processAttributes( attString.trim() );
+  }
+  
+  this.contextNodes.pop();
+}
+
+XMLParser.prototype.processCharData =
+function( matches ) {
+  if ( matches[0].trim() != "" ) {
+    var text = this.doc.createTextNode( matches[0] );
+    this.addNode( text );
+  }
+}
+
+XMLParser.prototype.processReference =
+function( matches ) {
+  var reference = this.doc.createEntityReference( matches[0] );
+  this.addNode( reference );
+}
+
+XMLParser.prototype.processCDSect =
+function( matches ) {
+  var cdsect = this.doc.createCDATASection( matches[1] );
+  this.addNode( cdsect );
+}
+
+XMLParser.prototype.processPI =
+function( matches ) {
+  var target = matches[1];
+  var data = matches[3];
+  var pi = this.doc.createProcessingInstruction( target, data );
+  this.addNode( pi );
+}
+
+XMLParser.prototype.processComment =
+function( matches ) {
+  var comment = this.doc.createComment( matches[1] );
+  this.addNode( comment );
+}
+
+XMLParser.prototype.addNode =
+function( node ) {
+  var currentContext = this.contextNodes.lastItem();
+  currentContext.appendChild( node );
+  
+  if ( node.nodeType == Node.ELEMENT_NODE ) {
+    var contextNode = currentContext.childNodes.item( -1 );
+    this.contextNodes.push( contextNode );
+    
+    if ( !this.doc.documentElement ) {
+      this.doc.documentElement = this.contextNodes.lastItem();
+    }
+  }
+}
+
+/// Utilities //////////////////////////////////////////////////////////////////
+
+/*
+ * Utility. Removes leading and trailing white space
+ * from a string
+ */
+String.prototype.trim =
+function() {
+  return this.replace( /^[ \n\r\t]+|[ \n\r\t]+$/g, "" );
+}
+
+/*
+ * Utility. Like pop(), but does not affect the length
+ * of the array
+ */
+Array.prototype.lastItem =
+function() {
+  return this[ this.length - 1 ];
+}
+
+String.prototype.removeQuotes =
+function() {
+  return this.replace( /^['"]|['"]$/g, "" );
+}
+
+/*
+ * Utility. Translates a string into a regex. Replaces identifiers
+ * (beginning with "$") with corresponding regex fragment
+ */
+String.prototype.resolve =
+function() {
+  var resolved = this;
+  var regex = /(\$[a-zA-Z0-9]+)/;
+  
+  while ( regex.test( resolved ) ) {
+    resolved = resolved.replace( RegExp.$1, String[ RegExp.$1 ] );
+  }
+  
+  return resolved.replace( / /g,"" );
+}
+
+/// Productions ////////////////////////////////////////////////////////////////
+
+// Character Range
+String.$Char          = "(?: \\u0009 | \\u000A | \\u000D | " +
+                        "[\\u0020-\\uD7FF] | [\\uE000-\\uFFFD] | " +
+                        "[\\u10000-\\u10FFFF] )";
+
+// White Space
+String.$S             = "(?: (?: \\u0020 | \\u0009 | \\u000D | \\u000A )+ )";
+
+// Names and matches
+String.$NameChar      = "(?: $Letter | $Digit | \\. | \\- | _ | : | " +
+                        "$CombiningChar | $Extender )";
+String.$Name          = "(?: $Letter | _ | : ) $NameChar*";
+
+// Literals
+String.$AttValue      = "(?: \" (?: [^<&\"] | $Reference )* \" ) | " + 
+                        "(?: ' (?: [^<&'] | $Reference )* ' )";
+String.$SystemLiteral = "(?: (?: \" [^\"]* \") | (?: ' [^']* '))";
+String.$PubidLiteral  = "(?: (?: \" $PubidChar* \") | " +
+                        "(?: ' (?: (?!')$PubidChar)* '))";
+String.$PubidChar     = "(?: \\u0020 | \\u000D | \\u000A | [a-zA-Z0-9] | " +
+                        "[-'()+,./:=?;!*#@$_%])";
+
+// Character Data
+//String.$CharData    = "(?![^<&]*]]>[^<&]*)[^<&]*"; // :REVISIT:
+String.$CharData      = "[^<&]+";
+
+// Comments
+String.$Comment       = "<!-- ( (?: (?: (?!- ) $Char ) | " +
+                        "(?: - (?: (?!- ) $Char ) ) )* ) -->";
+
+// Processing Instructions
+String.$PI            = "<\\? ( $PITarget ) ( $S $Char*? )? \\?>";
+String.$PITarget      = "(?: (?: \\b( $Letter | _ | : ) " +
+                        "(?: $NameChar ){0,1}\\b ) | " +
+                        "(?: (?! [Xx][Mm][Ll] ) (?: $Letter | _ | : ) " +
+                        "(?: $NameChar ){2} | (?: $Letter | _ | : ) " +
+                        "(?: $NameChar ){3,} ) )";
+
+// CDATA Sections
+String.$CDSect        = "<!\\[CDATA\\[ ( $Char*? ) ]]>";
+
+// Prolog
+String.$prolog        = "(?: $XMLDecl? $Misc* (?: $doctypedecl $Misc* )? )";
+String.$XMLDecl       = "<\\?xml $VersionInfo $EncodingDecl? " +
+                        "$SDDecl? $S? \\?>";
+String.$VersionInfo   = "(?: $S version $Eq ( ' $VersionNum ' | " +
+                        "\" $VersionNum \" ) )";
+String.$Eq            = "(?: $S? = $S? )";
+String.$VersionNum    = "(?: (?: [a-zA-Z0-9_.:] | - )+ )";
+String.$Misc          = "(?: $Comment | $PI | $S )";
+
+// Document Type Definition
+String.$doctypedecl   = "<!DOCTYPE $S ( $Name ) (?: $S $ExternalID)? $S? " +
+                        "(?: \\[ [^]]* \\] )? $S? >";
+
+// Standalone Document Declaration
+String.$SDDecl        = "(?: $S standalone $Eq ( (?: \"(?: yes|no )\" ) | " +
+                        "(?: '(?: yes|no)' ) ) )";
+
+// Start-tag
+String.$STag          = "< ( $Name ) ( (?: $S $Attribute )* ) $S? >";
+String.$Attribute     = "( $Name ) $Eq ( $AttValue )";
+
+// End-tag
+String.$ETag          = "</ ( $Name ) $S? >";
+
+// Tags for Empty Elements
+String.$EmptyElemTag  = "< ( $Name ) ( (?: $S $Attribute )* ) $S? />";
+
+// Character Reference
+String.$CharRef       = "(?: &#[0-9]+; | &#x[0-9a-fA-F]+; )";
+
+// Entity Reference
+String.$Reference     = "(?: $EntityRef | $CharRef )";
+String.$EntityRef     = "& $Name ;";
+
+// External Entity Declaration
+String.$ExternalID    = "(?: (?: SYSTEM $S ( $SystemLiteral ) ) | " +
+                        "(?: PUBLIC $S ( $PubidLiteral ) $S " +
+                        "( $SystemLiteral ) ) )";
+
+// Encoding Declaration
+String.$EncodingDecl  = "(?: $S encoding $Eq ( ' $EncName ' | " +
+                        "\" $EncName \" ) )";
+String.$EncName       = "[A-Za-z](?: [A-Za-z0-9._]|- )*";
+
+// Characters
+String.$Letter        = "(?: $BaseChar | $Ideographic )";
+  if (Boolean.$I18N != true) { // if i18n.js is included
+String.$BaseChar      = "(?: [\\u0041-\\u005A] | [\\u0061-\\u007A] )";
+String.$Ideographic   = "\\u0000";
+String.$CombiningChar = "\\u0000";
+String.$Digit         = "[\\u0030-\\u0039]";
+String.$Extender      = "\\u0000";
+  }
+
+// compile regular expressions
+RegExp.$prolog       = new RegExp( "^" + String.$prolog.resolve() );
+RegExp.$XMLDecl      = new RegExp( "^" + String.$XMLDecl.resolve() );
+RegExp.$doctypedecl  = new RegExp( "^" + String.$doctypedecl.resolve() );
+RegExp.$STag         = new RegExp( "^" + String.$STag.resolve() );
+RegExp.$ETag         = new RegExp( "^" + String.$ETag.resolve() );
+RegExp.$EmptyElemTag = new RegExp( "^" + String.$EmptyElemTag.resolve() );
+RegExp.$Attribute    = new RegExp( "^" + String.$Attribute.resolve() );
+RegExp.$CDSect       = new RegExp( "^" + String.$CDSect.resolve() );
+RegExp.$CharData     = new RegExp( "^" + String.$CharData.resolve() );
+RegExp.$Reference    = new RegExp( "^" + String.$Reference.resolve() );
+RegExp.$PI           = new RegExp( "^" + String.$PI.resolve() );
+RegExp.$Comment      = new RegExp( "^" + String.$Comment.resolve() );
+RegExp.$Misc         = new RegExp( "^" + String.$Misc.resolve() );
+RegExp.$S            = new RegExp( "^" + String.$S.resolve() );
\ No newline at end of file

Added: incubator/roller/branches/roller_1.x/web/theme/status.jsp
URL: http://svn.apache.org/viewcvs/incubator/roller/branches/roller_1.x/web/theme/status.jsp?rev=327589&view=auto
==============================================================================
--- incubator/roller/branches/roller_1.x/web/theme/status.jsp (added)
+++ incubator/roller/branches/roller_1.x/web/theme/status.jsp Fri Oct 21 14:27:36 2005
@@ -0,0 +1,19 @@
+<%@ include file="/taglibs.jsp" %>
+
+<logic:present name="loggedIn" scope="request" >
+    <fmt:message key="mainPage.loggedInAs" /> [<bean:write name="userName"/>].<br /><br />
+    <html:link forward="logout-redirect"><fmt:message key="navigationBar.logout"/></html:link>
+</logic:present>
+
+
+<logic:present name="allowNewUsers" scope="request" >
+    <html:link forward="login-redirect"><fmt:message key="navigationBar.login"/></html:link><br /><br />
+    <html:link forward="registerUser"><fmt:message key="navigationBar.register"/></html:link>
+</logic:present>
+
+
+<logic:notPresent name="loggedIn">
+    <logic:notPresent name="allowNewUsers">
+    <html:link forward="login-redirect"><fmt:message key="navigationBar.login"/></html:link>
+    </logic:notPresent>
+</logic:notPresent>