我在RHEL 6上使用gdb-7.5,使用gcc-4.7.2编译。我试着
为boost::multi_index
写一个漂亮的打印机并遇到问题
与gdb.lookup_type
。
下面给出的代码有以下声明。
TestSet ts;
现在,在gdb命令提示符下,我正在执行以下操作 操作(在python中)
gdb >> python
set_value = gdb.parse_and_eval('ts')
set_type = set_value.type.strip_typedefs()
t1 = set_type.template_argument(0) # Test
t2 = set_type.template_argument(1) # boost::mult_index::indexed_by ....
t3 = set_type.template_argument(2) # std::allocator<Test>
node_type = gdb.lookup_type('boost::multi_index::detail::multi_index_node_type < %s, %s, %s >::type' % (t1, t2, t3))
base = gdb.lookup_type ('boost::multi_index::detail::multi_index_base_type < %s, %s, %s >::type' % (t1, t2, t3))
allocator = gdb.lookup_type('boost::detail::allocator::rebind_to<%s, %s>::type' % (t3, node_type))
end
我正确获取node_type。但是gdb无法获取类型 对于'base'和'allocator'。
基础错误
Traceback (most recent call last):
File "<string>", line 1, in <module>
gdb.error: No type named boost::detail::multi_index_base_type < Test,
boost::multi_index::indexed_by<boost::multi_index::ordered_unique<boost::multi_index::member<Test,
std::basic_string<char, std::char_traits<char>, std::allocator<char>
>, &Test::s>, mpl_::na, mpl_::na>
, boost::multi_index::ordered_unique<boost::multi_index::tag<int,
mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na,
mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na,
mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na>, boost::multi_i
ndex::member<Test, int, &Test::i>, mpl_::na>,
boost::multi_index::ordered_unique<boost::multi_index::member<Test,
float, &Test::f>, mpl_::na, mpl_::na>, mpl_::na, mpl_::na, mpl_::na,
mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na,
mpl_::na, mpl_::na
, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na>,
std::allocator<Test> >::type.
Error while executing Python code.
和'allocator'的类似错误。
由boost::multi_index_container
派生而来
boost::detail::multi_index_base_type
,我期待gdb返回一个
有效的类型。
我在这里遗漏了什么。 ?
我在gdb邮件列表中发布了相同的问题,但没有答案。
代码:
#include <string>
using namespace std;
#include <boost/multi_index_container.hpp>
#include <boost/multi_index/member.hpp>
#include <boost/multi_index/key_extractors.hpp>
#include <boost/multi_index/ordered_index.hpp>
#include <boost/multi_index/hashed_index.hpp>
#include <boost/multi_index/sequenced_index.hpp>
#include <boost/multi_index/random_access_index.hpp>
using namespace boost::multi_index;
using namespace boost;
struct Test
{
Test (const string& ps, int pi, float pf)
: s(ps), i(pi), f(pf)
{
}
string s;
int i;
float f;
};
typedef multi_index_container <
Test,
indexed_by <
ordered_unique < member <Test, string, &Test::s> >,
ordered_unique < tag<int>, member <Test, int, &Test::i> >,
ordered_unique < member <Test, float, &Test::f> >
>
> TestSet;
int main(void)
{
TestSet ts;
ts.insert(Test("ABCDEF", 10, 1.0f));
ts.insert(Test("Some String", 5, 2.0f));
ts.insert(Test("PQRXYZ", 7, 0.3f));
return 0;
}
苏里亚
答案 0 :(得分:0)
我首先要试着找出这种类型是否确实存在。一种方法是挖掘&#34; readelf -wi&#34;输出。这会转储程序的DWARF信息。但是,它可能非常大,因此可能需要一段时间。
如果它存在于DWARF中,那么我将调试gdb以查看出现了什么问题。
如果它不在DWARF中,那么它可能是编译器错误,或者只是错误的编译参数。