Microsoft MVP성태의 닷넷 이야기
.NET Framework: 126.3. CAG - 간단한 유형의 모듈 제작 [링크 복사], [링크+제목 복사],
조회: 24891
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
부모글 보이기/감추기
(연관된 글이 3개 있습니다.)

간단한 유형의 모듈 제작


이번 글에서는 간단하게 모듈 추가 절차를 알아볼 텐데, 전체적인 내용은 다음의 글을 정리한 것입니다.

Composite Application Guidance for WPF - June 2008
How to: Create a Module
; https://docs.microsoft.com/en-us/previous-versions/msp-n-p/ff921345(v=pandp.10)




우선, 모듈이란 뭘까요? 위의 링크에서 제공되는 글의 서두에서 그 정의를 찾아볼 수 있는데요.

A module encapsulates a set of related concerns. Modules are independently developed and deployed, and they interact with each other to create the application.



비록 모듈의 정의가 그러하지만, 현실적으로 CAG 프레임워크로 보자면 Unity Framework의 관리하에 놓인 어셈블리라고 보시면 됩니다. 따라서, 모듈로 정의된 어셈블리는 Unity에 의해서 로드되면서 Reflection 등의 과정을 거쳐서 IoC와 같은 헤택을 받게되는 것입니다.

실제로 추가를 해보면서 이해를 해보는 것도 좋겠지요.

"모듈"로 동작되는 어셈블리를 만들기 위해 "[그림 1]"과 같이 "StatusBar"라는 이름으로 프로젝트를 추가합니다.

[그림 1: StatusBar 프로젝트 추가]
impl_cag_app_step_by_step_chapter3_1.png

다음의 프로젝트 참조를 참조합니다.

  • PresentationCore.dll
  • PresentationFramework.dll
  • WindowsBase.dll
  • Microsoft.Practices.Composite.dll
  • Microsoft.Practices.Composite.Presentation.dll

{ModuleName}Module.cs와 같은 이름 규칙에 따라 새로운 Module 타입을 "StatusBarModule.cs"라는 이름으로 추가하고 코드는 다음과 같이 작성해 줍니다.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Practices.Composite.Modularity;
using Microsoft.Practices.Composite.Regions;

namespace StatusBar
{
    public class StatusBarModule : IModule
    {
        private readonly IRegionManager regionManager;

        public StatusBarModule(IRegionManager regionManager)
        {
            this.regionManager = regionManager;
        }

        public void Initialize()
        {
            this.regionManager.Regions["StatusRegion"].Add(new DefaultStatusBar());
        }
    }
}

우선, StatusBarModule 생성자를 보시면 IRegionManager 인터페이스가 넘어오는 것을 볼 수 있습니다. 실제 인스턴스 타입은 "Microsoft.Practices.Composite.Presentation.Regions.RegionManager"로 정의된 것인데, 런타임 시에 Unity에 의해서 기 등록된 IRegionManager의 인스턴스가 주입(Injection)되어 넘어옵니다.

즉, 만약 Unity에 의해서 위의 모듈이 로드되지 않고 단순히 "StatusBarModule test = new StatusBarModule();"과 같은 식으로 생성을 했다면 - 다시 말해서 Unity의 "관리"에 놓이지 않는다면 - IRegionManager 등의 값은 당연히 배정되지 않습니다.

그다음으로 Initialize 메서드를 살펴보면,

이와 같이 모듈 내에서는 해당 모듈이 제공하는 View / Service를 등록해 주면 되는데, 위의 코드에서는 Region 영역에 "DefaultStatusBar" 뷰를 하나 등록하고 있습니다.

본론에서 벗어나지 않기 위해 DefaultStatusBar.xaml은 다음과 같이 간단하게 구현하는 것으로 끝내겠습니다.

<UserControl x:Class="StatusBar.DefaultStatusBar"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <Grid>
        <Button MinWidth="80" MinHeight="25" Name="button1">Button</Button>
    </Grid>
</UserControl>

이것으로, 간단한 유형의 모듈 하나가 완성되었습니다. 이제 지금까지 새롭게 만들어진 모듈을 CAG로 하여금 로드를 하라고 시켜야 할 텐데요.

"이전의 글"에서 Bootstrapper.GetModuleCatalog 안에 DirectoryModuleCatalog를 사용했기 때문에 이렇게 만들어진 Module의 출력 경로를 "$(SolutionDir)\bin\Debug\Modules"로 설정해 주면 되는데, 이번 경우에는 코드로도 추가하는 방법과 폴더를 지정하는 방법을 모두 사용할 수 있도록 하는 예시를 보여주기 위해 StatusBar 모듈을 직접 참조해서 코드로 추가해 보겠습니다.

===== Bootstrapper.cs =====

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Practices.Composite.UnityExtensions;
using System.Windows;
using Microsoft.Practices.Composite.Modularity;
using System.IO;
using StatusBar;

namespace DevToolManager
{
    public class Bootstrapper : UnityBootstrapper
    {
        protected override DependencyObject CreateShell()
        {
            Shell shell = Container.Resolve<Shell>();
            shell.Show();
            return shell;
        }

        protected override Microsoft.Practices.Composite.Modularity.IModuleCatalog GetModuleCatalog()
        {
            string modulePath = @".\Modules";
            if (Directory.Exists(modulePath) == false)
            {
                Directory.CreateDirectory(modulePath);
            }

            DirectoryModuleCatalog catalog = new DirectoryModuleCatalog() { ModulePath = modulePath };
            catalog.AddModule(typeof(StatusBarModule));
            return catalog;
        }
    }
}

간단하지요! 단순히 DirectoryModuleCatalog 인스턴스에서 정적 참조한 어셈블리에 정의된 모듈 타입을 AddModule로 전달해 주면 됩니다. 이렇게 해서 실행시키면 버튼 하나가 있는 WPF 응용 프로그램이 실행되는 것을 확인할 수 있습니다.

[그림 2: StatusBar 모듈이 반영된 실행 화면]
impl_cag_app_step_by_step_chapter3_2.png

다운로드: 예제 솔루션



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/17/2021]

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

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  [127]  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
2880정성태3/7/201521680개발 환경 구성: 260. C# Code Coverage 도구 - Semantic Designs 소개
2879정성태3/3/201526693개발 환경 구성: 259. Visual Studio 없이 Visual C++ 컴파일하는 방법
2878정성태2/28/201527593.NET Framework: 503. == 연산자보다는 Equals 메서드의 호출이 더 권장됩니다. [3]파일 다운로드1
2877정성태2/28/201521757.NET Framework: 502. 연산자 재정의(operator overloading)와 메서드 재정의(method overriding)의 다른 점 - 가상 함수 호출 여부 [3]파일 다운로드1
2876정성태2/27/201524218VS.NET IDE: 98. IntegraStudio - Visual Studio에서 Java 프로그램 개발
2875정성태2/26/201522843디버깅 기술: 72. Visual Studio 2013에서의 sos.dll 사용 제한
2874정성태2/26/201519581디버깅 기술: 71. windbg + 닷넷 디버깅 (2) - null 체크 패턴
2873정성태2/25/201537098.NET Framework: 501. FtpWebRequest 타입을 이용해 FTP 파일 업로드 [4]파일 다운로드1
2872정성태2/25/201521250디버깅 기술: 70. windbg + 닷넷 디버깅 (1) - 배열 인덱스 사용 패턴
2871정성태2/24/201525212개발 환경 구성: 258. 윈도우 8.1에서 방화벽과 함께 FTP 서버 여는 (하지만, 권장하지 않는) 방법 [1]
2870정성태2/24/201526359개발 환경 구성: 257. 윈도우 8.1에서 방화벽과 함께 FTP 서버 여는 방법
2869정성태2/23/201520317.NET Framework: 500. struct로 정의한 값 형식(Value Type)의 경우 Equals 재정의를 권장합니다.파일 다운로드1
2868정성태2/23/201524827VS.NET IDE: 97. Visual C++ 프로젝트 디버깅 시에 Step-Into(F11) 동작이 원치 않는 함수로 진입하는 것을 막는 방법 [2]
2867정성태2/23/201518548오류 유형: 273. File History - Failed to initiate user data backup (error 80070005)
2866정성태2/23/201520375오류 유형: 272. WAT080 : Failed to locate the Windows Azure SDK. Please make sure the Windows Azure SDK v2.1 is installed.
1868정성태2/20/201517679오류 유형: 271. The type '...' cannot be used as type parameter 'TContext' in the generic type or method 'System.ServiceModel.DomainServices.EntityFramework.LinqToEntitiesDomainService&lt;T&gt;
1866정성태2/20/201518607오류 유형: 270. "aspnet_regiis -i" 실행 시 0x00000006 오류 해결 방법
1865정성태2/20/201519902.NET Framework: 499. 특정 닷넷 프레임워크 버전 이후부터 제공되는 타입을 사용해야 한다면?
1864정성태2/18/201524867.NET Framework: 498. C#으로 간단하게 만들어 본 ASCII Art 프로그램 [2]파일 다운로드1
1862정성태2/18/201528718.NET Framework: 497. .NET Garbage Collection에 대한 정리 [6]
1861정성태2/18/201524066.NET Framework: 496. 마우스 커서가 놓인 지점의 문자열 얻는 방법 [1]파일 다운로드1
1860정성태2/18/201523886.NET Framework: 495. CorElementType의 요소 값 설명파일 다운로드1
1859정성태2/17/201524302Windows: 106. 컴퓨터를 재부팅하면 절전(Power Saver) 전원 모드로 돌아가는 경우
1858정성태2/16/201534267Windows: 105. 자동으로 로그아웃/잠김 화면 상태로 전환된다면? [2]
1857정성태2/16/201522286.NET Framework: 494. 값(struct) 형식의 제네릭(Generic) 타입이 박싱되는 경우의 메타데이터 토큰 값파일 다운로드1
1856정성태2/15/201521262.NET Framework: 493. TypeRef 메타테이블에 등록되는 타입의 조건파일 다운로드1
... 121  122  123  124  125  126  [127]  128  129  130  131  132  133  134  135  ...