周梦康 发表于 2014-07-31 9059 次浏览 标签 : ThinkSNS

首先说下开启调试模式完整操作。

1、\config\config.inc.php配置文件中增加两个键值对

    'APP_DEBUG'         =>  true,
    'SHOW_PAGE_TRACE'   =>  true,

2、把index.php里面的报错给开启

ini_set('display_errors',true);
error_reporting(E_ALL);
set_time_limit(0);

3、把\core\core.php里的$ts['_debug']改为true

如果没有做第三步操作,你可能需要去频繁的清除缓存。因为我们开发的时候我们是肯定不希望模版是被缓存的,因为变动很大嘛,我之前的解决办法是,在入口执行了一次清除缓存

pclose(popen('php '.__DIR__.'/cleancache.php','r'));

其实呢,这样做之后发现,模版目录_runtime已经被清空了,但是还是不是自己最新修改的内容。这是因为ThinkSNS的调试除了ThinkPHP自带的调试外,在模版编译这块使用的是自己的调试标识变量($ts['_debug'])。

看下$ts['_debug']在下面两处使用到了

# 第一处 \core\core.php

//载入核心运行时文件
if(file_exists(CORE_PATH.'/'.CORE_MODE.'Runtime.php') && !$ts['_debug']){
	include CORE_PATH.'/'.CORE_MODE.'Runtime.php';
}else{
	include CORE_LIB_PATH.'/'.CORE_MODE.'.php';
}

# 第二处 \core\OpenSociax\functions.inc.php
function fetch(...){
    if(!$ts['_debug'] && file_exists($templateCacheFile)) {
        extract($tvar, EXTR_OVERWRITE);
        //载入模版缓存文件
        include $templateCacheFile;
    //重新编译
    }else{
        tshook('tpl_compile',array('templateFile',$templateFile));
        // 缓存无效 重新编译
        tsload(CORE_LIB_PATH.'/Template.class.php');
        tsload(CORE_LIB_PATH.'/TagLib.class.php');
        tsload(CORE_LIB_PATH.'/TagLib/TagLibCx.class.php');
        $tpl    =   Template::getInstance();
        // 编译并加载模板文件
        $tpl->load($templateFile,$tvar,$charset);
    }
}

评论列表