Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor all attribute functions in rust-privacy-reporter.cc #3339

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

saeitoshi-10
Copy link
Contributor

gcc/rust/ChangeLog:
* checks/errors/privacy/rust-privacy-reporter.cc (find_proc_macro_attribute):"Removed checker function" (proc_macro_privacy_check): "modified checker implementation"
* util/rust-attributes.cc (is_proc_macro_type): "modifed fn into Attributes class" (Attributes::is_proc_macro_type): "modifed fn" (check_proc_macro_non_function): "modified checker implementation" (check_proc_macro_non_root): "modified checker implementation"
* util/rust-attributes.h: "included definition"

Thank you for making Rust GCC better!

If your PR fixes an issue, you can add "Fixes #issue_number" into this
PR description and the git commit message. This way the issue will be
automatically closed when your PR is merged. If your change addresses
an issue but does not fully fix it please mark it as "Addresses #issue_number"
in the git commit message.

Here is a checklist to help you with your PR.

Note that you can skip the above if you are just opening a WIP PR in
order to get feedback.

Addresses #3291
*Please write a comment explaining your change. This is the message
that will be part of the merge commit.

	* checks/errors/privacy/rust-privacy-reporter.cc (find_proc_macro_attribute):"Removed checker function"
	(proc_macro_privacy_check): "modified checker implementation"
	* util/rust-attributes.cc (is_proc_macro_type): "modifed fn into Attributes class"
	(Attributes::is_proc_macro_type): "modifed fn"
	(check_proc_macro_non_function): "modified checker implementation"
	(check_proc_macro_non_root): "modified checker implementation"
	* util/rust-attributes.h: "included definition"

Signed-off-by: Om Swaroop Nayak <[email protected]>
@philberty philberty requested a review from P-E-P January 10, 2025 12:37
@philberty
Copy link
Member

You need to fix your commit format before this can be merged

Copy link
Member

@philberty philberty left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

needs some changes

// attribute in a vector of attribute
for (const auto &attr : item->get_outer_attrs ())
{
if (Analysis::Attributes::is_proc_macro_type (attr) != tl::nullopt)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this seems odd i think you should be storing the result here in a variable instead of calling it twice like this

// Emit an error when one encountered attribute is either #[proc_macro],
// #[proc_macro_attribute] or #[proc_macro_derive]
static void
check_proc_macro_non_function (const AST::AttrVec &attributes)
{
for (auto &attr : attributes)
{
if (is_proc_macro_type (attr))
if (Attributes::is_proc_macro_type (attr) != tl::nullopt)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can this not just be if (Attributes::is_proc_macro_type (attr)) ?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You're right, it could be shortened.

@@ -258,7 +261,7 @@ check_proc_macro_non_root (AST::AttrVec attributes, location_t loc)
{
for (auto &attr : attributes)
{
if (is_proc_macro_type (attr))
if (Attributes::is_proc_macro_type (attr) != tl::nullopt)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same here


static bool
is_proc_macro_type (const AST::Attribute &attribute)
tl::optional<std::string>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could we return an enum instead of a string here ? Enums are cheap, strings are not. and if I'm reading this correctly string values are known statically.

static bool
is_proc_macro_type (const AST::Attribute &attribute)
tl::optional<std::string>
Attributes::is_proc_macro_type (const AST::Attribute &attribute)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You're changing the semantic of the function, either you need a new one (two different functions) or you need to rename this one, we're not deciding if an attribute is or is not a proc macro anymore but returning the kind of proc macro with your new code.

I'd keep two different functions, even if one is calling the other and simply using tl::optional::has_value()

// Emit an error when one encountered attribute is either #[proc_macro],
// #[proc_macro_attribute] or #[proc_macro_derive]
static void
check_proc_macro_non_function (const AST::AttrVec &attributes)
{
for (auto &attr : attributes)
{
if (is_proc_macro_type (attr))
if (Attributes::is_proc_macro_type (attr) != tl::nullopt)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You're right, it could be shortened.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: In progress
Development

Successfully merging this pull request may close these issues.

3 participants