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 ...
随机推荐
- How to get HTML code of a WebElement in Selenium
http://stackoverflow.com/questions/32234205/how-to-get-html-code-of-a-webelement-in-selenium WebElem ...
- SpringMVC轻松学习-环境搭建(二)
基于spring2.5的采用XML配置的spring MVC项目 注:本项目全部基于XML配置.同时,集成了hibernate.采用的是:spring MVC+hibernate+spring的开发架 ...
- Arch Linux 安装过程
在VM中装了Arch,由于过程较为曲折,现写博客一篇聊以慰藉. 1.新建虚拟机,将下载好的archlinux-2016.03.01-dual.iso挂到虚拟机设置的CD/DVD 2.进入Arch安装界 ...
- Zipf’s Law
Let f(w) be the frequency of a word w in free text. Suppose that all the words of a text are ranked ...
- Spring简单属性注入--不常用!!!
UserDAOImpl.java: package com.bjsxt.dao.impl; import com.bjsxt.dao.UserDAO; import com.bjsxt.model.U ...
- delphi显示hello world 和退出程序
Label1.Caption:='hello world!' Form1.close; application.Terminate; //终止程序 Application.Run; //程序运行 te ...
- php传输大数据大文件时候php.ini相关设置
post_max_size which is directly related to the POST size---针对采用post上传的,大文件,此项为关键 upload_max_filesize ...
- [转载] python利用psutil遍历进程名字和exe所在目录
本文转载自: http://www.duanzhihe.com/1594.html http://www.jianshu.com/p/64e265f663f6 import psutil,os,tim ...
- python实现断点续传下载文件
最近的任务里有一个功能是要我从日志服务器实时跟新日志到本地,日志在不断新增内容就需要我隔一段时间从上次下载的位置继续下载,并写入本地文件上次写完的位置后面. headers = {'Range': ' ...
- 获取IIS版本
近日,有一项目要分别获取iis6.0和7.5,然后对进程进行操作~ 研究良久,有以下办法获取iis版本. 代码: DirectoryEntry getEntity = new DirectoryEnt ...