第14周 【项目四 - 处理C++源代码的程序】(1)

第14周 【项目4 - 处理C++源代码的程序】(1)

问题描述: 

在CodeBlocks等IDE中都提供了代码格式整理的功能。完成这种功能的程序,操作的数据是用C++写的源代码文件。C++源文件是一种文本文件,可以通过程序进行操作。

集成开发环境(IDE)对对程序进行编译,操作的“数据”是源程序。编译中,要对源程序进行词法检查和语法检查,后续还要进行目标代码生成、代码优化等工作。相关的技术将在《编译原理》课中学习。这些技术可以用在很多领域,当然也能够让我们对于编程语言有更深的了解。
  本项目将以C++源程序为操作对象,完成对源程序的一系列处理。各功能可以分别编制一个程序实现(建议用这种简单的方案),也可以将其集成在一起(向着自己做出IDE努力)。
(1)读入一个C++程序,判断其中是否只有一个main()函数,输出“暂时没有发现问题”,或者“没有main()函数”,或者“不能定义多个main()函数”;
提示1:简单处理,可以只比较判断”main()”,考虑实际上的各种可能,main后面的括号中有任意多个空格及void的都应该算在内。建议按最简单的情形处理。

提示2:建议设计一个函数,将读到的代码与字符串”main()”进行比较。函数用于判断s1是否“包含”在读入的一行s2中,调用时,形参s1处的实参用”main()”即可,这样写提升了“抽象”级别,更容易实现,对应更高的代码质量。

代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <fstream>
#include <cstdlib>
#include <cctype>
using namespace std;
string s="main()";
string  f(string str)
{
    string return_str="";
    int length=str.length();
    for(int i=0;i<length;i++)
      if(str[i]!=' ')return_str+=str[i];
    return return_str;
}
int fun(string t){
    int c;
    int i=0,len=t.length(),j;
    for(i=0;i<len;++i){
        string k;
        k+=t[i];k+=t[i+1];k+=t[i+2];k+=t[i+3];k+=t[i+4];k+=t[i+5];k+=t[i+6];
        for(j=0,c=1;j<7;j++){
            if(k[j]!=s[j]){
                c=0;
                break;
            }
        }
      if(c)
        return 1;
    }
    return 0;
}
int main(){
    string t;
    int num=0,i;
    fstream myfile("source.cpp",ios::in);
    if(!myfile){
        cerr<<"can't find sorce.cpp\n";
        exit(1);
    }
    while(!myfile.eof()){
        getline(myfile,t);
        t=f(t);//删除空格
       num+=fun(t);//判断是否有main()
        if(num>1)break;
    }
    if(num==1)printf("source.cpp is legal\n");
    else printf("source.cpp is illegal\n");
    return 0;
}

运行结果:

第14周 【项目四 - 处理C++源代码的程序】(1)

大半夜终于搞定了!