Windows 以及 Xcode下编译调试 libcurl 源码
2014-12-13 15:59
323 查看
curl 这个工具大家都很熟悉. 前几天因为要跟踪curl的实现细节, 不得不设法搭建curl的调试工程. 我们分别在windows visual studio 和 mac 上的 xcode 下搭建调试. 这里记录一些细节,分享出来.
curl 可以在数十个平台上编译运行.
这是官网地址: http://curl.haxx.se
请在这里下载源码: http://curl.haxx.se/download.html
下载解压.
一. Windows 调试:
在 windows 上调试比较简单. 自带工程文件.
直接用 VS2012 打开 \projects\Windows\VC11 里面的 工程文件就可以了。
务必用vs2012 打开。
直接 F10 就可以单步 到 main 函数。
二. Mac Xcode 调试.
我们主要说说 xcode 调试.
大概是因为 *nix 上的编译比较方便, 所以都是使用 makefile 编译. 所以没有自带工程文件.
所幸的是, 开源项目 cmake 可以根据 makefile 和配置文件逆向生成工程文件. 而更好的消息是 curl 早期是支持 cmake 的. 所以我们需要修改一下 curl 的配置文件, 并结合 cmake 来逆向生成 它在 xcode 上的工程文件.
开工.
1) 需要先安装cmake
下载 cmake 源码, http://www.cmake.org/files/v3.1/cmake-3.1.0-rc1.tar.gz 然后解压, 进去: ./configure && make && make install
一切顺利的话,应该就能成功了。
2) 生成 makefile
第二步, 我们需要生成curl 的 makefile. 进入curl的源码目录:
说明一下, 我们这里指定了两个参数, 我们不需要 curl 支持 ssh, 所以把”–without-libssh2 ” 排除. 而且”–with-darwinssl” 指定使用 mac 上的 ssl 实现, 而不需要 openssl.
这样可以减少出错的可能性, 而且, 我们就需要 darwinssl.
3) 生成 xcode 工程.
前面几步都没什么特别的, 这一步是关键, 使用 cnamke 逆向生成工程.
在 curl 的源码根目录中, 有一个文件 “CMakeLists.txt” 这个是逆向生成所必须的配置文件. 这是curl 官方提供的, 但是已经很旧了, 年久失修, 不能工作了.
我们可以先尝试一下:
说明一下, 创建一个子目录保存工程. 然后使用命令:
来生成工程.
这一步会报大量的错误在”CMakeLists.txt” 中.
请使用附件中这个我修改过的版本代替源码中的版本, 然后再重复执行上面的命令生成.
CMakeLists.txt
工程文件已经生成了.
但是此时打开工程编译不过. 需要先对工程文件做一些修改:
具体请查看下面的命令.
在工程中添加了一些 link target. 比较简单. 不多说了.
现在设置一下 调试工程, 就可以调试了.
然后选中 curl 这个target:
然后找到 main 函数. 就可以单步调试了:
欢迎访问我的个人独立博客: http://byNeil.com
curl 可以在数十个平台上编译运行.
这是官网地址: http://curl.haxx.se
请在这里下载源码: http://curl.haxx.se/download.html
下载解压.
一. Windows 调试:
在 windows 上调试比较简单. 自带工程文件.
直接用 VS2012 打开 \projects\Windows\VC11 里面的 工程文件就可以了。
务必用vs2012 打开。
直接 F10 就可以单步 到 main 函数。
二. Mac Xcode 调试.
我们主要说说 xcode 调试.
大概是因为 *nix 上的编译比较方便, 所以都是使用 makefile 编译. 所以没有自带工程文件.
所幸的是, 开源项目 cmake 可以根据 makefile 和配置文件逆向生成工程文件. 而更好的消息是 curl 早期是支持 cmake 的. 所以我们需要修改一下 curl 的配置文件, 并结合 cmake 来逆向生成 它在 xcode 上的工程文件.
开工.
1) 需要先安装cmake
下载 cmake 源码, http://www.cmake.org/files/v3.1/cmake-3.1.0-rc1.tar.gz 然后解压, 进去: ./configure && make && make install
一切顺利的话,应该就能成功了。
2) 生成 makefile
第二步, 我们需要生成curl 的 makefile. 进入curl的源码目录:
./configure --without-libssh2 --with-darwinssl make
说明一下, 我们这里指定了两个参数, 我们不需要 curl 支持 ssh, 所以把”–without-libssh2 ” 排除. 而且”–with-darwinssl” 指定使用 mac 上的 ssl 实现, 而不需要 openssl.
这样可以减少出错的可能性, 而且, 我们就需要 darwinssl.
3) 生成 xcode 工程.
前面几步都没什么特别的, 这一步是关键, 使用 cnamke 逆向生成工程.
在 curl 的源码根目录中, 有一个文件 “CMakeLists.txt” 这个是逆向生成所必须的配置文件. 这是curl 官方提供的, 但是已经很旧了, 年久失修, 不能工作了.
我们可以先尝试一下:
mkdir -p build/xcode cd build/xcode cmake ../../$CURL -G Xcode
说明一下, 创建一个子目录保存工程. 然后使用命令:
cmake ../../$CURL -G Xcode
来生成工程.
这一步会报大量的错误在”CMakeLists.txt” 中.
请使用附件中这个我修改过的版本代替源码中的版本, 然后再重复执行上面的命令生成.
CMakeLists.txt
工程文件已经生成了.
但是此时打开工程编译不过. 需要先对工程文件做一些修改:
具体请查看下面的命令.
sed -i "" "s/OTHER_LDFLAGS = \"/OTHER_LDFLAGS = \"-framework Cocoa -framework CoreFoundation -framework CoreServices -framework Security -fobjc-link-runtime -framework LDAP/" CURL.xcodeproj/project.pbxproj
在工程中添加了一些 link target. 比较简单. 不多说了.
现在设置一下 调试工程, 就可以调试了.
然后选中 curl 这个target:
然后找到 main 函数. 就可以单步调试了:
欢迎访问我的个人独立博客: http://byNeil.com
相关文章推荐
- Nginx (一)Windows下编译Nginx源码以及安装 nginx for windows方法步骤
- ios: ffmpeg-0.9.2 xcode4.3.2 IOS5.1 真机调试编译过程以及Mac OSX10.7.3安装 gcc和make
- windows下使用MinGW+msys编译ffmpeg,以及如何加入eclipse CDT调试
- windows环境下编译spark源码和搭建源码调试环境
- Windows+VS2012环境下编译调试MySQL源码 转
- Nginx (一)Windows下编译Nginx源码以及安装 nginx for windows方法步骤
- Windows+VS2012环境下编译调试MySQL源码(四)
- 反编译利器Apktool和Dex2jar导入源码以及编译调试
- CentOS上编译OpenJDK8源码 以及 在eclipse上调试HotSpot虚拟机源码
- Windows上借助msys2编译并调试FFmpeg源码
- 深入解析Xcode无证书编译以及真机调试
- 在eclipse中调试launcher模块以及已编译launcher源码两份
- windows下编译调试mysql5.5.24源码
- VS编译以及调试 PostgreSQL 源码工程
- [置顶] Linux下编译OpenJDK源码以及在Eclipse中调试Hotspot虚拟机
- windows下xapian的编译以及编程环境的配置
- 用VS(c#)创建、调试windows service以及部署卸载
- EJABBERD在windows上的编译以及ejabberd的架构
- C# windows 服务 创建 以及调试