Revision 522
Added by Matthias about 17 years ago
trunk/CHANGELOG | ||
---|---|---|
12 | 12 |
|
13 | 13 |
------------------------------------- 2.7.0 ------------------------------------- |
14 | 14 |
09-Jan-2008 Matthias Gallas |
15 |
! Update codepress to Version 0.9.6 |
|
16 |
! Update phplib to Version 7.4a |
|
17 |
09-Jan-2008 Matthias Gallas |
|
15 | 18 |
! Upgrade pclzip to the newer more php5 complaint version 2.6, see ticket #526 |
16 |
09-Jan-2008 Matthias Gallas |
|
17 | 19 |
# Fixed ticket #542 (Thanks to Thorn) |
18 | 20 |
23-Dec-2007 Matthias Gallas |
19 | 21 |
! Changed all copyright notices to include now 2008 |
trunk/wb/include/codepress/codepress.js | ||
---|---|---|
18 | 18 |
self.style.width = self.textarea.clientWidth +'px'; |
19 | 19 |
self.textarea.style.overflow = 'auto'; |
20 | 20 |
self.style.border = '1px solid gray'; |
21 |
self.frameBorder = 0; // remove IE internal iframe border |
|
21 | 22 |
self.style.visibility = 'hidden'; |
22 | 23 |
self.style.position = 'absolute'; |
23 | 24 |
self.options = self.textarea.className; |
... | ... | |
34 | 35 |
self.style.display = 'inline'; |
35 | 36 |
} |
36 | 37 |
|
37 |
self.edit = function(id,language) { |
|
38 |
if(id) self.textarea.value = document.getElementById(id).value; |
|
38 |
// obj can by a textarea id or a string (code) |
|
39 |
self.edit = function(obj,language) { |
|
40 |
if(obj) self.textarea.value = document.getElementById(obj) ? document.getElementById(obj).value : obj; |
|
39 | 41 |
if(!self.textarea.disabled) return; |
40 |
self.language = language ? language : self.options.replace(/ ?codepress ?| ?readonly-on ?| ?autocomplete-off ?| ?linenumbers-off ?/g,''); |
|
41 |
if(!CodePress.languages[self.language]) self.language = 'generic'; |
|
42 |
self.src = CodePress.path+'codepress.html?engine='+CodePress.engine+'&language='+self.language+'&ts='+(new Date).getTime(); |
|
42 |
self.language = language ? language : self.getLanguage(); |
|
43 |
self.src = CodePress.path+'codepress.html?language='+self.language+'&ts='+(new Date).getTime(); |
|
43 | 44 |
if(self.attachEvent) self.attachEvent('onload',self.initialize); |
44 | 45 |
else self.addEventListener('load',self.initialize,false); |
45 | 46 |
} |
46 | 47 |
|
48 |
self.getLanguage = function() { |
|
49 |
for (language in CodePress.languages) |
|
50 |
if(self.options.match('\\b'+language+'\\b')) |
|
51 |
return CodePress.languages[language] ? language : 'generic'; |
|
52 |
} |
|
53 |
|
|
47 | 54 |
self.setOptions = function() { |
48 | 55 |
if(self.options.match('autocomplete-off')) self.toggleAutoComplete(); |
49 | 56 |
if(self.options.match('readonly-on')) self.toggleReadOnly(); |
... | ... | |
63 | 70 |
} |
64 | 71 |
|
65 | 72 |
self.toggleReadOnly = function() { |
66 |
self.textarea.readOnly = (self.textarea.readOnly) ? false : true;
|
|
73 |
self.textarea.readOnly = (self.textarea.readOnly) ? false : true; |
|
67 | 74 |
if(self.style.display != 'none') // prevent exception on FF + iframe with display:none |
68 | 75 |
self.editor.readOnly(self.textarea.readOnly ? true : false); |
69 | 76 |
} |
... | ... | |
94 | 101 |
} |
95 | 102 |
|
96 | 103 |
CodePress.languages = { |
104 |
csharp : 'C#', |
|
97 | 105 |
css : 'CSS', |
98 | 106 |
generic : 'Generic', |
99 | 107 |
html : 'HTML', |
... | ... | |
103 | 111 |
ruby : 'Ruby', |
104 | 112 |
php : 'PHP', |
105 | 113 |
text : 'Text', |
106 |
sql : 'SQL' |
|
114 |
sql : 'SQL', |
|
115 |
vbscript : 'VBScript' |
|
107 | 116 |
} |
108 | 117 |
|
109 |
CodePress.getEngine = function() { |
|
110 |
var engine = 'older'; |
|
111 |
var ua = navigator.userAgent; |
|
112 |
if(ua.match('MSIE')) engine = 'msie'; |
|
113 |
else if(ua.match('KHTML')) engine = 'khtml'; |
|
114 |
else if(ua.match('Opera')) engine = 'opera'; |
|
115 |
else if(ua.match('Gecko')) engine = 'gecko'; |
|
116 |
return engine; |
|
117 |
} |
|
118 | 118 |
|
119 | 119 |
CodePress.run = function() { |
120 |
CodePress.engine = CodePress.getEngine(); |
|
121 | 120 |
s = document.getElementsByTagName('script'); |
122 | 121 |
for(var i=0,n=s.length;i<n;i++) { |
123 | 122 |
if(s[i].src.match('codepress.js')) { |
trunk/wb/include/codepress/codepress.html | ||
---|---|---|
3 | 3 |
<head> |
4 | 4 |
<title>CodePress - Real Time Syntax Highlighting Editor written in JavaScript</title> |
5 | 5 |
<meta name="description" content="CodePress - source code editor window" /> |
6 |
|
|
6 |
|
|
7 | 7 |
<script type="text/javascript"> |
8 |
var L=location.href; |
|
9 |
var d=L.substring(L.indexOf("?")+1); |
|
10 |
var c=v=new Array(); c=d.split("&"); |
|
11 |
for(i=0;i<c.length&&c.length>0;i++) { |
|
12 |
v=c[i].split("="); if(v.length>1) |
|
13 |
eval(v[0]+"=unescape('"+v[1].replace(/\+/g," ")+"')");} |
|
8 |
var language = 'generic'; |
|
9 |
var engine = 'older'; |
|
10 |
var ua = navigator.userAgent; |
|
11 |
var ts = (new Date).getTime(); // timestamp to avoid cache |
|
12 |
var lh = location.href; |
|
14 | 13 |
|
15 |
if(language==null||language=='') language = 'generic'; |
|
16 |
|
|
17 |
ts = (new Date).getTime(); // timestamp to avoid cache |
|
14 |
if(ua.match('MSIE')) engine = 'msie'; |
|
15 |
else if(ua.match('KHTML')) engine = 'khtml'; |
|
16 |
else if(ua.match('Opera')) engine = 'opera'; |
|
17 |
else if(ua.match('Gecko')) engine = 'gecko'; |
|
18 |
|
|
19 |
if(lh.match('language=')) language = lh.replace(/.*language=(.*?)(&.*)?$/,'$1'); |
|
20 |
|
|
18 | 21 |
document.write('<link type="text/css" href="codepress.css?ts='+ts+'" rel="stylesheet" />'); |
19 | 22 |
document.write('<link type="text/css" href="languages/'+language+'.css?ts='+ts+'" rel="stylesheet" id="cp-lang-style" />'); |
20 | 23 |
document.write('<scr'+'ipt type="text/javascript" src="engines/'+engine+'.js?ts='+ts+'"></scr'+'ipt>'); |
... | ... | |
24 | 27 |
</head> |
25 | 28 |
|
26 | 29 |
<script type="text/javascript"> |
27 |
if (engine == "gecko") document.write('<body> </body>'); |
|
28 |
else if(engine == "msie") document.write('<body><pre></pre></body>'); |
|
30 |
if(engine == "msie" || engine == "gecko") document.write('<body><pre> </pre></body>'); |
|
31 |
else if(engine == "opera") document.write('<body></body>'); |
|
32 |
// else if(engine == "khtml") document.write('<body> </body>'); |
|
29 | 33 |
</script> |
30 | 34 |
|
31 | 35 |
</html> |
trunk/wb/include/codepress/codepress.css | ||
---|---|---|
1 |
html {border:none;} /*remove ie frameborder */ |
|
2 |
body {margin-top:13px;_margin-top:14px;background:white;font-family:monospace;font-size:13px;margin-left:32px;white-space:pre;background-image:url("images/line-numbers.png");background-repeat:repeat-y;background-position:0 3px;line-height:16px;} |
|
1 |
body { |
|
2 |
margin-top:13px; |
|
3 |
_margin-top:14px; |
|
4 |
background:white; |
|
5 |
margin-left:32px; |
|
6 |
font-family:monospace; |
|
7 |
font-size:13px; |
|
8 |
white-space:pre; |
|
9 |
background-image:url("images/line-numbers.png"); |
|
10 |
background-repeat:repeat-y; |
|
11 |
background-position:0 3px; |
|
12 |
line-height:16px; |
|
13 |
height:100%; |
|
14 |
} |
|
15 |
pre {margin:0;} |
|
3 | 16 |
html>body{background-position:0 2px;} |
4 | 17 |
P {margin:0;padding:0;border:0;outline:0;display:block;white-space:pre;} |
5 |
b, i, s, u, a, em, tt, ins, big, cite, strong {text-decoration:none;font-weight:normal;font-style:normal;font-size:13px;} |
|
18 |
b, i, s, u, a, em, tt, ins, big, cite, strong, var, dfn {text-decoration:none;font-weight:normal;font-style:normal;font-size:13px;}
|
|
6 | 19 |
|
7 | 20 |
body.hide-line-numbers {background:white;margin-left:16px;} |
8 | 21 |
body.show-line-numbers {background-image:url("images/line-numbers.png");margin-left:32px;} |
trunk/wb/include/phplib/template.inc | ||
---|---|---|
5 | 5 |
* (C) Copyright 1999-2000 NetUSE GmbH |
6 | 6 |
* Kristian Koehntopp |
7 | 7 |
* |
8 |
* $Id: template.inc,v 1.1.1.1 2005/01/30 10:32:06 rdjurovich Exp $
|
|
8 |
* $Id: template.inc,v 1.15 2004/07/23 20:36:29 layne_weathers Exp $
|
|
9 | 9 |
* |
10 | 10 |
*/ |
11 | 11 |
|
... | ... | |
32 | 32 |
* loadfile would try to load a file if the varval had been set to "" (rha) |
33 | 33 |
* in get_undefined, only match non-whitespace in variable tags as in finish (Layne Weathers & rha) |
34 | 34 |
* more elegant fix to the problem of subst stripping '$n', '\n' and '\\' strings (rha) |
35 |
* parse uses get_var to obtain return value (Jordi via SF) |
|
36 |
* set_block reports an error if the block could not be extracted (rha) |
|
37 |
* filename is now windows-pathname aware (krabu @ SF) |
|
35 | 38 |
* |
36 | 39 |
* |
37 | 40 |
* Changes in functionality which go beyond bug fixes: |
38 | 41 |
* |
42 |
* added ability for filename comments to be output (from phplib-users layne) |
|
39 | 43 |
* changed debug handling so set, get and internals can be tracked separately (rha) |
40 | 44 |
* added debug statements throughout to track most function calls (rha) |
41 | 45 |
* debug output contained raw HTML -- is now escaped with htmlentities (rha) |
... | ... | |
85 | 89 |
var $debug = false; |
86 | 90 |
|
87 | 91 |
/** |
92 |
* Determines whether Template outputs filename comments. |
|
93 |
* false = no filename outputs |
|
94 |
* true = HTML comments (e.g. <!-- START FILE $filename -->) placed in output |
|
95 |
* |
|
96 |
* @var int |
|
97 |
* @access public |
|
98 |
*/ |
|
99 |
var $filename_comments = false; |
|
100 |
|
|
101 |
/** |
|
102 |
* Determines the regular expression used to find unknown variable tags. |
|
103 |
* "loose" = traditional match all curly braces with no whitespace between |
|
104 |
* "strict" = adopts PHP's variable naming rules |
|
105 |
* ("loose" has a nasty habit of deleting JavaScript RegEx components) |
|
106 |
* (should future major version releases of PHPLib default this "strict"?) |
|
107 |
* |
|
108 |
* @var string |
|
109 |
* @access public |
|
110 |
*/ |
|
111 |
var $unknown_regexp = "loose"; |
|
112 |
|
|
113 |
/** |
|
88 | 114 |
* The base directory from which template files are loaded. |
89 | 115 |
* |
90 | 116 |
* @var string |
... | ... | |
194 | 220 |
* @return boolean |
195 | 221 |
*/ |
196 | 222 |
function set_root($root) { |
223 |
if(ereg('/$', $root)) { |
|
224 |
$root = substr($root, 0, -1); |
|
225 |
} |
|
197 | 226 |
if ($this->debug & 4) { |
198 | 227 |
echo "<p><b>set_root:</b> root = $root</p>\n"; |
199 | 228 |
} |
... | ... | |
266 | 295 |
$this->file[$varname] = $this->filename($filename); |
267 | 296 |
} else { |
268 | 297 |
reset($varname); |
269 |
while(list($v, $f) = each($varname)) { |
|
298 |
while (list($v, $f) = each($varname)) {
|
|
270 | 299 |
if ($this->debug & 4) { |
271 | 300 |
echo "<p><b>set_file:</b> (with array) varname = $v, filename = $f</p>\n"; |
272 | 301 |
} |
... | ... | |
316 | 345 |
$str = $this->get_var($parent); |
317 | 346 |
$reg = "/[ \t]*<!--\s+BEGIN $varname\s+-->\s*?\n?(\s*.*?\n?)\s*<!--\s+END $varname\s+-->\s*?\n?/sm"; |
318 | 347 |
preg_match_all($reg, $str, $m); |
319 |
$str = preg_replace($reg, "{" . "$name}", $str); |
|
348 |
if (!isset($m[1][0])) { |
|
349 |
$this->halt("set_block: unable to set block $varname."); |
|
350 |
return false; |
|
351 |
} |
|
352 |
$str = preg_replace($reg, "{" . $name . "}", $str); |
|
320 | 353 |
$this->set_var($varname, $m[1][0]); |
321 | 354 |
$this->set_var($parent, $str); |
322 | 355 |
return true; |
... | ... | |
364 | 397 |
} |
365 | 398 |
} else { |
366 | 399 |
reset($varname); |
367 |
while(list($k, $v) = each($varname)) { |
|
400 |
while (list($k, $v) = each($varname)) {
|
|
368 | 401 |
if (!empty($k)) { |
369 | 402 |
if ($this->debug & 1) { |
370 | 403 |
printf("<b>set_var:</b> (with array) <b>%s</b> = '%s'<br>\n", $k, htmlentities($v)); |
... | ... | |
410 | 443 |
} |
411 | 444 |
} else { |
412 | 445 |
reset($varname); |
413 |
while(list($k, $v) = each($varname)) { |
|
446 |
while (list($k, $v) = each($varname)) {
|
|
414 | 447 |
if (!empty($v)) { |
415 | 448 |
if ($this->debug & 1) { |
416 | 449 |
printf("<b>clear_var:</b> (with array) <b>%s</b><br>\n", $v); |
... | ... | |
452 | 485 |
} |
453 | 486 |
} else { |
454 | 487 |
reset($varname); |
455 |
while(list($k, $v) = each($varname)) { |
|
488 |
while (list($k, $v) = each($varname)) {
|
|
456 | 489 |
if (!empty($v)) { |
457 | 490 |
if ($this->debug & 1) { |
458 | 491 |
printf("<b>unset_var:</b> (with array) <b>%s</b><br>\n", $v); |
... | ... | |
492 | 525 |
|
493 | 526 |
// quote the replacement strings to prevent bogus stripping of special chars |
494 | 527 |
reset($this->varvals); |
495 |
while(list($k, $v) = each($this->varvals)) { |
|
528 |
while (list($k, $v) = each($this->varvals)) {
|
|
496 | 529 |
$varvals_quoted[$k] = preg_replace(array('/\\\\/', '/\$/'), array('\\\\\\\\', '\\\\$'), $v); |
497 | 530 |
} |
498 | 531 |
|
... | ... | |
578 | 611 |
} |
579 | 612 |
} else { |
580 | 613 |
reset($varname); |
581 |
while(list($i, $v) = each($varname)) { |
|
614 |
while (list($i, $v) = each($varname)) {
|
|
582 | 615 |
if ($this->debug & 4) { |
583 | 616 |
echo "<p><b>parse:</b> (with array) target = $target, i = $i, varname = $v, append = $append</p>\n"; |
584 | 617 |
} |
... | ... | |
594 | 627 |
if ($this->debug & 4) { |
595 | 628 |
echo "<p><b>parse:</b> completed</p>\n"; |
596 | 629 |
} |
597 |
return $str;
|
|
630 |
return $this->get_var($target);
|
|
598 | 631 |
} |
599 | 632 |
|
600 | 633 |
|
... | ... | |
644 | 677 |
echo "<p><b>get_vars:</b> constructing array of vars...</p>\n"; |
645 | 678 |
} |
646 | 679 |
reset($this->varkeys); |
647 |
while(list($k, $v) = each($this->varkeys)) { |
|
680 |
while (list($k, $v) = each($this->varkeys)) {
|
|
648 | 681 |
$result[$k] = $this->get_var($k); |
649 | 682 |
} |
650 | 683 |
return $result; |
... | ... | |
682 | 715 |
return $str; |
683 | 716 |
} else { |
684 | 717 |
reset($varname); |
685 |
while(list($k, $v) = each($varname)) { |
|
718 |
while (list($k, $v) = each($varname)) {
|
|
686 | 719 |
if (isset($this->varvals[$v])) { |
687 | 720 |
$str = $this->varvals[$v]; |
688 | 721 |
} else { |
... | ... | |
719 | 752 |
return false; |
720 | 753 |
} |
721 | 754 |
|
722 |
preg_match_all("/{([^ \t\r\n}]+)}/", $this->get_var($varname), $m); |
|
755 |
preg_match_all( |
|
756 |
(("loose" == $this->unknown_regexp) ? "/{([^ \t\r\n}]+)}/" : "/{([_a-zA-Z]\\w+)}/"), |
|
757 |
$this->get_var($varname), |
|
758 |
$m); |
|
723 | 759 |
$m = $m[1]; |
724 | 760 |
if (!is_array($m)) { |
725 | 761 |
return false; |
726 | 762 |
} |
727 | 763 |
|
728 | 764 |
reset($m); |
729 |
while(list($k, $v) = each($m)) { |
|
765 |
while (list($k, $v) = each($m)) {
|
|
730 | 766 |
if (!isset($this->varkeys[$v])) { |
731 | 767 |
if ($this->debug & 4) { |
732 | 768 |
echo "<p><b>get_undefined:</b> undefined: $v</p>\n"; |
... | ... | |
762 | 798 |
break; |
763 | 799 |
|
764 | 800 |
case "remove": |
765 |
$str = preg_replace('/{[^ \t\r\n}]+}/', "", $str); |
|
801 |
$str = preg_replace( |
|
802 |
(("loose" == $this->unknown_regexp) ? "/{([^ \t\r\n}]+)}/" : "/{([_a-zA-Z]\\w+)}/"), |
|
803 |
"", |
|
804 |
$str); |
|
766 | 805 |
break; |
767 | 806 |
|
768 | 807 |
case "comment": |
769 |
$str = preg_replace('/{([^ \t\r\n}]+)}/', "<!-- Template variable \\1 undefined -->", $str); |
|
808 |
$str = preg_replace( |
|
809 |
(("loose" == $this->unknown_regexp) ? "/{([^ \t\r\n}]+)}/" : "/{([_a-zA-Z]\\w+)}/"), |
|
810 |
"<!-- Template variable \\1 undefined -->", |
|
811 |
$str); |
|
770 | 812 |
break; |
771 | 813 |
} |
772 | 814 |
|
... | ... | |
829 | 871 |
if ($this->debug & 4) { |
830 | 872 |
echo "<p><b>filename:</b> filename = $filename</p>\n"; |
831 | 873 |
} |
832 |
if (substr($filename, 0, 1) != "/") { |
|
874 |
if (substr($filename, 0, 1) != "/" |
|
875 |
&& substr($filename, 0, 1) != "\\" |
|
876 |
&& substr($filename, 1, 2) != ":\\" |
|
877 |
&& substr($filename, 1, 2) != ":/" |
|
878 |
) { |
|
833 | 879 |
$filename = $this->root."/".$filename; |
834 | 880 |
} |
835 | 881 |
|
... | ... | |
853 | 899 |
* @return string |
854 | 900 |
*/ |
855 | 901 |
function varname($varname) { |
856 |
return preg_quote("{".$varname."}");
|
|
902 |
return preg_quote("{" . $varname . "}");
|
|
857 | 903 |
} |
858 | 904 |
|
859 | 905 |
|
... | ... | |
907 | 953 |
return false; |
908 | 954 |
} |
909 | 955 |
|
956 |
if ($this->filename_comments) { |
|
957 |
$str = "<!-- START FILE $filename -->\n$str<!-- END FILE $filename -->\n"; |
|
958 |
} |
|
910 | 959 |
if ($this->debug & 4) { |
911 | 960 |
printf("<b>loadfile:</b> loaded $filename into $varname<br>\n"); |
912 | 961 |
} |
Also available in: Unified diff
- Update codepress to Version 0.9.6
- Update phplib to Version 7.4a