1 Star 0 Fork 121

blog/kbengine

forked from likecg/kbengine 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
profile.ipp 2.31 KB
一键复制 编辑 原始数据 按行查看 历史
liquidx 提交于 2013-01-07 17:02 +08:00 . 继续完善cprofile。
/*
This source file is part of KBEngine
For the latest info, see http://www.kbengine.org/
Copyright (c) 2008-2012 KBEngine.
KBEngine is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
KBEngine is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with KBEngine. If not, see <http://www.gnu.org/licenses/>.
*/
namespace KBEngine
{
INLINE const char* ProfileGroup::name()const
{
return name_.c_str();
}
INLINE const ProfileGroup::PROFILEVALS& ProfileGroup::profiles()const
{
return profiles_;
}
INLINE const char * ProfileVal::c_str() const { return name_.c_str(); }
INLINE double ProfileVal::lastTimeInSeconds() const { return stampsToSeconds(lastTime_); }
INLINE double ProfileVal::sumTimeInSeconds() const { return stampsToSeconds( sumTime_ ); }
INLINE double ProfileVal::lastIntTimeInSeconds() const { return stampsToSeconds( lastIntTime_ ); }
INLINE double ProfileVal::sumIntTimeInSeconds() const { return stampsToSeconds( sumIntTime_ ); }
INLINE TimeStamp ProfileVal::lastTime() const
{
return this->running() ? TimeStamp( 0 ) : lastTime_;
}
INLINE TimeStamp ProfileVal::sumTime() const
{
return sumTime_;
}
INLINE TimeStamp ProfileVal::lastIntTime() const
{
return lastIntTime_;
}
INLINE TimeStamp ProfileVal::sumIntTime() const
{
return sumIntTime_;
}
INLINE bool ProfileVal::running() const
{
return inProgress_ > 0;
}
INLINE bool ProfileVal::stop(const char * filename, int lineNum, uint32 qty)
{
this->stop(qty);
const bool tooLong = isTooLong();
if (tooLong)
{
WARNING_MSG(boost::format("%s:%d: Profile %s took %.2f seconds\n") %
filename %
lineNum %
name_.c_str() %
(lastTime_ / stampsPerSecondD()));
}
return true;
}
INLINE bool ProfileVal::isTooLong() const
{
return !this->running() && (lastTime_ > warningPeriod_);
}
INLINE const char* ProfileVal::name()const
{
return name_.c_str();
}
INLINE uint32 ProfileVal::count() const
{
return count_;
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/blog/kbengine.git
git@gitee.com:blog/kbengine.git
blog
kbengine
kbengine
a1b691f57f98fa0bff1bcfb0210ebd07e318c0cd

搜索帮助