-
Notifications
You must be signed in to change notification settings - Fork 156
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
#1097 incoming call hierarchy #1164
Merged
TheAngryByrd
merged 13 commits into
ionide:main
from
TheAngryByrd:1097-call-hierarchy-1
Oct 10, 2023
Merged
Changes from all commits
Commits
Show all changes
13 commits
Select commit
Hold shift + click to select a range
4a027cf
WIP Incoming Hierarchy
TheAngryByrd e2cd39c
Call Hierarchy Incoming calls
TheAngryByrd d39f9e9
outgoing call poc
TheAngryByrd 7a04311
Using TryRangeOfNameOfNearestOuterBindingContainingPos for CallHierar…
TheAngryByrd 43f3fce
Fixing incoming call hierarchy plus tests
TheAngryByrd 0d51159
Fixing incoming call typechecks
TheAngryByrd 20c5fcd
formatting
baronfel bd04f10
Fixing up Adaptive Cancellation
TheAngryByrd 7d998c7
Adding Versioning to DiagnosticCollection
TheAngryByrd 8f35d64
Fixing tests
TheAngryByrd 30f546f
cleanup
TheAngryByrd 6d2b1e4
cleanup
TheAngryByrd 7c430d1
revert removing altcover
TheAngryByrd File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -74,17 +74,17 @@ module AsyncResult = | |
let recoverCancellation (ar: Async<Result<CoreResponse<'t>, exn>>) = | ||
recoverCancellationGeneric ar (sprintf "Request cancelled (exn was %A)" >> CoreResponse.InfoRes) | ||
|
||
let recoverCancellationIgnore (ar: Async<Result<unit, exn>>) = AsyncResult.foldResult id ignore ar | ||
let recoverCancellationIgnore (ar: Async<Result<unit, exn>>) = ar |> AsyncResult.foldResult id (ignore<exn>) | ||
|
||
[<RequireQualifiedAccess>] | ||
type NotificationEvent = | ||
| ParseError of errors: FSharpDiagnostic[] * file: string<LocalPath> | ||
| ParseError of errors: FSharpDiagnostic[] * file: string<LocalPath> * version: int | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I really wonder if we need some kind of 'file@version' abstraction here. Not now, but just immediately comes to mind. |
||
| Workspace of ProjectSystem.ProjectResponse | ||
| AnalyzerMessage of messages: FSharp.Analyzers.SDK.Message[] * file: string<LocalPath> | ||
| UnusedOpens of file: string<LocalPath> * opens: Range[] | ||
| AnalyzerMessage of messages: FSharp.Analyzers.SDK.Message[] * file: string<LocalPath> * version: int | ||
| UnusedOpens of file: string<LocalPath> * opens: Range[] * version: int | ||
// | Lint of file: string<LocalPath> * warningsWithCodes: Lint.EnrichedLintWarning list | ||
| UnusedDeclarations of file: string<LocalPath> * decls: range[] | ||
| SimplifyNames of file: string<LocalPath> * names: SimplifyNames.SimplifiableRange[] | ||
| UnusedDeclarations of file: string<LocalPath> * decls: range[] * version: int | ||
| SimplifyNames of file: string<LocalPath> * names: SimplifyNames.SimplifiableRange[] * version: int | ||
| Canceled of errorMessage: string | ||
| FileParsed of string<LocalPath> | ||
| TestDetected of file: string<LocalPath> * tests: TestAdapter.TestAdapterEntry<range>[] | ||
|
@@ -1251,7 +1251,7 @@ type Commands | |
//Diagnostics handler - Triggered by `CheckCore` | ||
do | ||
disposables.Add | ||
<| fileChecked.Publish.Subscribe(fun (parseAndCheck, file, _) -> | ||
<| fileChecked.Publish.Subscribe(fun (parseAndCheck, file, version) -> | ||
async { | ||
try | ||
NotificationEvent.FileParsed file |> notify.Trigger | ||
|
@@ -1265,7 +1265,7 @@ type Commands | |
|> Array.distinctBy (fun e -> | ||
e.Severity, e.ErrorNumber, e.StartLine, e.StartColumn, e.EndLine, e.EndColumn, e.Message) | ||
|
||
(errors, file) |> NotificationEvent.ParseError |> notify.Trigger | ||
(errors, file, version) |> NotificationEvent.ParseError |> notify.Trigger | ||
with _ -> | ||
() | ||
} | ||
|
@@ -1274,7 +1274,7 @@ type Commands | |
//Analyzers handler - Triggered by `CheckCore` | ||
do | ||
disposables.Add | ||
<| fileChecked.Publish.Subscribe(fun (parseAndCheck, file, _) -> | ||
<| fileChecked.Publish.Subscribe(fun (parseAndCheck, file, version) -> | ||
async { | ||
if hasAnalyzers then | ||
try | ||
|
@@ -1298,7 +1298,7 @@ type Commands | |
parseAndCheck.GetAllEntities | ||
) | ||
|
||
(res, file) |> NotificationEvent.AnalyzerMessage |> notify.Trigger | ||
(res, file, version) |> NotificationEvent.AnalyzerMessage |> notify.Trigger | ||
|
||
Loggers.analyzers.info ( | ||
Log.setMessage "end analysis of {file}" | ||
|
@@ -2435,6 +2435,7 @@ type Commands | |
let isScript = Utils.isAScript (UMX.untag file) | ||
|
||
let! (opts, source) = state.TryGetFileCheckerOptionsWithSource file | ||
let version = state.TryGetFileVersion file |> Option.defaultValue 0 | ||
|
||
let tyResOpt = checker.TryGetRecentCheckResultsForFile(file, opts, source) | ||
|
||
|
@@ -2444,13 +2445,14 @@ type Commands | |
let! unused = UnusedDeclarations.getUnusedDeclarations (tyRes.GetCheckResults, isScript) | ||
let unused = unused |> Seq.toArray | ||
|
||
notify.Trigger(NotificationEvent.UnusedDeclarations(file, unused)) | ||
notify.Trigger(NotificationEvent.UnusedDeclarations(file, unused, version)) | ||
} | ||
|> Async.Ignore<Result<unit, _>> | ||
|
||
member x.CheckSimplifiedNames file : Async<unit> = | ||
asyncResult { | ||
let! (opts, source) = state.TryGetFileCheckerOptionsWithLines file | ||
let version = state.TryGetFileVersion file |> Option.defaultValue 0 | ||
|
||
let tyResOpt = checker.TryGetRecentCheckResultsForFile(file, opts, source) | ||
|
||
|
@@ -2461,7 +2463,7 @@ type Commands | |
|
||
let! simplified = SimplifyNames.getSimplifiableNames (tyRes.GetCheckResults, getSourceLine) | ||
let simplified = Array.ofSeq simplified | ||
notify.Trigger(NotificationEvent.SimplifyNames(file, simplified)) | ||
notify.Trigger(NotificationEvent.SimplifyNames(file, simplified, version)) | ||
} | ||
|> Async.Ignore<Result<unit, _>> | ||
|> x.AsCancellable file | ||
|
@@ -2470,14 +2472,15 @@ type Commands | |
member x.CheckUnusedOpens file : Async<unit> = | ||
asyncResult { | ||
let! (opts, source) = state.TryGetFileCheckerOptionsWithLines file | ||
let version = state.TryGetFileVersion file |> Option.defaultValue 0 | ||
|
||
match checker.TryGetRecentCheckResultsForFile(file, opts, source) with | ||
| None -> return () | ||
| Some tyRes -> | ||
let! unused = | ||
UnusedOpens.getUnusedOpens (tyRes.GetCheckResults, (fun i -> (source: ISourceText).GetLineString(i - 1))) | ||
|
||
notify.Trigger(NotificationEvent.UnusedOpens(file, (unused |> List.toArray))) | ||
notify.Trigger(NotificationEvent.UnusedOpens(file, (unused |> List.toArray), version)) | ||
|
||
} | ||
|> Async.Ignore<Result<unit, _>> | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
oooohhhh, this is subtle. good spot.