/**
 * SyntaxHighlighter
 * http://alexgorbatchev.com/
 *
 * SyntaxHighlighter is donationware. If you are using it, please donate.
 * http://alexgorbatchev.com/wiki/SyntaxHighlighter:Donate
 *
 * @version
 * 2.1.364 (October 15 2009)
 * 
 * @copyright
 * Copyright (C) 2004-2009 Alex Gorbatchev.
 *
 * @license
 * This file is part of SyntaxHighlighter.
 * 
 * SyntaxHighlighter 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 3 of the License, or
 * (at your option) any later version.
 * 
 * SyntaxHighlighter is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with SyntaxHighlighter.  If not, see <http://www.gnu.org/copyleft/lesser.html>.
 */
SyntaxHighlighter.brushes.VisualForce = function()
{
	function getKeywordsCSS(str)
	{
		return '\\b([a-z_]|)' + str.replace(/ /g, '(?=:)\\b|\\b([a-z_\\*]|\\*|)') + '(?=:)\\b';
	};
	
	function getValuesCSS(str)
	{
		return '\\b' + str.replace(/ /g, '(?!-)(?!:)\\b|\\b()') + '\:\\b';
	};

	var keywords =	'ascent azimuth background-attachment background-color background-image background-position ' +
					'background-repeat background baseline bbox border-collapse border-color border-spacing border-style border-top ' +
					'border-right border-bottom border-left border-top-color border-right-color border-bottom-color border-left-color ' +
					'border-top-style border-right-style border-bottom-style border-left-style border-top-width border-right-width ' +
					'border-bottom-width border-left-width border-width border bottom cap-height caption-side centerline clear clip color ' +
					'content counter-increment counter-reset cue-after cue-before cue cursor definition-src descent direction display ' +
					'elevation empty-cells float font-size-adjust font-family font-size font-stretch font-style font-variant font-weight font ' +
					'height left letter-spacing line-height list-style-image list-style-position list-style-type list-style margin-top ' +
					'margin-right margin-bottom margin-left margin marker-offset marks mathline max-height max-width min-height min-width orphans ' +
					'outline-color outline-style outline-width outline overflow padding-top padding-right padding-bottom padding-left padding page ' +
					'page-break-after page-break-before page-break-inside pause pause-after pause-before pitch pitch-range play-during position ' +
					'quotes right richness size slope src speak-header speak-numeral speak-punctuation speak speech-rate stemh stemv stress ' +
					'table-layout text-align top text-decoration text-indent text-shadow text-transform unicode-bidi unicode-range units-per-em ' +
					'vertical-align visibility voice-family volume white-space widows width widths word-spacing x-height z-index';

	var values =	'above absolute all always aqua armenian attr aural auto avoid baseline behind below bidi-override black blink block blue bold bolder '+
					'both bottom braille capitalize caption center center-left center-right circle close-quote code collapse compact condensed '+
					'continuous counter counters crop cross crosshair cursive dashed decimal decimal-leading-zero default digits disc dotted double '+
					'embed embossed e-resize expanded extra-condensed extra-expanded fantasy far-left far-right fast faster fixed format fuchsia '+
					'gray green groove handheld hebrew help hidden hide high higher icon inline-table inline inset inside invert italic '+
					'justify landscape large larger left-side left leftwards level lighter lime line-through list-item local loud lower-alpha '+
					'lowercase lower-greek lower-latin lower-roman lower low ltr marker maroon medium message-box middle mix move narrower '+
					'navy ne-resize no-close-quote none no-open-quote no-repeat normal nowrap n-resize nw-resize oblique olive once open-quote outset '+
					'outside overline pointer portrait pre print projection purple red relative repeat repeat-x repeat-y rgb ridge right right-side '+
					'rightwards rtl run-in screen scroll semi-condensed semi-expanded separate se-resize show silent silver slower slow '+
					'small small-caps small-caption smaller soft solid speech spell-out square s-resize static status-bar sub super sw-resize '+
					'table-caption table-cell table-column table-column-group table-footer-group table-header-group table-row table-row-group teal '+
					'text-bottom text-top thick thin top transparent tty tv ultra-condensed ultra-expanded underline upper-alpha uppercase upper-latin '+
					'upper-roman url visible wait white wider w-resize x-fast x-high x-large x-loud x-low x-slow x-small x-soft xx-large xx-small yellow';

	var Apexkeywords =	'abstract assert boolean break byte case catch char class const ' +
				'continue default do double else enum extends ' +
				'false final finally float for goto if implements import ' +
				'instanceof int interface long native new null ' +
				'package private protected public return ' +
				'short static strictfp super switch synchronized this throw throws true ' +
				'transient try void volatile while testMethod List get System search Database String ' +
				'SELECT FROM WHERE INSERT UPDATE UPSERT IN GROUP BY ORDER ' +
				'Select From Where Insert Update Upsert In Group By Order ' +
				'select from where insert update upsert in group by order ';
	
	var fonts =		'[mM]onospace [tT]ahoma [vV]erdana [aA]rial [hH]elvetica [sS]ans-serif [sS]erif [cC]ourier mono sans serif';
	
	this.regexList = [
		{ regex: /\/\*([^\*][\s\S]*)?\*\//gm, css: 'comments' }, // multiline comments
		{ regex: SyntaxHighlighter.regexLib.doubleQuotedString,	css: 'attrString' },		// VF tags
		{ regex: SyntaxHighlighter.regexLib.singleQuotedString,	css: 'attrString' },		// VF tags
		{ regex: /\s([a-zA-Z]*?(=))/g, css: 'attr' },		// VF attribute tags
		{ regex: /<!--.*?-->/g, css: 'htmlComments' }, // HTML comments </c:
		{ regex: /(c\:)[a-zA-Z0-9]*/g, css: 'vfTag' }, // </c:
		{ regex: /(<apex\:)[a-zA-Z0-9]*/g, css: 'vfTag'},
		{ regex: /(&lt;apex\:)[a-zA-Z0-9]*/g, css: 'vfTag'},
		{ regex: /(<\/apex\:)[a-zA-Z0-9]*/g, css: 'vfTag'},
		{ regex: /(&lt;\/apex\:)[a-zA-Z0-9]*/g, css: 'vfTag'},
		{ regex: /\>/g, css: 'vfTag'},
		{ regex: /\&gt;/g, css: 'vfTag'},
		{ regex: SyntaxHighlighter.regexLib.multiLineCComments,	css: 'comments' },	// multiline comments
		{ regex: /\#[a-fA-F0-9]{3,6}/g,	css: 'value' },		// html colors
		{ regex: /(-?\d+)(\.\d+)?(px|em|pt|\:|\%|)/g, css: 'value' },		// sizes
		{ regex: /!important/g,	css: 'color3' },	// !important
		{ regex: new RegExp(getKeywordsCSS(keywords), 'gm'), css: 'keyword' },	// keywords
		{ regex: new RegExp(getValuesCSS(values), 'g'),	css: 'value' },		// values
		{ regex: new RegExp(this.getKeywords(fonts), 'g'), css: 'color1' },		// fonts
		{ regex: /(<|(<\/))(a|abbr|acronym|address|area|b|base|bdo|big|blockquote|body|br|button|caption|center|cite|code|col|colgroup|dd|del|dfn|dir|div|dl|dt|em|fieldset|fieldset|form|frame|frameset|h1|h2|h3|h4|h5|h6|head|hr|html|i|iframe|img|input|ins|isindex|kbd|label|legend|li|link|map|menu|meta|noframes|noscript|object|ol|optgroup|option|p|param|pre|q|s|samp|script|select|small|span|strike|strong|style|sub|sup|table|tbody|td|textarea|tfoot|th|thead|title|tr|tt|u|ul|var|)(>|\s)/g,	css: 'htmlTag' },		// HTML tags
		{ regex: /(&lt;|(&lt;\/))(a|abbr|acronym|address|area|b|base|bdo|big|blockquote|body|br|button|caption|center|cite|code|col|colgroup|dd|del|dfn|dir|div|dl|dt|em|fieldset|fieldset|form|frame|frameset|h1|h2|h3|h4|h5|h6|head|hr|html|i|iframe|img|input|ins|isindex|kbd|label|legend|li|link|map|menu|meta|noframes|noscript|object|ol|optgroup|option|p|param|pre|q|s|samp|script|select|small|span|strike|strong|style|sub|sup|table|tbody|td|textarea|tfoot|th|thead|title|tr|tt|u|ul|var|)(&gt;|\s)/g,	css: 'htmlTag' },		// HTML tags END TAG
		{ regex: SyntaxHighlighter.regexLib.singleLineCComments,	css: 'apexComments' },		// one line comments
		{ regex: /\/\*([^\*][\s\S]*)?\*\//gm,						css: 'apexComments' },	 	// multiline comments
		{ regex: /\/\*(?!\*\/)\*[\s\S]*?\*\//gm,					css: 'apexDocumentation' },	// documentation comments
		{ regex: /\b([\d]+(\.[\d]+)?|0x[a-f0-9]+)\b/gi,				css: 'value' },			// numbers
		{ regex: /(?!\@interface\b)\@[\$\w]+\b/g,					css: 'color1' },		// annotation @anno
		{ regex: /\@interface\b/g,									css: 'color2' },		// @interface keyword
		{ regex: /[a-zA-Z-_]{1}[a-zA-Z0-9-_]*__c/g,					css: 'apexObjects' },	// Objects color
		{ regex: new RegExp(this.getKeywords(Apexkeywords), 'gm'),		css: 'apexKey' }		// Apex keywords
		];

	this.forHtmlScript({
		left	: /(&lt;|<)%[@!=]?/g, 
		right	: /%(&gt;|>)/g 
	});
};

SyntaxHighlighter.brushes.VisualForce.prototype	= new SyntaxHighlighter.Highlighter();
SyntaxHighlighter.brushes.VisualForce.aliases		= ['VisualForce'];

