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

Visual Studio - Build Events에 robocopy를 사용할때 "Invalid Parameter #1" 오류가 발행하는 경우

이상하군요, 단순하게 다음과 같이 빌드 이벤트를 만들었는데,

$(ProjectDir)postBuildScript.bat "$(TargetDir)" $(TargetName)

REM postBuildScript.bat
robocopy %1 d:\temp %2.*

exit 0

빌드 시 오류가 발생합니다.

Error Invalid Parameter #1 : "E:\ConsoleApp1\bin\Debug" d:\temp ConsoleApp1.*"

원인은 지난 글에 쓴 것과 같은 이유인데,

robocopy - ERROR : No Destination Directory Specified.
; https://www.sysnet.pe.kr/2/0/12441

TargetDir이 넘겨주는 값이 "E:\ConsoleApp1\bin\Debug\"와 같이 마지막에 '\' 글자를 포함하고 있기 때문입니다. 하지만 오류 메시지의 출력 결과가 이번에는 다릅니다.

Rebuild started...
1>------ Rebuild All started: Project: ConsoleApp1, Configuration: Debug Any CPU ------
1>  ConsoleApp1 -> E:\ConsoleApp1\bin\Debug\ConsoleApp1.dll
1>  AnyCPU "E:\ConsoleApp1\bin\Debug\" ConsoleApp1
1>  
1>  -------------------------------------------------------------------------------
1>     ROBOCOPY     ::     Robust File Copy for Windows                              
1>  -------------------------------------------------------------------------------
1>  
1>    Started : 03 12월 2020 오전 10:24:53
1>     Source - 
1>       Dest - 
1>  
1>      Files : 
1>    Options : /DCOPY:DA /COPY:DAT /R:1000000 /W:30 
1>  
1>  ------------------------------------------------------------------------------
1>  
1>EXEC : error : Invalid Parameter #1 : "E:\ConsoleApp1\bin\Debug" d:\temp ConsoleApp1.*""
1>  
1>         Simple Usage :: ROBOCOPY source destination /MIR
1>  
1>               source :: Source Directory (drive:\path or \\server\share\path).
1>          destination :: Destination Dir  (drive:\path or \\server\share\path).
1>                 /MIR :: Mirror a complete directory tree.
1>  
1>      For more usage information run ROBOCOPY /?
1>  
1>                                                            
1>  ****  /MIR can DELETE files as well as copy them !
1>C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\MSBuild\Current\Bin\Microsoft.Common.CurrentVersion.targets(5461,5): error MSB3073: The command "E:\ConsoleApp1\postBuildScript.bat  AnyCPU "E:\ConsoleApp1\bin\Debug\" ConsoleApp1
1>C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\MSBuild\Current\Bin\Microsoft.Common.CurrentVersion.targets(5461,5): error MSB3073: " exited with code -1.
========== Rebuild All: 0 succeeded, 1 failed, 0 skipped ==========

어쨌든, 이 원인을 고치려면 지난 글에 소개한 3가지 방법 중 하나를 써야 하는데,

$(ProjectDir)postBuildScript.bat "$(TargetDir)" $(TargetName)

TargetDir 경로에 공백이 포함되어 있다면 다음과 같이 마지막에 '\' 문자를 하나 더 추가한 후 겹따옴표로 감쌀 수 있습니다.

$(ProjectDir)postBuildScript.bat $(PlatformName) "$(TargetDir)\" $(TargetName)




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







[최초 등록일: ]
[최종 수정일: 12/4/2020]

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

비밀번호

댓글 작성자
 




... [61]  62  63  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12410정성태11/12/202017549디버깅 기술: 174. windbg - System.TypeLoadException 예외 분석 사례
12409정성태11/12/202019402.NET Framework: 968. C# 9.0의 Function pointer를 이용한 함수 주소 구하는 방법파일 다운로드1
12408정성태11/9/202034655도서: 시작하세요! C# 9.0 프로그래밍 [8]
12407정성태11/9/202019751.NET Framework: 967. "clr!JIT_DbgIsJustMyCode" 호출이 뭘까요?
12406정성태11/8/202020722.NET Framework: 966. C# 9.0 - (15) 최상위 문(Top-level statements) [5]파일 다운로드1
12405정성태11/8/202018589.NET Framework: 965. C# 9.0 - (14) 부분 메서드에 대한 새로운 기능(New features for partial methods)파일 다운로드1
12404정성태11/7/202019219.NET Framework: 964. C# 9.0 - (13) 모듈 이니셜라이저(Module initializers)파일 다운로드1
12403정성태11/7/202018126.NET Framework: 963. C# 9.0 - (12) foreach 루프에 대한 GetEnumerator 확장 메서드 지원(Extension GetEnumerator)파일 다운로드1
12402정성태11/7/202019593.NET Framework: 962. C# 9.0 - (11) 공변 반환 형식(Covariant return types) [1]파일 다운로드1
12401정성태11/5/202018879VS.NET IDE: 153. 닷넷 응용 프로그램에서의 "My Code" 범위와 "Enable Just My Code"의 역할 [1]
12400정성태11/5/202015107오류 유형: 679. Visual Studio - "Source Not Found" 창에 "Decompile source code" 링크가 없는 경우
12399정성태11/5/202018616.NET Framework: 961. C# 9.0 - (10) 대상으로 형식화된 조건식(Target-typed conditional expressions)파일 다운로드1
12398정성태11/4/202018143오류 유형: 678. Windows Server 2008 R2 환경에서 Powershell을 psexec로 원격 실행할 때 hang이 발생하는 문제
12397정성태11/4/202018160.NET Framework: 960. C# - 조건 연산자(?:)를 사용하는 경우 달라지는 메서드 선택 사례파일 다운로드1
12396정성태11/3/202015186VS.NET IDE: 152. Visual Studio - "Tools" / "External Tools..."에 등록된 외부 명령어에 대한 단축키 설정 방법
12395정성태11/3/202017954오류 유형: 677. SSMS로 DB 접근 시 The server principal "..." is not able to access the database "..." under the current security context.
12394정성태11/3/202015583오류 유형: 676. cacls - The Recycle Bin on ... is corrupted. Do you want to empty the Recycle Bin for this drive?
12393정성태11/3/202015254오류 유형: 675. Visual Studio - 닷넷 응용 프로그램 디버깅 시 Disassembly 창에서 BP 설정할 때 "Error while processing breakpoint." 오류
12392정성태11/2/202019813.NET Framework: 959. C# 9.0 - (9) 레코드(Records) [4]파일 다운로드1
12390정성태11/1/202019460디버깅 기술: 173. windbg - System.Configuration.ConfigurationErrorsException 예외 분석 방법
12389정성태11/1/202018577.NET Framework: 958. C# 9.0 - (8) 정적 익명 함수 (static anonymous functions)파일 다운로드1
12388정성태10/29/202017655오류 유형: 674. 어느 순간부터 닷넷 응용 프로그램 실행 시 System.Configuration.ConfigurationErrorsException 예외가 발생한다면?
12387정성태10/28/202018451.NET Framework: 957. C# - static 필드의 정보가 GC Heap에 저장될까요? [3]파일 다운로드1
12386정성태10/28/202019175Linux: 34. 사용자 정보를 함께 출력하는 리눅스의 ps 명령어 사용 방법
12385정성태10/28/202016522오류 유형: 673. openssl - req: No value provided for Subject Attribute CN, skipped
12384정성태10/27/202018862오류 유형: 672. AllowPartiallyTrustedCallers 특성이 적용된 어셈블리의 struct 멤버 메서드를 재정의하면 System.Security.VerificationException 예외 발생
... [61]  62  63  64  65  66  67  68  69  70  71  72  73  74  75  ...