📄 debugout.c
字号:
/*
* 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: debugout.c,v 1.7 2003/06/30 15:44:11 takayuki Exp $
*/
#include "debugout.h"
#include "resource.h"
#ifdef DEBUG_ENABLE
#define DBG_SIZE_STRINGBUFFER 512
static HANDLE DebugConsole;
static HWND DialogHandle;
/*
* 僨僶僢僌梡僟僀傾儘僌偺儊僢僙乕僕僴儞僪儔
*/
static LRESULT CALLBACK DebugOutDialogProc(HWND hDlg,UINT Msg,WPARAM wParam,LPARAM lParam)
{
switch(Msg)
{
case WM_INITDIALOG:
DebugConsole = GetDlgItem(hDlg,IDC_DEBUGOUT);
ShowWindow(hDlg,SW_SHOW);
case WM_SIZE:
{
RECT client;
GetClientRect(hDlg,&client);
MoveWindow(DebugConsole,0,0,client.right,client.bottom,TRUE);
break;
}
case WM_CLOSE:
/* Never let this dialog close by pressing of the close button. */
break;
case WM_DESTROY:
DialogHandle = 0;
break;
case WM_QUIT:
DestroyWindow(hDlg);
break;
default:
return FALSE;
}
return TRUE;
}
void InitializeDebugServices(HINSTANCE hinst,HWND dlg)
{
DialogHandle = CreateDialog(hinst,MAKEINTRESOURCE(DEBUGOUTDIALOG),0l,DebugOutDialogProc);
ShowWindow(DialogHandle,SW_SHOW);
}
void FinalizeDebugServices(void)
{
if(DialogHandle != 0l)
DestroyWindow(DialogHandle);
}
int DebugOut(const char * format, ... )
{
int result;
int i;
char buffer[DBG_SIZE_STRINGBUFFER*2];
char * scope;
const char * work;
va_list vl;
if(format == 0l)
return 0;
va_start(vl, format);
/* format偵娷傑傟傞 '\n' 傪 '\r\n' 偵抲姺偡傞 */
scope = buffer;
work = format;
while(*format != '\0')
{
if(*format == '\n')
{
i = format - work;
lstrcpyn(scope, work, i);
scope += i;
work = format;
*(scope++) = '\r';
}
format ++;
}
i = format - work + 1;
lstrcpyn(scope, work, i); //+1偟偰'\x0'傕僐僺乕
scope += i;
if((result = wvsprintf(scope, buffer, vl)) > 0)
{
//弌椡偟偡偓偨傜彮偟僇僢僩
i = GetWindowTextLength(DebugConsole);
if(i > DEBUG_LIMITTERUPPERBOUND)
{
SendMessage(DebugConsole, EM_SETSEL, 0, i - DEBUG_LIMITTERUPPERBOUND);
SendMessage(DebugConsole, EM_REPLACESEL, (WPARAM)FALSE, (LPARAM)"");
}
SendMessage(DebugConsole,EM_SETSEL,i,i);
SendMessage(DebugConsole,EM_REPLACESEL,(WPARAM)FALSE,(LPARAM)scope);
}
return result;
}
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -