📄 redlofkillerdlg.h
字号:
// RedLofKillerDlg.h : header file
//
#if !defined(AFX_REDLOFKILLERDLG_H__04D8FDA2_CD63_4903_879B_7615DD6B6AC6__INCLUDED_)
#define AFX_REDLOFKILLERDLG_H__04D8FDA2_CD63_4903_879B_7615DD6B6AC6__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
/////////////////////////////////////////////////////////////////////////////
// CRedLofKillerDlg dialog
#define WM_CONFIRM WM_USER + 1
class CRedLofKillerDlg : public CDialog
{
friend class CConfirmDlg;
//公有静态方法定义
public:
static int CALLBACK BrowseCallBack(HWND hWnd, UINT uMsg, LPARAM lParam, LPARAM lpData);
static DWORD WINAPI ScanThread(LPVOID lpParam);
enum {SCAN_OK,SCAN_FAILED};
enum {VIRUS_DEL, VIRUS_CLEAR, VIRUS_IGNORE};
// Construction
public:
CRedLofKillerDlg(CWnd* pParent = NULL); // standard constructor
// Dialog Data
//{{AFX_DATA(CRedLofKillerDlg)
enum { IDD = IDD_REDLOFKILLER_DIALOG };
CListBox m_lstInfected;
CStatic m_stScanProgress;
//}}AFX_DATA
// ClassWizard generated virtual function overrides
//{{AFX_VIRTUAL(CRedLofKillerDlg)
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
//}}AFX_VIRTUAL
// Implementation
protected:
HICON m_hIcon;
// Generated message map functions
//{{AFX_MSG(CRedLofKillerDlg)
virtual BOOL OnInitDialog();
afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
afx_msg void OnSelectFolder();
afx_msg void OnScanStart();
afx_msg void OnScanStop();
//}}AFX_MSG
afx_msg void OnConfirm(WPARAM wParam,LPARAM lParam);
DECLARE_MESSAGE_MAP()
//自定义私有函数
private:
//对指定文件夹下的所有文件进行扫描,并杀毒
int ScanFolder(CString& argFolder);
//对指定文件进行查杀
int ScanFile(CString& argFile);
int InitApp();
//初始化计数器
int InitCnt();
//自定义私有成员变量
private:
CString m_strFolderScan; // 存储将要被扫描的文件夹的名称
CArray<CString,CString> m_strExt; //存储可能被感染的文件类型的扩展名
int m_nExtCnt; //可能被感染的文件扩展名的类型数
char m_lpVirusFlag[MAX_PATH];
char m_lpVirusExecStart[50]; //病毒执行码的起始标志字符串
char m_lpVirusExecEnd[50]; //病毒执行码的结束标志字符串
int m_handleType; //对被感染文件的处理方式
BOOL m_bUseToAll; //标志变量,决定是否将上一次的处理方式适用于所有对象
int m_nScanTotalCount; //扫描的所有文件的个数
int m_nInfectedCnt; //被感染的文件个数
int m_nKilledCnt; //被清除病毒的文件个数
int m_nDelCnt; //被删除的带毒文件个数
int m_nIgnoreCnt; //被忽略处理的带毒文件个数
HANDLE m_hThreadScan; //扫描线程的句柄
BOOL m_bExitScan; //标识退出线程的标志变量
};
//{{AFX_INSERT_LOCATION}}
// Microsoft Visual C++ will insert additional declarations immediately before the previous line.
#endif // !defined(AFX_REDLOFKILLERDLG_H__04D8FDA2_CD63_4903_879B_7615DD6B6AC6__INCLUDED_)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -