]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/rust/checks/errors/privacy/rust-pub-restricted-visitor.cc
Update copyright years.
[thirdparty/gcc.git] / gcc / rust / checks / errors / privacy / rust-pub-restricted-visitor.cc
CommitLineData
a945c346 1// Copyright (C) 2020-2024 Free Software Foundation, Inc.
ca246e57
AC
2
3// This file is part of GCC.
4
5// GCC is free software; you can redistribute it and/or modify it under
6// the terms of the GNU General Public License as published by the Free
7// Software Foundation; either version 3, or (at your option) any later
8// version.
9
10// GCC is distributed in the hope that it will be useful, but WITHOUT ANY
11// WARRANTY; without even the implied warranty of MERCHANTABILITY or
12// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13// for more details.
14
15// You should have received a copy of the GNU General Public License
16// along with GCC; see the file COPYING3. If not see
17// <http://www.gnu.org/licenses/>.
18
19#include "rust-pub-restricted-visitor.h"
20#include "rust-hir.h"
21#include "rust-hir-item.h"
22
23namespace Rust {
24namespace Privacy {
25
26bool
27PubRestrictedVisitor::is_restriction_valid (NodeId item_id,
28 const Location &locus)
29{
30 ModuleVisibility visibility;
31
32 // If there is no visibility in the mappings, then the item is private and
33 // does not contain any restriction
34 // FIXME: Is that correct?
35 if (!mappings.lookup_visibility (item_id, visibility))
36 return true;
37
38 for (auto mod = module_stack.rbegin (); mod != module_stack.rend (); mod++)
39 if (*mod == visibility.get_module_id ())
40 return true;
41
42 rust_error_at (locus, "restricted path is not an ancestor of the "
43 "current module");
44 return false;
45}
46
47PubRestrictedVisitor::PubRestrictedVisitor (Analysis::Mappings &mappings)
48 : mappings (mappings)
49{}
50
51void
52PubRestrictedVisitor::go (HIR::Crate &crate)
53{
54 // The `crate` module will always be present
55 module_stack.emplace_back (crate.get_mappings ().get_defid ());
56
57 // FIXME: When do we insert `super`? `self`?
58 // We need wrapper function for these
59
60 for (auto &item : crate.items)
61 {
62 if (item->get_hir_kind () == HIR::Node::VIS_ITEM)
63 {
64 auto vis_item = static_cast<HIR::VisItem *> (item.get ());
65 vis_item->accept_vis (*this);
66 }
67 }
68}
69
70void
71PubRestrictedVisitor::visit (HIR::Module &mod)
72{
73 // FIXME: We need to update `super` and `self` here
74 module_stack.push_back (mod.get_mappings ().get_defid ());
75
76 is_restriction_valid (mod.get_mappings ().get_nodeid (), mod.get_locus ());
77
78 for (auto &item : mod.get_items ())
79 {
80 if (item->get_hir_kind () == HIR::Node::VIS_ITEM)
81 {
82 auto vis_item = static_cast<HIR::VisItem *> (item.get ());
83 vis_item->accept_vis (*this);
84 }
85 }
86
87 module_stack.pop_back ();
88}
89
90void
91PubRestrictedVisitor::visit (HIR::ExternCrate &crate)
92{
93 is_restriction_valid (crate.get_mappings ().get_nodeid (),
94 crate.get_locus ());
95}
96
97void
98PubRestrictedVisitor::visit (HIR::UseDeclaration &use_decl)
99{
100 is_restriction_valid (use_decl.get_mappings ().get_nodeid (),
101 use_decl.get_locus ());
102}
103
104void
105PubRestrictedVisitor::visit (HIR::Function &func)
106{
107 is_restriction_valid (func.get_mappings ().get_nodeid (), func.get_locus ());
108}
109
110void
111PubRestrictedVisitor::visit (HIR::TypeAlias &type_alias)
112{
113 is_restriction_valid (type_alias.get_mappings ().get_nodeid (),
114 type_alias.get_locus ());
115}
116
117void
118PubRestrictedVisitor::visit (HIR::StructStruct &struct_item)
119{
120 is_restriction_valid (struct_item.get_mappings ().get_nodeid (),
121 struct_item.get_locus ());
122 // FIXME: Check fields here as well
123}
124
125void
126PubRestrictedVisitor::visit (HIR::TupleStruct &tuple_struct)
127{
128 is_restriction_valid (tuple_struct.get_mappings ().get_nodeid (),
129 tuple_struct.get_locus ());
130 // FIXME: Check fields here as well
131}
132
133void
134PubRestrictedVisitor::visit (HIR::Enum &enum_item)
135{
136 is_restriction_valid (enum_item.get_mappings ().get_nodeid (),
137 enum_item.get_locus ());
138}
139
140void
141PubRestrictedVisitor::visit (HIR::Union &union_item)
142{
143 is_restriction_valid (union_item.get_mappings ().get_nodeid (),
144 union_item.get_locus ());
145}
146
147void
148PubRestrictedVisitor::visit (HIR::ConstantItem &const_item)
149{
150 is_restriction_valid (const_item.get_mappings ().get_nodeid (),
151 const_item.get_locus ());
152}
153
154void
155PubRestrictedVisitor::visit (HIR::StaticItem &static_item)
156{
157 is_restriction_valid (static_item.get_mappings ().get_nodeid (),
158 static_item.get_locus ());
159}
160
161void
162PubRestrictedVisitor::visit (HIR::Trait &trait)
163{
164 is_restriction_valid (trait.get_mappings ().get_nodeid (),
165 trait.get_locus ());
166}
167
168void
169PubRestrictedVisitor::visit (HIR::ImplBlock &impl)
170{
171 is_restriction_valid (impl.get_mappings ().get_nodeid (), impl.get_locus ());
172}
173
174void
175PubRestrictedVisitor::visit (HIR::ExternBlock &block)
176{
177 is_restriction_valid (block.get_mappings ().get_nodeid (),
178 block.get_locus ());
179}
180
181} // namespace Privacy
182} // namespace Rust