OmniSharp.MSBuild.ProjectManager 尝试更新未加载的项目:
Posted
技术标签:
【中文标题】OmniSharp.MSBuild.ProjectManager 尝试更新未加载的项目:【英文标题】:OmniSharp.MSBuild.ProjectManager Attempted to update project that is not loaded: 【发布时间】:2019-08-27 08:16:51 【问题描述】:我开始使用 VS 代码开发 Asp.net Core Web API。但是当我输入代码时 Intellisense/Suggestions 无法正常工作。我在互联网上的一些资源中看到他们正在输入using Microsoft.
,
EntityFrameworkCore
显示为建议。但就我而言,它没有显示。在OmniSharp
日志中向我显示以下错误。
Starting OmniSharp server at 4/5/2019, 3:37:16 PM
Target: c:\Dotnet Core\NgWebApi
OmniSharp server started.
Path: C:\Users\Acer\.vscode\extensions\ms-vscode.csharp-1.18.0\.omnisharp\1.32.11\OmniSharp.exe
PID: 13684
[info]: OmniSharp.Stdio.Host
Starting OmniSharp on Windows 6.2.9200.0 (x64)
[info]: OmniSharp.Services.DotNetCliService
DotNetPath set to dotnet
[info]: OmniSharp.MSBuild.Discovery.MSBuildLocator
Located 1 MSBuild instance(s)
1: StandAlone 15.0 - "C:\Users\Acer\.vscode\extensions\ms-vscode.csharp-1.18.0\.omnisharp\1.32.11\msbuild\15.0\Bin"
[info]: OmniSharp.MSBuild.Discovery.MSBuildLocator
MSBUILD_EXE_PATH environment variable set to 'C:\Users\Acer\.vscode\extensions\ms-vscode.csharp-1.18.0\.omnisharp\1.32.11\msbuild\15.0\Bin\MSBuild.exe'
[info]: OmniSharp.MSBuild.Discovery.MSBuildLocator
Registered MSBuild instance: StandAlone 15.0 - "C:\Users\Acer\.vscode\extensions\ms-vscode.csharp-1.18.0\.omnisharp\1.32.11\msbuild\15.0\Bin"
CscToolExe = csc.exe
CscToolPath = C:\Users\Acer\.vscode\extensions\ms-vscode.csharp-1.18.0\.omnisharp\1.32.11\msbuild\15.0\Bin\Roslyn
MSBuildExtensionsPath = C:\Users\Acer\.vscode\extensions\ms-vscode.csharp-1.18.0\.omnisharp\1.32.11\msbuild
MSBuildToolsPath = C:\Users\Acer\.vscode\extensions\ms-vscode.csharp-1.18.0\.omnisharp\1.32.11\msbuild\15.0\Bin
[info]: OmniSharp.Cake.CakeProjectSystem
Detecting Cake files in 'c:\Dotnet Core\NgWebApi'.
[info]: OmniSharp.Cake.CakeProjectSystem
Could not find any Cake files
[info]: OmniSharp.WorkspaceInitializer
Project system 'OmniSharp.DotNet.DotNetProjectSystem' is disabled in the configuration.
[info]: OmniSharp.MSBuild.ProjectSystem
No solution files found in 'c:\Dotnet Core\NgWebApi'
[info]: OmniSharp.MSBuild.ProjectManager
Queue project update for 'c:\Dotnet Core\NgWebApi\NgWebApi.csproj'
[info]: OmniSharp.Script.ScriptProjectSystem
Detecting CSX files in 'c:\Dotnet Core\NgWebApi'.
[info]: OmniSharp.Script.ScriptProjectSystem
Could not find any CSX files
[info]: OmniSharp.WorkspaceInitializer
Invoking Workspace Options Provider: OmniSharp.Roslyn.CSharp.Services.CSharpWorkspaceOptionsProvider
[info]: OmniSharp.MSBuild.ProjectManager
Loading project: c:\Dotnet Core\NgWebApi\NgWebApi.csproj
[info]: OmniSharp.WorkspaceInitializer
Configuration finished.
[info]: OmniSharp.Stdio.Host
Omnisharp server running using Stdio at location 'c:\Dotnet Core\NgWebApi' on host 17188.
[warn]: OmniSharp.MSBuild.ProjectManager
Failed to load project file 'c:\Dotnet Core\NgWebApi\NgWebApi.csproj'.
c:\Dotnet Core\NgWebApi\NgWebApi.csproj(1,1)
Microsoft.Build.Exceptions.InvalidProjectFileException: The SDK 'Microsoft.NET.Sdk.Web' specified could not be found. c:\Dotnet Core\NgWebApi\NgWebApi.csproj
at Microsoft.Build.Shared.ProjectErrorUtilities.ThrowInvalidProject(String errorSubCategoryResourceName, IElementLocation elementLocation, String resourceName, Object[] args)
at Microsoft.Build.Evaluation.Evaluator`4.ExpandAndLoadImportsFromUnescapedImportExpressionConditioned(String directoryOfImportingFile, ProjectImportElement importElement, List`1& projects, Boolean throwOnFileNotExistsError)
at Microsoft.Build.Evaluation.Evaluator`4.ExpandAndLoadImports(String directoryOfImportingFile, ProjectImportElement importElement)
at Microsoft.Build.Evaluation.Evaluator`4.EvaluateImportElement(String directoryOfImportingFile, ProjectImportElement importElement)
at Microsoft.Build.Evaluation.Evaluator`4.PerformDepthFirstPass(ProjectRootElement currentProjectOrImport)
at Microsoft.Build.Evaluation.Evaluator`4.Evaluate(ILoggingService loggingService, BuildEventContext buildEventContext)
at Microsoft.Build.Evaluation.Project.Reevaluate(ILoggingService loggingServiceForEvaluation, ProjectLoadSettings loadSettings)
at Microsoft.Build.Evaluation.Project.ReevaluateIfNecessary(ILoggingService loggingServiceForEvaluation, ProjectLoadSettings loadSettings)
at Microsoft.Build.Evaluation.Project.Initialize(IDictionary`2 globalProperties, String toolsVersion, String subToolsetVersion, ProjectLoadSettings loadSettings)
at Microsoft.Build.Evaluation.Project..ctor(String projectFile, IDictionary`2 globalProperties, String toolsVersion, String subToolsetVersion, ProjectCollection projectCollection, ProjectLoadSettings loadSettings)
at Microsoft.Build.Evaluation.ProjectCollection.LoadProject(String fileName, IDictionary`2 globalProperties, String toolsVersion)
at OmniSharp.MSBuild.ProjectLoader.EvaluateProjectFileCore(String filePath)
at OmniSharp.MSBuild.ProjectLoader.BuildProject(String filePath)
at OmniSharp.MSBuild.ProjectFile.ProjectFileInfo.Load(String filePath, ProjectLoader loader)
at OmniSharp.MSBuild.ProjectManager.LoadOrReloadProject(String projectFilePath, Func`1 loader)
[fail]: OmniSharp.MSBuild.ProjectManager
Attempted to update project that is not loaded: c:\Dotnet Core\NgWebApi\NgWebApi.csproj
我重新安装了 VS Code 和 C#
, C# Extention
来解决这个问题,但它仍然在发生。我认为原因是没有显示项目未正确加载的 Intellisense/Suggestions。谁能告诉我如何避免此错误以及如何解决未显示问题的 Intellisense/Suggestions。
【问题讨论】:
【参考方案1】:为了解决这个问题,我做了几件事。首先,我通过安装他们的测试版来降级OmniSharp
版本。将该版本的.vsix
文件下载到我的机器上。使用以下步骤将.vsix
安装到 Visual Studio Code 中。
-
打开 Visual Studio Code 并从菜单中选择 View->Extensions 以显示 Extensions 窗格
点击扩展面板右上角的
...
,然后在菜单中选择“Install from VSIX...
”。
找到我下载的文件.vsix
并打开它
然后重启vs代码
但是问题还是出现了,于是我将.Net coreSDK v2.2.202
版本降级为2.1.202
,问题就解决了。
更新:重新安装 VS Code 后不得不再次遇到同样的问题,解决方式。
在 Visual Studio 代码菜单中,进入 文件 > 首选项 > 设置。或按 Ctrl+++,
在搜索设置字段中,输入omnisharp.path
点击在settings.json中编辑。
在那里像这样添加/编辑,
"omnisharp.path": "latest"
如果您的 settings.json 中已经有条目,请在最后一个后面加一个逗号并添加如下行:
"workbench.colorTheme": "Solarized Light",
"omnisharp.path": "latest"
最后,保存 settings.json
您会看到一个提示:“OmniSharp 配置已更改。您要使用更改重新启动 OmniSharp 服务器吗?”点击“重启 OmniSharp”按钮重新加载。
在“输出”窗口中,您可以在下载最新版本的同时查看更新
【讨论】:
【参考方案2】:实际上,omnisharp 路径对我不起作用。我在mac上。我最终所做的是下载早期版本的 .net,而不是最新的 5。
https://dotnet.microsoft.com/download/dotnet/thank-you/sdk-3.0.103-macos-x64-installer
【讨论】:
【参考方案3】:我找到了另一个解决方案,因为其他解决方案都不适合我,我正在寻找几个小时。(2021 年 7 月 8 日):
我在使用 .NET、.NET Core 或 .NET Framework 时遇到了同样的错误,以下是一些错误截图:
在错误输出中,它说要安装此框架版本的开发包。您可以在 .csproj 文件中找到版本:
通过在dotnet microsoft 站点上安装此版本的.NET Framework:.NET Framework download list 我在重新加载 VSCode 后修复了错误,并让我的 Intellisense 为 Unity 工作。
TLDR: 我的修复方法是安装 .NET Framework 4.7.1 版
【讨论】:
在 VSCode 1.60.0 中工作 这里是直接离线安装程序。它为我解决了这个问题:dotnet.microsoft.com/download/dotnet-framework/thank-you/…【参考方案4】:如果您安装了SDK
using snap / ubuntu 软件..这就是导致我同样错误的原因。我回答了我自己的类似问题here
【讨论】:
【参考方案5】:这可能失败的另一个原因是,当您安装了 Visual Studio 2019 16.7 or below
,因为 OmniSharp 需要来自 16.8
的 MsBuild。
使用 Visual Studio 安装程序更新 Visual Studio 为我解决了这个问题,而我正在使用替换机器,该机器现在处于休眠状态。
【讨论】:
【参考方案6】:我通过在 VSCode 上执行以下操作解决了这个问题:
-
进入设置。 (代码 -> 首选项 -> Mac 上的设置)
搜索“omnisharp”。
找到“Omnisharp:使用全局单声道”部分并将其设置为“始终”。
找到“Omnisharp:路径”部分,然后单击“在 settings.json 中编辑”。将“omnisharp.path”更改为“omnisharp.path”:latest”。
重新加载窗口。
【讨论】:
你拯救了我的一天。我从一个月开始就一直在寻找解决方案。 这为我指明了正确的方向,但我必须将其设置为“从不”。我想是因为我同时安装了 core 3.1 和 core 5。看起来我需要本地的 Mono,而不是全局的。 – RailinginDFW 1 小时前 在它起作用之前我必须做这两件事:1.从上面的答案中,将设置更改为"omnisharp.path": "latest"
,然后它将 OmniSharp 下载到我的 VSCode 副本中。然后 2. Use global mono: always
就像你建议的那样。这是一个集体的努力。谢谢!
我按照@Marquizzo 的描述做了,我已经加载了核心 3.1 和核心 5。
我根据您的建议编辑了答案@Marquizzo。我认为使用“omnisharp.path”:“latest”会更强大,因为没有它有时会再次出现问题。【参考方案7】:
这在最新的 Windows10 更新后开始发生。
重新安装 .NET Core Runtime,现在一切正常。
【讨论】:
【参考方案8】:我也面临同样的问题。如果上述解决方案均无效,则可以尝试以下解决方案。
在查看日志时,我意识到了真正的问题: “找不到指定的 SDK 'Microsoft.NET.Sdk'。”
我从这里 (6.8.0) 安装了最新的稳定 Mono: https://www.mono-project.com/download/stable/
然后打开~bash_profile,导出mono的框架路径: export FrameworkPathOverride=/Library/Frameworks/Mono.framework/Versions/Current
对我来说很好用。希望它也对你有用。
【讨论】:
【参考方案9】:我的 Mac 上同时安装了 VSCode 和 Visual Studio。使用 official guide 卸载 Visual Studio 解决了这个问题。
【讨论】:
【参考方案10】:我通过升级我的 Mono 项目版本解决了这个问题 https://www.mono-project.com/
【讨论】:
这很有效,实际上是 Unity for Visual Studio Code 指南推荐的。 请注意,如果您安装了 Visual Studio for Mac 并启用了自动更新,它将下载高于 Mono 网站上为“Visual Studio 频道”指定的版本的 Mono MDK .除此之外,让它在我的情况下工作的关键是卸载/重新安装“C#”扩展,然后按照 ege 的 solution 设置 VS 代码设置“Omnisharp:使用全局单声道”到“总是”。现在这两个 IDE 都按预期工作了。【参考方案11】:已解决:检查是否安装了 Visual Studio Build Packages,如果安装则将其卸载。只要卸载 VScode 就可以正常工作,智能感知功能就会回来。 祝你好运!
【讨论】:
已针对 Visual Studio Code 1.40.2(用户设置)、.NET Core 3.1 控制台应用程序和 Windows 10 Pro 1803 进行了验证【参考方案12】:已解决(在 Ubuntu 16.04 和 CentOS 7 上交叉检查):
在 VS Code 菜单中,进入 File / Preferences / Settings。
在“搜索设置”窗口中,输入 omnisharp.path
点击“在 settings.json 中编辑”链接。
像这样添加(或编辑):"omnisharp.path": "latest"
(来自:https://github.com/OmniSharp/omnisharp-vscode/issues/2965)
【讨论】:
这个解决方案对我有用:Win 10, VSCode: 1.32.3 and .Net Core 2.2.301 Mac OS X 10.15 running VS Code 1.40.2 我的 settings.json 没有这个条目。一旦我添加它,omnisharp 就会自行重新安装,瞧,intellisense 又回来了。谢谢@BernieB 我这样做了,但没有解决问题。 我昨天在我的 Ubuntu 20.04 系统上升级了 dotnet 包。似乎有一个突破性的变化影响了omnisharp。但是,最新版本的 omnisharp 可以与较新的 dotnet 包配合使用。设置"omnisharp.path": "latest"
导致VS Code 自动为我更新omnisharp,从而解决了智能感知问题。
修复了智能感知,但没有修复“OmniSharp.MSBuild.ProjectManager 尝试更新未加载的项目”错误。请参阅下面关于将 Omnisharp Use Global Mono 设置为“始终”的答案。以上是关于OmniSharp.MSBuild.ProjectManager 尝试更新未加载的项目:的主要内容,如果未能解决你的问题,请参考以下文章