1/** 2 * SyntaxHighlighter 3 * http://alexgorbatchev.com/SyntaxHighlighter 4 * 5 * SyntaxHighlighter is donationware. If you are using it, please donate. 6 * http://alexgorbatchev.com/SyntaxHighlighter/donate.html 7 * 8 * @version 9 * 3.0.90 (Sat, 18 Jun 2016 21:01:41 GMT) 10 * 11 * @copyright 12 * Copyright (C) 2004-2013 Alex Gorbatchev. 13 * 14 * @license 15 * Dual licensed under the MIT and GPL licenses. 16 */ 17;(function() 18{ 19 // CommonJS 20 SyntaxHighlighter = SyntaxHighlighter || (typeof require !== 'undefined'? require('shCore').SyntaxHighlighter : null); 21 22 function Brush() 23 { 24 function getKeywordsCSS(str) 25 { 26 return '\\b([a-z_]|)' + str.replace(/ /g, '(?=:)\\b|\\b([a-z_\\*]|\\*|)') + '(?=:)\\b'; 27 }; 28 29 function getValuesCSS(str) 30 { 31 return '\\b' + str.replace(/ /g, '(?!-)(?!:)\\b|\\b()') + '\:\\b'; 32 }; 33 34 var keywords = 'ascent azimuth background-attachment background-color background-image background-position ' + 35 'background-repeat background baseline bbox border-collapse border-color border-spacing border-style border-top ' + 36 'border-right border-bottom border-left border-top-color border-right-color border-bottom-color border-left-color ' + 37 'border-top-style border-right-style border-bottom-style border-left-style border-top-width border-right-width ' + 38 'border-bottom-width border-left-width border-width border bottom cap-height caption-side centerline clear clip color ' + 39 'content counter-increment counter-reset cue-after cue-before cue cursor definition-src descent direction display ' + 40 'elevation empty-cells float font-size-adjust font-family font-size font-stretch font-style font-variant font-weight font ' + 41 'height left letter-spacing line-height list-style-image list-style-position list-style-type list-style margin-top ' + 42 'margin-right margin-bottom margin-left margin marker-offset marks mathline max-height max-width min-height min-width orphans ' + 43 'outline-color outline-style outline-width outline overflow padding-top padding-right padding-bottom padding-left padding page ' + 44 'page-break-after page-break-before page-break-inside pause pause-after pause-before pitch pitch-range play-during position ' + 45 'quotes right richness size slope src speak-header speak-numeral speak-punctuation speak speech-rate stemh stemv stress ' + 46 'table-layout text-align top text-decoration text-indent text-shadow text-transform unicode-bidi unicode-range units-per-em ' + 47 'vertical-align visibility voice-family volume white-space widows width widths word-spacing x-height z-index'; 48 49 var values = 'above absolute all always aqua armenian attr aural auto avoid baseline behind below bidi-override black blink block blue bold bolder '+ 50 'both bottom braille capitalize caption center center-left center-right circle close-quote code collapse compact condensed '+ 51 'continuous counter counters crop cross crosshair cursive dashed decimal decimal-leading-zero default digits disc dotted double '+ 52 'embed embossed e-resize expanded extra-condensed extra-expanded fantasy far-left far-right fast faster fixed format fuchsia '+ 53 'gray green groove handheld hebrew help hidden hide high higher icon inline-table inline inset inside invert italic '+ 54 'justify landscape large larger left-side left leftwards level lighter lime line-through list-item local loud lower-alpha '+ 55 'lowercase lower-greek lower-latin lower-roman lower low ltr marker maroon medium message-box middle mix move narrower '+ 56 'navy ne-resize no-close-quote none no-open-quote no-repeat normal nowrap n-resize nw-resize oblique olive once open-quote outset '+ 57 'outside overline pointer portrait pre print projection purple red relative repeat repeat-x repeat-y rgb ridge right right-side '+ 58 'rightwards rtl run-in screen scroll semi-condensed semi-expanded separate se-resize show silent silver slower slow '+ 59 'small small-caps small-caption smaller soft solid speech spell-out square s-resize static status-bar sub super sw-resize '+ 60 'table-caption table-cell table-column table-column-group table-footer-group table-header-group table-row table-row-group teal '+ 61 'text-bottom text-top thick thin top transparent tty tv ultra-condensed ultra-expanded underline upper-alpha uppercase upper-latin '+ 62 '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'; 63 64 var fonts = '[mM]onospace [tT]ahoma [vV]erdana [aA]rial [hH]elvetica [sS]ans-serif [sS]erif [cC]ourier mono sans serif'; 65 66 this.regexList = [ 67 { regex: SyntaxHighlighter.regexLib.multiLineCComments, css: 'comments' }, // multiline comments 68 { regex: SyntaxHighlighter.regexLib.doubleQuotedString, css: 'string' }, // double quoted strings 69 { regex: SyntaxHighlighter.regexLib.singleQuotedString, css: 'string' }, // single quoted strings 70 { regex: /\#[a-fA-F0-9]{3,6}/g, css: 'value' }, // html colors 71 { regex: /(-?\d+)(\.\d+)?(px|em|pt|\:|\%|)/g, css: 'value' }, // sizes 72 { regex: /!important/g, css: 'color3' }, // !important 73 { regex: new RegExp(getKeywordsCSS(keywords), 'gm'), css: 'keyword' }, // keywords 74 { regex: new RegExp(getValuesCSS(values), 'g'), css: 'value' }, // values 75 { regex: new RegExp(this.getKeywords(fonts), 'g'), css: 'color1' } // fonts 76 ]; 77 78 this.forHtmlScript({ 79 left: /(<|<)\s*style.*?(>|>)/gi, 80 right: /(<|<)\/\s*style\s*(>|>)/gi 81 }); 82 }; 83 84 Brush.prototype = new SyntaxHighlighter.Highlighter(); 85 Brush.aliases = ['css']; 86 87 SyntaxHighlighter.brushes.CSS = Brush; 88 89 // CommonJS 90 typeof(exports) != 'undefined' ? exports.Brush = Brush : null; 91})(); 92