VisualGDB Makefiles
以下内容是VisualGDB官网对VisualGDB编译时获取相关编译信息的说明:
When you create a new project using VisualGDB, it will generate a Makefile for you. More specifically, it will generate 2 files: Makefile and flags.mak.
Overview
- When you add new files to the project, VisualGDB will update the Makefile automatically
- If you want to change the GCC/LD flags, edit the flags.mak file
- If you want to add more configurations or targets, modify the Makefile.
- If you don't want VisualGDB to touch the Makefile, remove the following line:
#VisualGDB: AutoSourceFiles
Detailed description
The Makefile contains basic targets (such as all and clean) and generally has the following structure:
SOURCEFILES := file1.cpp file2.cpp
TARGETNAME := MyExeName
include flags.mak
ifeq ($(CONFIG),DEBUG)
...
endif
...
$(BINARYDIR)/%.o : %.cpp $(BINARYDIR)
$(CXX) $(CFLAGS) -c $< -o $@ -MD -MF $(@:.o=.dep)
$(BINARYDIR)/%.o : %.c $(BINARYDIR)
$(CC) $(CXXFLAGS) -c $< -o $@ -MD -MF $(@:.o=.dep)
The SOURCEFILES line lists all source files used in the project. VisualGDB will automatically update this line when you add new files to the project. The "%.cpp" and "%.c" lines define generic rules to build .o files from the C/C++ source files.
The flags.mak defines GCC flags (such as optimization level) that are used by Makefile. Its typical structure looks the following way:
CXX := /usr/bin/g++
LD := /usr/bin/g++
...
CFLAGS := -ggdb -ffunction-sections
DEBUG_CFLAGS := -O0
RELEASE_CFLAGS := -O3
The following table summarizes all variables defined in flags.mak:
Variable | Meaning | Example |
---|---|---|
CC | Location of the GCC compiler | c:/gcc/gcc.exe |
CXX | Location of the C++ compiler | c:/gcc/g++.exe |
LD | Location of the linker (typically GCC/G++ is used for linking) | c:/gcc/g++.exe |
COMMON_MACROS | Preprocessor definitions to be defined in all configurations. | _WIN32 _CONSOLE |
DEBUG_MACROS | Preprocessor definitions to be defined in DEBUG configuration only | _DEBUG DEBUG |
RELEASE_MACROS | Preprocessor definitions to be defined in RELEASE configuration only | _NDEBUG _RELEASE |
MCUFLAGS | Additional flags specifying microcontroller type | -mmcu=msp430f2013 |
INCLUDE_DIRS | Additional include directories relative to the project location | ../lib1 ../lib2 |
LIBRARY_DIRS | Additional library directories | ../lib1/bin ../lib2/bin |
LIBRARY_NAMES | Additional libraries to link with (no "lib" prefix) | 1 2 |
CFLAGS | Additional GCC flags for all configurations | -ggdb -ffunction-sections |
DEBUG_CFLAGS | Additional GCC flags for DEBUG configuration | -O0 |
RELEASE_CFLAGS | Additional GCC flags for RELEASE configuration | -O3 |
CXXFLAGS | Additional C++ flags for all configurations | -fno-exceptions |
DEBUG_CXXFLAGS | Additional C++ flags for DEBUG configuration | |
RELEASE_CXXFLAGS | Additional C++ flags for RELEASE configuration | |
MACOS_FRAMEWORKS | Additional framework names (MacOS only) | iokit |
LDFLAGS | Additional flags to the linker (with -Wl, prefix when GCC is used for linking) | |
DEBUG_LDFLAGS | Additional linker flags for DEBUG configuration | |
RELEASE_LDFLAGS | Additional linker flags for RELEASE configuration | |
START_GROUP | Either an empty string, or "-Wl,--start-group" | |
END_GROUP | Either an empty string, or "-Wl,--end-group" |
The START_GROUP/END_GROUP flags surround the library/object file list and allow specifying them in an arbitrary order (otherwise the object file list has to be sorted manually). You can set those variables to empty strings if your linker (e.g. MacOS linker) does not require those flags.
对上面的内容可以理解为为:Debug模式下,完整的make执行需要Makefile和debug.mak两个文件;Release模式下则需要Makefile和release.mak两个文件
如果需要导出VisualGDB的Makefile文件,只需要合并相应的两个文件即可。将.mak文件的内容放到Makefile文件内容的前面,所得到的Makefile文件即可进行编译。
VisualGDB Makefiles的更多相关文章
- 使用VS+VisualGDB编译Linux版本RCF
RPC通信框架--RCF介绍中说了,RCF本身是支持跨平台的,其代码放到Linux平台,是可以通过gcc.make等工具,编译通过的. 官方提供的源码中,只有cmake编译脚本,并没有提供Makefi ...
- 使用VS+VisualGDB编译Linux版本RCF(相当于Linux也有COM版本了)
阅读目录 通过向导配置项目 配置目录结构 修改项目配置 添加RCF源代码 完成配置并进行编译 添加测试程序 添加测试代码——通过TCP进行通信 运行测试程序并查看测试结果 VisualGDB生成的所有 ...
- 使用VS+VisualGDB编译调试Linux程序
Linux程序开发变得越来越多,越来越多的程序.产品需要跨平台,甚至有些开源项目只支持Linux平台,所以掌握Linux开发变得越来越重要. 但是对于习惯了Windows下的开发,使用了VS这个宇宙第 ...
- VisualRust + VisualGDB编辑调试Rust
Rust到1.6了,到了一个相对成熟的阶段,可以试用做一些项目了.但是写的代码越多,就会发现一个好的IDE相当于效率的一半.这里分享我 在Visual Studio的使用Rust的经验. 首先需要下载 ...
- Makefiles 介绍
http://www-personal.umich.edu/~ppannuto/writings/makefiles.html Makefiles Makefiles (or, the GNU aut ...
- VisualGDB:使用VS创建CMake Linux项目
转载地址:点击打开链接 根据VisualGDB官网(https://visualgdb.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指正. 本文介绍如何使用 ...
- VisualGDB系列8:使用VS创建CMake Linux项目
根据VisualGDB官网(https://visualgdb.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指正. 本文介绍如何使用VS来创建.构建.调试一 ...
- VisualGDB系列11:Linux C++项目中使用外部Linux库
根据VisualGDB官网(https://visualgdb.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指正. 在<使用VS创建Linux静态库和 ...
- VisualGDB系列10:快速调试Linux应用程序
根据VisualGDB官网(https://visualgdb.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指正. 本文介绍如何快速调试GCC构建的Linu ...
随机推荐
- android systemUI--Notification 整理
PendingIntent Intent是一个意图,一个描述了想要启动一个Activity.Broadcast或是Service的意图.它主要持有的信息是它想要启动的组件(Activity.Broad ...
- JS操作DOM对象——JS基础知识(四)
一.JavaScript的三个重要组成部分 (1)ECMAScript(欧洲计算机制造商协会) 制定JS的规范 (2)DOM(文档对象模型)重点学习对象 处理网页内容的方法和接口 (3)BOM(浏览器 ...
- [iOS]C语言技术视频-11-指针变量练习一(交换值)
下载地址: 链接: http://pan.baidu.com/s/1pJIcGm3 密码: s83p
- hibernate---树状映射
总公司--分公司1, 分公司2 分公司1: 分公司1下部门1, 分公司1下部门2 分公司2: Org.java: package com.bjsxt.hibernate; import java.ut ...
- 使用maven管理后,依然找不到需要的jar包
使用maven管理后,依然报错,找不到,比如如下错误java.lang.ClassNotFoundException: org.springframework.web.context.ContextL ...
- Document Classification
Natural Language Processing with Python Chapter 6.1 由于nltk.FreqDist的排序问题,获取电影文本特征词的代码有些微改动. import n ...
- (简单) POJ 2750 Potted Flower,环+线段树。
Description The little cat takes over the management of a new park. There is a large circular statue ...
- 决策树ID3算法的java实现
决策树的分类过程和人的决策过程比较相似,就是先挑“权重”最大的那个考虑,然后再往下细分.比如你去看医生,症状是流鼻涕,咳嗽等,那么医生就会根据你的流鼻涕这个权重最大的症状先认为你是感冒,接着再根据你咳 ...
- MySQL 表的命令
1.查看表的结构: desc 表名; show columns from 表名; describe 表名; show create table 表名; 2.修改表名 rename table 原表名 ...
- webstorm安装express报错
.... Exit code: -1 解决方法: webstorm创建express 需要 预先安装express-generator npm install express-generator -g