1 20 50 150 500
欢迎来到瑞博软件站,找素材,搜软件,就上瑞博软件站!
当前位置 >首页 >软件下载 >电脑软件 >应用软件 >文档管理

去除c++多余头文件的工具(cxx clean include)

软件信息
  • 分类:文档管理
  • 大小:7.8M
  • 语言: 中文
  • 环境: WinAll, Win7, Mac
  • 更新:2024-11-13
  • 评级:
  • 系统: Windows Linux Mac Ubuntu
  • 软件类别: 国产软件 / 免费软件 / 文本编辑
  • 插件情况:

cxx-clean-include是一个用于清理c++文件中多余#include并自动生成前置声明的工具,目前支持对visual studio单个c++项目作清理,以及清理整个文件夹下的c++文件,可以对visual studio项目(2005及以上版本)进行清理,也可以对单个文件夹(含子文件夹)的c++源文件进行清理。

使用方法

1. 下载本项目

2. 双击运行hello文件夹下的run.bat

3. 如果成功的话,hello项目将被清理,且将在hello文件夹下生成清理日志(可使用浏览器查看)

4. 将run.bat里面的./hello.vcxproj改成你自己的vs工程文件,就可以清理你的工程了

注意:使用前请备份你的代码


(如果无法正常使用,请试着安装visual studio 2013的32位运行时组件,可到官网:https://www.microsoft.com/zh-cn/download/details.aspx?id=40784 中下载vcredist_x86.exe并安装)

cxx-clean-include的一些测试结果

目前,已在网上的一些开源vs项目上测试使用了本工具(只是自行测试)

https://github.com/MSOpenTech/redis

该项目是由[MS Open Tech组织]将redis移植到windows下的版本,使用本工具清理msvsRedisServer.vcxproj后发现共有28个文件(含.c文件和.h头文件)包含多余的#include,清理后仍可编译成功。 (清理前须将头文件包含路径中的$(SolutionDir)删掉)

cxx-clean-include的作用

由于cxx-clean-include基于llvm+clang库编写而成,依托于clang库对现有编译器的兼容,所以本项目也支持大部分msvc、gcc/g++的语法,并完整支持c++11标准。


cxx-clean-include可以做到

 清除c++文件中多余的#include(不仅可以清理cpp、cxx等后缀的源文件,也可以清理源文件包含的h、hxx、hh等后缀的头文件)

 自动生成前置声明(某些时候,会出现包含了某个文件,却仅使用了该文件内的类的指针或引用,而未访问其成员的情况,此时cxx-clean-include将移除相应的#include语句,并添加前置声明)

 自动替换文件(某些时候,会出现#include了某个文件a,却仅使用到该文件内包含的其中一个文件b的情况,此时cxx-clean-include将遵循头文件路径搜索规则把原有的#include a语句替换成#include b语句)

 针对整个项目进行分析,而不仅分析单个c++源文件,通过采用合适的冲突处理规则,尽可能清理源文件和头文件,并尽可能保证清理整个项目后,仍然没有编译错误

关于cxx-clean-include的实际作用,举个例子,假设有一个文件hello.cpp,里面的内容是:

#include "a.h"                    // a.h文件的内容是:class A{};

#include "b.h"                    // b.h文件的内容是:#include <stdio.h>

#include "c.h"                    // c.h文件的内容是:class C{};

#include "d.h"                    // d.h文件未被使用:class D{};

A *a;                             // 类A来自于a.h

void test_b() { printf(""); }     // 函数printf来自于stdio.h

C c;                              // 类C来自于c.h

cxx-clean-include将对hello.cpp文件进行分析:

~ 1. 首先,由于hello.cpp仅使用到a.h、b.h、c.h的内容,因此,可移除#include "d.h"语句

~ 2. 其次,经过分析,hello.cpp仅使用了a.h中类A的指针,因此,可新增前置声明class A,并移除#include "a.h"语句

~ 3. 最后,hello.cpp虽然包含了b.h,却仅使用到b.h所包含的stdio.h文件,因此,可将#include "b.h"语句替换为#include <stdio.h>

于是,在使用cxx-clean-include对hello.cpp进行清理后,hello.cpp将变为

class A;

#include <stdio.h>

#include "c.h"                    // c.h文件的内容是:class C{};

A *a;                             // 类A来自于a.h

void test_b() { printf(""); }     // 函数printf来自于stdio.h

C c;                              // 类C来自于c.h

可以看出,hello.cpp第1行和第2行均被替换为更合适的语句。第4行则被移除

注意:本项目在windows和linux系统下均可进行编译,具体编译过程可参考clang插件的编译方法。

cxx-clean-include的命令

cxx-clean-include目前支持清理visual studio项目(vs2005及以上版本),同时支持清理指定文件夹下的c++文件,同时输出结果是html格式,方便查看

1. 对于visual studio项目,可以使用以下命令:

cxxclean -vs vs项目名称

// 比如:cxxclean -vs d:/vs2005/hello.vcproj

// vs项目名称最好是绝对路径,如: d:/vs2005/hello.vcproj、d:/vs2008/hello.vcxproj

该命令将清理整个vs项目内的c++文件,同时将在当前文件夹自动生成清理日志

2. 对于单个文件夹,可以使用以下命令

cxxclean -clean 文件夹路径

// 比如:cxxclean -clean d:/a/b/hello/

// 文件夹路径最好是绝对路径,如: d:/a/b/hello/、/home/proj/hello/

该命令将清理该文件夹内的c++文件,同时将在当前文件夹自动生成清理日志

但很多情况下需要指定更详细的编译条件,如指定头文件路径、预定义宏等,clang库已内置提供了相应的命令行参数供使用,可使用如下方式(注意添加--号):

cxxclean -clean 文件夹路径 -- -I"你的头文件搜索路径" -D 需要预定义的宏 -include 需要强制包含的文件

(其中:-I、-D、-include均可使用多次)

// 例如:cxxclean -clean d:/a/b/hello/ -- -I"../../" -I"../" -I"./" -I"../include" -D DEBUG -D WIN32 -include platform.h

cxx-clean-include的命令行参数

在命令行中输入cxxclean -help可获取详细的命令行参数信息

cxx-clean-include提供以下选项:

  -vs=<string>    - 清理指定的visual studio项目(vs2005版本及以上): 例如: 

                        cxxclean -vs ./hello.vcproj

                        该命令将清理hello项目中的所有c++文件

                    -vs可和-clean结合使用,例如:

                        cxxclean -vs hello.vcproj -clean hello.cpp

                        该命令将根据hello.vcproj项目的配置(如头文件搜索路径、预定义宏等配置)来清理hello.cpp文件

  -clean=<string> - 清理指定的文件或文件夹, 例如: 

                        1. cxxclean -clean ../hello/

                           该命令将清理hello文件夹(包括子文件夹)下的c++文件

                        2. cxxclean -clean hello.cpp

                           该命令将清理hello项目中的所有c++文件

  -no             - 即no overwrite的首字母缩写, 当传入此参数时,本工具仅执行分析并打印分析结果,所有的c++文件将不会被改动

  -onlycpp        - 仅允许清理源文件(cpp、cc、cxx后缀等), 禁止清理头文件(h、hxx、hh后缀等)

  -print-project  - 打印本次清理的配置, 例如:打印待清理的c++文件列表、打印允许清理的文件夹或c++文件列表等等

  -print-vs       - 打印visual studio项目的配置文件内容, 例如:打印头文件搜索路径、打印项目c++文件列表、打印预定义宏等等

下载地址

热门软件

Top