小工具 - 用Astyle的DLL封装一个对目录进行代码格式化的工具

news2024/9/24 3:26:21

文章目录

    • 小工具 - 用Astyle的DLL封装一个对目录进行代码格式化的工具
    • 概述
    • 笔记
    • 效果
    • 编译AStyle的DLL
    • 初次使用接口的小疑惑
    • 测试程序 - 头文件
    • 测试程序 - 实现文件
    • 测试程序 - RC
    • 备注
    • END

小工具 - 用Astyle的DLL封装一个对目录进行代码格式化的工具

概述

上一个实验(vs2019 - astyle-extension 扩展插件的编译与使用)用Astyle的vs插件,在VS中,已经可以很方便的对实现文件或者选定的代码进行格式化。

正好想对自己手头要完工的工程进行入库前的全部格式化。
如果在VS中,手工逐个对文件进行格式化,那就蠢的连自己都看不过去。
以前做代码格式化,都是用AStyle.exe对单个文件做格式化。控制的粒度不够细,如果出了错误,也不知道啥错误。
想按照VS插件那样,用AStyle的dll封装一下,做个应用给自己用,实现对目录中实现文件的格式化。

用了2天,搞定。
遍历目录中的(.h, .cpp), 自动进行格式化。如果报错,就断言。

笔记

效果

在这里插入图片描述

编译AStyle的DLL

在这里插入图片描述
在这里插入图片描述
最好Debug/Release都编译了,可以和自己APP的Debug/Release版对上。
头文件只有2个
在这里插入图片描述

初次使用接口的小疑惑

在这里插入图片描述

psz_rc = AStyleMain(pSourceIn, pszOption, my_fpError, my_fpAlloc);

AStyleMain的参数1为pSourceIn 看起来像是要送入的源文件。
将pSourceIn赋值为源文件全路径名称(e.g. “d:\my_tmp\test.cpp”)
执行的没错,但是用BC4比较格式化完的文件与备份,发现没任何变化…
去查看AStyle自带的测试工程,才发现,原来pSourceIn是要格式化的文件内容…

测试程序 - 头文件


// myAstyleAppDlg.h: 头文件
//

#pragma once

#include <string>

// CmyAstyleAppDlg 对话框
class CmyAstyleAppDlg : public CDialogEx {
    // --------------------------------------------------------------------------------
    // my code begin
    // --------------------------------------------------------------------------------
  public:
    typedef bool (CmyAstyleAppDlg::*PFN_CB_FindFile)(CString csFilePathName);

  private:
    bool code_format_dir(const TCHAR* pszDirPathName, const char* pszOption);
    bool code_format_file(const TCHAR* pszWFilePathName, const char* pszOption);
    std::string my_W2A(std::wstring strW);

    size_t getFileSize(const TCHAR* pszFilePathName);
    bool ReadFileToBuffer(const TCHAR* pszFilePathName, uint8_t*& pBuf, int& lenBuf);
    bool WriteBufferToFile(const TCHAR* pszFilePathName, const uint8_t* pBuf, int lenBuf);
    bool findDir(CString csDirPathName, PFN_CB_FindFile pfn);
    bool CB_FindFile_code_format(CString csFilePathName);
    bool isObjFile(const TCHAR* pObjPostFix);
    bool addTip(CString csMsg);
    CString BrowserDir(CString DirToBrowser);

    int m_iProcessOk;

    // --------------------------------------------------------------------------------
    // my code end
    // --------------------------------------------------------------------------------

    // 构造
  public:
    CmyAstyleAppDlg(CWnd* pParent = nullptr);	// 标准构造函数

    // 对话框数据
    #ifdef AFX_DESIGN_TIME
    enum { IDD = IDD_MYASTYLEAPP_DIALOG };
    #endif

  protected:
    virtual void DoDataExchange(CDataExchange* pDX);	// DDX/DDV 支持


    // 实现
  protected:
    HICON m_hIcon;

    // 生成的消息映射函数
    virtual BOOL OnInitDialog();
    afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
    afx_msg void OnPaint();
    afx_msg HCURSOR OnQueryDragIcon();
    DECLARE_MESSAGE_MAP()
  public:
    afx_msg void OnBnClickedOk();
    afx_msg void OnBnClickedCancel();
    afx_msg void OnBnClickedButtonAstyleDir();
    afx_msg void OnBnClickedButtonSeclectDir();
    CString m_csDir;
    CString m_csAstyleOption;
    CString m_csTip;
    CEdit m_ctrlTip;
};

测试程序 - 实现文件


// myAstyleAppDlg.cpp: 实现文件
//

#include "pch.h"
#include "framework.h"
#include "myAstyleApp.h"
#include "myAstyleAppDlg.h"
#include "afxdialogex.h"
#include "CLsFileDialog.h"

#include "astyle_main.h"
#if defined(_DEBUG)
    #pragma comment(lib, "AStyle31d.lib")
#elif defined(NDEBUG)
    #pragma comment(lib, "AStyle31.lib")
#else
    #error "error, please modify code!"
#endif

#ifdef _DEBUG
    #define new DEBUG_NEW
#endif


// 用于应用程序“关于”菜单项的 CAboutDlg 对话框

class CAboutDlg : public CDialogEx {
  public:
    CAboutDlg();

    // 对话框数据
    #ifdef AFX_DESIGN_TIME
    enum { IDD = IDD_ABOUTBOX };
    #endif

  protected:
    virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

    // 实现
  protected:
    DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX) {
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX) {
    CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()


// CmyAstyleAppDlg 对话框



CmyAstyleAppDlg::CmyAstyleAppDlg(CWnd* pParent /*=nullptr*/)
    : CDialogEx(IDD_MYASTYLEAPP_DIALOG, pParent)
    , m_csDir(_T(""))
    , m_csTip(_T(""))
    , m_csAstyleOption(TEXT("")) {
    m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CmyAstyleAppDlg::DoDataExchange(CDataExchange* pDX) {
    CDialogEx::DoDataExchange(pDX);
    DDX_Text(pDX, IDC_EDIT_DIR, m_csDir);
    DDX_Text(pDX, IDC_EDIT_ASTYLE_OPTION, m_csAstyleOption);
    DDX_Text(pDX, IDC_EDIT_TIP, m_csTip);
    DDX_Control(pDX, IDC_EDIT_TIP, m_ctrlTip);
}

BEGIN_MESSAGE_MAP(CmyAstyleAppDlg, CDialogEx)
    ON_WM_SYSCOMMAND()
    ON_WM_PAINT()
    ON_WM_QUERYDRAGICON()
    ON_BN_CLICKED(IDOK, &CmyAstyleAppDlg::OnBnClickedOk)
    ON_BN_CLICKED(IDCANCEL, &CmyAstyleAppDlg::OnBnClickedCancel)
    ON_BN_CLICKED(IDC_BUTTON_ASTYLE_DIR, &CmyAstyleAppDlg::OnBnClickedButtonAstyleDir)
    ON_BN_CLICKED(IDC_BUTTON_SECLECT_DIR, &CmyAstyleAppDlg::OnBnClickedButtonSeclectDir)
END_MESSAGE_MAP()


// CmyAstyleAppDlg 消息处理程序

BOOL CmyAstyleAppDlg::OnInitDialog() {
    CDialogEx::OnInitDialog();
    // 将“关于...”菜单项添加到系统菜单中。
    // IDM_ABOUTBOX 必须在系统命令范围内。
    ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
    ASSERT(IDM_ABOUTBOX < 0xF000);
    CMenu* pSysMenu = GetSystemMenu(FALSE);

    if (pSysMenu != nullptr) {
        BOOL bNameValid;
        CString strAboutMenu;
        bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
        ASSERT(bNameValid);

        if (!strAboutMenu.IsEmpty()) {
            pSysMenu->AppendMenu(MF_SEPARATOR);
            pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
        }
    }

    // 设置此对话框的图标。  当应用程序主窗口不是对话框时,框架将自动
    //  执行此操作
    SetIcon(m_hIcon, TRUE);			// 设置大图标
    SetIcon(m_hIcon, FALSE);		// 设置小图标
    // TODO: 在此添加额外的初始化代码
    m_ctrlTip.SetLimitText(32 * 1024 * 1024); // 默认是32K, 太小了.
    m_csAstyleOption.Empty();
    m_csAstyleOption += TEXT("--mode=c");
    m_csAstyleOption += TEXT(" --style=google");
    m_csAstyleOption += TEXT(" --indent=spaces=4");
    m_csAstyleOption += TEXT(" --attach-namespaces");
    m_csAstyleOption += TEXT(" --attach-classes");
    m_csAstyleOption += TEXT(" --attach-inlines");
    m_csAstyleOption += TEXT(" --attach-extern-c");
    m_csAstyleOption += TEXT(" --attach-closing-while");
    m_csAstyleOption += TEXT(" --indent-classes");
    m_csAstyleOption += TEXT(" --indent-switches");
    m_csAstyleOption += TEXT(" --indent-cases");
    m_csAstyleOption += TEXT(" --indent-namespaces");
    m_csAstyleOption += TEXT(" --indent-after-parens");
    m_csAstyleOption += TEXT(" --indent-continuation=1");
    m_csAstyleOption += TEXT(" --indent-labels");
    m_csAstyleOption += TEXT(" --indent-preproc-block");
    m_csAstyleOption += TEXT(" --indent-preproc-define");
    m_csAstyleOption += TEXT(" --indent-preproc-cond");
    m_csAstyleOption += TEXT(" --indent-col1-comments");
    m_csAstyleOption += TEXT(" --min-conditional-indent=1");
    m_csAstyleOption += TEXT(" --max-continuation-indent=120");
    m_csAstyleOption += TEXT(" --break-blocks");
    m_csAstyleOption += TEXT(" --pad-oper");
    m_csAstyleOption += TEXT(" --pad-comma");
    m_csAstyleOption += TEXT(" --pad-header");
    m_csAstyleOption += TEXT(" --delete-empty-lines");
    m_csAstyleOption += TEXT(" --align-pointer=type");
    m_csAstyleOption += TEXT(" --align-reference=type");
    m_csAstyleOption += TEXT(" --break-one-line-headers");
    m_csAstyleOption += TEXT(" --add-braces");
    m_csAstyleOption += TEXT(" --close-templates");
    m_csAstyleOption += TEXT(" --max-code-length=120");
    UpdateData(FALSE);
    return TRUE;  // 除非将焦点设置到控件,否则返回 TRUE
}

bool CmyAstyleAppDlg::addTip(CString csMsg) {
    int len = 0;
    int len_limit = 0;
    len = m_ctrlTip.GetWindowTextLength();
    len_limit = m_ctrlTip.GetLimitText();

    // 清除溢出内容时, 保留后一半的内容, 使内容可读连续性好些
    if ((len + csMsg.GetLength() + 1024) >= (int)len_limit) {
        m_ctrlTip.SetSel(0, len / 2); // 选中所有
        m_ctrlTip.ReplaceSel(_T(""));
        len = m_ctrlTip.GetWindowTextLength();
    }

    m_ctrlTip.SetSel(len, len); // 将插入光标放在最后
    m_ctrlTip.ReplaceSel(csMsg);
    UpdateData(TRUE);
    return true;
}

void CmyAstyleAppDlg::OnSysCommand(UINT nID, LPARAM lParam) {
    if ((nID & 0xFFF0) == IDM_ABOUTBOX) {
        CAboutDlg dlgAbout;
        dlgAbout.DoModal();
    } else {
        CDialogEx::OnSysCommand(nID, lParam);
    }
}

// 如果向对话框添加最小化按钮,则需要下面的代码
//  来绘制该图标。  对于使用文档/视图模型的 MFC 应用程序,
//  这将由框架自动完成。

void CmyAstyleAppDlg::OnPaint() {
    if (IsIconic()) {
        CPaintDC dc(this); // 用于绘制的设备上下文
        SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
        // 使图标在工作区矩形中居中
        int cxIcon = GetSystemMetrics(SM_CXICON);
        int cyIcon = GetSystemMetrics(SM_CYICON);
        CRect rect;
        GetClientRect(&rect);
        int x = (rect.Width() - cxIcon + 1) / 2;
        int y = (rect.Height() - cyIcon + 1) / 2;
        // 绘制图标
        dc.DrawIcon(x, y, m_hIcon);
    } else {
        CDialogEx::OnPaint();
    }
}

//当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CmyAstyleAppDlg::OnQueryDragIcon() {
    return static_cast<HCURSOR>(m_hIcon);
}

void CmyAstyleAppDlg::OnBnClickedOk() {
    // TODO: 在此添加控件通知处理程序代码
    CDialogEx::OnOK();
}

void CmyAstyleAppDlg::OnBnClickedCancel() {
    // TODO: 在此添加控件通知处理程序代码
    CDialogEx::OnCancel();
}

int iErrCnt = 0;
void STDCALL my_fpError(int errorNumber, const char* errorMessage) {
    iErrCnt++;

    if (NULL != errorMessage) {
        assert(false);
    }
}

std::vector<char*> g_vec_pt;

char* STDCALL my_fpAlloc(unsigned long memoryNeeded) {
    char* pszBuf = new char[memoryNeeded];
    g_vec_pt.push_back(pszBuf);
    return pszBuf;
}

bool CmyAstyleAppDlg::code_format_file(const TCHAR* pszWFilePathName, const char* pszOption) {
    bool b_rc = false;
    char* psz_rc = NULL;
    char* pSourceIn = NULL;
    int iLenSource = 0;
    char* pMemBuf = NULL;
    size_t st_file = 0;
    size_t st_tmp = 0;
    uint8_t* pBuf = NULL;
    int lenBuf = 0;

    do {
        if ((NULL == pszWFilePathName) || (NULL == pszOption)) {
            break;
        }

        st_file = getFileSize(pszWFilePathName);

        if (st_file <= 0) {
            break;
        }

        // read file all into pSourceIn
        if (!ReadFileToBuffer(pszWFilePathName, pBuf, lenBuf)) {
            break;
        }

        pSourceIn = (char*)pBuf;
        psz_rc = AStyleMain(pSourceIn, pszOption, my_fpError, my_fpAlloc);

        if (!psz_rc) {
            break;
        }

        // write psz_rc to file
        st_tmp = strlen(psz_rc);

        if (!WriteBufferToFile(pszWFilePathName, (const uint8_t*)psz_rc, st_tmp)) {
            break;
        }

        b_rc = true;
    } while (false);

    if (NULL != pBuf) {
        delete[] pBuf;
        pBuf = NULL;
    }

    while (g_vec_pt.size() > 0) {
        pMemBuf = g_vec_pt.back();

        if (NULL != pMemBuf) {
            delete[] pMemBuf;
            pMemBuf = NULL;
        }

        g_vec_pt.pop_back();
    }

    return b_rc;
}

void CmyAstyleAppDlg::OnBnClickedButtonAstyleDir() {
    bool b_rc = false;
    CString csTmp;

    do {
        UpdateData(TRUE);

        if (m_csDir.IsEmpty()) {
            addTip(TEXT("请先选择要格式化的顶层目录, 再对目录进行格式化代码\r\n"));
            break;
        }

        if (m_csAstyleOption.IsEmpty()) {
            addTip(TEXT("请添加格式化选项, 然后再对目录进行格式化代码\r\n"));
            break;
        }

        m_iProcessOk = 0;
        b_rc = findDir(m_csDir, &CmyAstyleAppDlg::CB_FindFile_code_format);
        assert(b_rc);
        csTmp.Format(TEXT("process ok cnt = %d\r\n"), m_iProcessOk);
        addTip(csTmp);
    } while (false);
}

bool CmyAstyleAppDlg::isObjFile(const TCHAR* pObjPostFix) {
    bool b_rc = false;
    int i_rc = 0;
    const TCHAR** ppCur = NULL;
    CString csCur;
    const TCHAR* pszObj[] = {
        TEXT(".h"),
        TEXT(".c"),
        TEXT(".cpp"),
        NULL
    };
    assert(NULL != pObjPostFix);
    csCur = pObjPostFix;
    ppCur = pszObj;

    do {
        if ((NULL == ppCur) || (NULL == *ppCur)) {
            break;
        }

        i_rc = csCur.CompareNoCase(*ppCur);

        if (0 == i_rc) {
            b_rc = true;
            break;
        }

        ppCur++;
    } while (true);

    return b_rc;
}

std::string CmyAstyleAppDlg::my_W2A(std::wstring strW) {
    USES_CONVERSION;
    std::string str_rc = W2A(strW.c_str());
    return str_rc;
}

bool CmyAstyleAppDlg::CB_FindFile_code_format(CString csFilePathName) {
    bool bProcessOk = false;
    bool b_rc = false;
    int iPos = -1;
    int len = 0;
    CString csTmp;
    const TCHAR* pFilePathNameIn = csFilePathName;

    do {
        len = csFilePathName.GetLength();
        assert(len > 0);
        iPos = csFilePathName.ReverseFind(TEXT('.'));

        if (iPos > 0) {
            csTmp = csFilePathName.Right(len - iPos); // .h

            if (isObjFile(csTmp)) {
                b_rc = code_format_file(pFilePathNameIn, my_W2A(m_csAstyleOption.GetString()).data());
                assert(b_rc);
                csTmp.Format(TEXT("%s = %s\r\n"), (b_rc ? TEXT("ok") : TEXT("err")), pFilePathNameIn);
                addTip(csTmp);
                m_iProcessOk++;
            }
        }

        bProcessOk = true;
    } while (false);

    return bProcessOk;
}


bool CmyAstyleAppDlg::findDir(CString csDirPathName, PFN_CB_FindFile pfn) {
    bool b_rc = false;
    CString str;
    CFileFind finder;
    // build a string with wildcards
    CString strWildcard(csDirPathName);
    strWildcard += _T("\\*.*");
    // start working for files
    BOOL bWorking = finder.FindFile(strWildcard);

    while (bWorking) {
        bWorking = finder.FindNextFile();

        // skip . and .. files; otherwise, we'd
        // recur infinitely!

        if (finder.IsDots()) {
            continue;
        }

        // if it's a directory, recursively search it

        if (finder.IsDirectory()) {
            str = finder.GetFilePath();
            // TRACE(_T("%s\n"), (LPCTSTR)str);
            findDir(str, pfn);
        }

        // 是文件
        if (NULL != pfn) {
            str = finder.GetFilePath();
            b_rc = (this->*pfn)(str);

            if (!b_rc) {
                break;
            }
        }
    }

    finder.Close();
    return b_rc;
}

void CmyAstyleAppDlg::OnBnClickedButtonSeclectDir() {
    m_csDir = BrowserDir(TEXT("C:\\"));
    UpdateData(FALSE);
}

CString CmyAstyleAppDlg::BrowserDir(CString DirToBrowser) {
    CString csPathName = _T("");
    BROWSEINFO bi = { 0 };
    TCHAR tszPath[MAX_PATH] = TEXT("\0");
    memset(&bi, 0, sizeof(bi));
    bi.lpszTitle = TEXT("请选择要进行代码格式化的顶层文件夹");
    LPITEMIDLIST pidl = SHBrowseForFolder(&bi);

    if (pidl != NULL) {
        if (SHGetPathFromIDList(pidl, tszPath) == TRUE) {
            csPathName = tszPath;
        }

        CoTaskMemFree(pidl);
    }

    return csPathName;
}

bool CmyAstyleAppDlg::WriteBufferToFile(const TCHAR* pszFilePathName, const uint8_t* pBuf, int lenBuf) {
    bool b_rc = false;
    FILE* fp = NULL;
    size_t WriteCnt = 0;

    do {
        if ((NULL == pszFilePathName) || (NULL == pBuf) || (lenBuf <= 0)) {
            break;
        }

        fp = _tfopen(pszFilePathName, TEXT("w+b"));

        if (NULL == fp) {
            break;
        }

        WriteCnt = (int)fwrite(pBuf, sizeof(char), lenBuf, fp);

        if (WriteCnt != lenBuf) {
            break;
        }

        b_rc = true;
    } while (false);

    if (NULL != fp) {
        fclose(fp);
        fp = NULL;
    }

    return b_rc;
}

size_t CmyAstyleAppDlg::getFileSize(const TCHAR* pszFilePathName) {
    // 这是一个存储文件(夹)信息的结构体,其中有文件大小和创建时间、访问时间、修改时间等
    struct _stat64 statbuf;
    size_t filesize = 0;

    do {
        assert(NULL != pszFilePathName);
        // 提供文件名字符串,获得文件属性结构体
        _tstat64(pszFilePathName, &statbuf);
        // 获取文件大小
        filesize = statbuf.st_size;
    } while (false);

    return filesize;
}

bool CmyAstyleAppDlg::ReadFileToBuffer(const TCHAR* pszFilePathName, uint8_t*& pBuf, int& lenBuf) {
    bool b_rc = false;
    FILE* fp = NULL;
    size_t OptCnt = 0;
    int fileSize = 0;

    do {
        if (NULL == pszFilePathName) {
            break;
        }

        fileSize = (int)getFileSize(pszFilePathName);

        if (fileSize <= 0) {
            break;
        }

        lenBuf = fileSize;
        pBuf = new uint8_t[lenBuf + 1];
        pBuf[lenBuf] = 0x00;
        fp = _tfopen(pszFilePathName, TEXT("r+b"));

        if (NULL == fp) {
            break;
        }

        OptCnt = (int)fread(pBuf, sizeof(char), lenBuf, fp);

        if (OptCnt != lenBuf) {
            break;
        }

        b_rc = true;
    } while (false);

    if (NULL != fp) {
        fclose(fp);
        fp = NULL;
    }

    return b_rc;
}

测试程序 - RC

// Microsoft Visual C++ generated resource script.
//
#include "resource.h"

#define APSTUDIO_READONLY_SYMBOLS
/
//
// Generated from the TEXTINCLUDE 2 resource.
//
#ifndef APSTUDIO_INVOKED
#include "targetver.h"
#endif
#include "afxres.h"
#include "verrsrc.h"

/
#undef APSTUDIO_READONLY_SYMBOLS

/
// 中文(简体,中国) resources

#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_CHS)
LANGUAGE LANG_CHINESE, SUBLANG_CHINESE_SIMPLIFIED

#ifdef APSTUDIO_INVOKED
/
//
// TEXTINCLUDE
//

1 TEXTINCLUDE 
BEGIN
    "resource.h\0"
END

2 TEXTINCLUDE 
BEGIN
    "#ifndef APSTUDIO_INVOKED\r\n"
    "#include ""targetver.h""\r\n"
    "#endif\r\n"
    "#include ""afxres.h""\r\n"
    "#include ""verrsrc.h""\r\n"
    "\0"
END

3 TEXTINCLUDE 
BEGIN
    "#define _AFX_NO_SPLITTER_RESOURCES\r\n"
    "#define _AFX_NO_OLE_RESOURCES\r\n"
    "#define _AFX_NO_TRACKER_RESOURCES\r\n"
    "#define _AFX_NO_PROPERTY_RESOURCES\r\n"
    "\r\n"
    "#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_CHS)\r\n"
    "LANGUAGE 4, 2\r\n"
    "#include ""res\\myAstyleApp.rc2""  // 非 Microsoft Visual C++ 编辑的资源\r\n"
    "#include ""l.CHS\\afxres.rc""      // 标准组件\r\n"
    "#if !defined(_AFXDLL)\r\n"
    "#include ""l.CHS\\afxribbon.rc""   // MFC 功能区和控制条资源\r\n"
    "#endif\r\n"
    "#endif\r\n"
    "\0"
END

#endif    // APSTUDIO_INVOKED


/
//
// Icon
//

// Icon with lowest ID value placed first to ensure application icon
// remains consistent on all systems.
IDR_MAINFRAME           ICON                    "res\\myAstyleApp.ico"


/
//
// Dialog
//

IDD_ABOUTBOX DIALOGEX 0, 0, 170, 62
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU
CAPTION "关于 myAstyleApp"
FONT 9, "MS Shell Dlg", 0, 0, 0x1
BEGIN
    ICON            IDR_MAINFRAME,IDC_STATIC,14,14,21,20
    LTEXT           "myAstyleApp,版本 1.0",IDC_STATIC,42,14,114,8,SS_NOPREFIX
    LTEXT           "版权所有 (C) 2024",IDC_STATIC,42,26,114,8
    DEFPUSHBUTTON   "确定",IDOK,113,41,50,14,WS_GROUP
END

IDD_MYASTYLEAPP_DIALOG DIALOGEX 0, 0, 320, 200
STYLE DS_SETFONT | DS_FIXEDSYS | WS_POPUP | WS_VISIBLE | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME
EXSTYLE WS_EX_APPWINDOW
FONT 9, "MS Shell Dlg", 0, 0, 0x1
BEGIN
    DEFPUSHBUTTON   "确定",IDOK,209,179,50,14
    PUSHBUTTON      "取消",IDCANCEL,263,179,50,14
    GROUPBOX        "需要格式化代码的顶层目录",IDC_STATIC,7,7,306,34
    EDITTEXT        IDC_EDIT_DIR,7,24,293,14,ES_AUTOHSCROLL
    PUSHBUTTON      "...",IDC_BUTTON_SECLECT_DIR,301,24,12,14
    PUSHBUTTON      "对目录进行代码格式化",IDC_BUTTON_ASTYLE_DIR,239,75,74,14
    EDITTEXT        IDC_EDIT_TIP,7,90,306,86,ES_MULTILINE | ES_AUTOVSCROLL | ES_AUTOHSCROLL | ES_READONLY | ES_WANTRETURN | WS_VSCROLL | WS_HSCROLL
    GROUPBOX        "格式化选项",IDC_STATIC,7,42,306,31
    EDITTEXT        IDC_EDIT_ASTYLE_OPTION,7,55,306,14,ES_AUTOHSCROLL
END


/
//
// Version
//

VS_VERSION_INFO VERSIONINFO
 FILEVERSION 1,0,0,1
 PRODUCTVERSION 1,0,0,1
 FILEFLAGSMASK 0x3fL
#ifdef _DEBUG
 FILEFLAGS 0x1L
#else
 FILEFLAGS 0x0L
#endif
 FILEOS 0x40004L
 FILETYPE 0x1L
 FILESUBTYPE 0x0L
BEGIN
    BLOCK "StringFileInfo"
    BEGIN
        BLOCK "080404B0"
        BEGIN
            VALUE "CompanyName", "TODO: <公司名>"
            VALUE "FileDescription", "myAstyleApp"
            VALUE "FileVersion", "1.0.0.1"
            VALUE "InternalName", "myAstyleApp.exe"
            VALUE "LegalCopyright", "TODO:  (C) <公司名>。  保留所有权利。"
            VALUE "OriginalFilename", "myAstyleApp.exe"
            VALUE "ProductName", "TODO: <产品名>"
            VALUE "ProductVersion", "1.0.0.1"
        END
    END
    BLOCK "VarFileInfo"
    BEGIN
        VALUE "Translation", 0x804, 1200
    END
END


/
//
// DESIGNINFO
//

#ifdef APSTUDIO_INVOKED
GUIDELINES DESIGNINFO
BEGIN
    IDD_ABOUTBOX, DIALOG
    BEGIN
        LEFTMARGIN, 7
        RIGHTMARGIN, 163
        TOPMARGIN, 7
        BOTTOMMARGIN, 55
    END

    IDD_MYASTYLEAPP_DIALOG, DIALOG
    BEGIN
        LEFTMARGIN, 7
        RIGHTMARGIN, 313
        TOPMARGIN, 7
        BOTTOMMARGIN, 193
    END
END
#endif    // APSTUDIO_INVOKED


/
//
// AFX_DIALOG_LAYOUT
//

IDD_MYASTYLEAPP_DIALOG AFX_DIALOG_LAYOUT
BEGIN
    0
END


/
//
// String Table
//

STRINGTABLE
BEGIN
    IDS_ABOUTBOX            "关于 myAstyleApp(&A)..."
END

#endif    // 中文(简体,中国) resources
/



#ifndef APSTUDIO_INVOKED
/
//
// Generated from the TEXTINCLUDE 3 resource.
//
#define _AFX_NO_SPLITTER_RESOURCES
#define _AFX_NO_OLE_RESOURCES
#define _AFX_NO_TRACKER_RESOURCES
#define _AFX_NO_PROPERTY_RESOURCES

#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_CHS)
LANGUAGE 4, 2
#include "res\myAstyleApp.rc2"  // 非 Microsoft Visual C++ 编辑的资源
#include "l.CHS\afxres.rc"      // 标准组件
#if !defined(_AFXDLL)
#include "l.CHS\afxribbon.rc"   // MFC 功能区和控制条资源
#endif
#endif

/
#endif    // not APSTUDIO_INVOKED


备注

自己会写2句程序确实方便,有些小功能,如果现成软件中没有(或者下载不到有这种功能的软件),那就自己写一下。费不了多长时间,管用。

END

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1645089.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

记对MYSQL蜜罐的溯源反制研究

Mysql蜜罐的利用 Mysql任意文件读取 mysql蜜罐通过搭建一个简单的mysql服务&#xff0c;如果攻击者对目标客户进行3306端口爆破&#xff0c;并且用navicat等工具连接蜜罐服务器&#xff0c;就可能被防守方读取本地文件&#xff0c;包括微信配置文件和谷歌历史记录等等&#x…

LNMP一键安装包

LNMP一键安装包是什么? LNMP一键安装包是一个用Linux Shell编写的可以为CentOS/RHEL/Fedora/Debian/Ubuntu/Raspbian/Deepin/Alibaba/Amazon/Mint/Oracle/Rocky/Alma/Kali/UOS/银河麒麟/openEuler/Anolis OS Linux VPS或独立主机安装LNMP(Nginx/MySQL/PHP)、LNMPA(Nginx/MySQ…

sql中索引的使用分析

主要学习和记录sql中索引的使用 1.批量在库里插入了27W条数据 CREATE DEFINERroot% PROCEDURE 批量插入() BEGIN #Routine body goes here... DECLARE i int; SET i1; WHILE (i<100000) DO insert into kucun_info (shop_name,shop_code,shop_price,sh…

C#图像:1.图像区域分割与提取

&#xff08;1&#xff09;创建一个名为SplitImage的窗体的应用程序&#xff0c;将窗体改名为FormSplitImage。 &#xff08;2&#xff09;创建一个名为ImageProcessingLibrary的类库程序&#xff0c;为该工程添加名为ImageProcessing的静态类 &#xff08;3&#xff09;为Imag…

Video2Game:革新游戏开发,重塑虚拟世界的未来

Video2Game&#xff1a;革新游戏开发&#xff0c;重塑虚拟世界的未来 一、Video2Game的提出与意义二、Video2Game的核心技术三、Video2Game的实现与应用四、代码实例与未来展望 在数字化和虚拟化日益盛行的今天&#xff0c;高质量的交互式虚拟环境&#xff0c;如游戏和模拟器&a…

【精品毕设推荐】基于Javaee的影视创作论坛的设计与实现

点击下载原文及代码 摘 要 随着时代的发展&#xff0c;互联网的出现&#xff0c;给传统影视行业带来的最大便利就是&#xff0c;方便了影视从业人员以及爱好者的交流和互动&#xff0c;而为用户提供一个书写影评&#xff0c;阅读影评以及回复影评的平台&#xff0c;以影评为…

云原生专栏丨基于K8s集群网络策略的应用访问控制技术

在当今云计算时代&#xff0c;Kubernetes已经成为容器编排的事实标准&#xff0c;它为容器化应用提供了强大的自动化部署、扩展和管理能力。在Kubernetes集群中&#xff0c;网络策略(Network Policy)作为对Pod间通信进行控制的关键功能&#xff0c;对保障应用安全和隔离性起到了…

R可视化:不同分页界面分组添加显著性标记符号

介绍 对不同分页界面的分组数据添加显著性标记符号,虽然也可以通过ggpubr包的stat_compare_means()添加分组显著性标记符号,但它要求x轴必须是分组变量,不能对fill映射出来的分组做处理。为应对不同分组的fill映射分组,我们需要另寻他法。本文通过geom_text, geom_segment…

Linux编译内核模块生成.KO驱动示例

现在的Linux内核十分庞大&#xff0c;驱动繁多&#xff0c;但是仍有一些是内核所不包含的&#xff0c;或者我们前期进行了内核裁剪&#xff0c;但后面又需要添加一些驱动&#xff0c;但是又不想重新烧录内核&#xff0c;这时候就可以使用内核模块功能&#xff0c;对内核驱动进行…

Linux图形化界面怎么进入?CentOS 7图形界面切换

CentOS 7默认只安装命令行界面。要切换到图形界面&#xff0c;需要先检查系统是否安装图形界面&#xff0c;在终端输入以下命令&#xff1a; systemctl get-default若是返回结果是“multi-user.target”表示系统没有安装图形界面&#xff1b;若是返回结果是“graphical.target…

等保测评—Linux-CentOS标准范例截图

密码输入错误无法登录 用户账户情况包含root、guanli、shenji 查看审计用户权限 身份鉴别&#xff1a; cat /etc/passwd&#xff0c;核查用户名和 UID&#xff0c;是否存在同样的用户名和 UID cat /etc/shadow&#xff0c;查看文件中各用户名状态 &#xff0c; 核查密码一栏为…

文件批量改名字怎么改(怎样批量修改文件名)

文件批量改名字怎么改&#xff08;怎样批量修改文件名&#xff09; 批量重命名文件可以通过多种方法实现&#xff0c;具体取决于用户的操作系统和熟练程度。 以下是一些常见的方法&#xff1a; 下载地址https://download.csdn.net/download/dhyuan_88/89237041 使用操作系统自带…

On Hold 频发!又3本期刊被标记为On Hold ,大家谨慎投递!

【SciencePub学术】On Hold 频发&#xff01;小编在查阅资料的时候发现又有3本期刊被标记为On Hold 了&#xff0c;今天小编给大家详细介绍一下这3本期刊。 来源&#xff1a;科睿唯安官网 Results in Physics 1 期刊概况 【期刊简介】IF&#xff1a;5.3&#xff0c;JCR1区&am…

C++ stack and queue

1. stack模拟实现 CSTL中的栈是一种容器适配器&#xff0c;它是将vector/list进行封装&#xff0c;push/pop等接口直接调用vector/list的接口即可&#xff0c;不需要像C语言那样&#xff0c;从头开始造轮子 namespace byh {template<class T, class Container deque<T&…

python实验二 函数与类的应用

实验二 实验题目 1、请编写一个函数SDSearch(txt, word)&#xff0c;其中&#xff0c;txt是一段文本&#xff0c;word是给定的词汇&#xff0c;函数SDSearch可以找到word在txt中的所有位置&#xff0c;并将它们做为返回值返回&#xff0c;编写函数main()调用SDSearch(txt, wo…

连锁收银系统批量调整商品价格教程

1、进入系统后台&#xff0c;系统后台登录网址&#xff1a; 2、点击商品>商品调价 3、将按模板整理好的商品价格数据导入即可。 Tips&#xff1a;每次导入的商品数量不要超过6000 条。

英语翻译中文,如何找专业的翻译公司?

在国际交流日益频繁的今天&#xff0c;翻译业务如雨后春笋般崭露头角&#xff0c;众多翻译公司如百花争艳般崭露头角。然而&#xff0c;国内翻译公司水平层参不齐。为了确保翻译的质量和准确性&#xff0c;选择一家专业的翻译公司至关重要。那么&#xff0c;英语翻译中文&#…

Case中default的综合结果

在使用case语句时&#xff0c;不完备的case语句会导致Vivado综合时推断出锁存器。下面通过实例来详细看看各种情况下的综合结果&#xff1a; 1.完备的case语句 下述的verilog对应的电路结构是一个8选一的多路复用器&#xff1a; module case_test(input [2:0]sel,input data…

学习如何使用PyQt5实现notebook功能

百度搜索“pyqt5中notebook控件”&#xff0c;AI自动生成相应例子的代码。在 PyQt5 中&#xff0c;QTabWidget 类被用作 Notebook 控件。以下是一个简单的示例&#xff0c;展示如何创建一个带有两个标签的 Notebook 控件&#xff0c;并在每个标签中放置一些文本。 import sys f…

咖啡机定量出水的原理是什么

咖啡机实现定量出水的原理主要依赖于流量计的使用。流量计是一种能够测量液体或气体通过管道的速度和体积的装置。在咖啡机中&#xff0c;常用的小型流量计有霍尔式流量计和光电式流量计两种。 霍尔式流量计利用了霍尔效应的原理来实现流量测量。它包含一个带有两极磁铁的叶轮…