Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 4개 있습니다.)
개발 환경 구성: 296. .NET Core 프로젝트를 NuGet Gallery에 배포하는 방법
; https://www.sysnet.pe.kr/2/0/11034

.NET Framework: 793. C# - REST API를 이용해 NuGet 저장소 제어
; https://www.sysnet.pe.kr/2/0/11696

개발 환경 구성: 423. NuGet 패키지 제작 - Native와 Managed DLL을 분리하는 방법
; https://www.sysnet.pe.kr/2/0/11793

개발 환경 구성: 494. NuGet - nuspec의 패키지 스키마 버전(네임스페이스) 업데이트 방법
; https://www.sysnet.pe.kr/2/0/12234




NuGet - nuspec의 패키지 스키마 버전(네임스페이스) 업데이트 방법

지난 글에서,

C# - Source Generator를 적용한 XmlCodeGenerator
; https://www.sysnet.pe.kr/2/0/12228

만든 XmlSrcGenerator를 위한 nuspec은 대충 다음과 같은 식입니다.

<?xml version="1.0" encoding="utf-8"?>
<package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd">
  <metadata>
    <id>XmlSrcGenerator</id>
    <version>1.0.4</version>
    <title>C# Source Generator with XML + XSLT</title>
    <authors>SeongTae Jeong</authors>
    <owners>SeongTae Jeong</owners>
    <developmentDependency>true</developmentDependency>
    <requireLicenseAcceptance>false</requireLicenseAcceptance>
    <license type="expression">MIT</license>
    <licenseUrl>https://licenses.nuget.org/MIT</licenseUrl>
    <projectUrl>https://github.com/stjeong/XmlCodeGenerator</projectUrl>
    <description>C# Source Generator with XML + XSLT (same as https://marketplace.visualstudio.com/items?itemName=SeongTaeJeong.XmlCodeGenerator)</description>
    <tags>Analyzers CSharp xml xslt</tags>
  </metadata>
</package>

그런데, 여기서 package 노드의 xmlns를 다음과 같이 업데이트해봤는데요,

<package xmlns="http://schemas.microsoft.com/packaging/2011/10/nuspec.xsd">

이상하게 "nuget pack"을 한 후 생성된 nupkg의 압축을 해제해서 확인해 보면 다시 "http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd"로 돌아가 있는 것을 확인할 수 있습니다. 혹시 업데이트 방법이 없을까요? ^^

그래서 찾아봤더니 다음의 글이 나옵니다.

How to specify Nuget schema?
; https://stackoverflow.com/questions/33225461/how-to-specify-nuget-schema

그러니까, 저 스키마 버전은 nuget.exe가 내부적으로 자동 지정한다는 것입니다. 그러면서 소스 코드 링크를 걸어주었는데, 실제로 다음과 같은 규칙을 확인할 수 있습니다.

// PackageBuilder
// https://github.com/NuGet/NuGet2/blob/2.8.7/src/Core/Authoring/PackageBuilder.cs#L284-L299

private static int DetermineMinimumSchemaVersion(Collection<IPackageFile> Files)
{
    if (HasXdtTransformFile(Files))
    {
        // version 5
        return ManifestVersionUtility.XdtTransformationVersion;
    }

    if (RequiresV4TargetFrameworkSchema(Files))
    {
        // version 4
        return ManifestVersionUtility.TargetFrameworkSupportForDependencyContentsAndToolsVersion;
    }

    return ManifestVersionUtility.DefaultVersion;
}

// ManifestSchemaUtility
// https://github.com/NuGet/NuGet2/blob/2.8.7/src/Core/Authoring/ManifestVersionUtility.cs#L25-L52

private static int GetMaxVersionFromMetadata(ManifestMetadata metadata)
{
    // Important: check for version 5 before version 4
    bool referencesHasTargetFramework =
        metadata.ReferenceSets != null &&
        metadata.ReferenceSets.Any(r => r.TargetFramework != null);

    if (referencesHasTargetFramework)
    {
        return TargetFrameworkSupportForReferencesVersion;
    }

    bool dependencyHasTargetFramework =
        metadata.DependencySets != null &&
        metadata.DependencySets.Any(d => d.TargetFramework != null);
    if (dependencyHasTargetFramework)
    {
        return TargetFrameworkSupportForDependencyContentsAndToolsVersion;
    }

    SemanticVersion semanticVersion;
    if (SemanticVersion.TryParse(metadata.Version, out semanticVersion) && !String.IsNullOrEmpty(semanticVersion.SpecialVersion))
    {
        return SemverVersion;
    }

    return DefaultVersion;
}

여러분들은 저처럼 애쓰지 말라는 의미로 기록을 남깁니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 6/19/2020]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
12536정성태2/9/202110133개발 환경 구성: 542. BDP(Bandwidth-delay product)와 TCP Receive Window
12535정성태2/9/20219241개발 환경 구성: 541. Wireshark로 확인하는 LSO(Large Send Offload), RSC(Receive Segment Coalescing) 옵션
12534정성태2/8/20219811개발 환경 구성: 540. Wireshark + C/C++로 확인하는 TCP 연결에서의 closesocket 동작 [1]파일 다운로드1
12533정성태2/8/20219474개발 환경 구성: 539. Wireshark + C/C++로 확인하는 TCP 연결에서의 shutdown 동작파일 다운로드1
12532정성태2/6/20219954개발 환경 구성: 538. Wireshark + C#으로 확인하는 ReceiveBufferSize(SO_RCVBUF), SendBufferSize(SO_SNDBUF) [3]
12531정성태2/5/20218982개발 환경 구성: 537. Wireshark + C#으로 확인하는 PSH flag와 Nagle 알고리듬파일 다운로드1
12530정성태2/4/202113160개발 환경 구성: 536. Wireshark + C#으로 확인하는 TCP 통신의 Receive Window
12529정성태2/4/202110208개발 환경 구성: 535. Wireshark + C#으로 확인하는 TCP 통신의 MIN RTO [1]
12528정성태2/1/20219603개발 환경 구성: 534. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 윈도우 환경
12527정성태2/1/20219814개발 환경 구성: 533. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 리눅스 환경파일 다운로드1
12526정성태2/1/20217668개발 환경 구성: 532. Azure Devops의 파이프라인 빌드 시 snk 파일 다루는 방법 - Secure file
12525정성태2/1/20217396개발 환경 구성: 531. Azure Devops - 파이프라인 실행 시 빌드 이벤트를 생략하는 방법
12524정성태1/31/20218488개발 환경 구성: 530. 기존 github 프로젝트를 Azure Devops의 빌드 Pipeline에 연결하는 방법 [1]
12523정성태1/31/20218553개발 환경 구성: 529. 기존 github 프로젝트를 Azure Devops의 Board에 연결하는 방법
12522정성태1/31/202110052개발 환경 구성: 528. 오라클 클라우드의 리눅스 VM - 9000 MTU Jumbo Frame 테스트
12521정성태1/31/202110001개발 환경 구성: 527. 이더넷(Ethernet) 환경의 TCP 통신에서 MSS(Maximum Segment Size) 확인 [1]
12520정성태1/30/20218567개발 환경 구성: 526. 오라클 클라우드의 VM에 ping ICMP 여는 방법
12519정성태1/30/20217607개발 환경 구성: 525. 오라클 클라우드의 VM을 외부에서 접근하기 위해 포트 여는 방법
12518정성태1/30/202125061Linux: 37. Ubuntu에 Wireshark 설치 [2]
12517정성태1/30/202112698Linux: 36. 윈도우 클라이언트에서 X2Go를 이용한 원격 리눅스의 GUI 접속 - 우분투 20.04
12516정성태1/29/20219337Windows: 188. Windows - TCP default template 설정 방법
12515정성태1/28/202110590웹: 41. Microsoft Edge - localhost에 대해 http 접근 시 무조건 https로 바뀌는 문제 [3]
12514정성태1/28/202110839.NET Framework: 1021. C# - 일렉트론 닷넷(Electron.NET) 소개 [1]파일 다운로드1
12513정성태1/28/20218902오류 유형: 698. electronize - User Profile 디렉터리에 공백 문자가 있는 경우 빌드가 실패하는 문제 [1]
12512정성태1/28/20218671오류 유형: 697. The program can't start because VCRUNTIME140.dll is missing from your computer. Try reinstalling the program to fix this problem.
12511정성태1/27/20218426Windows: 187. Windows - 도스 시절의 8.3 경로를 알아내는 방법
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...