IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 记录C,C++关键字的位置,直接跳过注释和字符串文本。(再次修正,加上字符串语法检查) -> 正文阅读

[C++知识库]记录C,C++关键字的位置,直接跳过注释和字符串文本。(再次修正,加上字符串语法检查)

上次版本,遇到字符串错误语法会终止,或者在字符串中

有引号,也会不正确:

修改后:?

?

/// <summary>
///  记录C,C++关键字的位置,跳过注释和字符串文本。
/// </summary>
/// <returns></returns>
/// 创建时间: 2022-12-19      最后一次修改时间:2022-12-21  已测试
DList<TextColor> Syntax::GetTextColorPosForC_Keywords3() const
{ 

    DList<TextColor> dtResult;

    if (_code.length() <= 0) return dtResult;

    const _char* p = _code.c_str();

    _string sWord(_t(""), 50);  //50个_char缓冲

    Color_  cKeyWordColor = GetColor(SyntaxType::关键字);

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

            if (i < _code.length())
            {
                if (p[i] == _t('/')) //是"//"注释,查找注释结束位置 \n ,跳过注释
                {
                    ++i;

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

                    bool bFind = false;
                    while (i + 1 < _code.length()) //查找下一个 "*/"
                    {
                        if (p[i] == '*' && p[i + 1] == '/')
                        {
                            i += 2;
                            bFind = true;
                            break;
                        }
                        ++i;
                    }
                    if (!bFind) return dtResult;
                }
            }
            else
            {
                return dtResult;
            }
        }
        else if (p[i] == _t('\"')) //字符开始
        {
            if (i - 1 > 0 && p[i - 1] != '\\')
            {
                ++i;

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

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

                        ei.Text = _t("当前行已结束,还未找到引号配对?");

                        ei.Text += _t("错误行号为第:");
                        ei.LineNumber = _code.GetLineIndexForCharIndex(i - 1);
                        ei.Text += _tostr(ei.LineNumber + 1);
                        ei.Text += _t("行。");
                      
                        //输出错误信息
                        PrintSyntaxCheckError(ei.Text);
                        
                        Error.Add(ei);

                        ++i;
                        bFind = true;
                        break;
                    }

                    ++i;
                }
                if (!bFind) return dtResult;
            }
            else
            {
                ++i;
            }
        }

        if (gs.s_Syntax_IsWordSeparator(p[i]))
        {
            //关键字最小长度大于2,且全是小写字母
            if (sWord.length() >= 2 && sWord.IsAllLowerCaseEnglishLetter())
            {
                if (C_Keyword.findNoteItem(sWord) != null) //是关键字,记录位置
                {
                    dtResult.Add(TextColor(i - sWord.length(), sWord.length(), cKeyWordColor));
                }

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


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

    return dtResult;
}

?

之前版本:

依据第二版本,可以写一个跳过注释的查找函数

C_IndexOfWord

Java_IndexOfWord

CSharp_IndexOfWord

还有一种方法,可以先把所有注释用空格代替,查出的字符位置也不变。

以前版本:

DList<TextColor> Syntax::GetTextColorPosForC_Keywords1() const
{
? ? DList<TextColor> dtResult;
? ? int nPos = -1;

? ? if (_LanguageType == LanguageType::C)//-----------------------------------C&C++ Begin
? ? {


? ? ? ? //-----------------------------------------------------------------关键字
? ? ? ? for (_string s : C_Keyword)
? ? ? ? {
? ? ? ? ? ? nPos = _code.IndexOfWord(s);

? ? ? ? ? ? while (nPos != -1)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? dtResult.Add(TextColor(nPos, s.length(), GetColor(SyntaxType::关键字)));

? ? ? ? ? ? ? ? nPos = _nh_en.IndexOfWord(s, nPos + s.length());
? ? ? ? ? ? }
? ? ? ? }
? ? }

? ? return dtResult;
}
?

修改版本:

/// <summary>
/// ?记录C,C++关键字的位置,跳过注释和字符串文本。
/// </summary>
/// <returns></returns>
/// 创建时间: 2022-12-19 ? ? ?最后一次修改时间:2022-12-19
DList<TextColor> Syntax::GetTextColorPosForC_Keywords2() const
{
? ? DList<TextColor> dtResult;

? ? if (_code.length() <= 0) return dtResult;

? ? const _char *p = _code.c_str();
? ? ? ? ?
? ? _string sWord(_t(""), 50); ?//50个_char缓冲

? ? Color_ ?cKeyWordColor = GetColor(SyntaxType::关键字);

? ? for(int i = 0; i < _code.length(); ++ i)
? ? {
? ? ? ? if ( p[i] == _t('/'))
? ? ? ? {
? ? ? ? ? ? if (i + 1 < _code.length())
? ? ? ? ? ? {
? ? ? ? ? ? ? ? if (p[i + 1] == _t('/') ) //是"//"注释,查找注释结束位置 \n ,跳过注释
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? i += 2;
? ? ? ? ? ? ? ? ? ? while (p[i] != 0 && p[i] != '\n')
? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ++i;
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? else if (p[i + 1] == _t('*')) //是"/*"注释,查找注释结束位置 */ ,跳过注释
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? i += 2;
? ? ? ? ? ? ? ? ? ? while (p[i] != 0 && p[i] != _t('*'))
? ? ? ? ? ? ? ? ? ? {?
? ? ? ? ? ? ? ? ? ? ? ? if (p[i + 1] != 0 && p[i + 1] != '/') //结束位置
? ? ? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ++i;
? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? else
? ? ? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ++i;
? ? ? ? ? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ? ? else
? ? ? ? ? ? {
? ? ? ? ? ? ? ? return dtResult;
? ? ? ? ? ? } ? ? ?
? ? ? ? }
? ? ? ? else if (p[i] == _t('\"')) //字符开始
? ? ? ? {
? ? ? ? ? ? ++i;
? ? ? ? ? ? while(p[i] != 0 && p[i] != '\"')
? ? ? ? ? ? {
? ? ? ? ? ? ? ?++i; ??
? ? ? ? ? ? } ? ? ? ??
? ? ? ? }

? ? ? ? if (gs.s_Syntax_IsWordSeparator(p[i]))
? ? ? ? {
? ? ? ? ? ? //关键字最小长度大于2,且全是小写字母
? ? ? ? ? ? if (sWord.length() >= 2 && sWord.IsAllLowerCaseEnglishLetter())
? ? ? ? ? ? {
? ? ? ? ? ? ? ? if (C_Keyword.findNoteItem(sWord) != null) //是关键字,记录位置
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? dtResult.Add(TextColor(i - sWord.length(), sWord.length(), cKeyWordColor));
? ? ? ? ? ? ? ? }

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

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

? ? return dtResult;
}

/// <summary>
///  记录C,C++关键字的位置,跳过注释和字符串文本。
/// </summary>
/// <returns></returns>
/// 创建时间: 2022-12-19      最后一次修改时间:2022-12-19
DList<TextColor> Syntax::GetTextColorPosForC_Keywords2() const
{
    DList<TextColor> dtResult;

    if (_code.length() <= 0) return dtResult;

    const _char *p = _code.c_str();
         
    _string sWord(_t(""), 50);  //50个_char缓冲

    Color_  cKeyWordColor = GetColor(SyntaxType::关键字);

    for(int i = 0; i < _code.length(); ++ i)
    {
        if ( p[i] == _t('/'))
        {
            if (i + 1 < _code.length())
            {
                if (p[i + 1] == _t('/') ) //是"//"注释,查找注释结束位置 \n ,跳过注释
                {
                    i += 2;
                    while (p[i] != 0 && p[i] != '\n')
                    {
                        ++i;
                    }
                }
                else if (p[i + 1] == _t('*')) //是"/*"注释,查找注释结束位置 */ ,跳过注释
                {
                    i += 2;
                    while (p[i] != 0 && p[i] != _t('*'))
                    { 
                        if (p[i + 1] != 0 && p[i + 1] != '/') //结束位置
                        {
                            ++i;
                        }
                        else
                        {
                            ++i;
                            break;
                        }
                    }
                }
            }
            else
            {
                return dtResult;
            }      
        }
        else if (p[i] == _t('\"')) //字符开始
        {
            ++i;
            while(p[i] != 0 && p[i] != '\"')
            {
               ++i;   
            }         
        }

        if (gs.s_Syntax_IsWordSeparator(p[i]))
        {
            //关键字最小长度大于2,且全是小写字母
            if (sWord.length() >= 2 && sWord.IsAllLowerCaseEnglishLetter())
            {
                if (C_Keyword.findNoteItem(sWord) != null) //是关键字,记录位置
                {
                    dtResult.Add(TextColor(i - sWord.length(), sWord.length(), cKeyWordColor));
                }

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

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

    return dtResult;
}

其中:

?? ?/// <summary>
?? ?/// 判断字符是否单词的有效分隔符
?? ?/// </summary>
?? ?/// <param name="c"></param>
?? ?/// <returns></returns>
?? ?inline static bool s_Syntax_IsWordSeparator(_char c) {
?? ??? ?return (gs.c_IsPunctuation(c) || gs.c_IsControl(c) || Math_::strchr(IdentifierSpecial, c) != -1) && c != _t('_');
?? ?}


const _char* global_c_str::IdentifierSpecial = _t("~!@#$%^&*()+-/.{}[]|\\ `=");

虽然结果正确,但不严谨,以下修正:

/// <summary>
///  记录C,C++关键字的位置,跳过注释和字符串文本。
/// </summary>
/// <returns></returns>
/// 创建时间: 2022-12-19      最后一次修改时间:2022-12-21  已测试
DList<TextColor> Syntax::GetTextColorPosForC_Keywords2() const
{
    DList<TextColor> dtResult;

    if (_code.length() <= 0) return dtResult;

    const _char *p = _code.c_str();
         
    _string sWord(_t(""), 50);  //50个_char缓冲

    Color_  cKeyWordColor = GetColor(SyntaxType::关键字);

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

            if (i < _code.length())
            {
                if (p[i] == _t('/') ) //是"//"注释,查找注释结束位置 \n ,跳过注释
                {
                    ++i;

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

                    bool bFind = false;
                    while (i + 1 < _code.length()) //查找下一个 "*/"
                    {
                        if (p[i] == '*' && p[i + 1] == '/')
                        {
                            i += 2;
                            bFind = true;
                            break;
                        }
                        ++i;
                    }
                    if (!bFind) return dtResult;
                }
            }
            else
            {
                return dtResult;
            }      
        }
        else if (p[i] == _t('\"')) //字符开始
        {
            ++i;
            bool bFind = false; //查找下一个 "\""
            while (i + 1 < _code.length())
            {
                if (p[i] == '\"')
                {
                    i += 2;
                    bFind = true;
                    break;
                }
                ++i;
            }
            if (!bFind) return dtResult;
        }

        if (gs.s_Syntax_IsWordSeparator(p[i]))
        {
            //关键字最小长度大于2,且全是小写字母
            if (sWord.length() >= 2 && sWord.IsAllLowerCaseEnglishLetter())
            {
                if (C_Keyword.findNoteItem(sWord) != null) //是关键字,记录位置
                {
                    dtResult.Add(TextColor(i - sWord.length(), sWord.length(), cKeyWordColor));
                }

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

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

    return dtResult;
}

另加上查找函数:

/// <summary>
	/// 跳过注释和字符串值查找字符,这里假设注释和字符串书写模式正确,而且你
	/// 不要去查找一个双引号( '\"') ,永远都返回-1。
	/// </summary>
	/// <param name="c"></param>
	/// <param name="iFindStart"></param>
	/// <param name="bMatchCase"></param>
	/// <returns></returns>
	/// 创建时间: 2021-12-21      最后一次修改时间:2022-12-21    已测试
	int Syntax_C_IndexOf(const _char c, const int iFindStart = 0)const
	{
		int iStart = iFindStart <= 0 ? 0 : iFindStart;

		if (c == 0 || _nLength <= 0 || iStart >= _nLength) return -1;

		const _char* p = _pData;

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

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

						bool bFind = false;
						while (i + 1 < _nLength) //查找下一个 "*/"
						{
							if (p[i] == '*' && p[i + 1] == '/')
							{
								i += 2;
								bFind = true;
								break;
							}
							++i;
						}
						if (!bFind) return -1;
					}
					else
					{
						if (p[i] == c) { return i; }
					}
				}
				else
				{
					return -1;
				}
			}
			else if (p[i] == _t('\"')) //字符开始
			{
				++i;
				bool bFind = false;
				while (i < _nLength)   //查找下一个 "\""
				{
					if (p[i] == '\"')
					{
						bFind = true;
						++i;
						break;
					}
					++i;
				}
				if (!bFind) return -1;
			}
			else
			{
				if (p[i] == c) { return i; }
			}

		}

		return -1;
	}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-12-25 10:47:31  更:2022-12-25 10:51:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/22 18:54:44-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码