amxmodx/tools/docgen/generate/updater.php
2014-07-31 10:22:04 -07:00

567 lines
13 KiB
PHP
Executable File

<pre><?php
set_time_limit(300);
$downloadnew = FALSE;
$dir = ''; // Put DIR here
// Database credentials.
$host = '';
$user = '';
$password = '';
$database = '';
// Output filename.
$filename = '../www/SMfuncs.js';
// Start defines
$funcs = Array();
$filefunclist = Array();
$tableinfo = Array();
$consts = Array();
$version = "";
$thebasedir = dirname(__FILE__);
$defines = Array();
$javascript = "var SMfunctions=new Array()\nvar SMconstant=new Array()\nvar SMfiles=new Array()\nvar SMfiledata=new Array()\n";
function GetFunctionType($str){
switch (strtolower($str)) {
case "native": return 1; break;
case "stock": return 2; break;
case "forward": return 3; break;
case "functag": return 4; break;
}
return 0;
}
function PrepareJava($string){
return addslashes(str_replace("\n","",nl2br($string)));
}
function DecodeTheFile($file){
global $funcs, $conts;
$thelines = file($file);
$thelines[] = "/**";
$basename = basename($file);
$linescount = count($thelines) - 1;
$lines = Array();
$isanotherone = false;
foreach ($thelines as $line_num => $lin) {
$line = trim($lin);
if($line == "") continue;
if(substr($line,0,7) == "#define")
AddDefine(substr($line,8));
if(($line == "/**" && !$isanotherone) || $linescount == $line_num){
if(isset($lines[1])){
$temp = explode(" ",$lines[1][0]);
$type = GetFunctionType($temp[0]);
if($type > 0){
MakeFunction($lines, implode("", $lines[1]) ,$type,$basename);
}else
MakeConstant($lines,$basename);
}
$lines = Array();
$isanotherone = false;
$commented = true;
}
if($line == "{")
$isanotherone = true;
elseif($line{0} == "}")
$isanotherone = false;
if($commented){
$lines[0][] = $line;
} else {
$lines[1][] = $lin;
}
if($line == "*/" && !$isanotherone)
$commented = false;
}
return implode("",$thelines);
}
function AddDefine($str){
if($str{0} == "_")
return;
global $defines;
//Sryl, Preg match is just not working out, too much iregularitires
//The * will bug the preg_match
/*$str = str_replace("*","",$str);
$pattern = '/([$A-Z|8|_^]+)\b([^.*]+)([ | | ]\/)/';
if(!preg_match($pattern, $str, $matches,PREG_OFFSET_CAPTURE)){
echo $str . "\n";
return;
}
$new = substr($str , $matches[2][1] + strlen($matches[2][0]) );
if(strlen($new) > 0){
$new = str_replace(
Array ("/**", "<" , "","/"),
Array ("", "" , "",""),
$new
);
}
*/
$stage = 0;
$stageinfo = Array('','','');
$strlen = strlen($str);
for($i=0; $i < $strlen; $i++){
if(trim($str{$i}) == "" && $stage == 0){
$stage++;
continue;
}
if($str{$i} == "/"){
if(substr($str,$i,3) == "/**"){
$stage++;
$i += 3;
continue;
}
}
if($str{$i} == "*"){
if(substr($str,$i,2) == '*/'){
break;
}
}
$stageinfo[$stage] .= $str{$i};
}
foreach($stageinfo as $i => $a)
$stageinfo[$i] = trim($a);
if($stageinfo[1] != ""){
$defines[] = Array (
'variable' => $stageinfo[0],
'value' => wordwrap(trim($stageinfo[1]) , 35, " " , true ),
'comment' => isset($stageinfo[2]) ? trim($stageinfo[2]) : "",
);
}
if($stageinfo[0] == "SOURCEMOD_VERSION"){
global $version;
$version = str_replace('"',"",$stageinfo[1]);
}
}
function MakeConstant($lines,$file){
global $consts;
$info = Array();
$content = Array();
foreach($lines[0] as $line){
if(substr($line,0,1) != "*") continue;
$thesub = trim(substr($line,2));
if($thesub == "") continue;
$info[] = $thesub;
}
$theinfo = str_replace("@section","", implode("\n",$info));
if(strpos($theinfo,"All rights reserved.")){
$theinfo = "<i>Unclassified</i>";
$newline = Array();
foreach($lines[1] as $lin){
$line = trim($lin);
if(substr($line,0,7) == "#define" && $line{8} != "_")
$newline[] = $line . "\n";
}
if(count($newline) == 0)
return;
$lines[1] = $newline;
}
$consts[] = Array(
'info' => $theinfo,
'content' => trim(implode('',$lines[1])),
'file' => $file,
);
}
function MakeFunction($lines,$function,$type,$file){
global $funcs;
$description = Array();
$funcinput = Array();
$return = Array();
$onerror = Array();
$notes = Array();
$depreached = 0;
$infostarted = false;
$lastone = 0;
foreach($lines[0] as $line){
if(substr($line,0,1) != "*") continue;
$thesub = trim(substr($line,2));
if($thesub == "") continue;
if ($thesub{0} == "@")
$infostarted = true;
if(!$infostarted){
$description[] = $thesub;
}
if ($infostarted && $thesub{0} != "@"){
switch ($lastone) {
case 0:
// if(!isset($funcinput[ count($funcinput) - 1 ]))
// echo $file . "\n" . $function . "\n\n";
$funcinput[ count($funcinput) - 1 ] .= " " . $thesub;
break;
case 1: $return[ count($return) - 1 ] .= " " . $thesub; break;
case 2: $onerror[ count($onerror) - 1 ] .= " " . $thesub; break;
case 3: $notes[ count($notes) - 1 ] .= " " . $thesub; break;
case 4: $description[ count($description) - 1 ] .= " " . $thesub; break;
}
}
if(!$infostarted)
$continue;
if(substr($thesub, 0, 7) == "@return"){
$return[] = trim(substr($thesub, 7));
$lastone = 1;
} elseif(substr($thesub, 0, 11) == "@deprecated"){
$depreached = 1;
} elseif(substr($thesub, 0, 6) == "@error"){
$onerror[] = trim(substr($thesub, 6));
$lastone = 2;
} elseif(substr($thesub, 0, 9) == "@noreturn"){
$return[] = 0;
} elseif(substr($thesub, 0, 5) == "@note"){
$notes[] = substr($thesub, 5);
$lastone = 3;
} elseif(substr($thesub, 0, 6) == "@param") {
$funcinput[] = substr($thesub, 6);
$lastone = 0;
} elseif(substr($thesub, 0, 6) == "@brief") {
$description[] = substr($thesub, 6);
$lastone = 4;
}
}
/*$fullcommand = str_replace(
Array("Float:","Handle:","Action:","bool:","any:","GroupId:","Function:","ReplySource:","QueryCookie:"),
Array("","","","","","","","",""),
$function);*/
$temp = explode("(",$function);
$func = $temp[0];
if(strpos($func, " ") !== false){
$func = trim(substr( $func , strpos($func , " ") ));
}
if(strpos($function, "{") !== false){
$function = trim(substr( $function, 0, strpos($function, "{") ));
}
$thestrpos = strpos($func,":");
if($thestrpos !== false){
$func = substr($func ,$thestrpos + 1);
}
$funcs[] = Array(
'description' => implode("\n",$description),
'input' => implode("\n",$funcinput),
'function' => $func,
'fullfunc' => trim($function),
'return' => implode("\n",$return),
'onerror' => implode("\n",$onerror),
'notes' => implode("\n",$notes),
'file' => $file,
'typeof' => $type,
'depreached' => $depreached
);
}
function db_query($query){
$q = mysql_query($query);
if(!$q){
echo "\n" . mysql_error() . "\n" . $query . "<hr>";
}
return $q;
}
function GetFileAddr(){
$lines = file("http://www.sourcemod.net/builds.php");
foreach ($lines as $line_num => $lin) {
if(substr($lin, 0, 13) == "<li><a href='"){
$explode = explode("<a href='", $lin);
foreach($explode as $a){
if(strpos($a, ".zip")){
$b = explode("'>", $a);
return $b[0];
}
}
}
}
}
function DownloadNew(){
global $thebasedir;
copy( GetFileAddr() ,'build.zip');
$zip = new ZipArchive;
if ($zip->open('build.zip') === TRUE) {
$zip->extractTo($thebasedir . "/build/" );
$zip->close();
} else {
exit( 'Failed to zip' );
}
}
function full_rmdir( $dir ){
if ( !is_writable( $dir ) ){
if ( !@chmod( $dir, 0777 ) ){
return FALSE;
}
}
$d = dir( $dir );
while ( FALSE !== ( $entry = $d->read() ) ){
if ( $entry == '.' || $entry == '..' ){
continue;
}
$entry = $dir . '/' . $entry;
if ( is_dir( $entry ) ){
if ( !$this->full_rmdir( $entry ) ){
return FALSE;
}
continue;
}
if ( !@unlink( $entry ) ){
$d->close();
return FALSE;
}
}
$d->close();
return rmdir( $dir );
}
function FindFileID($file){
global $tableinfo;
foreach($tableinfo['sm_smfiles'] as $fname => $id)
if($file == $fname)
return $id;
return -1;
}
function FindUnusedid($arrayname){
global $tableinfo;
// if(!isset($tableinfo[ $arrayname ]))
// return 0;
$tempinfo = array_flip($tableinfo[ $arrayname ]);
$i = 0;
//Hope this works!!
while( TRUE ){
if(!isset($tempinfo[ $i ]))
return $i;
$i++;
}
}
if($downloadnew)
DownloadNew();
if(strlen(trim($dir)) == 0)
$dir = $thebasedir . '/build/addons/sourcemod/scripting/include';
$files = Array();
if(!($dir_handle = opendir($dir))){
exit('Could not open ' . $dir);
}
while($file = readdir($dir_handle)){
if($file == "." || $file == "..") continue;
if(substr($file, -4, 4) == ".inc"){
$filedir = $dir . "/" . $file;
// if($file == "version.inc"){
// GetVersion($filedir);
// } else {
$files[] = Array(
'Addr' => $filedir,
'name' => $file,
// 'fcount' => 0,
// 'ccount' => 0,
'content' => DecodeTheFile($filedir),
);
// }
}
}
closedir($dir_handle);
$link = mysql_connect($host, $user, $password)
or die('Could not connect: ' . mysql_error());
mysql_select_db($database) or die('Could not select database');
db_query("TRUNCATE TABLE `sm_smconst`");
db_query("TRUNCATE TABLE `sm_smfilescon`");
db_query("TRUNCATE TABLE `sm_smdefine`");
db_query("UPDATE sm_smfunctions SET depreached = 2 WHERE typeof <> 4");
//db_query("TRUNCATE TABLE `smfiles`");
//db_query("TRUNCATE TABLE `smfunctions`");
$tables = Array (
'sm_smfiles' => Array ('filename','id'),
'sm_smfunctions' => Array ('func','id'),
);
foreach ($tables as $name => $table){
$result = db_query('SELECT ' . $table[0] . ',' . $table[1] . ' FROM ' . $name);
$tableinfo[$name] = Array();
while ($line = mysql_fetch_array($result, MYSQL_NUM)) {
$tableinfo[$name][$line[0]] = $line[1];
}
mysql_free_result($result);
}
foreach($files as $file){
$onlyname = str_replace('.inc','',$file['name']);
if(!isset($tableinfo['sm_smfiles'][ $file['name'] ])){
//0 is a ID, so count will make it just right...
$tableinfo['sm_smfiles'][ $file['name'] ] = FindUnusedid('sm_smfiles');
db_query('INSERT INTO sm_smfiles(id,name,filename) VALUES ('. $tableinfo['sm_smfiles'][ $file['name'] ] .',"'.$onlyname.'","'.$file['name'].'")');
}
db_query('INSERT INTO `sm_smfilescon` VALUES ('. $tableinfo['sm_smfiles'][ $file['name'] ] .',\''. addslashes( $file['content'] ) .'\')');
$javascript .= 'SMfiles['. $tableinfo['sm_smfiles'][ $file['name'] ] .'] = "'. $onlyname .'"' . "\n";
}
foreach($funcs as $go){
$gop = str_replace('"', '\"', $go );
$fid = FindFileID($gop['file']);
$javacontent = PrepareJava($gop['description'] );
if(isset($tableinfo['sm_smfunctions'][ $gop['function'] ])){
$sql = 'UPDATE sm_smfunctions
SET fullfunc = "'.$gop['fullfunc'].'",
description = "'.$gop['description'].'",
`treturn` = "'.$gop['return'].'",
`onerror` = "'.$gop['onerror'].'",
`funcinput` = "'.$gop['input'].'",
inc = '.$fid.',
incname = "'.$gop['file'].'",
typeof ='.$gop['typeof'].',
depreached = '.$gop['depreached'].'
WHERE id = '. $tableinfo['sm_smfunctions'][ $gop['function'] ] .'';
} else {
$tableinfo['sm_smfunctions'][ $gop['function'] ] = FindUnusedid('sm_smfunctions');
$sql = 'INSERT INTO sm_smfunctions(id,func,fullfunc,description,`treturn`,`onerror`,`funcinput`,inc,incname,typeof,version) VALUES
('. $tableinfo['sm_smfunctions'][ $gop['function'] ] .',
"'.$gop['function'].'",
"'.$gop['fullfunc'].'",
"'.$javacontent.'",
"'.$gop['return'].'",
"'.$gop['onerror'].'",
"'.$gop['input'].'",
'.$fid.',
"'.$gop['file'].'",
'.$gop['typeof'].',
\''.$version.'\'
)';
}
$javascript .= 'SMfunctions['. $tableinfo['sm_smfunctions'][ $gop['function'] ] .'] = Array ("'.$gop['function'].'","'.$javacontent.'");' . "\n";
$filefunclist[$fid][] = $tableinfo['sm_smfunctions'][ $gop['function'] ];
$query = db_query($sql);
}
foreach($consts as $go){
$gop = str_replace('"', '\"', $go );
$fid = FindFileID($gop['file']);
$sql = 'INSERT INTO sm_smconst(fileid,descrip,`fulltext`) VALUES
('.$fid.',
"'.$gop['info'].'",
"'.$gop['content'].'"
)';
$query = db_query($sql);
}
foreach($filefunclist as $id => $go){
$javascript .= 'SMfiledata['. $id .'] = Array ('. implode(",",$go) .');' . "\n";
}
foreach($defines as $id => $go){
$gop = str_replace('"', '\"', $go );
$sql = 'INSERT INTO `sm_smdefine` (`id`,`variable` ,`value` ,`comment`) VALUES ('.$id.',"'.$gop['variable'].'", "'.$gop['value'].'", "'.$gop['comment'].'")';
$javascript .= 'SMconstant['.$id.'] = Array ("'. PrepareJava($gop['variable']) .'","'. PrepareJava($gop['value']) .'","'. PrepareJava($gop['comment']) .'");' . "\n";
db_query($sql);
}
db_query('UPDATE `sm_sminfo` SET infob = "'.$version.'" WHERE master = "version"');
foreach($tableinfo['sm_smfiles'] as $fid){
db_query('UPDATE sm_smfiles SET
`fcount` = (SELECT COUNT(*) FROM sm_smfunctions WHERE inc = '.$fid.'),
`ccount` = (SELECT COUNT(*) FROM sm_smconst WHERE fileid = '.$fid.')
WHERE id = '.$fid.'');
}
$res = mysql_query("SELECT id FROM sm_smfunctions WHERE depreached = 2");
while (($row = mysql_fetch_array($res)) !== FALSE)
{
db_query("DELETE FROM sm_smposts WHERE func = " . $row[0]);
db_query("DELETE FROM sm_smfunctions WHERE id = " . $row[0]);
}
mysql_free_result($res);
mysql_close($link);
//$filename = "SMfuncs.js";
if (!$handle = fopen($filename, 'w')) {
echo "Cannot open file ($filename)";
exit;
}
echo $javascript;
// Write $somecontent to our opened file.
if (fwrite($handle, $javascript) === FALSE) {
echo "Cannot write to file ($filename)";
exit;
}
fclose($handle);
?>