// FIXME this needs to be protected behind nominal type-checks see:
// rustc --explain E0118
+ // issue #2634
ResolveType::go (impl_block.get_type ().get ());
// Setup paths
self_cpath.get ().c_str ());
CanonicalPath impl_type = self_cpath;
- CanonicalPath impl_prefix = prefix.append (impl_type);
+ CanonicalPath impl_type_seg
+ = CanonicalPath::inherent_impl_seg (impl_block.get_node_id (), impl_type);
+ CanonicalPath impl_prefix = prefix.append (impl_type_seg);
// see https://godbolt.org/z/a3vMbsT6W
CanonicalPath cpath = CanonicalPath::create_empty ();
if (canonical_prefix.size () <= 1)
{
- cpath = self_cpath;
+ cpath = impl_prefix;
}
else
{
void visit (AST::InherentImpl &impl_block) override
{
std::string raw_impl_type_path = impl_block.get_type ()->as_string ();
- CanonicalPath impl_type
+ CanonicalPath impl_type_seg
= CanonicalPath::new_seg (impl_block.get_type ()->get_node_id (),
raw_impl_type_path);
- CanonicalPath impl_prefix = prefix.append (impl_type);
+
+ CanonicalPath impl_type
+ = CanonicalPath::inherent_impl_seg (impl_block.get_node_id (),
+ impl_type_seg);
+ CanonicalPath impl_prefix = prefix.append (impl_type_seg);
for (auto &impl_item : impl_block.get_impl_items ())
ResolveToplevelImplItem::go (impl_item.get (), impl_prefix);
+ trait_seg.get () + ">");
}
+ static CanonicalPath inherent_impl_seg (NodeId id,
+ const CanonicalPath &impl_type_seg)
+ {
+ return CanonicalPath::new_seg (id, "<" + impl_type_seg.get () + ">");
+ }
+
std::string get () const
{
std::string buf;