今天学习了一下Boost的文件遍历功能,同一时候发现GNU编译器有-MM选项。能够自己主动生成依赖关系,于是利用以上两点写了一个Makefile生成器。

能够生成一般的单个可运行文件的Makefile。使用的是Windows+Mingw+boost环境。假设使用Linux,仅仅需在程序中的两个System系统调用处和clean标签生成处将del 改成rm相关操作就好了。

如今更改成了Linux版本号。下载的版本号是Windows的。

以下是源码:

makemake.cpp:

#include <iostream>  
#include <fstream>  
#include <cstdlib>  
#include <vector>  
#include <string>  
#include <exception>  
#include <boost/filesystem/operations.hpp>  
#include <boost/filesystem/path.hpp>  
#include <boost/algorithm/string.hpp>  
#include <boost/program_options.hpp>   using namespace std;  
namespace po = boost::program_options;  
using namespace boost::filesystem;  
using namespace boost;   void getFiles(vector<string>& src);   const string head = string(  
"######################################################################\n")+  
"# This makefile is generated by makemake.                            #\n"+  
"# By Eric Brown.                                                     #\n"+  
"# 2014/10/27                                                         #\n"+  
"######################################################################\n";   int main(int argc, char* argv[])  
{  
    vector<string> src;  
    string compiler = "g++";  
    string target = "a";  
    vector<string> objs;  
    bool debug = false;       try  
    {  
        po::options_description desc("---Help---");  
        desc.add_options()  
            ("help,h", "print this message.")  
            ("gcc,c", "use gcc compiler. Program uses g++ default.")  
            ("debug,g", "use debug option(-g) in makefile.")  
            ("out,o", po::value<string>(), "the target file name.");  
        po::positional_options_description p;  
        p.add("out", -1);  
        po::variables_map vm;  
        po::store(po::command_line_parser(argc, argv).options(desc).  
                positional(p).run(), vm);  
        po::notify(vm);           if (vm.count("help"))  
        {  
            cout << desc << endl;  
            return 0;  
        }  
        if (vm.count("gcc"))  
            compiler = "gcc";  
        if (vm.count("out"))  
            target = vm["out"].as<string>();  
        if (vm.count("debug"))  
            debug = true;  
    } catch(std::exception& e) {  
        cout << e.what() << endl;  
        return 1;  
    }       getFiles(src);       ofstream make;  
    make.open("Makefile", ios_base::out);       make << head << endl;  
    make << "CC = " << compiler << endl;  
    make << "Flags = " << endl;  
    make << "LIBS = ";
    if (debug)  
        make << "-g";       make << endl;       make << "src = ";  
    for (int i = 0; i < src.size(); ++i)  
    {  
        make << src[i] << ' ';  
        std::system(string(compiler + " -MM \"" + src[i] + "\" >> .temp~").c_str());  
    }       make << "\nObjs = ";  
    for (int i = 0; i < src.size(); ++i)  
    {  
        if (ends_with(src[i], ".cpp"))  
            objs.push_back(replace_last_copy(src[i], ".cpp", ".o"));  
        if (ends_with(src[i], ".c"))  
            objs.push_back(replace_last_copy(src[i], ".c", ".o"));  
        make << objs[i] << ' ';  
    }  
    make << endl;       make << '\n' << target << ": $(Objs)" << endl;  
    make << "\t$(CC) $(Flags) $(Objs) -o " << target << " ${LIBS}" << endl;  
    make << "$(Objs): $<" << endl;
    make << "\t$(CC) $(Flags) $< -c\n" << endl;       ifstream in(".temp~");  
    string line;  
    while(getline(in, line))  
        make << line << endl;  
    make << endl;       make << "clean:" << endl;  
    make << "\trm -f ${Objs}" << endl;  
    make << "cleanbak:" << endl;  
    make << "\trm -f *~" << endl;  
    in.close();       std::system("rm -f .temp~");       make.close();       return 0;  
}   void getFiles(vector<string>& src)  
{  
    path p = current_path();  
    directory_iterator beg(p);  
    directory_iterator end;  
    for (; beg != end; beg++)  
    {  
        string name = beg->path().filename().string();  
        if (ends_with(name, ".cpp") ||  
                ends_with(name, ".c"))  
            src.push_back(name);  
    }  
}  

可运行程序能够在这里下载:http://download.csdn.net/detail/pdcxs007/8090981。

Makefile生成器,使用C++和Boost实现的更多相关文章

  1. boost 随机数发生器

    Random     随机数 在很多应用中都需要使用随机数.本库力求提供一个高效的,通用的随机数库.boost库有多种随机数生成方式.先熟悉一下各种随机数生成器的概念. 数字生成器(Number Ge ...

  2. Android学习——windows下搭建NDK_r9环境

    1. NDK(Native Development Kit) 1.1 NDK简介 Android NDK是一套允许开发人员使用本地代码(如C/C++)进行Android APP功能开发的工具,通过这个 ...

  3. NDK开发

    1 CDT 是 Eclipse 插件,它将把 Eclipse 转换为功能强大的 C/C++ IDE. C/C++在Eclipse平台下的开发工具.它提供的功能包括:C/C++编辑器(一些基本的功能:语 ...

  4. Java开源项目(备查)

    转自:http://www.blogjava.net/Carter0618/archive/2008/08/11/221222.html Spring Framework  [Java开源 J2EE框 ...

  5. qmake和moc的功能(★firecat推荐★)

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://devbean.blog.51cto.com/448512/355100 前面我们 ...

  6. Qt核心剖析: moc

    前面我们说过,Qt 不是使用的“标准的” C++ 语言,而是对其进行了一定程度的“扩展”.这里我们从Qt新增加的关键字就可以看出来:signals.slots 或者 emit.所以有人会觉得 Qt 的 ...

  7. Android下NDK开发环境搭建

    Android下NDK开发环境搭建 1.     AndroidNDK安装与配置 1.1  NDK简介 Android NDK是一套允许开发人员使用本地代码(如C/C++)进行Android APP部 ...

  8. Caffe源码中common文件分析

    Caffe源码(caffe version:09868ac , date: 2015.08.15)中的一些重要头文件如caffe.hpp.blob.hpp等或者外部调用Caffe库使用时,一般都会in ...

  9. QObject 源代码阅读

    我们进入 qt/src 文件夹.你可能对这里的目录名时曾相识,因为几乎这里的所有文件夹名都对应着 Qt 的模块的名字:gui,network,multimedia等等.我们从最核心的 QtCore 开 ...

随机推荐

  1. Sound.loadCompressedDataFromByteArray

    前不久Adobe发布了Flash Player 11的release版本, Flash Player 11 带来了很多新特性, 最最红火的就是Stage3D了,但是这里讲的是这个版本的另一个新特性, ...

  2. MySQL round函数

    在mysql中,round函数用于数据的四舍五入,它有两种形式: 1.round(x,d)  ,x指要处理的数,d是指保留几位小数 这里有个值得注意的地方是,d可以是负数,这时是指定小数点左边的d位整 ...

  3. JAVA常见算法题(三十一)---冒泡排序

    package com.jege.spring.boot.hello.world; /** * java算法之冒泡排序<br> * 将数组按照从大到小的顺序排列<br> * * ...

  4. 一次SQL查询语句的优化

    1.项目中之前的"我关注的拍品列表"需要添加筛选功能,因为目前显示的关注的拍品太多没有进行分类,用户体验差. 2.添加筛选条件之后,可以筛选出“未开始”“进行中”“已结束”三种情况 ...

  5. Robot Framework 安装及环境配置

    Robot Framework 安装及环境配置 Robot Framework 介绍 Robot Framework是一款python编写的功能自动化测试框架.具备良好的可扩展性,支持关键字驱动,可以 ...

  6. 2016年终总结--一个Python程序猿的跨界之旅

    时间过得真快.感觉15年年终总结刚写完,16年就结束了.看了blog,16年就写了可怜的8篇,对我来说16年还算顺风顺水. 真正可能出乎意料的是年底我离开了呆了2年半的龙图游戏,临时放弃了用了3年半的 ...

  7. go语言基础之不同作用域同名变量

    1.不同作用域同名变量 示例: package main import "fmt" var a byte //全局变量 func main() { var a int //局部变量 ...

  8. [转载][概念]Storage Pool, Private RAID Group, Private LUN

    Storage Pool的起源 ========================== Some time ago, EMC introduced the concept of Virtual Prov ...

  9. 高性能WEB开发:重排与重绘

    DOM编程可能最耗时的地方,重排和重绘. 1.什么是重排和重绘 浏览器下载完页面中的所有组件——HTML标记.JavaScript.CSS.图片之后会解析生成两个内部数据结构——DOM树和渲染树. D ...

  10. SVG Viewer 3.0安装发现SVG Viewer License.txt无法介入写入,安装失败

    这几天研究SVG,发现"SVG Viewer 3.0安装发现SVG Viewer License.txt无法介入写入,安装失败"这个问题,晚上没找到解答的答案,后来被我们项目经理搞 ...