YourWBB


yourWBB » WoltLab Burning Board Generation 2 * » Alles von und für das WBB Lite 1.0.x » [WBB Lite 1.0.x] Allg. Fragen und Probleme » Database Error » Hallo Gast [Anmelden|Registrieren]
Letzter Beitrag | Erster ungelesener Beitrag 1.546 Views | | Thema zu Favoriten hinzufügen

Neues Thema erstellen Antwort erstellen

Dieses Thema wurde als unerledigt markiert. Thread unerledigt

Zum Ende der Seite springen Database Error
Autor
Beitrag « Vorheriges Thema | Nächstes Thema »
feuerkerk
Mitglied


Dabei seit: 10.11.05
Beiträge: 123
Forenversion: 3.0

 Database Error Antworten Zitieren Editieren Melden       UP

Bekomme folgenden Fehler, wenn ich in mein Forum gehe.

Warning: mysql_connect() [function.mysql-connect]: Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) in wbblite/acp/lib/class_db_mysql.php on line 30
SQL-DATABASE ERROR

Database error in WoltLab Burning Board: Link-ID == false, connect failed
mysql error: Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
mysql error number: 2002
Date: 11.03.2007 @ 16:48
Script: /wbblite/install.php
Referer:

Wäre nett, wenn mir jemand helfen würde.
11.03.07 16:52 feuerkerk ist offline E-Mail Finden Als Freund hinzufügen
hardcore-punk hardcore-punk ist männlich
Dünngsöchter


images/avatars/avatar-4380.gif

Dabei seit: 01.11.04
Beiträge: 4.591
Fähigkeiten: WBB3 Fortgeschritten; WBB2 Profi; WBB Lite 2 Anfänger; WBB Lite 1 Profi
Herkunft: Im tiefsten Wald von Österreich
Forenversion: 2.3; Lite 1.0

Antworten Zitieren Editieren Melden       UP

sind in deiner acp/lib/config.inc.php die richitgen Daten eingeschrieben?

__________________
***

DOWNR!DERS LINZ
Downriders-Linz'Downhill'Freeride'Dirtjump'MTB

***

11.03.07 18:00 hardcore-punk ist offline E-Mail WWW Finden Als Freund hinzufügen Füge hardcore-punk in deine Kontaktliste ein AIM-Name von hardcore-punk: huemerdaniel YIM-Name von hardcore-punk: sportsitz MSN Passport-Profil von hardcore-punk anzeigen
feuerkerk
Mitglied


Dabei seit: 10.11.05
Beiträge: 123
Forenversion: 3.0

Themenstarter Thema begonnen von feuerkerk
Antworten Zitieren Editieren Melden       UP

Waren sie nicht, hab ich geändert - danke.

Neuer Fehler traurig

Warning: file(templates/frameset.htm) [function.file]: failed to open stream: No such file or directory in wbblite/acp/lib/functions.php on line 733

Warning: implode() [function.implode]: Bad arguments. in wbblite/acp/lib/functions.php on line 733
11.03.07 18:42 feuerkerk ist offline E-Mail Finden Als Freund hinzufügen
Maniac_81 Maniac_81 ist männlich
PHP Profi


images/avatars/avatar-5230.gif

Dabei seit: 27.06.06
Beiträge: 2.087
Fähigkeiten: WBB3 Anfänger; WBB2 Profi
Herkunft: localhost/
Forenversion: 2.3; Lite 2.0

Antworten Zitieren Editieren Melden       UP

alle schreibrechte gesetzt?

__________________
zufrieden mit meinem Support? dann hier bitte bewerten!

Sie haben 3 gelbe Bananen gewählt!

ÄPFEL! 3!!!

11.03.07 18:55 Maniac_81 ist offline E-Mail WWW Finden Als Freund hinzufügen Füge Maniac_81 in deine Kontaktliste ein MSN Passport-Profil von Maniac_81 anzeigen
feuerkerk
Mitglied


Dabei seit: 10.11.05
Beiträge: 123
Forenversion: 3.0

Themenstarter Thema begonnen von feuerkerk
Antworten Zitieren Editieren Melden       UP

Hm... functions.php hat chmod 777 ...
11.03.07 19:02 feuerkerk ist offline E-Mail Finden Als Freund hinzufügen
derkleene derkleene ist männlich
Alternativ Mitglied


Dabei seit: 28.08.06
Beiträge: 181
Fähigkeiten: WBB2 Fortgeschritten; WBB Lite 1 Profi
Herkunft: Niedersachsen
Forenversion: Lite 1.0

Antworten Zitieren Editieren Melden       UP

acp/templates/frameset.htm die datei fehlt

__________________
---
Es grüßt
DerKleene
NeoTower
11.03.07 20:58 derkleene ist offline E-Mail WWW Finden Als Freund hinzufügen
Bolop Bolop ist männlich
Mitglied


images/avatars/avatar-5687.gif

Dabei seit: 12.06.04
Beiträge: 1.792
Fähigkeiten: WBB Lite 2 Fortgeschritten; WBB Lite 1 Profi
Herkunft: Darmstadt (Hessen)
Forenversion: Lite 2.0; Lite 1.0

Antworten Zitieren Editieren Melden       UP

/edit:

haste Rechte gesetzt? Funktionierts?

Dieser Beitrag wurde 1 mal editiert, zum letzten Mal von Bolop: 11.03.07 21:02.

11.03.07 21:01 Bolop ist offline E-Mail Finden Als Freund hinzufügen Füge Bolop in deine Kontaktliste ein AIM-Name von Bolop: xshivatm YIM-Name von Bolop: bolop90@ymail.com MSN Passport-Profil von Bolop anzeigen
feuerkerk
Mitglied


Dabei seit: 10.11.05
Beiträge: 123
Forenversion: 3.0

Themenstarter Thema begonnen von feuerkerk
Antworten Zitieren Editieren Melden       UP

@derkleene: Nö...

@Bolop: Der ganze wbblite-Ordner hat chmod 777. Funktioniert aber nicht.

Hier meine functions.php

php:
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
48:
49:
50:
51:
52:
53:
54:
55:
56:
57:
58:
59:
60:
61:
62:
63:
64:
65:
66:
67:
68:
69:
70:
71:
72:
73:
74:
75:
76:
77:
78:
79:
80:
81:
82:
83:
84:
85:
86:
87:
88:
89:
90:
91:
92:
93:
94:
95:
96:
97:
98:
99:
100:
101:
102:
103:
104:
105:
106:
107:
108:
109:
110:
111:
112:
113:
114:
115:
116:
117:
118:
119:
120:
121:
122:
123:
124:
125:
126:
127:
128:
129:
130:
131:
132:
133:
134:
135:
136:
137:
138:
139:
140:
141:
142:
143:
144:
145:
146:
147:
148:
149:
150:
151:
152:
153:
154:
155:
156:
157:
158:
159:
160:
161:
162:
163:
164:
165:
166:
167:
168:
169:
170:
171:
172:
173:
174:
175:
176:
177:
178:
179:
180:
181:
182:
183:
184:
185:
186:
187:
188:
189:
190:
191:
192:
193:
194:
195:
196:
197:
198:
199:
200:
201:
202:
203:
204:
205:
206:
207:
208:
209:
210:
211:
212:
213:
214:
215:
216:
217:
218:
219:
220:
221:
222:
223:
224:
225:
226:
227:
228:
229:
230:
231:
232:
233:
234:
235:
236:
237:
238:
239:
240:
241:
242:
243:
244:
245:
246:
247:
248:
249:
250:
251:
252:
253:
254:
255:
256:
257:
258:
259:
260:
261:
262:
263:
264:
265:
266:
267:
268:
269:
270:
271:
272:
273:
274:
275:
276:
277:
278:
279:
280:
281:
282:
283:
284:
285:
286:
287:
288:
289:
290:
291:
292:
293:
294:
295:
296:
297:
298:
299:
300:
301:
302:
303:
304:
305:
306:
307:
308:
309:
310:
311:
312:
313:
314:
315:
316:
317:
318:
319:
320:
321:
322:
323:
324:
325:
326:
327:
328:
329:
330:
331:
332:
333:
334:
335:
336:
337:
338:
339:
340:
341:
342:
343:
344:
345:
346:
347:
348:
349:
350:
351:
352:
353:
354:
355:
356:
357:
358:
359:
360:
361:
362:
363:
364:
365:
366:
367:
368:
369:
370:
371:
372:
373:
374:
375:
376:
377:
378:
379:
380:
381:
382:
383:
384:
385:
386:
387:
388:
389:
390:
391:
392:
393:
394:
395:
396:
397:
398:
399:
400:
401:
402:
403:
404:
405:
406:
407:
408:
409:
410:
411:
412:
413:
414:
415:
416:
417:
418:
419:
420:
421:
422:
423:
424:
425:
426:
427:
428:
429:
430:
431:
432:
433:
434:
435:
436:
437:
438:
439:
440:
441:
442:
443:
444:
445:
446:
447:
448:
449:
450:
451:
452:
453:
454:
455:
456:
457:
458:
459:
460:
461:
462:
463:
464:
465:
466:
467:
468:
469:
470:
471:
472:
473:
474:
475:
476:
477:
478:
479:
480:
481:
482:
483:
484:
485:
486:
487:
488:
489:
490:
491:
492:
493:
494:
495:
496:
497:
498:
499:
500:
501:
502:
503:
504:
505:
506:
507:
508:
509:
510:
511:
512:
513:
514:
515:
516:
517:
518:
519:
520:
521:
522:
523:
524:
525:
526:
527:
528:
529:
530:
531:
532:
533:
534:
535:
536:
537:
538:
539:
540:
541:
542:
543:
544:
545:
546:
547:
548:
549:
550:
551:
552:
553:
554:
555:
556:
557:
558:
559:
560:
561:
562:
563:
564:
565:
566:
567:
568:
569:
570:
571:
572:
573:
574:
575:
576:
577:
578:
579:
580:
581:
582:
583:
584:
585:
586:
587:
588:
589:
590:
591:
592:
593:
594:
595:
596:
597:
598:
599:
600:
601:
602:
603:
604:
605:
606:
607:
608:
609:
610:
611:
612:
613:
614:
615:
616:
617:
618:
619:
620:
621:
622:
623:
624:
625:
626:
627:
628:
629:
630:
631:
632:
633:
634:
635:
636:
637:
638:
639:
640:
641:
642:
643:
644:
645:
646:
647:
648:
649:
650:
651:
652:
653:
654:
655:
656:
657:
658:
659:
660:
661:
662:
663:
664:
665:
666:
667:
668:
669:
670:
671:
672:
673:
674:
675:
676:
677:
678:
679:
680:
681:
682:
683:
684:
685:
686:
687:
688:
689:
690:
691:
692:
693:
694:
695:
696:
697:
698:
699:
700:
701:
702:
703:
704:
705:
706:
707:
708:
709:
710:
711:
712:
713:
714:
715:
716:
717:
718:
719:
720:
721:
722:
723:
724:
725:
726:
727:
728:
729:
730:
731:
732:
733:
734:
735:
736:
737:
738:
739:
740:
741:
742:
743:
744:
745:
746:
747:
748:
749:
750:
751:
752:
753:
754:
755:
756:
757:
758:
759:
760:
761:
762:
763:
764:
765:
766:
767:
768:
769:
770:
771:
772:
773:
774:
775:
776:
777:
778:
779:
780:
781:
782:
783:
784:
785:
786:
787:
788:
789:
790:
791:
792:
793:
794:
795:
796:
797:
798:
799:
800:
801:
802:
803:
804:
805:
806:
807:
808:
809:
810:
811:
812:
813:
814:
815:
816:
817:
818:
819:
820:
821:
822:
823:
824:
825:
826:
827:
828:
829:
830:
831:
832:
833:
834:
835:
836:
837:
838:
839:
840:
841:
842:
843:
844:
845:
846:
847:
848:
849:
850:
851:
852:
853:
854:
855:
856:
857:
858:
859:
860:
861:
862:
863:
864:
865:
866:
867:
868:
869:
870:
871:
872:
873:
874:
875:
876:
877:
878:
879:
880:
881:
882:
883:
884:
885:
886:
887:
888:
889:
890:
891:
892:
893:
894:
895:
896:
897:
898:
899:
900:
901:
902:
903:
904:
905:
906:
907:
908:
909:
910:
911:
912:
913:
914:
915:
916:
917:
918:
919:
920:
921:
922:
923:
924:
925:
926:
927:
928:
929:
930:
931:
932:
933:
934:
935:
936:
937:
938:
939:
940:
941:
942:
943:
944:
945:
946:
947:
948:
949:
950:
951:
952:
953:
954:
955:
956:
957:
958:
959:
960:
961:
962:
963:
964:
965:
966:
967:
968:
969:
970:
971:
972:
973:
974:
975:
976:
977:
978:
979:
980:
981:
982:
983:
984:
985:
986:
987:
988:
<?php
function get_vars_old() {
 global $HTTP_COOKIE_VARS$HTTP_POST_FILES$HTTP_POST_VARS$HTTP_GET_VARS$HTTP_SERVER_VARS$_REQUEST$_COOKIE$_POST$_GET$_SERVER$_FILES;

 if(is_array($HTTP_COOKIE_VARS)) {
  while(list($key,$val)=each($HTTP_COOKIE_VARS)) {
   $_REQUEST[$key]=$val;
   $_COOKIE[$key]=$val;
  }
 }

 if(is_array($HTTP_POST_VARS)) {
  while(list($key,$val)=each($HTTP_POST_VARS)) {
   $_REQUEST[$key]=$val;
   $_POST[$key]=$val;
  }
 }

 if(is_array($HTTP_GET_VARS)) {
  while(list($key,$val)=each($HTTP_GET_VARS)) {
   $_REQUEST[$key]=$val;
   $_GET[$key]=$val;
  }
 }

 if(is_array($HTTP_POST_FILES)) while(list($key,$val)=each($HTTP_POST_FILES)) $_FILES[$key]=$val;
 if(is_array($HTTP_SERVER_VARS)) while(list($key,$val)=each($HTTP_SERVER_VARS)) $_SERVER[$key]=$val;
}

function convert_url($url,$hash,$nosessionhash=0) {
 if($nosessionhash==0$url=preg_replace("/sid=[0-9a-z]*/","sid=$hash",$url);
 else $url=preg_replace("/sid=[0-9a-z]*/","sid=",$url);
 return $url;
}

function rehtmlspecialchars($text) {
 $text str_replace("&lt;","<",$text);
 $text str_replace("&gt;",">",$text);
 $text str_replace("&quot;","\"",$text);
 $text str_replace("&amp;","&",$text);

 return $text;
}

function stripslashes_array(&$array) {
 reset($array);
 while(list($key,$val)=each($array)) {
  if(is_string($val)) $array[$key]=stripslashes($val);
  elseif(is_array($val)) $array[$key]=stripslashes_array($val);
 }
 return $array;
}

function trim_array(&$array) {
 reset($array);
 while(list($key,$val)=each($array)) {
  if(is_array($val)) $array[$key]=trim_array($val);
  elseif(is_string($val)) $array[$key]=trim($val);
 }
 return $array;
}

function htmlspecialchars_array(&$array) {
 reset($array);
 while(list($key,$val)=each($array)) {
  if(is_array($val)) $array[$key]=htmlspecialchars_array($val);
  elseif(is_string($val)) $array[$key]=htmlspecialchars($val);
 }
 return $array;
}

function ifelse($expression,$returntrue,$returnfalse="") {
 if($expression) return $returntrue;
 else return $returnfalse;
}

function bbcookie($name$value$time) {
 global $cookiepath$cookiedomain;

 if($cookiedomainsetcookie($name$value$time$cookiepath$cookiedomain);
 elseif($cookiepathsetcookie($name$value$time$cookiepath);
 else setcookie($name$value$time);

}

function mailer($email,$subject,$text,$sender="",$other="") {
 global $frommail$master_board_name;

 if($sender) return @mail($email,$subject,$text,"From: $sender".$other);
 else return @mail($email,$subject,$text,"From: $frommail".$other);
}

function makehreftag($url$name$target="") {
 return "<a href=\"".$url."\"".ifelse($target," target=\"".$target."\"").">".$name."</a>";
}

function makeimgtag($path,$alt="") {
 return "<img src=\"$path\" ".ifelse($alt,"alt=\"".$alt."\" ","")."border=0>";
}

function formatdate($timeformat,$timestamp,$replacetoday=0) {
 global $wbbuserdata$tpl$default_timezoneoffset;
 $summertime date("I")*3600;
 $timestamp+=3600*intval($default_timezoneoffset)+$summertime;
 if($replacetoday==1) {
  if(gmdate("Ymd",$timestamp)==gmdate("Ymd",time()+3600*intval($default_timezoneoffset)+$summertime)) {
   eval ("\$today = \"".$tpl->get("today")."\";");
   return $today;
  }
  else $replacetoday=0;
 }
 if($replacetoday==0) return gmdate($timeformat$timestamp);
}

function getSubboards($boardid) {
 global $boardcache$session$tpl$permissioncache;

 if (!isset($boardcache[$boardid])) return;

 while(list($key1,$val1)=each($boardcache[$boardid])) {
  while(list($key2,$boards)=each($val1)) {
   if($boards['invisible']==|| ($boards['invisible']==&& !$permissioncache[$boards['boardid']]['boardpermission'])) continue;

   eval ("\$subboardbit .= \"".$tpl->get("index_subboardbit")."\";");
   $subboardbit.=getSubboards($boards['boardid']);
  }
 }
 return $subboardbit;
}

function makeboardbit($boardid,$depth=1) {
 global $db$n$tpl$boardvisit$threadvisit$boardcache$visitcache$permissioncache$modcache$wbbuserdata$session$hidecats$index_depth$show_subboards$showlastposttitle$dateformat$timeformat$filename$temp_boardid;

 if(!isset($boardcache[$boardid])) return;
 reset($boardcache[$boardid]);

 $boardbit="";
 while(list($key1,$val1)=each($boardcache[$boardid])) {
  while(list($key2,$boards)=each($val1)) {
   if($boards['invisible']==|| ($boards['invisible']==&& !$permissioncache[$boards['boardid']]['boardpermission'])) continue;
   if($boards['description']) eval ("\$boards['description'] = \"".$tpl->get("index_boarddescription")."\";");
   $subboardbit="";
   $subboards="";
   if($depth==$index_depth && $show_subboards==1) {
    $subboardbit=getSubboards($boards['boardid']);
    if($subboardbit) {
     $subboardbit=substr($subboardbit0, -2);
     eval ("\$subboards = \"".$tpl->get("index_subboard")."\";");
    }
   }

   if($wbbuserdata['lastvisit'] > $boards['lastposttime'] || $boardvisit[$boards['boardid']] > $boards['lastposttime']) $onoff="off";
   else {
    $onoff="off";
    $tempids explode(",","$boards[boardid],$boards[childlist]");
    for($j=0;$j<count($tempids);$j++) {
     if($tempids[$j]==0) continue;
     if(is_array($visitcache[$tempids[$j]]) && count($visitcache[$tempids[$j]])) {
      reset($visitcache[$tempids[$j]]);
      while(list($threadid,$lastposttime)=each($visitcache[$tempids[$j]])) {
       if($threadvisit[$threadid]<$lastposttime && $boardvisit[$tempids[$j]]<$lastposttime) {
        $onoff="on";
        break 2;
       } // end if
      // end while
     // end if
    // end for
   // end else

   if($boards['isboard']) {

   if($boards['closed']==1$onoff.="closed";
   elseif((!$permissioncache[$boards['boardid']]['startpermission'] && !$permissioncache[$boards['boardid']]['replypermission']) || (!$wbbuserdata['canstarttopic'] && !$wbbuserdata['canreplytopic'])) $onoff.="closed";

   if($boards['threadcount']) {
    $lastpostdate=formatdate($dateformat,$boards['lastposttime'],1);
    $lastposttime=formatdate($timeformat,$boards['lastposttime']);
    if($boards['lastposterid']) eval ("\$lastposter = \"".$tpl->get("index_lastposter")."\";");
    else eval ("\$lastposter = \"".$tpl->get("index_lastposter_guest")."\";");
    if($showlastposttitle==1) {
     if(!$permissioncache[$boards['boardid']]['boardpermission'] || $boards['password']!="") eval ("\$lastposttitle = \"".$tpl->get("index_lastpost_title_hide")."\";");
     else {
      if(strlen($boards['topic'])>30$topic=cutTopic($boards['topic']);
      else $topic=$boards['topic'];
      eval ("\$lastposttitle = \"".$tpl->get("index_lastpost_title_show")."\";");
     }
     if(isset($boards['iconid'])) $ViewPosticon=makeimgtag($boards['iconpath'],$boards['icontitle']);
     else $ViewPosticon=makeimgtag("{imagefolder}/icons/icon14.gif");

     if(isset($boards['threadprefix']) && $boards['threadprefix']!="") {
      $threads['prefix']=$boards['threadprefix'];
      eval ("\$prefix = \"".$tpl->get("board_thread_prefix")."\";");
     }
     else $prefix="";

     eval ("\$lastpost = \"".$tpl->get("index_lastpost_title")."\";");
    }
    else eval ("\$lastpost = \"".$tpl->get("index_lastpost")."\";");
   }
   else eval ("\$lastpost = \"".$tpl->get("index_nolastpost")."\";");

    $moderators="";
    $moderatorbit="";
    if(isset($modcache[$boards['boardid']])) {
     while (list($mkey,$moderator)=each($modcache[$boards['boardid']])) {
      if($moderatorbit) eval ("\$moderatorbit .= \", ".$tpl->get("index_moderatorbit")."\";");
      else eval ("\$moderatorbit = \"".$tpl->get("index_moderatorbit")."\";");
     }
    }
    else $moderatorbit="&nbsp;";
    eval ("\$moderators = \"".$tpl->get("index_moderators")."\";");
    eval ("\$boardbit .= \"".$tpl->get("index_boardbit$depth")."\";");

   }
   else {
    eval ("\$boardbit .= \"".$tpl->get("index_catbit$depth")."\";");
   }
   if ((isset($hidecats[$boards['boardid']]) && $hidecats[$boards['boardid']]==0) || ($depth<$index_depth && (!isset($hidecats[$boards['boardid']]) || $hidecats[$boards['boardid']]!=1))) $boardbit.=makeboardbit($boards['boardid'],$depth+1);
  }
 }
 unset($boardcache[$boardid]);

 return $boardbit;
}

function getNavbar($parentlist,$template="navbar_board") {
 global $db$n$session$url2board$lines$tpl$boardnavcache;
 if($parentlist=="0") return;
 else {
  $navbar="";
  if(!isset($boardnavcache) || !is_array($boardnavcache) || !count($boardnavcache)) {
   $result $db->query("SELECT boardid, title FROM bb".$n."_boards WHERE boardid IN ($parentlist)");
   while($row=$db->fetch_array($result)) $boardnavcache[$row['boardid']]=$row;
  }
  $parentids=explode(","$parentlist);
  for($i=1;$i<count($parentids);$i++) {
   if($template=="print_navbar"$lines.=str_repeat("-",$i);
   $board=$boardnavcache[$parentids[$i]];
   eval ("\$navbar .= \"".$tpl->get($template)."\";");
  }
  return $navbar;
 }
}

function getcodebuttons() {
 global $bbcodemode$tpl;
 if($bbcodemode==1$modechecked[1]="checked";
 else $modechecked[0]="checked";

 eval ("\$bbcode_sizebits = \"".$tpl->get("bbcode_sizebits")."\";");
 eval ("\$bbcode_fontbits = \"".$tpl->get("bbcode_fontbits")."\";");
 eval ("\$bbcode_colorbits = \"".$tpl->get("bbcode_colorbits")."\";");
 eval ("\$bbcode_buttons = \"".$tpl->get("bbcode_buttons")."\";");
 return $bbcode_buttons;
}

function getclickysmilies($tableColumns=3,$maxSmilies=-1) {
 global $db$n$tpl$showsmiliesrandom;

 if($showsmiliesrandom==1$result $db->query("SELECT smiliepath, smilietitle, smiliecode FROM bb".$n."_smilies ORDER BY RAND()");
 else $result $db->query("SELECT smiliepath, smilietitle, smiliecode FROM bb".$n."_smilies ORDER BY smilieorder ASC");
 $totalSmilies $db->num_rows($result);

 if (($maxSmilies == -1) || ($maxSmilies >= $totalSmilies)) $maxSmilies $totalSmilies;
 elseif ($maxSmilies $totalSmilies) eval ("\$bbcode_smilies_getmore = \"".$tpl->get("bbcode_smilies_getmore")."\";");

 $i=0;
 while($row $db->fetch_array($result)) {
  eval ("\$smilieArray[\"".$i."\"] = \"".$tpl->get("bbcode_smiliebit")."\";");
  $i++;
 }

 $tableRows ceil($maxSmilies/$tableColumns);
 $count 0;
 for ($i=0$i<$tableRows$i++) {
  $smiliebits .= "\t<tr bgcolor=\"{tablecolorb}\" id=\"tableb\">\n";
  for ($j=0$j<$tableColumns$j++) {
   $smiliebits .= $smilieArray[$count];
   $count++;
  }
  $smiliebits .= "\t</tr>\n";
 }

 eval ("\$bbcode_smilies = \"".$tpl->get("bbcode_smilies")."\";");
 return $bbcode_smilies;
}

function getone($number$one$two) {
 if($number 2) return $one;
 else return $two;
}

function makeboardjump($current) {
 global $wbbuserdata$boardcache$permissioncache$tpl$session$boardnavcache;

 if(!isset($boardcache) || !isset($permissioncache)) {
  global $db$n$wbbuserdata;

  $result $db->query("SELECT boardid, parentid, boardorder, title, invisible FROM bb".$n."_boards ORDER by parentid ASC, boardorder ASC");
  while ($row $db->fetch_array($result)) {
   $boardcache[$row['parentid']][$row['boardorder']][$row['boardid']] = $row;
   $boardnavcache[$row['boardid']]=$row;
  }
  $result $db->query("SELECT * FROM bb".$n."_permissions WHERE groupid = '$wbbuserdata[groupid]'");
  while ($row $db->fetch_array($result)) $permissioncache[$row['boardid']] = $row;
 }
 if(is_array($boardcache) && count($boardcache)) {
  reset($boardcache);
  $boardoptions=makeboardselect(0,1,$current);
 }
 eval ("\$boardjump = \"".$tpl->get("boardjump")."\";");
 return $boardjump;
}

function makeboardselect($boardid,$depth=1,$current=0) {
 global $boardcache$permissioncache;
 if(!isset($boardcache[$boardid])) return;
 $boardbit="";
 while (list($key1,$val1) = each($boardcache[$boardid])) {
  while(list($key2,$boards) = each($val1)) {
   if($boards['invisible']==&& $permissioncache[$boards['boardid']]['boardpermission'] == 0) continue;
   if($depth>1$prefix=str_repeat("--",$depth-1)." ";
   else $prefix="";
   $boardbit .= makeoption($boards['boardid'],$prefix.$boards['title'],$current,1);
   $boardbit .= makeboardselect($boards['boardid'],$depth+1,$current);
  }
 }
 unset($boardcache[$boardid]);
 return $boardbit;
}

function formatRI($images) {
 if(!$images) return;

 $imgArray explode(";",$images);

 for($i=0;$i<count($imgArray);$i++)
  $RI.="<img src=\"$imgArray[$i]\">";

 return $RI;
}

function parseURL($message) {
 $urlsearch[]="/([^]@_a-z0-9-=\"'\/])((https?|ftp):\/\/|www\.)([^ \r\n\(\)\^\$!`\"'\|\[\]\{\}<>]*)/si";
 $urlsearch[]="/^((https?|ftp):\/\/|www\.)([^ \r\n\(\)\^\$!`\"'\|\[\]\{\}<>]*)/si";
 $urlreplace[]="\\1[URL]\\2\\4[/URL]";
 $urlreplace[]="[URL]\\1\\3[/URL]";
 $emailsearch[]="/([\s])([_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*@[a-zA-Z0-9-]+(\.[a-zA-Z0-9-]+)*(\.[a-zA-Z]{2,}))/si";
 $emailsearch[]="/^([_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*@[a-zA-Z0-9-]+(\.[a-zA-Z0-9-]+)*(\.[a-zA-Z]{2,}))/si";
 $emailreplace[]="\\1[EMAIL]\\2[/EMAIL]";
 $emailreplace[]="[EMAIL]\\0[/EMAIL]";
 $message preg_replace($urlsearch$urlreplace$message);
 if (strpos($message"@")) $message preg_replace($emailsearch$emailreplace$message);
 return $message;
}

function makepagelink($link,$page,$pages,$number) {
 global $tpl;
 eval ("\$pagelink = \"".$tpl->get("pagelink")."\";");

 if($page-$number>1) eval ("\$pagelink .= \"".$tpl->get("pagelink_first")."\";");
 if($page>1) {
  $temppage=$page-1;
  eval ("\$pagelink .= \"".$tpl->get("pagelink_left")."\";");
 }
 $count ifelse($page+$number>=$pages,$pages,$page+$number);
 for($i=$page-$number;$i<=$count;$i++) {
  if($i<1$i=1;
  if($i==$page) eval ("\$pagelink .= \"".$tpl->get("pagelink_current")."\";");
  else eval ("\$pagelink .= \"".$tpl->get("pagelink_nocurrent")."\";");
 }

 if($page<$pages) {
  $temppage=$page+1;
  eval ("\$pagelink .= \"".$tpl->get("pagelink_right")."\";");
 }
 if($page+$number<$pages) eval ("\$pagelink .= \"".$tpl->get("pagelink_last")."\";");

 return $pagelink;
}

function makeoption($value,$text,$selected_value="",$selected=1,$style="") {
 $option_selected="";
 if($selected==1) {
  if(is_array($selected_value)) {
   if(in_array($value,$selected_value)) $option_selected=" selected";
  }
  elseif($selected_value==$value$option_selected=" selected";
 }
 return "<option value=\"$value\"".ifelse($style!=""," style=\"color:$style\"").$option_selected.">$text</option>";
}

function getmonth($number) {
 global $months$tpl;
 if(!isset($months)) $months explode("|"$tpl->get("months"));
 return $months[$number-1];
}

function getday($number) {
 global $days$tpl;
 if(!isset($days)) $days explode("|"$tpl->get("days"));
 return $days[$number];
}

function access_error() {
 global $wbbuserdata$header$footer$headinclude$session$master_board_name$REQUEST_URI$tpl;

 if($wbbuserdata['userid']) eval ("\$access_errorbit = \"".$tpl->get("access_error_user")."\";");
 else eval ("\$access_errorbit = \"".$tpl->get("access_error_guest")."\";");

 eval("\$tpl->output(\"".$tpl->get("access_error")."\");");
 exit();
}

function verify_username($username) {
 global $db$n$ban_name;

 $ban_name=explode("\n",preg_replace("/\s*\n\s*/","\n",strtolower(trim($ban_name))));
 if(count($ban_name) && in_array(strtolower($username),$ban_name)) return false;
 $result $db->query_first("SELECT COUNT(*) FROM bb".$n."_users WHERE username = '".addslashes(htmlspecialchars($username))."'");
 if($result[0]!=0) return false;
 else return true;
}

function verify_email($email) {
 global $db$n$multipleemailuse$ban_email;

 $email=strtolower($email);
 if(!preg_match("/^([_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*@[a-zA-Z0-9-]+(\.[a-zA-Z0-9-]+)*(\.[a-zA-Z]{2,}))$/si",$email)) return false;
 $ban_email=explode("\n",preg_replace("/\s*\n\s*/","\n",strtolower(trim($ban_email))));
 for($i 0$i count($ban_email); $i++) {
  $ban_email[$i]=trim($ban_email[$i]);
  if(!$ban_email[$i]) continue;
  if(strstr($ban_email[$i], "*")) {
   $ban_email[$i] = str_replace("*",".*",$ban_email[$i]);
   if(preg_match("/$ban_email[$i]/i",$email)) return false;
  }
  elseif($email==$ban_email[$i]) return false;
 }
 if($multipleemailuse==1) return true;
 else {
  $result $db->query_first("SELECT COUNT(*) FROM bb".$n."_users WHERE email = '".$email."'");
  if($result[0]!=0) return false;
  else return true;
 }
}

function verify_ip($ip) {
 global $ban_ip;

 if($ban_ip) {
  $ban_ip=explode("\n",preg_replace("/\s*\n\s*/","\n",strtolower(trim($ban_ip))));
  for($i 0$i count($ban_ip); $i++) {
   $ban_ip[$i]=trim($ban_ip[$i]);
   if(!$ban_ip[$i]) continue;
   if(strstr($ban_ip[$i], "*")) {
    $ban_ip[$i] = str_replace("*",".*",$ban_ip[$i]);
    if(preg_match("/$ban_ip[$i]/i",$ip)) access_error();
   }
   elseif($ip==$ban_ip[$i]) access_error();
  }
 }
}

function flood_control($userid,$ipaddress,$avoidfc) {
 if($avoidfc==1) return false;

 global $db$n$fctime;
 if($userid$result=$db->query_first("SELECT postid FROM bb".$n."_posts WHERE userid='$userid' AND posttime>='".(time()-$fctime)."'",1);
 else $result=$db->query_first("SELECT postid FROM bb".$n."_posts WHERE ipaddress='$ipaddress' AND posttime>='".(time()-$fctime)."'",1);
 if($result['postid']) return true;
 else return false;
}


function password_generate($numbers=2,$length=8) {

 $time intval(substr(microtime(), 28));
 mt_srand($time);

 $numberchain="1234567890";

 for($i=0;$i<$numbers;$i++) {
  $random=mt_rand(0,strlen($numberchain)-1);
  $number[intval($numberchain[$random])]=mt_rand(1,9);
  $numberchain=str_replace($random,"",$numberchain);
 }

 $chain "abcdefghijklmnopqrstuvwxyz";
 for($i=0;$i<$length;$i++) {
  if($number[$i]) $password.=$number[$i];
  else $password.=$chain[mt_rand(0,strlen($chain)-1)];
 }
 return $password;
}

function code_generate() {

 $time intval(substr(microtime(), 28));
 mt_srand($time);

 return mt_rand(1000000,10000000);
}

function error($error_msg) {
 global $headinclude$master_board_name$tpl;
 eval("\$tpl->output(\"".$tpl->get("error")."\");");
 exit();
}

function redirect($msg,$url,$waittime=5) {
 global $headinclude$master_board_name$tpl;
 eval("\$tpl->output(\"".$tpl->get("redirect")."\");");
 exit();
}

function acp_error($error_msg) {
 eval("print(\"".gettemplate("error")."\");");
 exit();
}

function acp_error_frame($error_msg) {
 eval("\$temp = \"".gettemplate("error_frame")."\";");
 return $temp;
}

function stopShooting($topic) {
 if($topic==strtoupper($topic)) return ucwords(strtolower($topic));
 return $topic;
}

function cutTopic($topic,$length=28) {
 $topic=str_replace("&quot;","\"",$topic);
 $topic=str_replace("&lt;","<",$topic);
 $topic=str_replace("&gt;",">",$topic);
 $topic=str_replace("&amp;","&",$topic);

 $topic trim(substr($topic0$length))."...";
 return htmlspecialchars($topic);
}

function htmlspecialchars_wbb($text) {
 $text=str_replace("\"","&quot;",$text);
 $text=str_replace("<","&lt;",$text);
 $text=str_replace(">","&gt;",$text);

 return $text;
}

function add2list($list,$add) {
 if($list=="") return $add;
 else {
  $listelements=explode(' ',$list);
  if(!in_array($add,$listelements)) {
   $listelements[]=$add;
   return implode(' ',$listelements);
  }
  else return -1;
 }
}

function removeFromlist($list,$remove) {
 $listelements=explode(' ',$list);
 if(!in_array($remove,$listelements)) return -1;
 else {
  $count=count($listelements);
  for($i=0;$i<$count;$i++) {
   if($listelements[$i]==$remove) {
    if($i==$count-1array_pop($listelements);
    else $listelements[$i]=array_pop($listelements);
    break;
   }
  }
  return implode(' ',$listelements);
 }
}

function wordmatch($postid,$message,$topic) {
 global $db$n$minwordlength$maxwordlength$badsearchwords;

 if($topic) {
  $topicwords=preg_replace("/[\s,]/s"," ",$topic);
  $topicwords=preg_replace("/(\.+)($| |\n|\t)/s"," ",$topicwords);
  $topicwords=str_replace("["," [",$topicwords);
  $topicwords=str_replace("]","] ",$topicwords);
  $topicwords=preg_replace("/[\/:;'\"\(\)\[\]?!#{}%_\-+\\\\]/s","",$topicwords);
  $topicwords=strtolower(trim(str_replace("  "," ",$topicwords)));
  $temparray=explode(" ",$topicwords);
  while (list($key,$val)=each($temparray)) $topicwordarray[$val]=1;
 }

 $words=preg_replace("/[\s,]/s"," ",$message);
 $words=preg_replace("/(\.+)($| |\n|\t)/s"," ",$words);
 $words=str_replace("["," [",$words);
 $words=str_replace("]","] ",$words);
 $words=preg_replace("/[\/:;'\"\(\)\[\]?!#{}_\-+\\\\]/s","",$words);
 $words=strtolower(trim(str_replace("  "," ",$words)));
 if($topicwords$words.=" ".$topicwords;
 $wordarray=explode(" ",$words);

 $result $db->query("SELECT wordid, word FROM bb".$n."_wordlist WHERE word IN ('".str_replace(" ","','",$words)."')");
 while($row=$db->fetch_array($result)) $wordcache[$row[word]]=$row[wordid];
 $db->free_result($result);

 $badwords=array();
 if($badsearchwords) {
  $temp=explode("\n",$badsearchwords);
  while(list($key,$val)=each($temp)) $badwords[trim($val)]=1;
 }

 $alreadyadd=array();
 $wordmatch_sql="";
 $newtopicwords="";
 $newwords="";
 while(list($key,$val)=each($wordarray)) {
  if($badwords[$val]==|| strlen($val)<$minwordlength || strlen($val)>$maxwordlength) {
   unset($wordarray[$key]);
   continue;
  }

  if($val && $alreadyadd[$val]!=1) {
   if($wordcache[$val]) $wordmatch_sql.=",($wordcache[$val],$postid,".ifelse($topicwordarray[$val]==1,1,0).")";
   else {
    if($topicwordarray[$val]==1$newtopicwords.=$val." ";
    else $newwords.=$val." ";
   }
   $alreadyadd[$val]=1;
  }
 }

 if($wordmatch_sql$db->query("REPLACE INTO bb".$n."_wordmatch (wordid,postid,intopic) VALUES ".substr($wordmatch_sql,1));

 if ($newwords) {
  $newwords=trim($newwords);
  $insertwords="(NULL,'".str_replace(" ","'),(NULL,'",addslashes($newwords))."')";
  $db->query("INSERT IGNORE INTO bb".$n."_wordlist (wordid,word) VALUES $insertwords");
  $selectwords="word IN('".str_replace(" ","','",addslashes($newwords))."')";
  $db->query("INSERT IGNORE INTO bb".$n."_wordmatch (wordid,postid) SELECT DISTINCT wordid,$postid FROM bb".$n."_wordlist WHERE $selectwords");
 }

 if ($newtopicwords) {
  $newtopicwords=trim($newtopicwords);
  $insertwords="(NULL,'".str_replace(" ","'),(NULL,'",addslashes($newtopicwords))."')";
  $db->query("INSERT IGNORE INTO bb".$n."_wordlist (wordid,word) VALUES $insertwords");
  $selectwords="word IN('".str_replace(" ","','",addslashes($newtopicwords))."')";
  $db->query("REPLACE INTO bb".$n."_wordmatch (wordid,postid,intopic) SELECT DISTINCT wordid,$postid,1 FROM bb".$n."_wordlist WHERE $selectwords");
 }
}

function deletethread($threadid) {
 global $db$n$thread$board$boardid;

 $db->query("DELETE FROM bb".$n."_threads WHERE threadid = '$threadid'"); // delete thread
 $db->unbuffered_query("DELETE FROM bb".$n."_threads WHERE pollid = '$threadid' AND closed=3",1);
 if($thread['important']==2$db->unbuffered_query("DELETE FROM bb".$n."_announcements WHERE threadid = '$threadid'",1);
 $db->query("DELETE FROM bb".$n."_subscribethreads WHERE threadid = '$threadid'"); // delete subscriptions

 if($thread['pollid']) { // delete poll
  $db->query("DELETE FROM bb".$n."_polls WHERE pollid = '$thread[pollid]'");
  $pollvotes=" OR (id = '$thread[pollid]' AND votemode=1)";
  $db->query("DELETE FROM bb".$n."_polloptions WHERE pollid = '$thread[pollid]'");
 }
 else $pollvotes="";
 $db->query("DELETE FROM bb".$n."_votes WHERE (id = '$threadid' AND votemode=2)$pollvotes"); // delete ratings

  $result $db->query("SELECT COUNT(postid) AS posts, userid FROM bb".$n."_posts WHERE threadid='$threadid' AND visible=1 AND userid>0 GROUP BY userid");
  while($row=$db->fetch_array($result)) $db->query("UPDATE bb".$n."_users SET userposts=userposts-'$row[posts]' WHERE userid='$row[userid]'");

 $db->query("DELETE FROM bb".$n."_posts WHERE threadid = '$threadid'"); // delete posts
 $thread['replycount']+=1;

 /* update boardcount */
 if($thread['visible']==1$db->query("UPDATE bb".$n."_boards SET threadcount=threadcount-1, postcount=postcount-'$thread[replycount]' WHERE boardid IN ($boardid,$board[parentlist])");
 if($board['lastthreadid']==$threadidupdateBoardInfo("$boardid,$board[parentlist]",0,$threadid);
}

function deleteposts($postids,$threadid,$postcount) {
 global $db$n$thread$board$boardid;

 $result $db->query("SELECT postid, parentpostid FROM bb".$n."_posts WHERE postid IN ($postids) ORDER BY posttime DESC");
 while($row=$db->fetch_array($result)) $db->query("UPDATE bb".$n."_posts SET parentpostid='$row[parentpostid]' WHERE parentpostid='$row[postid]'");

  $result $db->query("SELECT COUNT(postid) AS posts, userid FROM bb".$n."_posts WHERE postid IN ($postids) AND visible=1 AND userid>0 GROUP BY userid");
  while($row=$db->fetch_array($result)) $db->unbuffered_query("UPDATE bb".$n."_users SET userposts=userposts-'$row[posts]' WHERE userid='$row[userid]'",1);

 $db->query("DELETE FROM bb".$n."_posts WHERE postid IN ($postids)");

 $db->query("UPDATE bb".$n."_boards SET postcount=postcount-'$postcount' WHERE boardid IN ($boardid,$board[parentlist])");
 $result=$db->query_first("SELECT userid, username, posttime FROM bb".$n."_posts WHERE threadid='$threadid' ORDER BY posttime DESC",1);
 $db->query("UPDATE bb".$n."_threads SET replycount=replycount-'$postcount', lastposttime='$result[posttime]', lastposterid='$result[userid]', lastposter='".addslashes($result['username'])."' WHERE threadid='$threadid'");

 updateBoardInfo("$boardid,$board[parentlist]",$thread['lastposttime']);
}

function updateBoardInfo($boardidlist,$lastposttime=-1,$lastthreadid=-1) {
 global $db$n;
 if($lastthreadid!=-1$result $db->query("SELECT boardid, childlist FROM bb".$n."_boards WHERE boardid IN ($boardidlist) AND lastthreadid='$lastthreadid'");
 elseif($lastposttime!=-1$result $db->query("SELECT boardid, childlist FROM bb".$n."_boards WHERE boardid IN ($boardidlist) AND lastposttime<='$lastposttime'");
 else $result $db->query("SELECT boardid, childlist FROM bb".$n."_boards WHERE boardid IN ($boardidlist)");
 while($row=$db->fetch_array($result)) {
  $lastpost=$db->query_first("SELECT p.threadid, p.userid, p.username, p.posttime FROM bb".$n."_posts p, bb".$n."_threads t WHERE p.threadid=t.threadid AND t.boardid IN ($row[boardid],$row[childlist]) AND p.visible=1 ORDER BY p.posttime DESC",1);
  $db->unbuffered_query("UPDATE bb".$n."_boards SET lastthreadid='$lastpost[threadid]', lastposttime='$lastpost[posttime]', lastposterid='$lastpost[userid]', lastposter='".addslashes($lastpost['username'])."' WHERE boardid='$row[boardid]'",1);
 }
}

function userrating($count,$points,$userid) {
 global $tpl;

 if($count==0) eval ("\$userrating = \"".$tpl->get("userrating_rate")."\";");
 else {
  $doubletemp=$points/$count;
  $temp=number_format($doubletemp,1);
  $rating=number_format($doubletemp,2);

  $width=$temp*10;
  if($temp>6.6) eval ("\$ratingbar = \"".$tpl->get("userrating_green")."\";");
  elseif($temp>3.3) eval ("\$ratingbar = \"".$tpl->get("userrating_yellow")."\";");
  else eval ("\$ratingbar = \"".$tpl->get("userrating_red")."\";");
  eval ("\$userrating = \"".$tpl->get("userrating")."\";");
 }
 return $userrating;
}

function stripcrap($post) {
 if($post) {
  $post=preg_replace("/(\?|\&){1}sid=[a-z0-9]{32}/","\\1sid=",$post);
  $post=preg_replace("/(&#)(\d+)(;)/e","chr(intval('\\2'))",$post);
 }
 return $post;
}

function gettemplate($template,$php=0) {
 $file=implode("",file("templates/".$template.".htm"));
 if($php) return $file;
 else return str_replace("\"","\\\"",$file);
}

function movethread($threadid,$mode,$newboardid) {
 global $board$thread$db$n$newboard;

 $boardid=$board['boardid'];
 if(!is_array($newboard)) $newboard $db->query_first("SELECT * FROM bb".$n."_boards WHERE boardid = '$newboardid'");

 if($mode=="onlymove" || $mode=="movewithredirect") {
  if($thread['important']==2) {
   list($announcements) = $db->query_first("SELECT COUNT(*) FROM bb".$n."_announcements WHERE threadid='$threadid'");
   if($announcements>1$db->query("INSERT IGNORE INTO bb".$n."_announcements (boardid,threadid) VALUES ('$newboardid','$threadid')");
   else $db->query("UPDATE bb".$n."_announcements SET boardid='$newboardid' WHERE threadid='$threadid' AND boardid='$boardid'");
  }

  $db->query("UPDATE bb".$n."_threads SET boardid='$newboardid' WHERE threadid='$threadid'");
  if($mode=="movewithredirect"$db->query("INSERT INTO bb".$n."_threads (boardid,prefix,topic,iconid,starttime,starterid,starter,lastposttime,lastposterid,lastposter,replycount,views,closed,voted,votepoints,pollid,visible) VALUES ('$boardid','".addslashes($thread['prefix'])."','".addslashes($thread['topic'])."','$thread[iconid]','$thread[starttime]','$thread[starterid]','".addslashes($thread['starter'])."','$thread[lastposttime]','$thread[lastposterid]','".addslashes($thread['lastposter'])."','$thread[replycount]','$thread[views]','3','$thread[voted]','$thread[votepoints]','$threadid','$thread[visible]')");

  $thread['replycount']+=1;
  $db->query("UPDATE bb".$n."_boards SET threadcount=threadcount-1, postcount=postcount-'$thread[replycount]' WHERE boardid IN ($boardid,$board[parentlist])");
  $db->query("UPDATE bb".$n."_boards SET threadcount=threadcount+1, postcount=postcount+'$thread[replycount]' WHERE boardid IN ($newboardid,$newboard[parentlist])");

  if($board['lastthreadid']==$threadidupdateBoardInfo("$boardid,$board[parentlist]",0,$threadid);
  if($newboard['lastposttime']<=$thread['lastposttime']) updateBoardInfo("$newboardid,$newboard[parentlist]",$thread['lastposttime']);

 }
 if($mode=="copy") {
  $db->query("INSERT INTO bb".$n."_threads (threadid,boardid,topic,iconid,starttime,starterid,starter,lastposttime,lastposterid,lastposter,replycount,views,closed,voted,votepoints,pollid,important,visible)
  VALUES (NULL,'$newboardid','".addslashes($thread[topic])."','$thread[iconid]','$thread[starttime]','$thread[starterid]','".addslashes($thread[starter])."','$thread[lastposttime]','$thread[lastposterid]','".addslashes($thread[lastposter])."','$thread[replycount]','$thread[views]','$thread[closed]','$thread[voted]','$thread[votepoints]','$thread[pollid]','$thread[important]','$thread[visible]')");
  $newthreadid=$db->insert_id();

  $result $db->query("SELECT * FROM bb".$n."_announcements WHERE threadid='$threadid'");
  if($db->num_rows($result) > 0) {
   while($row=$db->fetch_array($result)) $db->query("INSERT INTO bb".$n."_announcements (boardid,threadid) VALUES ('$row[boardid]','$newthreadid')");
   $db->query("INSERT IGNORE INTO bb".$n."_announcements (boardid,threadid) VALUES ('$newboardid','$newthreadid')");
  }

  $result $db->query("SELECT * FROM bb".$n."_posts WHERE threadid='$threadid'");
  while($row=$db->fetch_array($result)) {
   $db->query("INSERT INTO bb".$n."_posts (postid,threadid,userid,username,iconid,posttopic,posttime,message,edittime,editorid,editor,editcount,allowsmilies,showsignature,ipaddress,visible,reindex)
   VALUES (NULL,'$newthreadid','$row[userid]','".addslashes($row[username])."','$row[iconid]','".addslashes($row[posttopic])."','$row[posttime]','".addslashes($row[message])."','$row[edittime]','$row[editorid]','".addslashes($row[editor])."','$row[editcount]','$row[allowsmilies]','$row[showsignature]','$row[ipaddress]','$row[visible]','1')");
  }

  $thread['replycount']+=1;
  $db->query("UPDATE bb".$n."_boards SET threadcount=threadcount+1, postcount=postcount+'$thread[replycount]' WHERE boardid IN ($newboardid,$newboard[parentlist])");

  if($newboard['lastposttime']<=$thread['lastposttime']) updateBoardInfo("$newboardid,$newboard[parentlist]",$thread['lastposttime']);

  if($newboard['countuserposts']==1) {
   $result $db->query("SELECT COUNT(postid) AS posts, userid FROM bb".$n."_posts WHERE threadid='$newthreadid' AND visible = 1 AND userid>0 GROUP BY userid");
   while($row=$db->fetch_array($result)) $db->query("UPDATE bb".$n."_users SET userposts=userposts+'$row[posts]' WHERE userid='$row[userid]'");
  }
 }
}

function decode_cookie($data) {
 $result=array();
 $data explode(",",$data);
 for($i=0;$i<count($data)/2;$i++) $result[$data[($i*2)]]=$data[($i*2+1)];
 return $result;
}

function encode_cookie($name,$time=0,$is_visittime=true) {
 global $$name$wbbuserdata;
 $newdata="";
 while(list($key,$val)=each($$name)) {
  if($is_visittime && $wbbuserdata['lastvisit']>=$val) continue;
  if($newdata$newdata.=",$key,$val";
  else $newdata="$key,$val";
 }
 bbcookie($name,$newdata,$time);
}

function isAdmin($mod=0) {
 global $wbbuserdata;

 if($mod==-1) {
  if(!$wbbuserdata['canuseacp'] && !$wbbuserdata['issupermod'] && !$wbbuserdata['ismod']) {
   eval("print(\"".gettemplate("access_error")."\");");
   exit();
  }
 }
 elseif(!$wbbuserdata['canuseacp']) {
  eval("print(\"".gettemplate("access_error")."\");");
  exit();
 }
}

function refresh($url,$time=2) {
 eval("print(\"".gettemplate("refresh")."\");");
}

function makeboardoptions($boardid$depth=1$selected=0$selboardid=0) {
 global $boardcache;

 if(!isset($boardcache[$boardid])) return;

 while (list($key1,$val1) = each($boardcache[$boardid])) {
  while(list($key2,$boards) = each($val1)) {
   $out .= "<option value=\"".$boards[boardid]."\"".ifelse($selected==&& $boards[boardid]==$selboardid," selected").">";
   if($depth>1$out .= str_repeat("--",$depth-1)." ".$boards[title]."</option>";
   else $out .= $boards[title]."</option>";
   $out.=makeboardoptions($boards[boardid],$depth+1,$selected,$selboardid);
  }
 }
 unset($boardcache[$boardid]);
 return $out;
}

function userlevel($userposts,$regdate) {
 global $tpl;

 $regdate = (time()-$regdate)/86400;
 $exp ceil($userposts*$regdate);
 if($exp!=0$level pow(log10($exp),2);
 else $level 0;
 $showlevel floor($level) + 1;
 $nextexp ceil(pow(10,pow($showlevel,0.5)));
 if($showlevel==1$prevexp 0;
 else $prevexp ceil(pow(10,pow($showlevel-1,0.5)));

 $width=ceil((($exp-$prevexp)/($nextexp-$prevexp))*100);
 $needexp number_format($nextexp-$exp,0,"",".");
 eval ("\$expbar = \"".$tpl->get("userlevel_expbar")."\";");

 $exp number_format($exp,0,"",".");
 $nextexp number_format($nextexp,0,"",".");

 eval ("\$userlevel = \"".$tpl->get("userlevel")."\";");
 return $userlevel;
}

function formatFilesize($byte) {
 $string "Byte";
 if($byte>1024) {
  $byte/=1024;
  $string="KB";
 }
 if($byte>1024) {
  $byte/=1024;
  $string="MB";
 }
 if($byte>1024) {
  $byte/=1024;
  $string="GB";
 }

 if(number_format($byte,0)!=$byte$byte=number_format($byte,2);
 return $byte." ".$string;
}

function getIpAddress() {
 global $_SERVER;

 $REMOTE_ADDR=$_SERVER['REMOTE_ADDR'];
 if(isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
     $HTTP_X_FORWARDED_FOR=$_SERVER['HTTP_X_FORWARDED_FOR'];
 }
 else $HTTP_X_FORWARDED_FOR '';

 if($HTTP_X_FORWARDED_FOR!="") {
  if(preg_match("/^([0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)/"$HTTP_X_FORWARDED_FOR$ip_match)) {
   $private_ip_list = array("/^0\./""/^127\.0\.0\.1/""/^192\.168\..*/""/^172\.16\..*/""/^10..*/""/^224..*/""/^240..*/");
   $REMOTE_ADDR preg_replace($private_ip_list$REMOTE_ADDR$ip_match[1]);
  }
 }

 if(strlen($REMOTE_ADDR)>16$REMOTE_ADDR=substr($REMOTE_ADDR016);
 return $REMOTE_ADDR;
}

function updateList($boardidlist,$update,$field="parentlist",$remove=false) {
 global $db$n;

 $update var2key(explode(",",$update));
 unset($update[0]);
 if(count($update)) {
  $result $db->query("SELECT boardid, $field FROM bb".$n."_boards WHERE boardid IN ($boardidlist)");
  while($row=$db->fetch_array($result)) {
   $temp var2key(explode(",",$row[$field]));

   reset($update);
   while(list($key,$val)=each($update)) {
    if($remove) unset($temp[$key]);
    else $temp[$key]=1;
   }

   $temp implode(",",key2var($temp));

   $db->query("UPDATE bb".$n."_boards SET $field = '$temp' WHERE boardid='$row[boardid]'");
  }
 }
}

function var2key($varArray,$value=1) {
 $keyArray=array();

 reset($varArray);
 while(list($key,$val)=each($varArray)) $keyArray[$val]=$value;

 return $keyArray;
}

function key2var($keyArray) {
 $varArray=array();

 reset($keyArray);
 while(list($key,$val)=each($keyArray)) $varArray[]=$key;

 return $varArray;
}

/**
* function version_compare for php < 4.1.0
*
* @param string vercurrent
* @param string vercheck
*
* @param integer check
*/
if (!function_exists('version_compare')) {
    function version_compare($vercurrent$vercheck) {
        $minver explode('.'$vercheck);
        $curver explode('.'$vercurrent);

        if (($curver[0] < $minver[0]) || (($curver[0] == $minver[0]) && ($curver[1] < $minver[1])) || (($curver[0] == $minver[0]) && ($curver[1] == $minver[1]) && ($curver[2][0] < $minver[2][0])))
         return - 1;
        elseif ($curver[0] == $minver[0] && $curver[1] == $minver[1] && $curver[2] == $minver[2])
         return 0;
        else
         return 1;
    }
}

//----------- Start letzte aktivitaet

function tag($timestamp){
  $tag date('d.m.Y'$timestamp);
  $mktime explode('.'date('d.m.Y'time()-86400));
  $uhrzeit date('H:i:s'$timestamp);
  if($tag == date('d.m.Y'time())){
    $tag 'Heute';
  }
  elseif($timestamp >= mktime(000$mktime[1], $mktime[0], $mktime[2]) AND $timestamp <= mktime(235959$mktime[1], $mktime[0], $mktime[2])){
    $tag 'Gestern';
  }
  $return $tag.', '.$uhrzeit;
  return $return;
}

//------------ End

?>

Dieser Beitrag wurde 1 mal editiert, zum letzten Mal von feuerkerk: 12.03.07 19:34.

12.03.07 13:39 feuerkerk ist offline E-Mail Finden Als Freund hinzufügen
Baumstruktur | Brettstruktur
Gehe zu:

Neues Thema erstellen Antwort erstellen

yourWBB » WoltLab Burning Board Generation 2 * » Alles von und für das WBB Lite 1.0.x » [WBB Lite 1.0.x] Allg. Fragen und Probleme » Database Error