在项目开发中发现对php的文档缺少管理,别人写了一个,功能不多
docdirname = doc/;
}
/**
* 函数名称: createdoc($root,$newdir,$mode=1,$filter=null)
* 函数功能: 创建文档
* 输入参数: $root -------------- 源目录
$newdir ----------- 目标目录
$mode ------------- 模式,1为普通,2为扩展
$filter ------------ 过滤目录
* 函数返回值: 返回值说明
* 其它说明: 2004-10-13
*/
function createdoc($root,$newdir,$mode=1,$filter=null)
{
$getarr = $this->loopdir($root,$filter);
$i = 0;
$this->createframe($newdir);
foreach($getarr as $key=>$val)
{
if($this->getphpfiles($val))
{
$content = $this->getcontent($val);
$content = $this->getdoc($content,$mode);
$filepath = $this->setfilepath($val,$root,$newdir);
$filedir = $this->getfiledir($filepath);
$this->mkdirs($filedir);
$this->setdoc($filepath,$content);
$data[$i]['url'] = $filepath;
$data[$i]['name'] = $val;
$i++;
}
}
if(!empty($data))
{
$this->createmenu($newdir,$data);
$this->redirect($this->docdir);
}
}
/**
* 函数名称: redirect($path)
* 函数功能: 转向
* 输入参数: $path ---------------- 转向路径
* 函数返回值: 返回值说明
* 其它说明: 2004-10-13
*/
function redirect($path)
{
echo 生成文档成功,点击此处查看;
}
/**
* 函数名称: loopdir($root,$filter=null)
* 函数功能: 遍历目录
* 输入参数: $root ------------------- 源目录
$filter ----------------- 过滤
* 函数返回值: array
* 其它说明: 2004-10-13
*/
function loopdir($root,$filter=null)
{
static $getarr=array();
$d = dir($root);
while (false !== ($entry = $d->read()))
{
if ($entry == . || $entry == ..)
{
continue;
}
if($this->filter($entry,$filter))
{
if(is_dir($root.$entry))
{
$this->loopdir($d->path.$entry./);
}
else
{
$getarr[] = $d->path.$entry;
}
}
}
$d->close();
return $getarr;
}
/**
* 函数名称: getphpfiles($path)
* 函数功能: 提取php文档
* 输入参数: $path ---------------- 文档路径
* 函数返回值: bool
* 其它说明: 2004-10-13
*/
function getphpfiles($path)
{
$type = preg_replace('/.*\.(.*[^\.].*)/i','\\1',$path);
$type = strtolower($type);
if($type==php)
{
return true;
}
else
{
return false;
}
}
/**
* 函数名称: getcontent($path)
* 函数功能: 读取文件内容
* 输入参数: $path ------------------- 文件路径
* 函数返回值: string
* 其它说明: 2004-10-13
*/
function getcontent($path)
{
$fp = file($path);
$content = implode('',$fp);
return $content;
}
/**
* 函数名称: getdoc($content,$mode=1)
* 函数功能: 取出php文件中的注释
* 输入参数: $content ------------ 文档内容
$mode --------------- 模式,1为普通,2为扩展
* 函数返回值: string
* 其它说明: 2004-10-13
*/
function getdoc($content,$mode=1)
{
switch($mode)
{
case '1':
$pattern = '/\/(\*)[\r\n].*\*\//isu';
break;
case '2':
$pattern = '/\/\*.*\*\//isu';
break;
}
preg_match_all($pattern,$content,$carr);
$getarr = array();
foreach($carr[0] as $key=>$val)
{
$getarr[] = trim($val);
}
$str = implode(
,$getarr);
$str = preg_replace('/[\r]/i','
',$str);
$style = $this->getstyle();
$str = $this->gettable($str);
$str = $style.$str;
return $str;
}
/**
* 函数名称: etfilepath($filepath,$oldroot,$newroot)
* 函数功能: 设置生成文件的路径
* 输入参数: $filepath -------------- 源文件路径
$oldroot -------------- 源目录路径
$newroot -------------- 目标目录路径
* 函数返回值: string
* 其它说明: 2004-10-13
*/
function setfilepath($filepath,$oldroot,$newroot)
{
$oldroot = str_replace('/',\\/,$oldroot);
$pattern = /.$oldroot.(.*)/iu;
$filepath = preg_replace($pattern,'\\1',$filepath);
$newpath = $newroot.$this->docdirname.$filepath;//echo $newpath
;
$newpath = preg_replace('/(.*\.)(.*[^\.].*)/i','\\1htm',$newpath);
return $newpath;
}
/**
* 函数名称: getfiledir($path)
* 函数功能: 取得文档目录
* 输入参数: $path ------------- 文档路径
* 函数返回值: string
* 其它说明: 2004-10-13
*/
function getfiledir($path)
{
$getpath = preg_replace('/(.*)(\/.*[^\.].*)/i','\\1',$path);
return $getpath;
}
/**
* 函数名称: setdoc
* 函数功能: 将注释写入指定目录并生成页面
* 输入参数: $filepath --------------- 目录路径
$content ---------------- 写入的内容
* 函数返回值: 返回值说明
* 其它说明: 说明
*/
function setdoc($filepath,$content)
{
$fp = fopen($filepath,w+);
flock($fp,lock_ex);
fwrite($fp,$content);
flock($fp, lock_un);
}
/**
* 函数名称: mkdirs($path)
* 函数功能: 创建目录
* 输入参数: $path ------------------- 路径
* 函数返回值: none
* 其它说明: 2004-10-13
*/
function mkdirs($path)
{
$adir = explode('/',$path);
$dirlist = '';
$rootdir = $adir[0];
array_shift ($adir);
foreach($adir as $key=>$val)
{
if($val!='.'&&$val!='..')
{
$dirlist .= /.$val;
$dirpath = $rootdir.$dirlist;
if(!file_exists($dirpath)&&!is_file($dirpath))
{
mkdir($dirpath);
chmod($dirpath,0777);
}
}
}
}
/**
* 函数名称: filter($item,$arr=null)
* 函数功能: 过滤
* 输入参数: $item -------------- 内容
$arr --------------- 过滤项
* 函数返回值: bool
* 其它说明: 2004-10-13
*/
function filter($item,$arr=null)
{
$item = strtolower($item);
$filter = explode(',',$arr);
if($arr==null||!in_array($item,$filter))
{
return true;
}
else
{
return false;
}
}
/**
* 函数名称: createframe($root)
* 函数功能: 生成框架页
* 输入参数: $root --------------- 首页的存放目录
* 函数返回值: str
* 其它说明: 2004-10-13
*/
function createframe($root)
{
$str = '