Ошибка при извлечении метаданных в проекте docfx
Несмотря на чтение документации docfx и многочисленные проблемы с Github, я не могу заставить мой проект docfx работать.
Предпринятые шаги:
- Инициализировать корневой каталог
docfx init -q
- Сборка из корневого каталога
docfx build
(без ошибок) - обслуживать
docfx "/user/docfx_project/docfx.json" --serve
Трассировки стека:
Error:Error extracting metadata for /user/docfx_project/src/MyApp/MyApp.csproj,/user/docfx_project/src/MyApp.Tests/MyApp.Tests.csproj: System.NullReferenceException: Object reference not set to an instance of an object
at Microsoft.DocAsCode.Metadata.ManagedReference.ExtractMetadataWorker.SaveAllMembersFromCacheAsync () [0x00380] in <0779a76130d64c11baa2c8c084cbfe7c>:0
at Microsoft.DocAsCode.Metadata.ManagedReference.ExtractMetadataWorker.ExtractMetadataAsync () [0x000c0] in <0779a76130d64c11baa2c8c084cbfe7c>:0
Окружающая обстановка:
- OSX 10.13.6
- docfx 2.56.2.0
- Пакет SDK для.NET Core (3.1.401)
- Моно JIT-компилятор версии 6.10.0.104
Структура проекта:
docfx-project
|
+-- _site
+-- api
+-- apidoc
+-- articles
+-- docfx.json
+-- images
+-- index.md
+-- obj
+-- src
|
+-- MyApp
|
+-- MyApp.csproj
+-- toc.yml
docfx.json:
{
"metadata": [
{
"src": [
{
"files": [
"src/**/**.csproj"
]
}
],
"dest": "api",
"disableGitFeatures": false,
"disableDefaultFilter": false
}
],
"build": {
"content": [
{
"files": [
"api/**.yml",
"api/index.md"
]
},
{
"files": [
"articles/**.md",
"articles/**/toc.yml",
"toc.yml",
"*.md"
]
}
],
"resource": [
{
"files": [
"images/**"
]
}
],
"overwrite": [
{
"files": [
"apidoc/**.md"
],
"exclude": [
"obj/**",
"_site/**"
]
}
],
"dest": "_site",
"globalMetadataFiles": [],
"fileMetadataFiles": [],
"template": [
"default"
],
"postProcessors": [],
"markdownEngineName": "markdig",
"noLangKeyword": false,
"keepFileLink": false,
"cleanupCacheHistory": false,
"disableGitFeatures": false
}
}
Halp.
1 ответ
У меня относительно слабое представление о том, почему это работает, но то, что потребовалось на моей машине CI, было
export VSINSTALLDIR=
- иными словами, очистка
VSINSTALLDIR
переменная среды перед запуском
docfx metadata
. Я считаю, что это влияет на версию msbuild (или, по крайней мере, на некоторые файлы msbuild), которую использует docfx.
Это было исправлением для других проблем в прошлом - одна из них утверждает, что была исправлена некоторое время назад, но похоже, что тот же обходной путь работает и для этой проблемы... по крайней мере, на моей машине CI.