Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

하나의 T4 템플릿으로 여러 개의 소스코드 파일을 자동으로 생성하는 방법

T4를 이용한 자동 생성 코드는 예전에 한번 소개해 드렸습니다.

T4 를 이용한 INotifyPropertyChanged 코드 자동 생성
; https://www.sysnet.pe.kr/2/0/1619

그런데, 때로는 출력 파일을 다중으로 할 필요가 있습니다. 다행히, 이에 대한 방법은 아래의 글에 전부 공개되어 있습니다.

How to generate multiple outputs from single T4 template
; http://www.olegsych.com/2008/03/how-to-generate-multiple-outputs-from-single-t4-template/

좀 복잡하니, ^^ 간단하게 정리해 볼까요?

우선 "How to generate multiple outputs from single T4 template" 글에 공개된 예제 프로젝트를 다운로드 받습니다.

Source code 
; http://www.olegsych.com/wp-content/uploads/2008/03/multioutputpot.zip

이 압축 파일의 내용 중에 MultiOutput.tt 파일만 필요하니 그것만 복사해서 여러분들의 솔루션에 추가해 줍니다. MultiOutput.tt 파일의 경우 스스로에 대한 소스 코드 생성이 목적은 아니므로 "Custom Tool"의 내용을 지워줍니다.

t4_multiple_output_1.png

자, 이제 소스 코드를 생성할 용도의 tt 파일을 원하는 만큼 추가해줍니다. 여기서는 csgen.tt, jsgen.tt 2개의 파일을 추가합니다. 2개 모두 마찬가지로 "Custom Tool"의 내용을 지워줍니다.

예를 들어, 아래는 jsgen.tt 파일의 내용이고,

<#@ template language="C#" #>
<#@ output extension=".js" #>
<#@ import namespace="System.Runtime.Remoting.Messaging" #>

var <#= Parameter #> = {
}

<#+
    string Parameter
    {
        get 
        { 
            string result = (string)CallContext.GetData("Parameter");
            if (result == null)
                result = string.Empty;
            return result; 
        }
    }
#>

다음은 csgen.tt 파일입니다.

<#@ template language="C#" #>
<#@ output extension=".cs" #>
<#@ import namespace="System.Runtime.Remoting.Messaging" #>

public class <#= Parameter #>
{
}

<#+
    string Parameter
    {
        get 
        { 
            string result = (string)CallContext.GetData("Parameter");
            if (result == null)
                result = string.Empty;
            return result; 
        }
    }
#>

마지막으로 2개의 tt 파일과 MultiOutput.tt에서 제공되는 메서드를 이용해 다중 파일을 생성하는 tt 파일을 만들어 줍니다.

<#@ import namespace="System.Runtime.Remoting.Messaging" #>
<#@ include file="MultiOutput.tt" #>
<#
    CallContext.SetData("Parameter", "MyType"); // csgen.tt, jsgen.tt 내부에서 활용할 데이터를 전달

    ProcessTemplate("csgen.tt", "DataObject.cs");
    ProcessTemplate("jsgen.tt", "DataObject.js");

    DeleteOldOutputs();
#>

이번 tt 파일은 소스 코드를 생성할 것이므로 Custom Tool의 내용을 지워서는 안됩니다. 이렇게 만들고 tt 파일을 저장하면 하위에 다음과 같이 3개의 파일이 생성됩니다

t4_multiple_output_2.png

이 중에서 DataObject.cs, DataObject.js 파일은 각각 csgen.tt, jsgen.tt에 의해 생성된 것이고 DataObjectGen.js 파일은 본래의 DataObjectGen.tt에 의해 성성된 것입니다. (현재는 DataObjectGen.tt에 별다른 출력 내용이 없으므로 아무것도 포함하고 있지 않습니다.)




그리하여, "T4 를 이용한 INotifyPropertyChanged 코드 자동 생성" 글과 이번 글의 내용을 합치면 어떻게 될까요?

단일 XML 하나에 정의된 Data Object 스키마를 통해 다중 언어로의 구현 타입으로 자동으로 출력하는 것이 가능합니다. ^^

(첨부된 파일은 위의 실습을 포함한 프로젝트입니다.)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/24/2014]

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

비밀번호

댓글 작성자
 



2014-05-26 11시01분
[spowner] 와우! 브라보!
[guest]

1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13372정성태6/15/20233359개발 환경 구성: 682. SQL Server TLS 통신을 위해 사용되는 키 길이 확인 방법
13371정성태6/15/20233470개발 환경 구성: 681. openssl - 인증서 버전(V1 / V3)
13370정성태6/14/20233615개발 환경 구성: 680. C# - Ubuntu + Microsoft.Data.SqlClient + SQL Server 2008 R2 연결 방법 - TLS 1.2 지원
13369정성태6/13/20233425개발 환경 구성: 679. PyCharm(을 비롯해 JetBrains에 속한 여타) IDE에서 내부 Window들의 탭이 없어진 경우
13368정성태6/13/20233574개발 환경 구성: 678. openssl로 생성한 인증서를 SQL Server의 암호화 인증서로 설정하는 방법
13367정성태6/10/20233744오류 유형: 864. openssl로 만든 pfx 인증서를 Windows Server 2016 이하에서 등록 시 "The password you entered is incorrect" 오류 발생
13366정성태6/10/20233505.NET Framework: 2128. C# - 윈도우 시스템에서 지원하는 암호화 목록(Cipher Suites) 나열파일 다운로드1
13365정성태6/8/20233175오류 유형: 863. MODIFY FILE encountered operating system error 112(failed to retrieve text for this error. Reason: 15105)
13364정성태6/8/20234046.NET Framework: 2127. C# - Ubuntu + Microsoft.Data.SqlClient + SQL Server 2008 R2 연결 방법 [1]
13363정성태6/7/20233609스크립트: 49. 파이썬 - "Transformers (신경망 언어모델 라이브러리) 강좌" - 1장 2절 코드 실행 결과
13362정성태6/1/20233577.NET Framework: 2126. C# - 서버 측의 요청 제어 (Microsoft.AspNetCore.RateLimiting)파일 다운로드1
13361정성태5/31/20233924오류 유형: 862. Facebook - ASP.NET/WebClient 사용 시 graph.facebook.com/me 호출에 대해 403 Forbidden 오류
13360정성태5/31/20233267오류 유형: 861. WSL/docker - failed to start shim: start failed: io.containerd.runc.v2: create new shim socket
13359정성태5/19/20233589오류 유형: 860. Docker Desktop - k8s 초기화 무한 반복한다면?
13358정성태5/17/20234053.NET Framework: 2125. C# - Semantic Kernel의 Semantic Memory 사용 예제 [1]파일 다운로드1
13357정성태5/16/20233880.NET Framework: 2124. C# - Semantic Kernel의 Planner 사용 예제파일 다운로드1
13356정성태5/15/20234207DDK: 10. Device Driver 테스트 설치 관련 오류 (Code 37, Code 31) 및 인증서 관련 정리
13355정성태5/12/20234126.NET Framework: 2123. C# - Semantic Kernel의 ChatGPT 대화 구현 [1]파일 다운로드1
13354정성태5/12/20234268.NET Framework: 2122. C# - "Use Unicode UTF-8 for worldwide language support" 설정을 한 경우, 한글 입력이 '\0' 문자로 처리
13352정성태5/12/20233960.NET Framework: 2121. C# - Semantic Kernel의 대화 문맥 유지파일 다운로드1
13351정성태5/11/20234426VS.NET IDE: 185. Visual Studio - 원격 Docker container 내에 실행 중인 응용 프로그램에 대한 디버깅 [1]
13350정성태5/11/20233724오류 유형: 859. Windows Date and Time - Unable to continue. You do not have permission to perform this task
13349정성태5/11/20234066.NET Framework: 2120. C# - Semantic Kernel의 Skill과 Function 사용 예제파일 다운로드1
13348정성태5/10/20233961.NET Framework: 2119. C# - Semantic Kernel의 "Basic Loading of the Kernel" 예제
13347정성태5/10/20234346.NET Framework: 2118. C# - Semantic Kernel의 Prompt chaining 예제파일 다운로드1
13346정성태5/10/20234192오류 유형: 858. RDP 원격 환경과 로컬 PC 간의 Ctrl+C, Ctrl+V 복사가 안 되는 문제
1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...