对C,C++宏进行代码分析(自上而下)

 宏定义:

  

    //#define _pi(var) (_cout <<#var<<_t(" = ")<<_tostr(var) << _t("\t"))
    //#define  _class class 
           
    //语法一:

    //#define 标识符 被标识符代表的字符串 //这种用法很简单,就是一种替换.

    //语法二 :

    //#define 标识符[(参数1,.....,参数n)] 被标识符代表的字符串 //其中,在"被标识符代表的

        字符串"中出现的形参将在使用时被实参替代. 就像写函数一样.

    //  补充一点 : 在用#define 定义时, 可以用斜杠("\") 续行.与vb中的下划线(" _")作用同. 

执行前:

 执行后:

 

 

 

else if (p[i] == _t('#'))
        { //这里开始分析C++宏定义语法
         
            //#ifndef  _MS_WINDOWS_       正确
            //# ifndef _MS_WINDOWS_  正确
            //#include<test.h">
            //# include <test.h> 正确
            // # + 预处理命令 + ?
            
            //着色预处理命令

            _string s1(_t(""), 50), s2(_t(""), 50), s3(_t(""), 50);
            
            int j = i + 1;
            int k = j;
           
            //跳过空格
            while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }
          
                    
            while (j < iTextLength){
                if (!gs.s_Syntax_IsWordSeparator(p[j])){
                    s1.add(p[j]);
                }else{
                    break;
                }
                ++j;
            }

            if (C_Preprocessor.indexOf(s1) != -1){ dtResult.Add(TextColor(i, j - i, Color_::Red)); }

            if (s1 == _t("define"))
            {
                //#define _pi(var) (_cout <<#var<<_t(" = ")<<_tostr(var) << _t("\t"))
                //#define  _class class 
           
                //语法一:

                //#define 标识符 被标识符代表的字符串 //这种用法很简单,就是一种替换.

                    //语法二 :

                //#define 标识符[(参数1,.....,参数n)] 被标识符代表的字符串 //其中,在"被标识符代表的字符串"中出现的形参将在使用时被实参替代. 就像写函数一样.

                //  补充一点 : 在用#define 定义时, 可以用斜杠("\") 续行.与vb中的下划线(" _")作用同.

                //检查有没有续行符
                bool bContinuation = false;

                //检查最后一位字符是不是续行符
                k = j;
                while (k < iTextLength)
                {
                    if (p[k] == _t('\n'))
                    { 
                        break;
                    }  
                    ++k; 
                }

                //宏定义续行
                if (p[k - 1] == '\\') { bContinuation = true; }


                //跳过空格
                while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }

                //拷贝第一部分
                while (j < iTextLength) {
                    if (p[j] != _t(' ')) {
                        s2.add(p[j]);
                    }
                    else {
                        break;
                    }
                    ++j;
                }


                if (s2.IndexOf(_t('(')) != -1) //函数格式
                {
                    //跳过空格
                    while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }
                    if (bContinuation)
                    {
                        //拷贝第二部分
                        ++k;
                        while (k < iTextLength && bContinuation)
                        {
                            if (p[k] == _t('\n'))
                            {
                                if (p[k - 1] != _t('\\'))
                                {
                                    bContinuation = false;
                                    break;
                                }
                            }

                            if (!bContinuation)break;
                            ++k;
                        }

                        for (int m = j; m < k; ++m)
                        {
                            if (p[m] != _t('\n') && p[m] != _t('\\'))
                                s3.add(p[m]);
                        }
                    }
                    else
                    {
                        //拷贝第二部分,拷贝到行尾
                        while (j < iTextLength) {
                            if (p[j] != _t('\n'))
                            {
                                s3.add(p[j]);
                            }
                            else
                            {
                                break;
                            }
                            ++j;
                        }
                    }
                   
                }
                else
                {
                    //跳过空格
                    while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }

                    
                    if (bContinuation)
                    {
                        //拷贝第二部分
                        ++k;
                        while (k < iTextLength && bContinuation)
                        {
                            if (p[k] == _t('\n'))
                            {
                                if (p[k - 1] != _t('\\'))
                                {
                                    bContinuation = false;
                                    break;
                                }
                            }                             

                            if (!bContinuation)break;
                            ++k;
                        }

                        for (int m = j; m < k; ++m)
                        {
                            if(p[m] != _t('\n') && p[m] != _t('\\'))
                                s3.add(p[m]);
                        }
                    }
                    else
                    {
                        //拷贝第二部分
                        while (j < iTextLength) {
                            if (p[j] != _t(' ') && p[j] != _t('\n'))
                            {
                                s3.add(p[j]);
                            }
                            else
                            {
                                break;
                            }
                            ++j;
                        }
                    }
   
                    sd.Define.Add(Pair<_string, _string>(s2, s3));
                    //#define _class class
                    if (s3 == _t("class") || s3 == _t("struct"))
                    {
                        sd.DefineClass.Add(s2);
                    }
                }


                //log::d(s2);
                //log::d(s3);
            }

完整代码:

/// <summary>
/// 一次性记录关键字,注释,字符串值,运算符,宏,括号配对,预处理命令的位置,并设置自定义数据颜色
/// </summary>
/// <param name="CustomData">生成自定义数据列表</param>
/// <returns></returns>
/// 创建时间: 2022-12-24      最后一次修改时间:2022-12-28
DList<TextColor> Syntax::GetTextColorPos_C(SyntaxData &sd)
{ 
    sd.Clear();  //清空原来的数据

    DList<TextColor> dtResult;

    //可见字符开始位置
    const _char* p = _code.c_str();

    //可见字符长度
    const int iTextLength = _code.length();

    if (iTextLength <= 0) return dtResult;
      
    _string sWord(_t(""), 50);  //50个_char缓冲

    Color_  cKeyWordColor = GetColor(SyntaxType::关键字);
    Color_  cExplanatoryNote = GetColor(SyntaxType::注释);
 
    Color_  cOS = GetColor(SyntaxType::运算符号);

    for (int i = 0; i < iTextLength; ++i)
    {
        if (p[i] == _t('/'))
        {
            ++i;

            if (i < iTextLength)
            {
                if (p[i] == _t('/')) //是"//"注释,查找注释结束位置 \n ,跳过注释
                {
                    int iStart = i - 1;
                    ++i;
                    bool bFind = false; //查找下一个 "\n"
                    while (i < iTextLength)
                    {
                        if (p[i] == '\n')
                        {
                            bFind = true;
                            break;
                        }
                        ++i;
                    }
                    if (!bFind)
                    {
                        return dtResult;
                    }
                    else
                    {
                        dtResult.Add(TextColor(iStart, i - iStart, cExplanatoryNote));
                    }
                }
                else if (p[i] == _t('*')) //是"/*"注释,查找注释结束位置 */ ,跳过注释
                {
                    int iStart = i - 1;

                    ++i;

                    bool bFind = false;
                    while (i + 1 < iTextLength ) //查找下一个 "*/"
                    {
                        if (p[i] == '*' && p[i + 1] == '/')
                        {
                            i += 1;
                            bFind = true;
                            break;
                        }
                        ++i;
                    }
                    if (!bFind)
                    {
                        return dtResult;
                    }
                    else
                    {
                        dtResult.Add(TextColor(iStart, i - iStart + 1, cExplanatoryNote));
                    }
                }
            }
            else
            {
                return dtResult;
            }
        }
        else if (p[i] == _t('\"')) {  //字符串开始

            if (i - 1 > 0 && p[i - 1] != _t('\\'))
            {
                int iStart = i;

                ++i;

                bool bFind = false; //查找下一个 "\""

                while (i < iTextLength )
                {
                    if (p[i] == '\"' && p[i - 1] != _t('\\'))
                    {                       
                        bFind = true;
                        break;
                    }
                    else if (p[i] == _t('\n')) //当前行已结束,还未找到引号配对
                    {                     
                        bFind = true;
                        break;
                    }

                    ++i;
                }
                if (!bFind)
                {
                    return dtResult;
                }
                else
                {
                    dtResult.Add(TextColor(iStart, i - iStart + 1, Color_::字符串));
                }
            }
            else
            {
                ++i;
            }
        }
        else if (p[i] == _t('\'')) { //字符开始

            if (i - 1 > 0 && p[i - 1] != _t('\\'))
            {
                int iStart = i;

                ++i;

                bool bFind = false; //查找下一个 "\'"

                while (i < iTextLength )
                {
                    if (p[i] == _t('\'') && p[i - 1] != _t('\\'))
                    {   
                        bFind = true;
                        break;
                    }
                    else if (p[i] == _t('\n')) //当前行已结束,还未找到引号配对
                    {
                        bFind = true;
                        break;
                    }

                    ++i;
                }
                if (!bFind)
                {
                    return dtResult;
                }
                else
                {
                    dtResult.Add(TextColor(iStart, i - iStart + 1, Color_::字符串));
                }
            }
            else
            {
                ++i;
            }
        }
        else if (Syntax::C_OperationalCharacter.IndexOf(p[i]) != -1)
        {
            dtResult.Add(TextColor(i, 1, cOS));
        }
        else if (p[i] == _t('{'))  //大括号查找全部文本
        {
            int iFlag = 0;

            for (int j = i + 1; j < iTextLength ; ++j)  //查找配对,直到遇到分号;
            {
                _char cRight = p[j];

                if (cRight == _t('}'))
                {
                    if (iFlag == 0)
                    {
                        Color_ c = Color_::RedRandom();
                        dtResult.Add(TextColor(i, 1, c));
                        dtResult.Add(TextColor(j, 1, c));
                        break;
                    }
                    --iFlag;
                }
                else if (cRight == _t('{'))
                {
                    ++iFlag;
                }
            }
        }
        else if ( p[i] == _t('['))
        {
            int iFlag = 0;
            for (int j = i + 1; j < iTextLength; ++j)  //查找配对,直到遇到分号;
            {
                _char cRight = p[j];

                if (cRight == _t(']'))
                {
                    if (iFlag == 0)
                    {
                        Color_ c = Color_::RedRandom();
                        dtResult.Add(TextColor(i, 1, c));
                        dtResult.Add(TextColor(j, 1, c));
                        break;
                    }
                    --iFlag;
                }
                else if (cRight == _t('['))
                {
                    ++iFlag;
                }
                else if (ga.c_IsPunctuation(cRight))  //遇到标点符号停止
                {
                    break;
                }
            }
        }
        else if (p[i] == _t('('))
        {

            int iFlag = 0;
            for (int j = i + 1; j < iTextLength; ++j)  //查找配对,直到遇到分号;
            {
                _char cRight = p[j];

                if (cRight == _t(')'))
                {
                    if (iFlag == 0)
                    {
                        Color_ c = Color_::RedRandom();
                        dtResult.Add(TextColor(i, 1, c));
                        dtResult.Add(TextColor(j, 1, c));
                        break;
                    }
                    --iFlag;
                }
                else if (cRight == _t('('))
                {
                    ++iFlag;
                }
                else if (cRight == _t(';'))
                {
                    break;
                }
            }

            //这里找出是否函数定义
            int j = i - 1;

            //去掉空格
            while (j > 0)
            {
                if (p[j] != _t(' ')) {   break; }
                --j;
            }

            _string sFun(_t(""), 50);
            while (j > 0)
            {
                if (!gs.s_Syntax_IsWordSeparator(p[j]))
                {
                    sFun.add(p[j]);
                }
                else
                {
                    break;
                }
                --j;
            }

           
            if (sFun.length() > 0)
            {
                sFun.Reversal();

                if (C_Keyword.indexOf(sFun) == -1) //不是关键字
                {
                    dtResult.Add(TextColor(j + 1, sFun.length(), Color_::函数));
                    //log::d(sFun);
                }
 
            }
     

        }
        else if (p[i] == _t('<')) //这里究竟是小于号还是尖括号
        {
            int iFlag = 0;

            for (int j = i + 1; j < iTextLength; ++j)  //查找配对,直到遇到分号;
            {
                _char cRight = p[j];

                if (cRight == _t('>'))
                {
                    if (iFlag == 0)
                    {
                        Color_ c = Color_::RedRandom();
                        dtResult.Add(TextColor(i, 1, c));
                        dtResult.Add(TextColor(j, 1, c));
                        break;
                    }
                    --iFlag;
                }
                else if (cRight == _t('<'))
                {
                    ++iFlag;
                }
                else if (cRight == _t(';'))
                {
                    break;
                }
            }

        }
        else if (p[i] == _t('#'))
        { //这里开始分析C++宏定义语法
         
            //#ifndef  _MS_WINDOWS_       正确
            //# ifndef _MS_WINDOWS_  正确
            //#include<test.h">
            //# include <test.h> 正确
            // # + 预处理命令 + ?
            
            //着色预处理命令

            _string s1(_t(""), 50), s2(_t(""), 50), s3(_t(""), 50);
            
            int j = i + 1;
            int k = j;
           
            //跳过空格
            while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }
          
                    
            while (j < iTextLength){
                if (!gs.s_Syntax_IsWordSeparator(p[j])){
                    s1.add(p[j]);
                }else{
                    break;
                }
                ++j;
            }

            if (C_Preprocessor.indexOf(s1) != -1){ dtResult.Add(TextColor(i, j - i, Color_::Red)); }

            if (s1 == _t("define"))
            {
                //#define _pi(var) (_cout <<#var<<_t(" = ")<<_tostr(var) << _t("\t"))
                //#define  _class class 
           
                //语法一:

                //#define 标识符 被标识符代表的字符串 //这种用法很简单,就是一种替换.

                    //语法二 :

                //#define 标识符[(参数1,.....,参数n)] 被标识符代表的字符串 //其中,在"被标识符代表的字符串"中出现的形参将在使用时被实参替代. 就像写函数一样.

                //  补充一点 : 在用#define 定义时, 可以用斜杠("\") 续行.与vb中的下划线(" _")作用同.



                //检查有没有续行符
                bool bContinuation = false;

                //检查最后一位字符是不是续行符
                k = j;
                while (k < iTextLength)
                {
                    if (p[k] == _t('\n'))
                    { 
                        break;
                    }  
                    ++k; 
                }

                //宏定义续行
                if (p[k - 1] == '\\') { bContinuation = true; }


                //跳过空格
                while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }

                //拷贝第一部分
                while (j < iTextLength) {
                    if (p[j] != _t(' ')) {
                        s2.add(p[j]);
                    }
                    else {
                        break;
                    }
                    ++j;
                }


                if (s2.IndexOf(_t('(')) != -1) //函数格式
                {
                    //跳过空格
                    while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }
                    if (bContinuation)
                    {
                        //拷贝第二部分
                        ++k;
                        while (k < iTextLength && bContinuation)
                        {
                            if (p[k] == _t('\n'))
                            {
                                if (p[k - 1] != _t('\\'))
                                {
                                    bContinuation = false;
                                    break;
                                }
                            }

                            if (!bContinuation)break;
                            ++k;
                        }

                        for (int m = j; m < k; ++m)
                        {
                            if (p[m] != _t('\n') && p[m] != _t('\\'))
                                s3.add(p[m]);
                        }
                    }
                    else
                    {
                        //拷贝第二部分,拷贝到行尾
                        while (j < iTextLength) {
                            if (p[j] != _t('\n'))
                            {
                                s3.add(p[j]);
                            }
                            else
                            {
                                break;
                            }
                            ++j;
                        }
                    }
                   
                }
                else
                {
                    //跳过空格
                    while (j < iTextLength) { if (p[j] == _t(' '))   ++j;   else   break; }

                    
                    if (bContinuation)
                    {
                        //拷贝第二部分
                        ++k;
                        while (k < iTextLength && bContinuation)
                        {
                            if (p[k] == _t('\n'))
                            {
                                if (p[k - 1] != _t('\\'))
                                {
                                    bContinuation = false;
                                    break;
                                }
                            }                             

                            if (!bContinuation)break;
                            ++k;
                        }

                        for (int m = j; m < k; ++m)
                        {
                            if(p[m] != _t('\n') && p[m] != _t('\\'))
                                s3.add(p[m]);
                        }
                    }
                    else
                    {
                        //拷贝第二部分
                        while (j < iTextLength) {
                            if (p[j] != _t(' ') && p[j] != _t('\n'))
                            {
                                s3.add(p[j]);
                            }
                            else
                            {
                                break;
                            }
                            ++j;
                        }
                    }
   
                    sd.Define.Add(Pair<_string, _string>(s2, s3));
                    //#define _class class
                    if (s3 == _t("class") || s3 == _t("struct"))
                    {
                        sd.DefineClass.Add(s2);
                    }
                }


                //log::d(s2);
                //log::d(s3);
            }
            

            //i = k;  //把 字符定位在#define 最后
            i = i + s1.length();
        }
       

        //开始查找,关键字,自定义类、等等

        if (gs.s_Syntax_IsWordSeparator(p[i]))
        {
            if (sWord.length() > 0)
            {           
                bool bFind = false;

            
                //自定义类
                DListNote<s_class>* pClass = sd.Class.First();

                while (pClass != null)
                {
                    if (pClass->Data.Name == sWord)
                    {
                        dtResult.Add(TextColor(i - sWord.length(), sWord.length(), Color_::自定义类));
                        //log::d(pClass->Data.Name);
                        bFind = true;
                        break;
                    }
                    pClass = pClass->Next;
                }
        
                //自定义函数
                DListNote<s_function> *pFun = sd.Function.First();

                while (pFun != null)
                {
                    if (pFun->Data.Name == sWord)
                    {
                        dtResult.Add(TextColor(i - sWord.length(), sWord.length(), Color_::自定义函数));
                        bFind = true;
                        break;
                    }
                    pFun = pFun->Next;
                }
   

                if(!bFind) //自定义类和函数不能是关键字
                { 
                    //关键字最小长度大于2,且全是小写字母
                    if (sWord.length() >= 2)
                    {
                        int n = sd.DefineClass.indexOf(sWord);
                        
                      
                        if ( sWord == _t("class") || sWord == _t("struct") || n != -1 ) //分析类定义,如果不在 #define 定义中
                        {
                            

                            //template<class T> T Max(T t1, T t2) { }
                            // template<class T1, class T2>  v
                            //class X { public : int i; };
                            //class A : public virtual X { public : int j ; };
                            //class B : public virtual X { public : double d; } ;
                            //class C : public A, public B { public : int k; };
                            //class D : public C {  };
                            //class Str : public Str<A>{};
                            //class
                            //bb{ };
                            //class CC : public std::string{}
                            //class cc{};
                            //template<class T> class Int{};    //先出现 > 

                            //typedef class MyClass* pMyClass;

                            //#define  _class class

                            //#define _class
                            // 
                            //class
                            // 
                            //_class dd{};
                            //

                            if (n == -1)
                            {
                              
                                dtResult.Add(TextColor(i - sWord.length(), sWord.length(), cKeyWordColor));
                            }
                            else
                            {
                              
                                dtResult.Add(TextColor(i - sWord.length(), sWord.length(), Color_::宏定义值));
                            }
                           
                            bool bDef = false;

                            //一定要 j = i - 1,否则可能跳到下一行内
                            //例:
                            //#define _string class
                            //
                            //...
                            for (int j = i - 1; j > 0; --j)
                            {
                                if (p[j] == _t('#'))
                                {
                                   
                                    bDef = true;
                                    break;
                                }

                                if (p[j] == _t('\n')) break;
                            }

                            if (!bDef)  //如果不是在宏义中
                            { 

                                bool bFind = false;
                                int j = i + 1;
                                int iCopyStart = -1;
                                int bCopyEnd = false;
                                _string sClassName(_t(""), 50);
                                while (j < iTextLength)
                                {

                                    //if (p[j] == _t(';')) break;      //typedef class MyClass* pMyClass;

                                    //比{ 和 : 先出现的 >  和 , 都是模板参数 或者 typedef
                                    if (p[j] == '>' || p[j] == _t(',') || p[j] == _t(';'))
                                    {
                                        break;
                                    }

                                    if (p[j] == _t('{') || p[j] == _t(':'))
                                    {
                                        bFind = true;
                                        break;
                                    }

                                    if (p[j] != _t(' ') && p[j] != _t('\t') && p[j] != _t('\n'))
                                    {
                                        if (iCopyStart == -1)  iCopyStart = j; //拷贝开始

                                        if (!bCopyEnd) sClassName.add(p[j]);
                                    }
                                    else
                                    {
                                        if (iCopyStart != -1) bCopyEnd = true; //拷贝结束,因为遇到了空格或 \t 或 \n
                                    }

                                    ++j;
                                }

                                if (bFind && iCopyStart != -1)
                                {
                                    s_class s;
                                    s.Name = sClassName;
                                    s.DefinitionPos = i + 1;                             

                                    dtResult.Add(TextColor(iCopyStart, sClassName.length(), Color_::自定义类));

                                    sd.Class.Add(s);  //添加自定义类                                     

                                    i = j;
                                }
                            }
                   
                        }
                        else
                        { 
                            if (C_Keyword.indexOf(sWord) != -1) //是关键字,记录位置
                            {
                                dtResult.Add(TextColor(i - sWord.length(), sWord.length(), cKeyWordColor));

                            }
                            else
                            {
                                //log::d(sWord);
                            }
                        }              
                  
                    }
                }           

                //log::d(_getc(sWord));

                sWord.Clear(); //清空
            }
        }
        else
        {
            sWord.add(p[i]);
        }
    }

    return dtResult;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值