dotnet / vscode-csharp

Official C# support for Visual Studio Code
MIT License
2.86k stars 672 forks source link

C# complains that dotnet is not in the PATH, but it is #3751

Closed DrStrangepork closed 4 years ago

DrStrangepork commented 4 years ago

Issue Description

Whenever I open a C# project, the plugin complains with a popup "The .NET Core SDK cannot be located. .NET Core debugging will not be enabled. Make sure the .NET Core SDK is installed and is on the path." But dotnet is in my PATH:

# which dotnet
/usr/local/bin/dotnet

Steps to Reproduce

Open any C# project

Expected Behavior

No complaining and functional debugging

Actual Behavior

Logs

OmniSharp log

Starting OmniSharp server at 5/1/2020, 4:09:31 PM Target: /Users/n0304144/git/my_repo/WebSocketComms.sln OmniSharp server started. Path: /Users/n0304144/.vscode/extensions/ms-dotnettools.csharp-1.21.17/.omnisharp/1.35.0/run PID: 26733 [info]: OmniSharp.Stdio.Host Starting OmniSharp on MacOS 10.15.4 (x64) [info]: OmniSharp.Services.DotNetCliService DotNetPath set to dotnet [info]: OmniSharp.MSBuild.Discovery.MSBuildLocator Located 1 MSBuild instance(s) 1: StandAlone 16.4 - "/Users/n0304144/.vscode/extensions/ms-dotnettools.csharp-1.21.17/.omnisharp/1.35.0/omnisharp/.msbuild/Current/Bin" [info]: OmniSharp.MSBuild.Discovery.MSBuildLocator MSBUILD_EXE_PATH environment variable set to '/Users/n0304144/.vscode/extensions/ms-dotnettools.csharp-1.21.17/.omnisharp/1.35.0/omnisharp/.msbuild/Current/Bin/MSBuild.dll' [info]: OmniSharp.MSBuild.Discovery.MSBuildLocator Registered MSBuild instance: StandAlone 16.4 - "/Users/n0304144/.vscode/extensions/ms-dotnettools.csharp-1.21.17/.omnisharp/1.35.0/omnisharp/.msbuild/Current/Bin" CscToolExe = csc.exe MSBuildToolsPath = /Users/n0304144/.vscode/extensions/ms-dotnettools.csharp-1.21.17/.omnisharp/1.35.0/omnisharp/.msbuild/Current/Bin CscToolPath = /Users/n0304144/.vscode/extensions/ms-dotnettools.csharp-1.21.17/.omnisharp/1.35.0/omnisharp/.msbuild/Current/Bin/Roslyn BypassFrameworkInstallChecks = true MSBuildExtensionsPath = /Users/n0304144/.vscode/extensions/ms-dotnettools.csharp-1.21.17/.omnisharp/1.35.0/omnisharp/.msbuild [info]: OmniSharp.Cake.CakeProjectSystem Detecting Cake files in '/Users/n0304144/git/my_repo'. [info]: OmniSharp.Cake.CakeProjectSystem Could not find any Cake files [info]: OmniSharp.MSBuild.ProjectSystem Detecting projects in '/Users/n0304144/git/my_repo/WebSocketComms.sln'. [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/OnConnect/OnConnect.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/OnConnect.Tests/OnConnect.Tests.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/OnDisconnect/OnDisconnect.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/OnDisconnect.Tests/OnDisconnect.Tests.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/SendMessage/SendMessage.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/SendMessage.Tests/SendMessage.Tests.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/WebSocketModels/WebSocketModels.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/WebSocketEnvironment/WebSocketEnvironment.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/UpdateConnection/UpdateConnection.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/UpdateConnection.Tests/UpdateConnection.Tests.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/LookupConnection/LookupConnection.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/LookupConnection.Tests/LookupConnection.Tests.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/PayStatus/PayStatus.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/PayStatus.Tests/PayStatus.Tests.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/CallTwilioPay/CallTwilioPay.csproj' [info]: OmniSharp.MSBuild.ProjectManager Queue project update for '/Users/n0304144/git/my_repo/CallTwilioPay.Tests/CallTwilioPay.Tests.csproj' [info]: OmniSharp.Script.ScriptProjectSystem Detecting CSX files in '/Users/n0304144/git/my_repo'. [info]: OmniSharp.Script.ScriptProjectSystem Could not find any CSX files [info]: OmniSharp.WorkspaceInitializer Invoking Workspace Options Provider: OmniSharp.Roslyn.CSharp.Services.CSharpFormattingWorkspaceOptionsProvider, Order: 0 [info]: OmniSharp.MSBuild.ProjectManager Loading project: /Users/n0304144/git/my_repo/OnConnect/OnConnect.csproj [info]: OmniSharp.WorkspaceInitializer Invoking Workspace Options Provider: OmniSharp.Roslyn.CSharp.Services.RenameWorkspaceOptionsProvider, Order: 100 [info]: OmniSharp.WorkspaceInitializer Invoking Workspace Options Provider: OmniSharp.Roslyn.CSharp.Services.ImplementTypeWorkspaceOptionsProvider, Order: 110 [info]: OmniSharp.WorkspaceInitializer Invoking Workspace Options Provider: OmniSharp.Roslyn.CSharp.Services.BlockStructureWorkspaceOptionsProvider, Order: 140 [info]: OmniSharp.WorkspaceInitializer Invoking Workspace Options Provider: OmniSharp.Roslyn.CSharp.Services.EditorConfigWorkspaceOptionsProvider, Order: 200 [info]: OmniSharp.WorkspaceInitializer Configuration finished. [info]: OmniSharp.Stdio.Host Omnisharp server running using Stdio at location '/Users/n0304144/git/my_repo' on host 26353. It was not possible to find any installed .NET Core SDKs Did you mean to run .NET Core SDK commands? Install a .NET Core SDK from: https://aka.ms/dotnet-download [warn]: OmniSharp.MSBuild.ProjectManager Failed to load project file '/Users/n0304144/git/my_repo/OnConnect/OnConnect.csproj'. /Users/n0304144/git/my_repo/OnConnect/OnConnect.csproj(1,1) Microsoft.Build.Exceptions.InvalidProjectFileException: The SDK 'Microsoft.NET.Sdk' specified could not be found. /Users/n0304144/git/my_repo/OnConnect/OnConnect.csproj at Microsoft.Build.Shared.ProjectErrorUtilities.ThrowInvalidProject (System.String errorSubCategoryResourceName, Microsoft.Build.Shared.IElementLocation elementLocation, System.String resourceName, System.Object[] args) [0x00040] in :0 at Microsoft.Build.Shared.ProjectErrorUtilities.VerifyThrowInvalidProject[T1] (System.Boolean condition, System.String errorSubCategoryResourceName, Microsoft.Build.Shared.IElementLocation elementLocation, System.String resourceName, T1 arg0) [0x00003] in :0 at Microsoft.Build.Shared.ProjectErrorUtilities.ThrowInvalidProject[T1] (Microsoft.Build.Shared.IElementLocation elementLocation, System.String resourceName, T1 arg0) [0x00000] in :0 at Microsoft.Build.Evaluation.Evaluator`4[P,I,M,D].ExpandAndLoadImportsFromUnescapedImportExpressionConditioned (System.String directoryOfImportingFile, Microsoft.Build.Construction.ProjectImportElement importElement, System.Collections.Generic.List`1[Microsoft.Build.Construction.ProjectRootElement]& projects, Microsoft.Build.BackEnd.SdkResolution.SdkResult& sdkResult, System.Boolean throwOnFileNotExistsError) [0x00254] in :0 at Microsoft.Build.Evaluation.Evaluator`4[P,I,M,D].ExpandAndLoadImports (System.String directoryOfImportingFile, Microsoft.Build.Construction.ProjectImportElement importElement, Microsoft.Build.BackEnd.SdkResolution.SdkResult& sdkResult) [0x00027] in :0 at Microsoft.Build.Evaluation.Evaluator`4[P,I,M,D].EvaluateImportElement (System.String directoryOfImportingFile, Microsoft.Build.Construction.ProjectImportElement importElement) [0x0000d] in :0 at Microsoft.Build.Evaluation.Evaluator`4[P,I,M,D].PerformDepthFirstPass (Microsoft.Build.Construction.ProjectRootElement currentProjectOrImport) [0x000e6] in :0 at Microsoft.Build.Evaluation.Evaluator`4[P,I,M,D].Evaluate (Microsoft.Build.BackEnd.Logging.ILoggingService loggingService, Microsoft.Build.Framework.BuildEventContext buildEventContext) [0x0014c] in :0 at Microsoft.Build.Evaluation.Evaluator`4[P,I,M,D].Evaluate (Microsoft.Build.Evaluation.IEvaluatorData`4[P,I,M,D] data, Microsoft.Build.Construction.ProjectRootElement root, Microsoft.Build.Evaluation.ProjectLoadSettings loadSettings, System.Int32 maxNodeCount, Microsoft.Build.Collections.PropertyDictionary`1[T] environmentProperties, Microsoft.Build.BackEnd.Logging.ILoggingService loggingService, Microsoft.Build.Evaluation.IItemFactory`2[S,T] itemFactory, Microsoft.Build.Evaluation.IToolsetProvider toolsetProvider, Microsoft.Build.Evaluation.ProjectRootElementCacheBase projectRootElementCache, Microsoft.Build.Framework.BuildEventContext buildEventContext, Microsoft.Build.BackEnd.SdkResolution.ISdkResolverService sdkResolverService, System.Int32 submissionId, Microsoft.Build.Evaluation.Context.EvaluationContext evaluationContext, System.Boolean interactive) [0x00044] in :0 at Microsoft.Build.Evaluation.Project+ProjectImpl.Reevaluate (Microsoft.Build.BackEnd.Logging.ILoggingService loggingServiceForEvaluation, Microsoft.Build.Evaluation.ProjectLoadSettings loadSettings, Microsoft.Build.Evaluation.Context.EvaluationContext evaluationContext) [0x00063] in :0 at Microsoft.Build.Evaluation.Project+ProjectImpl.ReevaluateIfNecessary (Microsoft.Build.BackEnd.Logging.ILoggingService loggingServiceForEvaluation, Microsoft.Build.Evaluation.ProjectLoadSettings loadSettings, Microsoft.Build.Evaluation.Context.EvaluationContext evaluationContext) [0x00035] in :0 at Microsoft.Build.Evaluation.Project+ProjectImpl.ReevaluateIfNecessary (Microsoft.Build.BackEnd.Logging.ILoggingService loggingServiceForEvaluation, Microsoft.Build.Evaluation.Context.EvaluationContext evaluationContext) [0x00000] in :0 at Microsoft.Build.Evaluation.Project+ProjectImpl.ReevaluateIfNecessary (Microsoft.Build.Evaluation.Context.EvaluationContext evaluationContext) [0x00007] in :0 at Microsoft.Build.Evaluation.Project+ProjectImpl.Initialize (System.Collections.Generic.IDictionary`2[TKey,TValue] globalProperties, System.String toolsVersion, System.String subToolsetVersion, Microsoft.Build.Evaluation.ProjectLoadSettings loadSettings, Microsoft.Build.Evaluation.Context.EvaluationContext evaluationContext) [0x0012b] in :0 at Microsoft.Build.Evaluation.Project..ctor (System.String projectFile, System.Collections.Generic.IDictionary`2[TKey,TValue] globalProperties, System.String toolsVersion, System.String subToolsetVersion, Microsoft.Build.Evaluation.ProjectCollection projectCollection, Microsoft.Build.Evaluation.ProjectLoadSettings loadSettings, Microsoft.Build.Evaluation.Context.EvaluationContext evaluationContext) [0x00075] in :0 at Microsoft.Build.Evaluation.Project..ctor (System.String projectFile, System.Collections.Generic.IDictionary`2[TKey,TValue] globalProperties, System.String toolsVersion, System.String subToolsetVersion, Microsoft.Build.Evaluation.ProjectCollection projectCollection, Microsoft.Build.Evaluation.ProjectLoadSettings loadSettings) [0x00000] in :0 at Microsoft.Build.Evaluation.Project..ctor (System.String projectFile, System.Collections.Generic.IDictionary`2[TKey,TValue] globalProperties, System.String toolsVersion, Microsoft.Build.Evaluation.ProjectCollection projectCollection, Microsoft.Build.Evaluation.ProjectLoadSettings loadSettings) [0x00000] in :0 at Microsoft.Build.Evaluation.Project..ctor (System.String projectFile, System.Collections.Generic.IDictionary`2[TKey,TValue] globalProperties, System.String toolsVersion, Microsoft.Build.Evaluation.ProjectCollection projectCollection) [0x00000] in :0 at Microsoft.Build.Evaluation.ProjectCollection.LoadProject (System.String fileName, System.Collections.Generic.IDictionary`2[TKey,TValue] globalProperties, System.String toolsVersion) [0x000f7] in :0 at Microsoft.Build.Evaluation.ProjectCollection.LoadProject (System.String fileName, System.String toolsVersion) [0x00000] in :0 at OmniSharp.MSBuild.ProjectLoader.EvaluateProjectFileCore (System.String filePath) [0x0003f] in :0 at OmniSharp.MSBuild.ProjectLoader.BuildProject (System.String filePath) [0x0000d] in :0 at OmniSharp.MSBuild.ProjectFile.ProjectFileInfo.Load (System.String filePath, OmniSharp.MSBuild.ProjectIdInfo projectIdInfo, OmniSharp.MSBuild.ProjectLoader loader) [0x00015] in :0 at OmniSharp.MSBuild.ProjectManager+<>c__DisplayClass29_0.b__0 () [0x00000] in :0 at (wrapper delegate-invoke) System.Func`1[System.ValueTuple`3[OmniSharp.MSBuild.ProjectFile.ProjectFileInfo,System.Collections.Immutable.ImmutableArray`1[OmniSharp.MSBuild.Logging.MSBuildDiagnostic],OmniSharp.MSBuild.Notification.ProjectLoadedEventArgs]].invoke_TResult() at OmniSharp.MSBuild.ProjectManager.LoadOrReloadProject (System.String projectFilePath, System.Func`1[TResult] loader) [0x0001b] in :0 [fail]: OmniSharp.MSBuild.ProjectManager Attempted to update project that is not loaded: /Users/n0304144/git/my_repo/OnConnect/OnConnect.csproj

C# log

Post the output from Output-->C# here

Environment information

VSCode version: 1.44.2 C# Extension: 1.21.17

Mono Information OmniSharp using built-in mono
Dotnet Information A valid dotnet installation could not be found.
Visual Studio Code Extensions |Extension|Author|Version| |---|---|---| |alignment|annsk|0.3.0| |aws-toolkit-vscode|amazonwebservices|1.9.0| |azure-account|ms-vscode|0.8.9| |beautify|HookyQR|1.5.0| |bracket-jumper|sashaweiss|1.1.8| |bracket-pair-colorizer|CoenraadS|1.0.61| |code-settings-sync|Shan|3.4.3| |code-spell-checker|streetsidesoftware|1.8.0| |csharp|ms-dotnettools|1.21.17| |debugger-for-chrome|msjsdiag|4.12.6| |dictionary-completion|yzhang|0.8.4| |EditorConfig|EditorConfig|0.14.5| |git-project-manager|felipecaputo|1.7.1| |githistory|donjayamanne|0.6.5| |gitlens|eamodio|10.2.1| |google-search-ext|adelphes|0.2.1| |JavaScriptSnippets|xabikos|1.8.0| |jbockle-format-files|jbockle|3.0.0| |jenkins-declarative-support|jmMeessen|0.1.0| |jenkinsfile-support|secanis|0.1.0| |json-tools|eriklynd|1.0.2| |json2yaml|tuxtina|0.2.0| |MagicPython|magicstack|1.1.0| |markdown-all-in-one|yzhang|2.8.0| |markdown-preview-github-styles|bierner|0.1.6| |markdown-shortcuts|mdickin|0.12.0| |material-theme|zhuangtongfa|3.3.1| |nodejs-extension-pack|waderyan|0.1.9| |npm-intellisense|christian-kohler|1.3.0| |path-intellisense|christian-kohler|1.4.2| |powershell|ms-vscode|2020.4.0| |python|ms-python|2020.4.76186| |ReplaceWithNewline|jmallien|0.0.1| |search-node-modules|jasonnutter|1.3.0| |serverless-ide-vscode|ThreadHeap|0.5.18| |serverless-vscode|frankschmid|1.0.0| |shell-format|foxundermoon|7.0.1| |shellcheck|timonwong|0.9.0| |sort-lines|Tyriar|1.9.0| |swagger-viewer|Arjun|2.2.2| |terraform|mauve|1.4.0| |twilio-sid-generator|LuisSantos|1.0.3| |vagrant|bbenoist|0.5.0| |VS-code-vagrantfile|marcostazi|0.0.7| |vs-remote-debugger|mkloubert|3.0.0| |vscode-ansible|vscoss|0.5.2| |vscode-azurefunctions|ms-azuretools|0.22.0| |vscode-cfn-lint|kddejong|0.11.2| |vscode-codemetrics|kisstkondoros|1.24.0| |vscode-docker|ms-azuretools|1.1.0| |vscode-eslint|dbaeumer|2.1.5| |vscode-for-node-js-development-pack|nodesource|2.0.1| |vscode-icons|vscode-icons-team|10.1.1| |vscode-import-cost|wix|2.12.0| |vscode-markdownlint|DavidAnson|0.35.1| |vscode-npm-script|eg2|0.3.11| |vscode-sort-json|richie5um2|1.18.0| |vscode-yaml|redhat|0.7.2| |vsliveshare|ms-vsliveshare|1.0.2104| |vsliveshare-audio|ms-vsliveshare|0.1.85| |xml|DotJoshJohnson|2.5.0|;
gregg-miskelly commented 4 years ago

Hi @DrStrangepork this is not a problem with this extension -- dotnet really isn't on the PATH that this extension sees. You can look at this wiki page for information to troubleshoot this.

djweaver-dev commented 4 years ago

I had this same issue and restarting my pc solved it (as stated in the wiki linked by @gregg-miskelly )