📄 message.cpp
字号:
/*
* TOPPERS/JSP Kernel
* Toyohashi Open Platform for Embedded Real-Time Systems/
* Just Standard Profile Kernel
*
* Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
* Toyohashi Univ. of Technology, JAPAN
*
* 忋婰挊嶌尃幰偼丆埲壓偺 (1)乣(4) 偺忦審偐丆Free Software Foundation
* 偵傛偭偰岞昞偝傟偰偄傞 GNU General Public License 偺 Version 2 偵婰
* 弎偝傟偰偄傞忦審傪枮偨偡応崌偵尷傝丆杮僜僼僩僂僃傾乮杮僜僼僩僂僃傾
* 傪夵曄偟偨傕偺傪娷傓丏埲壓摨偠乯傪巊梡丒暋惢丒夵曄丒嵞攝晍乮埲壓丆
* 棙梡偲屇傇乯偡傞偙偲傪柍彏偱嫋戻偡傞丏
* (1) 杮僜僼僩僂僃傾傪僜乕僗僐乕僪偺宍偱棙梡偡傞応崌偵偼丆忋婰偺挊嶌
* 尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕偑丆偦偺傑傑偺宍偱僜乕
* 僗僐乕僪拞偵娷傑傟偰偄傞偙偲丏
* (2) 杮僜僼僩僂僃傾傪丆儔僀僽儔儕宍幃側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒傞宍偱嵞攝晍偡傞応崌偵偼丆嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡
* 幰儅僯儏傾儖側偳乯偵丆忋婰偺挊嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰
* 偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (3) 杮僜僼僩僂僃傾傪丆婡婍偵慻傒崬傓側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒側偄宍偱嵞攝晍偡傞応崌偵偼丆師偺偄偢傟偐偺忦審傪枮偨偡偙
* 偲丏
* (a) 嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡幰儅僯儏傾儖側偳乯偵丆忋婰偺挊
* 嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (b) 嵞攝晍偺宍懺傪丆暿偵掕傔傞曽朄偵傛偭偰丆TOPPERS僾儘僕僃僋僩偵
* 曬崘偡傞偙偲丏
* (4) 杮僜僼僩僂僃傾偺棙梡偵傛傝捈愙揑傑偨偼娫愙揑偵惗偠傞偄偐側傞懝
* 奞偐傜傕丆忋婰挊嶌尃幰偍傛傃TOPPERS僾儘僕僃僋僩傪柶愑偡傞偙偲丏
*
* 杮僜僼僩僂僃傾偼丆柍曐徹偱採嫙偝傟偰偄傞傕偺偱偁傞丏忋婰挊嶌尃幰偍
* 傛傃TOPPERS僾儘僕僃僋僩偼丆杮僜僼僩僂僃傾偵娭偟偰丆偦偺揔梡壜擻惈傕
* 娷傔偰丆偄偐側傞曐徹傕峴傢側偄丏傑偨丆杮僜僼僩僂僃傾偺棙梡偵傛傝捈
* 愙揑傑偨偼娫愙揑偵惗偠偨偄偐側傞懝奞偵娭偟偰傕丆偦偺愑擟傪晧傢側偄丏
*
* @(#) $Id: message.cpp,v 1.1 2006/04/14 02:46:06 9564907 Exp $
*/
// $Header: J:\\SapporoSoft\\usb20\\S1R72V05\\Debug\\Repository/S1R72V05_Toppers/Toppers/cfg/base/message.cpp,v 1.1 2006/04/14 02:46:06 9564907 Exp $
#include "base/message.h"
using namespace std;
/*****************************************************************************/
/*
* 儊僢僙乕僕弌椡梡暥帤楍惍宍僿儖僷乕僋儔僗
*/
//僨僼僅儖僩僐儞僗僩儔僋僞
Formatter::Formatter(void) throw() : templatestring(""), accept(false)
{}
//僐儞僗僩儔僋僞
Formatter::Formatter(string src) throw() : templatestring(src)
{ shift(); }
//僐僺乕僐儞僗僩儔僋僞
Formatter::Formatter(const Formatter & src) throw() : templatestring(src.templatestring), accept(src.accept)
{
string work;
work = src.content.str();
content << work;
}
//師偺堷悢偺憓擖愭傊偲堏摦
void Formatter::shift(void) throw()
{
string::size_type pos;
accept = false;
if(!templatestring.empty()) {
do {
pos = templatestring.find_first_of("%");
if(pos != string::npos) {
/* %偑偁偭偰偦傟偑\%偲偄偆宍側傜丄%傪偦偺傑傑弌偡 */
if(pos != string::npos && pos != 0 && templatestring.at(pos - 1) == '\\') {
if(pos > 1)
content << templatestring.substr(0, pos - 2);
content << '%';
templatestring = templatestring.substr(pos + 1);
continue;
}
else {
/* %偑傑偩偁傞 */
if(pos != string::npos)
accept = true;
break;
}
}
} while(pos != string::npos);
if(pos != string::npos) {
if(pos != 0)
content << templatestring.substr(0, pos);
templatestring = templatestring.substr(pos + 1);
}
else {
content << templatestring;
templatestring.erase();
}
}
}
//枹愝掕偺堷悢傪 (null) 偱抲姺
void Formatter::shift_all(void) throw()
{
while(accept)
*this << "(null)";
}
//撪晹儊僢僙乕僕偺庢傝弌偟
string Formatter::str(void) throw()
{
shift_all();
return content.str();
}
//僥儞僾儗乕僩暥帤楍偺愝掕 (拞恎偼徚偊傞)
void Formatter::assign(string src) throw()
{
clear();
templatestring.assign(src);
shift();
}
//撪梕偺徚嫀
void Formatter::clear(void) throw()
{
if(!templatestring.empty())
templatestring.erase();
content.str(string(""));
accept = false;
}
//戙擖墘嶼巕
Formatter & Formatter::operator =(const Formatter & src) throw()
{
string work;
templatestring = src.templatestring;
accept = src.accept;
work = src.content.str();
content << work;
return *this;
}
/*****************************************************************************/
/*
* 儊僢僙乕僕弌椡梡暥帤楍惍宍僿儖僷乕僋儔僗
*/
const char * Message::MessageControl::select(const char * msg1, const char * msg2, va_list vl) throw()
{
const char * msg = msg1;
int i = language;
if(i > 0) {
msg = msg2;
while(--i > 0)
msg = va_arg(vl, const char *);
}
return msg;
}
//僨僼僅儖僩僐儞僗僩儔僋僞 (僥僗僩梡)
Message::Message(void) throw()
{}
//僐儞僗僩儔僋僞
Message::Message(string src) throw() : Formatter(src)
{}
//僐儞僗僩儔僋僞 (暋悢尵岅)
Message::Message(const char * src1, const char * src2, ...) throw()
{
va_list vl;
va_start(vl, src2);
templatestring.assign(Singleton<MessageControl>::getInstance()->select(src1, src2, vl));
shift();
}
//僐僺乕僐儞僗僩儔僋僞
Message::Message(const Message & src) throw() : Formatter(src)
{}
//攈惗僋儔僗偺弶婜壔梡娭悢 (暋悢尵岅)
void Message::_initialize(const char * src1, const char * src2, va_list vl) throw()
{
content.clear();
accept = false;
templatestring.assign(Singleton<MessageControl>::getInstance()->select(src1, src2, vl));
shift();
}
//尵岅慖戰
void Message::selectLanguage(enum tagLanguage lang) throw()
{
if(lang >= 0 && lang < LAST_LANG)
Singleton<Message::MessageControl>::getInstance()->setLanguage(lang);
}
//僥儞僾儗乕僩暥帤楍偺愝掕 (拞恎偼徚偊傞)
void Message::assign(const char * src1, const char * src2, ... ) throw()
{
va_list vl;
clear();
va_start(vl, src2);
templatestring.assign(Singleton<MessageControl>::getInstance()->select(src1, src2, vl));
shift();
}
/*****************************************************************************/
/*
* 忕挿弌椡梡暥帤楍惍宍僿儖僷乕僋儔僗
*/
//僨僼僅儖僩僐儞僗僩儔僋僞
VerboseMessage::VerboseMessage(void) throw() : Message()
{}
//僐儞僗僩儔僋僞
VerboseMessage::VerboseMessage(const char * src) throw() : Message(src)
{}
//僐儞僗僩儔僋僞
VerboseMessage::VerboseMessage(const string & src) throw() : Message(src)
{}
//僐儞僗僩儔僋僞
VerboseMessage::VerboseMessage(const char * src1, const char * src2, ... ) throw() : Message()
{
va_list vl;
va_start(vl, src2);
_initialize(src1, src2, vl);
}
//僨僗僩儔僋僞
VerboseMessage::~VerboseMessage(void) throw()
{ Singleton< VerboseControl >::getInstance()->operator << (str()); }
/*****************************************************************************/
/*
* 椺奜儊僢僙乕僕梡暥帤楍惍宍僿儖僷乕僋儔僗
*/
//僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(const char * src) throw() : Message(src), level(DEFAULT)
{}
//僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(const std::string & src) throw() : Message(src), level(DEFAULT)
{}
//僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(const char * src1, const char * src2, ...) throw() : Message(), level(DEFAULT)
{
va_list vl;
va_start(vl, src2);
_initialize(src1, src2, vl);
}
//僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(enum tagLevel _level) throw() : Message(), level(_level)
{}
//僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(enum tagLevel _level, const char * src) throw() : Message(src), level(_level)
{}
//僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(enum tagLevel _level, const std::string & src) throw() : Message(src), level(_level)
{}
//僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(enum tagLevel _level, const char * src1, const char * src2, ...) throw() : Message(), level(_level)
{
va_list vl;
va_start(vl, src2);
_initialize(src1, src2, vl);
}
//僐僺乕僐儞僗僩儔僋僞
ExceptionMessage::ExceptionMessage(const ExceptionMessage & src) throw() : Message(src), level(src.level)
{}
/*****************************************************************************/
/*
* 僨僶僢僌儊僢僙乕僕梡暥帤楍惍宍僿儖僷乕僋儔僗
*/
//僐儞僗僩儔僋僞
DebugMessage::DebugMessage(string src) throw() : Formatter(src)
{}
//僨僗僩儔僋僞
DebugMessage::~DebugMessage(void) throw()
{ Singleton<DebugControl>::getInstance()->operator << (str()); }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -