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

Fixes issue #371 - outName static cast error in debug builds #383

Merged
merged 2 commits into from
Aug 10, 2023

Conversation

fearn-e
Copy link
Member

@fearn-e fearn-e commented Aug 8, 2023

@AlexHarker
As discussed in #372, here's a new PR with a cleaned up branch.

This fixes the original static cast bug that arose from a CLASS_ATTR_SYM being used for a t_atom type.

Instead of changing the CLASS_ATTR, as the variable is only ever used as a t_atom once and is being converted to a symbol type many times, it is changed to a t_symbol type and now only ever converted to a t_atom once (lines 257-259).

@fearn-e fearn-e marked this pull request as ready for review August 8, 2023 15:18
@AlexHarker AlexHarker requested a review from tremblap August 8, 2023 15:22
@AlexHarker
Copy link
Contributor

This looks correct to me. @tremblap - can you review please?

Copy link
Member

@tremblap tremblap left a comment

Choose a reason for hiding this comment

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

@AlexHarker should we avoid allocation at line 257 and make it part of the struct?

@AlexHarker
Copy link
Contributor

@AlexHarker should we avoid allocation at line 257 and make it part of the struct?

There is no heap allocation in this case - the t_atom is just a local variable allocated on the stack which is pre-allocated for the thread (I think that's when the allocation happens).

Allocating in the object is actually a potential source of less efficiency, because the object requires dereferencing and although it is likely to be in a cache line, the stack definitely is, so no I don't think we should make it part of the struct.

@tremblap
Copy link
Member

if @weefuzzy agrees then I'll merge. I've just learnt I was drilled to be paranoid about mem alloc :D

@weefuzzy
Copy link
Member

Can someone catch me up on why #372 got closed and this more extensive PR replaced it?

@AlexHarker
Copy link
Contributor

AlexHarker commented Aug 10, 2023

Yes - it's a better fix, because the attribute should never be anything other than a symbol (and the atom was getting set to a symbol manually in the code). Previously max thought the field in the object it was a t_symbol *, and likely set the first part of the t_atom and it just happened to work, because the t_atom was getting set elsewhere, thus setting the type flag.

I see nothing here to worry about, but there were possible concerns about just changing it to CLASS_ATTR_ATOM (like possibly allowing the user to set it to a number).

@weefuzzy
Copy link
Member

@AlexHarker I didn't see your comment fearn-e@d410b7e#commitcomment-123632941 for some reason, which would have reduced the mystery.

FWIW, my maintainer-preference is always for the smallest fix needed to close an issue, and any secondary stuff (like whether it would be better to have another type or whatever) to be followed up as separate changes with their own (quite probably lower priority) issues. IOW, I don't doubt that you're right, but the future process of working out why a commit is the way it is will be more befuddling for future-me now.

@weefuzzy
Copy link
Member

@tremblap if / when you're happy it works on both platforms, then please merge. As @AlexHarker says, there isn't a worrying allocation issue.

@AlexHarker
Copy link
Contributor

I tend to leave any problems to future-me. It always works out really well.

@tremblap tremblap merged commit e44f726 into flucoma:main Aug 10, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants