2

我在 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.

以及“分配器”的类似错误。
由于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;
} 

苏里亚

4

1 回答 1

0

我会首先尝试找出这种类型是否确实存在。一种方法是挖掘“readelf -wi”输出。这将为您的程序转储 DWARF 信息。但是,它可能非常大,因此可能需要一段时间。

如果它存在于 DWARF 中,那么我将调试 gdb 以查看出现了什么问题。

如果它不在 DWARF 中,则可能是编译器错误,或者只是错误的编译参数。

于 2013-05-23T17:46:45.967 回答