首页
/ CGDB 技术文档

CGDB 技术文档

2024-12-27 07:28:46作者:温艾琴Wonderful

CGDB 是一个轻量级的控制台前端,用于 GNU 调试器。它提供了一个分屏界面,显示 GDB 会话在下方,程序源代码在上方。该界面模仿了 vim 的设计,因此 vim 用户应该能够轻松上手。

以下为 CGDB 的安装指南、使用说明和项目 API 使用文档。

1. 安装指南

依赖项

在构建 CGDB 之前,您必须确保已安装以下包:

  • sh
  • autoconf
  • automake
  • aclocal
  • autoheader
  • libtool
  • flex
  • bison
  • gcc/g++(支持 C11/C++11)

配置准备

在当前工作目录中运行 ./autogen.sh 以生成配置脚本。

运行配置、编译和安装

您可以在源代码目录内运行 ./configure,但我通常从源代码目录外部运行配置脚本,如下所示:

mkdir ../build
cd ../build
../cgdb/configure --prefix=$PWD/../prefix
make -srj4
make install

CGDB 是一个 C11/C++11 项目,与 GDB 类似。由于该标准相对较新,您的 gcc/g++ 可能默认支持,或者可能需要 -std=c11-std=c++11 标志。

以下是如何在配置调用中设置这些标志的示例:

YFLAGS="-Wno-deprecated" CFLAGS="-std=c11 -g -O0 -Wall -Wextra -Wshadow -pedantic -Wno-unused-parameter" CXXFLAGS="-std=c++11 -g -O0 -Wall -Wextra -Wshadow -Werror -pedantic -Wmissing-include-dirs -Wno-unused-parameter -Wno-sign-compare -Wno-unused-but-set-variable -Wno-unused-function -Wno-variadic-macros" ../cgdb/configure --prefix=$PWD/../prefix

如果您想要进行静默构建,并且不想看到 libtool 的链接行,可以通过以下环境变量来抑制输出:

LIBTOOLFLAGS=--silent

2. 项目使用说明

CGDB 的使用非常直观,特别是对 vim 用户来说。它提供了一个分屏界面,使得您可以同时查看 GDB 会话和程序源代码。

  • 界面:GDB 会话位于屏幕下方,源代码位于屏幕上方。
  • 键盘快捷键:CGDB 的键盘接口模仿了 vim,因此大多数快捷键与 vim 相似。

3. 项目 API 使用文档

CGDB 的 API 文档目前未提供,但用户可以通过阅读源代码和项目 Wiki 来获取相关信息。

4. 项目安装方式

项目的安装方式已在“安装指南”部分详细说明。简而言之,您需要准备依赖项,运行 autogen.sh 脚本生成配置脚本,然后执行配置、编译和安装步骤。

以上就是 CGDB 的技术文档,希望对您的使用有所帮助。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
269
2.54 K
flutter_flutterflutter_flutter
暂无简介
Dart
558
124
fountainfountain
一个用于服务器应用开发的综合工具库。 - 零配置文件 - 环境变量和命令行参数配置 - 约定优于配置 - 深刻利用仓颉语言特性 - 只需要开发动态链接库,fboot负责加载、初始化并运行。
Cangjie
57
11
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
cangjie_runtimecangjie_runtime
仓颉编程语言运行时与标准库。
Cangjie
126
104
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
357
1.84 K
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.02 K
434
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.03 K
605
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
728
70