- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
当我尝试在 Qt 应用程序中使用 libclang 时遇到了一个奇怪的错误。
测试.cpp
#include <QApplication>
#include <QMainWindow>
#include <clang-c/Index.h>
int main (int argc, char *argv[]) {
QApplication a(argc, argv);
QMainWindow w;
w.show();
CXIndex index = clang_createIndex(0, 0);
Q_UNUSED(index)
return a.exec();
}
test.pro
QT += core widgets
TARGET = test
TEMPLATE = app
SOURCES += test.cpp
LIBS += -lclang
Shell 命令和输出:
$ ls
test.cpp test.pro
$ qmake
$ make
g++ -c -pipe -march=x86-64 -mtune=generic -O2 -pipe -fstack-protector --param=ssp-buffer-size=4 -Wall -W -D_REENTRANT -fPIE -DQT_NO_DEBUG -DQT_WIDGETS_LIB -DQT_GUI_LIB -DQT_CORE_LIB -I/usr/lib/qt/mkspecs/linux-g++ -I. -I/usr/include/qt -I/usr/include/qt/QtWidgets -I/usr/include/qt/QtGui -I/usr/include/qt/QtCore -I. -o test.o test.cpp
g++ -Wl,-O1,--sort-common,--as-needed,-z,relro -Wl,-O1 -o test test.o -lclang -lQt5Widgets -lQt5Gui -lQt5Core -lGL -lpthread
$ ./test
Two passes with the same argument (-alloca-hoisting) attempted to be registered!
Segmentation fault
如果我在不使用 qmake 的情况下手动运行 g++,我会得到同样的错误:
$ g++ -fPIE test.cpp -o test -I/usr/include/qt -I/usr/include/qt/QtWidgets -lQt5Widgets -lclang
$ ./test
Two passes with the same argument (-alloca-hoisting) attempted to be registered!
Segmentation fault
w.show();
行,程序会编译并运行,即使它在没有显示窗口的情况下进入主循环也是如此。CXIndex index = clang_createIndex(0, 0);
和 Q_UNUSED(index)
行,程序将编译并运行。它进入主循环,窗口可见。我正在使用 Qt 5.1 和 ArchLinux,我安装了 clang
包(3.3 版),其中包括 libclang header 和文件/usr/lib/libclang.so 和/usr/lib/libclang.a.
此程序无法运行的原因是什么,我该如何解决?
更新:我找到了 this page .运行 LIBGL_ALWAYS_INDIRECT=1 ./test
效果很好,但我想要的不止于此。我不必设置该环境变量就可以运行我的程序。
最佳答案
我可以回答你的问题,我不知道怎么解决。
首先,如果您没有 -Wl,--as-needed
,删除 CXIndex index = clang_createIndex(0, 0);
将无法解决问题删除它只会修复它,因为链接器注意到您实际上并没有调用 libclang,因此如果没有 CXIndex index = clang_createIndex(0, 0);
行,您实际上不会将您的程序链接到它。
出现问题的原因是因为您使用的任何 Mesa 后端(ATI 或 NVIDIA)也链接到 clang。似乎正在发生的事情是,当您的程序首次加载并且动态链接已解析时,链接器会加载 libclang 和其他 LLVM 内容 libclang 链接到并运行全局对象的构造函数,这就是 LLVM 自动注册其内置传递的方式。所以此时所有内置的 LLVM passes 都已注册,然后 QT 启动并创建一个 OpenGL 上下文,因此 Mesa 加载适当的 DRI 后端,当它发生在您的系统上时,后端使用 clang/LLVM,并且出于某种原因它似乎所有这些构造函数都再次运行,并且 LLVM 注意到“两次”传递(实际上是同一传递试图注册两次)共享相同的名称并中止您的程序。
就像我说的,我真的不知道为什么构造函数会运行两次,也不知道如何让它停止。如果您没有得到答案,请尝试在 mesa-users
邮件列表上询问,请尝试 mesa-dev
Mesa 邮件列表:http://mesa3d.org/lists.html
编辑:您应该确保您的 Mesa 拷贝链接到您尝试使用的相同版本的 LLVM,如果它没有修复通行证注册,那么您的问题将是最少的。
尝试执行 ls/usr/lib64/llvm/libLLVM-?.?.so
如果你得到两个结果,你有两个版本的 libLLVM,这本身不是问题,但如果你链接到一个版本,而 Mesa 链接到另一个可能解释事情的版本。
关于c++ - 不能在 Qt 中使用 libclang,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17953156/
如果我在一个大项目中有多个文件,所有文件共享大量包含的头文件,有什么办法可以共享解析头文件的工作吗?我曾希望创建一个索引,然后向其中添加多个 translationUnits 可能会导致一些工作被共享
如果我在一个大项目中有多个文件,所有这些文件共享大量包含的头文件,有没有办法分担解析头文件的工作?我曾希望创建一个 Index 然后向其添加多个 translationUnits 可能会导致一些工作被
我使用 libclang 来解析源文件并获取对某种类型的引用,如 CXType ,假设它是“const std::__1::basic_string ”(由 clang_getTypeSpelling
我正在使用最新的 LibClang 来解析一些 C 头文件。我处理的代码来自 CXUnsavedFile 的(它都是动态生成的,没有任何内容存在于磁盘上)。例如: FileA.h 包含: struct
有时,当我尝试在Xcode中构建项目时(大约十分之一),它崩溃并退出。然后,我得到一个错误框,其中显示:“使用libclang.dylib插件时Xcode意外退出”。 Xcode有时也会随机崩溃,没有
我使用的是 Linux Mint,并且使用 Clang Complete 中的 makefile 安装了 clang_complete ,但它不起作用。当我打开 cpp 文件时,出现错误消息: Loa
我正在尝试使用 libclang 构建一个小型解析程序。 要解析的源文件(Node.h): #pragma once struct Node { int value; struct N
Currentlty 我正在做一个项目,用 libclang 转储 C++ 代码的类信息。还有一些关于类型限定符的悲惨经历:const、volatile、&、&& 以及它们的组合。以下是转储函数删除参
有什么方法可以从 libclang 中获取信息,了解源文件中的 C++ 代码是否具有正确的语法?即使使用无效的 C++ 代码,Libclang 也会尝试创建翻译单元。 最佳答案 一般问题的一般答案是肯
如何使用 libclang 获取原始文字的值? 例如,如果我有一个游标类型为 CXCursor_IntegerLiteral 的 CXCursor,我该如何提取文字值。 更新: 我在使用 libcla
我有以下使用 clang-c API 的代码。 #include #include #include CXChildVisitResult printVisitor(CXCursor curso
我有一个 c++ 文件,它会更改,其余所有头文件保持不变。但是每当我重新解析一个翻译单元时,libclang 最终会消耗大量的 cpu 和 ram。虽然它使用预编译头和所有(我可以看到生成的前导文件)
class aclass{ public: int num; }; int main() { aclass *ok; ok->num = 4; return 0; }
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 4年前关闭。 Improve this qu
我正在使用 LibClang 列出所有函数调用及其相应的定义。 以下是执行此操作的python脚本: def traverse(node): if node.kind == CALL_EXPR:
我尝试使用 libClang 解析 C++ 方法,但在尝试获取函数的参数/参数时,有时会给出错误的类型。 例子: 我有两种不同的方法 std::string Method::exportMethod(
我尝试使用 libClang 解析 C++ 方法,但在尝试获取函数的参数/参数时,有时会给出错误的类型。 例子: 我有两种不同的方法 std::string Method::exportMethod(
我试图了解如何使用 libclang 完成代码。我看过“超越编译器的思考”,并且查看了 c-index-test,我发现了一个简单的示例程序 here 我编译了该程序,并在我制作的示例文件上运行它,该
我需要解析一个 C++ 代码文件并找到其中所有具有完全限定名称的函数调用。我正在使用 libclang 的 Python 绑定(bind),因为它似乎比编写我自己的 C++ 解析器更容易,即使文档很少
我正在学习使用 Python + libclang 解析 C++ 文件,并借助 Eli Bendersky 提供的这个信息量很大(但有点过时)的教程. 我的目标是解析 C++ 文件并识别这些文件中存在
我是一名优秀的程序员,十分优秀!