-
Notifications
You must be signed in to change notification settings - Fork 6.7k
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
[AOT] Refactor Logger function to improve performance and mark managedCommon as AOT compatible #36327
base: main
Are you sure you want to change the base?
Conversation
When we publish application with AOT enable. Some reflection usage will be forbidden. So, we need to make this change. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe we need advice + know the knowledge on how to analysis PowerToys logging :-D
} | ||
|
||
private static MethodBase GetCallerMethod(StackTrace stackTrace) | ||
private static string GetCallerInfo(string memberName, string sourceFilePath, int sourceLineNumber) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For sourceLineNumber.
Given originally they don't have, we need to ask for PMs, that any parser of the log it will break this.
If Yes, we should still keep the original "TypeName::MethodName" format first.
Last but not least, do we know how to view PowerToys log? If we can parrse the log and show a summary of before after, it will give confidence of this changes.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There's currently no automated parsing. The logs are saved on %LOCALAPPDATA%\Microsoft\PowerToys\ and then inside a folder with the module name.
{ | ||
Log(string.Empty, TraceFlag); | ||
Log(string.Empty, TraceFlag, memberName, sourceFilePath, sourceLineNumber); | ||
} | ||
|
||
[MethodImpl(MethodImplOptions.NoInlining)] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
May be we don't need this one anymore.
@@ -53,18 +52,37 @@ public static void InitializeLogger(string applicationLogPath, bool isLocalLow = | |||
Trace.AutoFlush = true; | |||
} | |||
|
|||
public static string GetVersion() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we just ask the caller to pass in its own class type?
From Github copilot, the following code should be AOT compatible:
var versionInfo = FileVersionInfo.GetVersionInfo(typeof(Program).Assembly.Location);
Console.WriteLine($"Version: {versionInfo.FileVersion}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@moooyo , I agree with @yeelam-gordon here that this doesn't make much sense. This is looking for PowerToys.exe when we should get the own version of the module that calls the Logger. Also, this needs to work for things logged in WinUI3 applications as well, which reside in a different folder in runtime, so I'm not sure the current state of the code would work for them.
/azp run |
Azure Pipelines successfully started running 1 pipeline(s). |
/azp run |
Azure Pipelines successfully started running 1 pipeline(s). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've added some comments next to Yeelam's comments.
Summary of the Pull Request
To drop all reflection usage, we can get about 18% performance improvement by this PR change. Here's a simple test which call Logger.LogError 100k times. (Left: before this change, Right with this change)
By this change, we can remove the wired useage of reflection which try to get some infromation from stack frame. It's hard to understand and maintain.
About the log format. I've compared the advancedPaste module's log. Most of them are equal, but some of them are not the same.
Such as:
The original code will retrieve the caller info from the stack frame. The caller name will be so strange in some case. After this change merged, we will get a more clear information.
PR Checklist
Detailed Description of the Pull Request / Additional comments
Validation Steps Performed