gpt4 book ai didi

c++ - cldoc 在模板部分特化时崩溃

转载 作者:塔克拉玛干 更新时间:2023-11-03 02:17:09 24 4
gpt4 key购买 nike

这个问题被标记为不清楚我在问什么。为清楚起见,我要求一种解决方法,以使该文档生成器针对我的代码库正常工作。 (也许将作业分成批处理?cldocs 可能吗?也许发出不同的命令行选项?也许我的调用是错误的或被误导的?)

我已经针对该项目提交了一个错误,您可以在此处找到有关我的环境的一些其他信息(包括位于此处的完整命令行:http://pastebin.com/JxWf9hRB)。

https://github.com/jessevdk/cldoc/issues/73

原始问题:

我正在调查使用 cldocs 进行自动文档编制。但是,它在我的代码库上崩溃,并出现以下错误:

Traceback (most recent call last):
File "/usr/local/bin/cldoc", line 9, in <module>
load_entry_point('cldoc==1.6', 'console_scripts', 'cldoc')()
File "/usr/local/lib/python2.7/site-packages/cldoc/__init__.py", line 57, in run
run_generate(rest)
File "/usr/local/lib/python2.7/site-packages/cldoc/__init__.py", line 27, in run_generate
cmdgenerate.run(args)
File "/usr/local/lib/python2.7/site-packages/cldoc/cmdgenerate.py", line 151, in run
run_generate(t, opts)
File "/usr/local/lib/python2.7/site-packages/cldoc/cmdgenerate.py", line 33, in run_generate
generator.generate(xmlout)
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/xml.py", line 55, in generate
Generator.generate(self, outdir)
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/generator.py", line 22, in generate
self.generate_node(node)
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/xml.py", line 543, in generate_node
self.generate_page(node)
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/xml.py", line 510, in generate_page
elem = self.node_to_xml(node)
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/xml.py", line 496, in node_to_xml
chelem = self.node_to_xml(child)
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/xml.py", line 485, in node_to_xml
self.call_type_specific(node, elem, 'to_xml')
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/xml.py", line 465, in call_type_specific
getattr(self, nm)(node, elem)
File "/usr/local/lib/python2.7/site-packages/cldoc/generators/xml.py", line 273, in method_to_xml
if len(node.override) > 0:
File "/usr/local/lib/python2.7/site-packages/cldoc/nodes/method.py", line 43, in override
bases = list(self.parent.bases)
AttributeError: 'Namespace' object has no attribute 'bases'

编辑:

很长一段时间后,我已经能够将它简化为一个最小的例子。

template<typename T>
struct Foo {
int baz(T const& t) const { }
};

template<typename T, int N>
class Bar { };

template<typename T, int N>
struct Foo<Bar<T, N>> {
int baz(Bar<T, N> const& a) const;
};

template<typename T, int N>
int Foo<Bar<T, N>>::baz(Bar<T, N> const& a) const { }

虽然这是可行的:

template<typename T>
struct Foo {
int baz(T const& t) const { }
};

template<typename T, int N>
class Bar { };

template<typename T, int N>
struct Foo<Bar<T, N>> {
int baz(Bar<T, N> const& a) const { }
};

最佳答案

首先cldoc依赖 clang 解析源代码,它需要适当的 C/C++ 标志(例如 -std=c++11 )才能正常运行。

然后,即使有适当的标志,它也会在某些看起来有效的结构上爆炸。特别是它试图处理看似错误上下文的模板类方法定义。特别是 Foo<Bar<T, N>>::baz() 的问题定义是在处理它的过程中 self.parent等于RootNamespace对象(显然没有并且不应该有“bases”属性),而不是 Class或类似的对象,bases用于追踪特定方法的覆盖列表。

我已经为这个问题准备了一个解决方法,它简单地“放松”了对 self.parent 的操作。爆炸点的属性并将其发布为对该问题的评论。但肯定不是解决方案。也许一个合适的解决方案应该首先决定是否必须以这种方式处理此类类外方法定义,可能正确的方法是仅在方法声明处处理覆盖列表。

这是补丁:

diff --git a/cldoc/nodes/method.py b/cldoc/nodes/method.py
index f910241..3e1208f 100644
--- a/cldoc/nodes/method.py
+++ b/cldoc/nodes/method.py
@@ -40,7 +40,7 @@ class Method(Function):
return self._override

# Lookup in bases, recursively
- bases = list(self.parent.bases)
+ bases = list(getattr(self.parent, "bases", []))
mname = self.name

self._override = []

关于c++ - cldoc 在模板部分特化时崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27144748/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com