Microsoft MVP성태의 닷넷 이야기
오류 유형: 902. Visual Studio - error MSB3021: Unable to copy file [링크 복사], [링크+제목 복사],
조회: 9166
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Visual Studio - error MSB3021: Unable to copy file

Visual Studio에서 csproj의 ItemGroup/Content를 이용한 파일 복사를 하다 보면,

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        <OutputType>Exe</OutputType>
        <TargetFramework>net8.0</TargetFramework>
        <ImplicitUsings>enable</ImplicitUsings>
        <Nullable>enable</Nullable>
    </PropertyGroup>

    <ItemGroup>
        <PackageReference Include="IronPython" Version="3.4.1" />
        <PackageReference Include="IronPython.StdLib" Version="3.4.1" />
    </ItemGroup>

    <ItemGroup>
        <Content Include="C:\Python310\**">
            <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
        </Content>
    </ItemGroup>

    <ItemGroup>
        <None Update="test.py">
            <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
        </None>
    </ItemGroup>

</Project>

경우에 따라 이런 복사 오류가 발생할 수 있습니다

C:\Program Files\Microsoft Visual Studio\2022\Enterprise\MSBuild\Current\Bin\amd64\Microsoft.Common.CurrentVersion.targets(5254,5): error MSB3021: Unable to copy file "C:\Python312\tensorflow\python\Lib\site-packages\tensorflow\include\tensorflow\compiler\xla\mlir_hlo\_virtual_includes\shape_component_analysis\mhlo\analysis\shape_component_analysis.h" to "bin\Debug\net8.0\python\Lib\site-packages\tensorflow\include\tensorflow\compiler\xla\mlir_hlo\_virtual_includes\shape_component_analysis\mhlo\analysis\shape_component_analysis.h". Could not find a part of the path 'bin\Debug\net8.0\python\Lib\site-packages\tensorflow\include\tensorflow\compiler\xla\mlir_hlo\_virtual_includes\shape_component_analysis\mhlo\analysis\shape_component_analysis.h'.


메시지에 포함된 "Could not find a part of the path" 문구가 다소 혼란스러운데요, 물론 경로를 찾지 못한 상황에서도 발생할 수 있겠지만 위와 같은 경우에는 경로가 너무 길어서 발생하는 문제입니다.

재미있는 건, 해당 문제는 비주얼 스튜디오와 MSBuild로 빌드할 때만 발생한다는 점입니다. 반면 dotnet으로 직접 빌드하면 오류 없이 잘 복사가 됩니다. ^^;

이상하군요, 원래 dotnet은 내부적으로 MSBuild를 호출하는 것으로 아는데... 어쨌든, 현상이 저렇게 나옵니다.




만약 명령행으로 빌드하는 경우라면, 그냥 msbuild에서 dotnet으로 변경하면 되겠지만 문제는 비주얼 스튜디오에서 빌드 시 저런 문제가 발생한다는 점입니다.

이런 경우 문제 해결이 아닌, 우회 해법으로 그냥 경로가 너무 길지 않도록 OutputPath를 지정하는 방법이 있습니다.

<Project Sdk="Microsoft.NET.Sdk">
    <!-- 생략 -->

    <PropertyGroup Condition="'$(Configuration)' == 'Debug'">
        <OutputPath>c:\temp\Console</OutputPath>
    </PropertyGroup>
</Project>

msbuild ConsoleApp3.csproj -p:Configuration=Debug

또는, Windows 10 이상의 운영체제라면 깔끔하게 레지스트리 설정을 통해 제약을 없앨 수 있습니다.

Enable Long Paths in Windows 10, Version 1607, and Later
; https://learn.microsoft.com/en-us/windows/win32/fileio/maximum-file-path-limitation?tabs=registry
; https://www.backupery.com/how-to-enable-ntfs-long-paths-in-windows/

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem]
"LongPathsEnabled"=dword:00000001

(과거 버전은 어땠는지 모르겠지만) 현재의 Windows 11 환경에서는 재부팅 필요 없이 바로 반영돼 오류 없이 빌드할 수 있습니다.




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







[최초 등록일: ]
[최종 수정일: 4/30/2024]

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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13743정성태9/26/20246401닷넷: 2298. C# - Console 프로젝트에서의 await 대상으로 Main 스레드 활용하는 방법 [1]
13742정성태9/26/20246686닷넷: 2297. C# - ssh-keygen으로 생성한 ecdsa 유형의 Public Key 파일 해석 [1]파일 다운로드1
13741정성태9/25/20245867디버깅 기술: 202. windbg - ASP.NET MVC Web Application (.NET Framework) 응용 프로그램의 덤프 분석 시 요령
13740정성태9/24/20245728기타: 86. RSA 공개키 등의 modulus 값에 0x00 선행 바이트가 있는 이유(ASN.1 인코딩)
13739정성태9/24/20245876닷넷: 2297. C# - ssh-keygen으로 생성한 Public Key 파일 해석과 fingerprint 값(md5, sha256) 생성 [1]파일 다운로드1
13738정성태9/22/20245599C/C++: 174. C/C++ - 윈도우 운영체제에서의 file descriptor, FILE*파일 다운로드1
13737정성태9/21/20245962개발 환경 구성: 727. Visual C++ - 리눅스 프로젝트를 위한 빌드 서버의 msbuild 구성
13736정성태9/20/20245962오류 유형: 923. Visual Studio Code - Could not establish connection to "...": Port forwarding is disabled.
13735정성태9/20/20246036개발 환경 구성: 726. ARM 플랫폼용 Visual C++ 리눅스 프로젝트 빌드
13734정성태9/19/20245744개발 환경 구성: 725. ssh를 이용한 원격 docker 서비스 사용
13733정성태9/19/20246074VS.NET IDE: 194. Visual Studio - Cross Platform / "Authentication Type: Private Key"로 접속하는 방법
13732정성태9/17/20246111개발 환경 구성: 724. ARM + docker 환경에서 .NET 8 설치
13731정성태9/15/20246695개발 환경 구성: 723. C# / Visual C++ - Control Flow Guard (CFG) 활성화 [1]파일 다운로드2
13730정성태9/10/20246362오류 유형: 922. docker - RULE_APPEND failed (No such file or directory): rule in chain DOCKER
13729정성태9/9/20247105C/C++: 173. Windows / C++ - AllocConsole로 할당한 콘솔과 CRT 함수 연동 [1]파일 다운로드1
13728정성태9/7/20246916C/C++: 172. Windows - C 런타임에서 STARTUPINFO의 cbReserved2, lpReserved2 멤버를 사용하는 이유파일 다운로드1
13727정성태9/6/20247454개발 환경 구성: 722. ARM 플랫폼 빌드를 위한 미니 PC(?) - Khadas VIM4 [1]
13726정성태9/5/20247373C/C++: 171. C/C++ - 윈도우 운영체제에서의 file descriptor와 HANDLE파일 다운로드1
13725정성태9/4/20246124디버깅 기술: 201. WinDbg - sos threads 명령어 실행 시 "Failed to request ThreadStore"
13724정성태9/3/20247983닷넷: 2296. Win32/C# - 자식 프로세스로 HANDLE 상속파일 다운로드1
13723정성태9/2/20248249C/C++: 170. Windows - STARTUPINFO의 cbReserved2, lpReserved2 멤버 사용자 정의파일 다운로드2
13722정성태9/2/20245984C/C++: 169. C/C++ - CRT(C Runtime) 함수에 의존성이 없는 프로젝트 생성
13721정성태8/30/20246019C/C++: 168. Visual C++ CRT(C Runtime DLL: msvcr...dll)에 대한 의존성 제거 - 두 번째 이야기
13720정성태8/29/20246174VS.NET IDE: 193. C# - Visual Studio의 자식 프로세스 디버깅
13719정성태8/28/20246331Linux: 79. C++ - pthread_mutexattr_destroy가 없다면 메모리 누수가 발생할까요?
13718정성태8/27/20247401오류 유형: 921. Visual C++ - error C1083: Cannot open include file: 'float.h': No such file or directory [2]
1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...