/[health_html]/inc/global.php
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /inc/global.php

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.5 by ravilov, Thu Aug 16 09:08:42 2001 UTC revision 1.19 by ravilov, Tue Oct 23 16:13:59 2001 UTC
# Line 1  Line 1 
1  <?php  <?php
2          function MyEscape($str) {  
3                  $allowed = array("", "B", "I", "U", "UL", "OL", "LI");          function MyUpper($str) {
4                  $str = preg_replace("/(\<\/?\s*(\w+)>[^\>]*\>)/e",                  return strtr(strtoupper($str), "", "Ʈ");
5                          "array_search(strtoupper('\\2'),\$allowed,false)?'\\1':HTMLSpecialChars('\\1')",          }
6                          $str);  
7                  $str = preg_replace("/(^\s+|\s+$)/", "", $str);          function MyLower($str) {
8                  $str = ereg_replace("\"", "&quot;", $str);                  return strtr(strtolower($str), "Ʈ", "");
9            }
10    
11            function Letters() { return "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; }
12    
13            function Slova($alpha_only = false) {
14                    $sl = preg_split('//', Letters());
15                    array_shift($sl);       // First element is empty.
16                    array_pop($sl);         // Last element is empty.
17                    if (!$alpha_only) array_unshift($sl, "@");
18                    return $sl;
19            }
20    
21            function MyCompare($a, $b) {
22                    $slova = Letters();
23                    $weights = "\x14\x15\x16\x17\x18\x19\x1A\x1B\x1C\x1D\x1E\x1F\x20\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2A\x2B\x2C\x2D\x2E\x2F\x30\x31\x32";
24                    return strcasecmp(strtr(MyUpper($a), $slova, $weights),
25                            strtr(MyUpper($b), $slova, $weights));
26            }
27    
28            function my_replace($str, $start, $end, $pat = "", $rep = "") {
29                    if (!$pat) $pat = '\s*(\r\n?|\n\r?)';
30                    $idx1 = $idx2 = -1;
31                    while (true) {
32                            $str2 = strtoupper($str);
33                            $idx1 = strpos($str2, $start, $idx1 + 1);
34                            if ($idx1 === false) break;
35                            $idx2 = strpos($str2, $end, $idx2 + 1);
36                            if ($idx2 === false) break;
37                            if ($idx1 > $idx2) break;
38                            $idx2 += strlen($end);
39                            $str1 = substr($str, 0, $idx1);
40                            $str2 = preg_replace('/'.$pat.'/m', $rep,
41                                    substr($str, $idx1, $idx2 - $idx1));
42                            $str3 = substr($str, $idx2, strlen($str) - $idx2);
43                            $str = $str1.$str2.$str3;
44                    }
45                  return $str;                  return $str;
46          }          }
47          function ParseNewline($str) {  
48                  if (!$str) return $str;          function MyEscape($str, $full = false) {
49                  $str = preg_replace('/\s*(\r\n\r\n|\n\r\n\r|\n\n|\r\r)/m', '</p> <p class="ptext">', $str);                  if ($full) {
50                  $str = preg_replace('/\s*(\r\n|\n\r|\r|\n)/m', '<br>', $str);                          $str = str_replace("&", "&amp;", $str);
51                            $str = str_replace("<", "&lt;", $str);
52                            $str = str_replace(">", "&gt;", $str);
53                    }
54                    $allowed = array("", "A", "B", "I", "U", "UL", "OL", "LI", "TABLE", "TR", "TH", "TD", "HR", "SUP", "SUB");
55                    $str = preg_replace('/(^[       ]+|[    ]+$)/m', '', $str);
56                    $str = preg_replace('/(\<\/?\s*(\w+)\\b[^\>]*\>)/e', 'array_search(MyUpper("\2"),'.
57                            '\$allowed,false)?"\1":HTMLSpecialChars("\1")', $str);
58                    if (!$full) {
59                            $str = preg_replace('/(\<\s*TABLE\b)/i', '\\1 class=normal', $str);
60                            $str = preg_replace('/(\<\s*A\b)/i', '\\1 class=underlined target=_blank', $str);
61                            $str = preg_replace('/(class=[^         ]+)( class=[^   ]+)+/', '\\1', $str);
62                            $str = preg_replace('/(class=[^         ]+ target=_blank)( class=[^     ]+ target=_blank)+/', '\\1', $str);
63                    }
64                    $str = my_replace($str, "<TABLE", "/TABLE>");
65                    $str = my_replace($str, "<UL", "/UL>", true);
66                    $str = my_replace($str, "<OL", "/OL>");
67                    if (!$full) $str = my_replace($str, "<", ">", '"', "'|'");
68                    $str = str_replace('"', "&quot;", $str);
69                    if (!$full) $str = str_replace("'|'", '"', $str);
70                  return $str;                  return $str;
71          }          }
72          function MyQuote($str) {  
73                  global $dbh;          function ParseNewline($str, $paragraphs = false) {
74                  if (!$dbh) return "'$str'";                  if (!$str) return $str;
75                  return $dbh->quote($str);                  $str = str_replace("\r\n", "\n", $str);
76          }                  if ($paragraphs) $str = preg_replace('/[        ]*\n\n/s', ' </p><p class="ptext">', $str);
77          function MyMove($src, $dest) {                  $str = preg_replace('/[         ]*\n/s', '<br>'."\n", $str);
78                  $cmd = "mv -f '".EscapeShellCmd($src)."' '".EscapeShellCmd($dest)."'";                  return $str;
                 return exec($cmd);  
         }  
         function MyDelete($src) {  
                 @unlink($src);  
79          }          }
80    
81          function error($msg) {          function error($msg) {
82                  if (is_array($msg)) $msg = implode(" ", $msg);                  if (is_array($msg)) $msg = implode(" ", $msg);
83                  echo "<BR>\n<FONT COLOR=\"#FF0000\">[".HTMLSpecialChars($msg).                  echo "<BR>\n<FONT COLOR=\"#FF0000\">[".HTMLSpecialChars($msg)."]</FONT><BR>\n";
                         "]</FONT><BR>\n";  
84          }          }
85          function PicSize($pic) {  
86                  global $syspicdir;          function convert_html($str) {
87                  $ret = array(0, 0);                  $entities = array(
88                  if ($pic) {                          "nbsp" => " ", "#160" => " ",   # nbsp
89                          @$size = GetImageSize($syspicdir."/".$pic);                          "amp" => " ", "#38" => " ",     # amp
90                          $ret = array($size[0], $size[1]);                          "quot" => "\"", "#34" => "\"",  # quot
91                  }                          "lt" => "<", "#60" => "<",      # lt
92                  return $ret;                          "gt" => ">", "#62" => ">",      # gt
93                            "Scaron" => "", "#352" => "",
94                            "scaron" => "", "#353" => "",
95                            "Ccaron" => "", "#268" => "", "#268" => "",
96                            "ccaron" => "", "egrave" => "", "#232" => "", "#269" => "",
97                            "Cgrave" => "", "#262" => "", "#" => "",
98                            "cgrave" => "", "aelig" => "", "#230" => "", "#263" => "",
99                            "<?>" => "", "#272" => "", "#" => "",
100                            "<?>" => "", "eth" => "", "#273" => "",
101                            "Zcaron" => "", "#381" => "",
102                            "zcaron" => "", "#382" => "",
103                    );
104                    # Skip if not a scalar
105                    if (!is_string($str)) return $str;
106                    # If a number, don't touch it
107                    if (strcmp(intval($str)."", $str."") == 0) return $str;
108    
109                    # Replace "``", "''", "<<" and ">>" with """ (normal ASCII double quote)
110                    $str = str_replace("", '"', $str);
111                    $str = str_replace("", '"', $str);
112                    $str = str_replace("", '"', $str);
113                    $str = str_replace("", '"', $str);
114                    # Replace "-" with "-"
115                    $str = str_replace("", '-', $str);
116                    # Replace character references ("&...;" and "&#...;") with its value
117                    $str = preg_replace('/\&([^;]+);/em', '$entities["$1"]?$entities["$1"]:"?"', $str);
118                    # Remove all whitespace from line beginnings and endings
119                    $str = preg_replace('/(^[       ]+|[    ]+$)/s', '', $str);
120                    # Remove "<P>[whitespace]</P>"
121                    $str = preg_replace('/\<\s*P[^\>]*\>\s*\<\/\s*P\s*\>/im', "", $str);
122                    # Replace "<BR>\n" with "\n"
123                    $str = preg_replace('/\<[       ]*BR[^\>]*\>([\n\r]+)/im', '$1', $str);
124                    # Replace "<P>" with "\n"
125                    $str = preg_replace('/\<\s*P[^\>]*\>/im', "", $str);
126                    # Replace "</P>" with "\n"
127                    $str = preg_replace('/\<\/\s*P[^\>]*\>/im', "\n", $str);
128                    # Replace "<BR>" with "\n"
129                    $str = preg_replace('/\<BR\>/im', "\n", $str);
130                    # Replace "<...>\n" with "\n<...>"
131                    $str = preg_replace('/(\<[^\/][^\>]*\>)[        ]*([\r\n]*)[    ]*/m', '$2$1', $str);
132                    # Replace "\n</...>" with "</...>\n"
133                    $str = preg_replace('/[         ]*([\n\r]*)[    ]*(\<\/[^\>]+\>)/m', '$2$1', $str);
134                    # Remove "<HEAD>" and "</HEAD>", and anything in between.
135                    $str = preg_replace('/\<\s*HEAD[^\>]*\>.*\<\/\s*HEAD\s*\>(\r\n?|\n\r?)*/ims', '', $str);
136                    # Remove all "<HTML>", "<HEAD>", "<BODY>" and "<FONT>" tags, along with their pairs
137                    $str = preg_replace('/\<\/?\s*(HTML|HEAD|BODY|FONT|DIR)[^\>]*\>/im', '', $str);
138                    # Remove all table elements "<TABLE>", "<TR>", "<TH>", "<TD>")
139                    #$str = preg_replace('/\<\/?\s*(TABLE|TR|TH|TD)[^\>]*\>/im', '', $str);
140                    # Replace "\n<LI>" or "<LI>\n" with "<LI>"
141                    $str = preg_replace('/([        ]*[\r\n]*)(\<\/?\s*(LI|UL|OL)[  ]*\>)([         ]*[\r\n]*)/m', '$2', $str);
142                    # Replace "<UL>\n" or "<OL>\n" with "<UL>" or "<OL>", respectively
143                    $str = preg_replace('/(\<\s*(UL|OL)\s*\>)([     ]*(\r\n?|\n\r?))+/m', '$1', $str);
144                    # Replace "\n</UL>" or "\n</OL>" with "</UL>" or "</OL>", respectively
145                    $str = preg_replace('/([        ]*(\r\n?|\n\r?))+(\<\/\s*(UL|OL)\s*\>)/m', '$3', $str);
146                    # Replace "<[whitespace]/>" with "</"
147                    $str = preg_replace('/\<\s*\//', '</', $str);
148                    # Do some wild exchanges...
149                    $str = preg_replace('/(\<[      ]*(B|U|I)[^\>]*\>)[     ]*(\<\/[        ]*(UL|OL|LI)[^\>]*\>)/', '$3$1', $str);
150                    $str = preg_replace('/(\<[      ]*(UL|OL|LI)[^\>]*\>)[  ]*(\<\/[        ]*(B|U|I)[^\>]*\>)/', '$3$1', $str);
151                    # Convert Win1250 to ISO8859-2
152                    # (Actually, it should already be in ISO8859-2, but you never know.)
153                    $str = strtr($str, "Ǝ", "Ʈ");
154                    return $str;
155          }          }
156          function isEdit() {  
157                  global $PHP_SELF;          function LinkIt($str) {
158                  return stristr($PHP_SELF, "/edit/") ? true : false;                  $allowed = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.";
159                    $idx = 0;
160                    while (true) {
161                            $idx = strpos($str, "@", $idx);
162                            if ($idx === false) break;
163                            $idx1 = $idx - 1;
164                            $idx2 = $idx + 1;
165                            while ($idx1 > 0 && stristr($allowed, $str[$idx1 - 1])) $idx1--;
166                            while ($idx2 < strlen($str) && stristr($allowed, $str[$idx2])) $idx2++;
167                            if ($idx2 > strlen($str) - 1) $idx2 = strlen($str) - 1;
168                            if ($str[$idx2 - 1] == '.') $idx2--;
169                            $str1 = substr($str, 0, $idx1);
170                            $str2 = substr($str, $idx1, $idx2 - $idx1);
171                            $str3 = substr($str, $idx2, strlen($str));
172                            $str4 = '<A HREF="mailto:'.$str2.'" CLASS="underlined">'.$str2.'</A>';
173                            $str = $str1.$str4.$str3;
174                            $idx = $idx1 + strlen($str4);
175                    }
176                    return $str;
177          }          }
178  ?>  ?>

Legend:
Removed from v.1.5  
changed lines
  Added in v.1.19

  ViewVC Help
Powered by ViewVC 1.1.26