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

Remove unnecessary[MethodImpl(MethodImplOptions.NoInlining)] #931

Open
paulirwin opened this issue Mar 13, 2024 · 1 comment
Open

Remove unnecessary[MethodImpl(MethodImplOptions.NoInlining)] #931

paulirwin opened this issue Mar 13, 2024 · 1 comment
Assignees
Labels

Comments

@paulirwin
Copy link
Contributor

Note that we have added [MethodImpl(MethodImplOptions.NoInlining)] more liberally than what was actually required. For example, for this case we have added it to every method named Flush in the whole solution. There may be a slight performance improvement if we allowed inlining everywhere except for the specific methods that are actually being scanned for in the stack traces of all tests.

This is low priority, but perhaps we should add an issue to remove unnecessary [MethodImpl(MethodImplOptions.NoInlining)] attributes. An analysis of which specific methods are being scanned for in the stack trace would be required to work this out, though. Or they could be removed one at a time and rolled back if removing the attribute causes a failure in any one of multiple test runs.

Originally posted by @NightOwl888 in #926 (comment)

@paulirwin paulirwin mentioned this issue Mar 13, 2024
4 tasks
@paulirwin paulirwin added this to the 4.8.0 milestone Oct 28, 2024
@paulirwin paulirwin modified the milestones: 4.8.0, 4.8.0-beta00018 Nov 11, 2024
@paulirwin paulirwin added pri:low is:task A chore to be done up-for-grabs This issue is open to be worked on by anyone labels Nov 21, 2024
paulirwin added a commit to paulirwin/lucene.net that referenced this issue Jan 12, 2025
@paulirwin
Copy link
Contributor Author

#1099 Removed many usages, but there remain quite a few on the Flush/Abort/etc. methods. Need to investigate to see if those can be removed particularly in some of the derived class cases.

There are other one-off ones like "SealFlushedSegment" where the string method name can be replaced with nameof safely (as there's only one method with that name, and it's obvious which one it's looking for).

My goal is to use nameof as much as possible to have traceability from the test to which method it's expecting to find in the stack trace.

Ideally I wish we didn't have to do this at all, as inspecting the stack trace to change behavior is a design smell, but in some cases it's unavoidable (for now, within reason) to match Lucene's test behavior.

@paulirwin paulirwin self-assigned this Jan 12, 2025
@paulirwin paulirwin added performance and removed up-for-grabs This issue is open to be worked on by anyone labels Jan 12, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant