출처 : http://blog.empas.com/bwangel/9314543 원문 : http://www.nullsoft.com/free/nsis/makensis.htm 주로 이용하는 것들 (NSIS/예제1, NSIS/예제2, NSIS/예제3 을 작성할 때 필요한 것 정도의 수준)위주로 정리. 좀 더 자세한 것에 대해서는 원문을 참조.
Installer attributesGeneral
Install Directory
License Page - 라이센스 관련 페이지에 쓰이는 속성들
Component Page - 설치할 항목을 선택하는 페이지에 쓰이는 속성들
Directory Page - 설치할 디렉토리를 선택하는 페이지에 쓰이는 속성들
Install Page - 실질적인 Install 화면을 표시하는 페이지에 쓰이는 속성들
UninstallUninstall 화면에 대한 설정들.
Compiler Flags
SectionSection 은 설치를 위한 일종의 하나의 모듈, 컴포넌트이다. Section 과 InstType? 은 다르다.InstType? 하나당 여러개의 Section 묶음으로 되어있는 것이다. 사용자는 각각의 Section 에 대해 활성/비활성화 함으로서 설치될 모듈들을 고를 수 있다. 단, Uninstall Section은 언인스톨을 위한 특수한 Section이다.
Function (함수)유의 사항attribute
LabelsLabel은 Goto 명령어나 기타 조건제어문들 (IfErrors?, MessageBox?, IfFileExists?, StrCmp? 등)을 위해 이용한다.
Label 은 반드시 Section 이나 Function 내에 존재해야 한다. Label 은 해당 Section 과 Function 내에서만 그 범위를 가진다. 선언은 간단하다. MyLabel: InstructionsBasic
Registry/INI
Advanced
Branching/etc
File/directory i/o
Misc
StringsStack
IntegersRebootUninstall
Variablesmodifiable variables that are usable in Instructions
constant variables that are usable in Instructions and InstallDir?
usable anywhere in a stringUninstall SectionSection "Uninstall" Callback functionsInstall callbackUninstall callbackCompiler utility commandsCompiler defines / conditional compilation |
'NSIS'에 해당되는 글 3건
NSIS는 이미 알고 있듯이 스크립트로 만들어서 컴파일 하는 과정을 거치게 되어 있다. 아주 복잡한 인스톨 프로그램까지 만들 수 있지만, 천리길도 한 걸음부터라고 가장 기본부터 하나씩 정리해볼 생각이다. 누군가에게 도움이 되기를 바라는 마음도 있지만, 나 자신의 알고 있음을 한번 더 정리하는것도 크니 꾸준하게 정리해서 목표는 현재 곰플레이어 인스톨 하는 수준까지 만드는게 목표이다.
- NSIS를 다운 받자
http://nsis.sourceforge.net/Main_Page
- 쓸만한 텍스트 에디터를 사용한다. 내가 생각하기에 제일 쉬운 에디터는 HM NIS Edit이다.
http://hmne.sourceforge.net/
둘 다 인스톨 했으면 HM NIS Edit 을 실행한다. 이제 필요한 스크립트를 만들 준비가 다 되었다. HM NIS Edit의 "파일" 메뉴를 보면 위에서부터 네 개의 메뉴가 있다. 일반적인 에디터와 다르게 "스크립트 작성 마법사"를 사용하면 간단하게 인스톨 프로그램을 작성할 수 있다. "인스톨-옵션 파일 만들기"는 플러그인을 활용하여 인스톨 중에 사용자로부터 선택을 받아서 인스톨 하는 프로그램을 만들때 사용할 수 있다. 처음에는 그냥 "빈 스크립트 만들기" 메뉴를 이용하여 전체적인 스크립트를 다 만들어 보도록 하겠다.
1. Commands
NSIS 의 스크립트는 기본적으로 한 줄에 하나의 명령을 쓰게 되어 있다. 즉 한번에 해석되는 것이 한 줄 단위라는 것이다. 일반적으로 C의 경우 세미콜론(;) 단위로 실행되게 되어 있는데, NSIS는 줄 단위로 해석된다고 생각하면 된다. 만약 한 줄에 썼을때 에디터에서 보기도 힘들고 할 경우에는 끊고 싶은 부분에서 back-slash(\)를 쓰면 다음 줄까지 연결해서 해석 한다.
형태는 'command [parameters]' 로 사용한다.
예를 들자면
2. Comments
스크립트 언어 이므로 나중에 안 헷갈리기 위해서 가능한 주석을 달아 놓는게 좋다. 주석의 경우 세 가지 방법으로 주석을 나타낼 수 있다. ; 또는 # 을 사용할 경우 이 두 기호 이후부터 줄 끝까지를 주석으로 해석한다. 만약 한꺼번에 여러 줄을 주석으로 처리해야 할 경우는 C와 똑같은 주석을 쓸 수 있다. 즉 /* */ 로 여러 줄을 한꺼번에 주석 처리할 수 있는 것이다. 만약 ; 나 # 을 파라메터로 넘겨줘야 할 경우는 " " 로 감싸면 된다.
3. Plug-ins
NSIS에서 플러그인 이란 자체적으로 제공하지 않는 기능을 사용자가 직접 추가 하기 위한 방법을 제공하는 것이다. 이런 플러그인에 있는 command를 사용하기 위해서는
4. Numbers
숫자를 파라메터로 넘겨 줄 경우에는 10진수, 8진수(시작을 o로 할 경우), 16진수(시작을 ox)로 넘겨 줄 수 있다.
5. Strings
문자열을 표시할때는 "와 "로 감싸면 공백을 포함한 문자열을 만들 수 있다. " 대신에 ' 또는 ` 등을 사용할 수 있다. 또한 문자열 안에서 "를 표시하기 위해서는 $\ 를 사용하면 된다.
-
-
MessageBox MB_OK "$\"A quote from a wise man$\" said the wise man"; "를 문자열 내에 포함
-
문자열내에서 특별히 NSIS에서 변경할 수 없게 만들어 놓은 것들이 있다.
$$ $를 문자열 내에 표시할 경우 사용한다.
$\r 케리지 리턴을 표시한다
$\n 다음 줄을 표시한다.
$\t 탭을 표시한다.
위의 정확한 뜻은 예제를 하면서 한꺼번에 설명하도록 하겠다.
6. Variables
프로그래밍이 가능하므로 변수를 사용할 수 있다. 변수는 항상 시작을 $로 시작해야 한다. 그리고 사용하기전에 선언되어야 한다. 즉 실제로 사용하기전에 Var 라는 Command로 먼저 선언하고 사용해야 한다. Variables에 대해서도 뒤에 좀 더 자세하게 살펴 보겠다.
7. Long commands
명령어를 한 줄에 적다가 너무 길어지면 에디터에서 한 눈에 들어 오지 않으므로 여러 줄에 나누어서 작성하는 경우가 있다. 이럴때는 back-slash(\)를 사용하면 된다. 필요한 연결은 알아서 해준다.
"$INSTDIR\source\zip2exe\zip2exe.dsw"
MessageBox MB_YESNO|MB_ICONQUESTION \
"Do you want to remove all files in the folder? \
(If you have anything you created that you want \
to keep, click No)" \
IDNO NoRemoveLabel
위에 5번을 보면 주석문에도 \ 를 써서 다음 줄까지 주석문 임을 알릴 수 있지만 헷갈릴 수 있으므로 주석문에는 사용하지 않는게 좋다.
8. Configuration file
뒤에 따로 설명할 기회가 있을때 하겠다.
이상은 NSIS 메뉴얼 중에 Chapter 4 에 있는 Script File Format 이라는 부분에 있는 내용을 설명한 것이다. 이것만 가지고는 도대체 뭘 할지 알 수 없으니 예제를 하나 돌리면서 생각을 해보자
HM NIS Edit(앞으로 일반적으로 에디터라고 하면 이 에디터를 지칭한다) 에 위와 같이 글을 쓰고 나서 저장을 한다. 저장은 원하는 이름으로 저장하면 된다. 위에서 다른 부분은 신경쓰지 말고 현재는 command 중에서 outfile 에 파라메터로 주어진 값이 실제로 만들어지는 인스톨 프로그램이라는 것을 생각하자. 여기서는 "hello world.exe"로 만들었다. Section은 나중에 설명할테니 지금은 저렇게 Section 으로 시작하고 SectionEnd로 끝난다는 것만 기억하면 되겠다.
MessageBox의 경우 위에서 이미 설명한 것을 그대로 복사해서 만들었으니 실제로 실행했을때 어떻게 되는지 한번 보도록 하자. 실행을 하기 위해서는 먼저 컴파일을 하고 실행해야 하므로 아래와 같이 메뉴중에 NSIS 아래에 스크립트 컴파일 을 선택하면 컴파일이 되며, 컴파일 및 실행 을 선택하면 컴파일을 하고 자동으로 실행까지 해 주는 것이다. 일단 먼저 컴파일만 해보면 스크립트 파일을 저장한 폴더에 "hello world.exe" 파일이 생성된 것을 볼 수 있다. 이것을 한번 실행시켜 보자. 실행시키면 아래 그림과 같이 나오는 것을 볼 수 있다.
아래 그림에서 앞쪽에 나온 메시지 박스를 잘 보면 스크립트에서 적어 놓은데로 충실하게 출력을 하고 있는 것을 알 수 있다. 맨 앞에 물음표 아이콘이 바로 MB_ICONQUESTION 으로 지정된 것이며, MB_YESNO 가 버튼에서 예, 아니오 버튼이 나온 것이다. 그리고 문자열로 넘겨준 것들이 에디터에 보기 편하게 세줄로 나눈것이지 실제로 메시지 박스로 넘어 갈때는 한 줄로 해석되는 것을 알 수 있다.
간단하게 스크립트를 작성해서 어떻게 동작하는지를 알아 보았다. NSIS는 공개 소프트웨어라서 많은 사람들이 문서화를 해놓았다. 물론 NSIS 홈페이지에도 많은 문서가 있다. 웹에서 찾아 보면 더 많은 문서를 찾아 볼 수 있을 것이다. 여기에 적는 대부분의 내용은 NSIS에 있는 메뉴얼을 중심으로 필요한 내용만 뽑아서 예제를 많이 넣어서 이해하기 쉽게 적을려고 한다.
다음에는 Variables에 대해서 좀 더 자세하게 알아 보도록 하자.
참, 위에 메시지 박스에 적혀 있는 문자열에 $\r$\n 을 포함하여 어떻게 되는지 한번 보는 것도 좋은 경험이 될듯하다.
정말 적기 힘드네요...
물론 이렇게 노가다로 일일히 안해도 됩니다.
HM NIS Edit 라는 스크립트 에디터 툴을 쓰시거나 Venis 라는 툴을 사용하셔도 됩니다.
하지만 한번 만들어 놓은 스크립트는 특별한 스크립트가 들어가지 않는한 변하질 않기 때문에 저 같은 경우 만들어 놓은걸 복사해서 일부분만 고쳐서 사용을 하죠...
아래 설치 스크립트에 대한 부분에 주석을 달아 놓았으니 참고하세요...^^
; 배포 프로그램 이름 지정
!define APPNAME "FreemontEncoder"
; 배포 프로그램의 이름 및 버전 표시 (실제 배포 프로그램 실행 시 화면에 표시되는 이름)
!define APPNAMEANDVERSION "FreemontEncoder 2.0"
<?xml:namespace prefix = o />
; Main Install settings
; 프로그램 이름 : 위에미리 정의한 APPNAMEANDVERSION을 지정한다.
Name "${APPNAMEANDVERSION}"
; 기본 설치 경로
InstallDir"$PROGRAMFILES\Freemont\Freemont Encoder"
; 배포 프로그램 정보가 등록될 레지스트리 경로
InstallDirRegKey HKLM"Software\${APPNAME}" ""
; 컴파일 후 배포 프로그램이 출력될 경로 지정
OutFile "C:\FMSSetup.exe"
; Modern interface settings
; UI를 Modern 으로설정한다.
!include "MUI.nsh"
; 경고 페이지 및 설치 종료 후 바로 실행할 파일 지정
!define MUI_ABORTWARNING
!define MUI_FINISHPAGE_RUN"$INSTDIR\Freemont Encoder.exe"
; 설치 및 삭제 아이콘 지정(주의 : 반드시 설치와 삭제 아이콘은 포멧이 일치해야 한다.)
!define MUI_ICON "res\FMS.ico"
!define MUI_UNICON"res\UnInstall.ico"
; 매크로 페이지 삽입
; 환영 메시지 페이지
!insertmacro MUI_PAGE_WELCOME
; 설치 경로 선택 페이지
!insertmacro MUI_PAGE_DIRECTORY
; 설치 상태 페이지 : 설치퍼센트 표시되는 페이지
!insertmacro MUI_PAGE_INSTFILES
; 완료 페이지
!insertmacro MUI_PAGE_FINISH
; 삭제 확인 페이지
!insertmacro MUI_UNPAGE_CONFIRM
; 삭제 상태 페이지 : 삭제퍼센트 표시되는 페이지
!insertmacro MUI_UNPAGE_INSTFILES
; Set languages (first is default language)
; 설치 시 표시 가능한 언어를 설정한다.
; 처음에 설정한 언어가 기본 언어가 된다.
!insertmacro MUI_LANGUAGE"Korean"
!insertmacro MUI_LANGUAGE"English"
!insertmacro MUI_RESERVEFILE_LANGDLL
; 설치 섹션
Section "Freemont Encoder"Section1
;설치 경로에 동일한 파일 존재 시 덮어씌우라는 의미
SetOverwriteon
;파일이 설치될 경로를 위에서 지정한 INSTDIR 로 한다.
SetOutPath"$INSTDIR\"
;INSTDIR 에 설치할 로컬 파일 경로를 지정한다.
File"C\FMS\release\Freemont Encoder.exe"
File"C\FMS\release\config.ini"
;파일이 설치될 경로를 windows\system32로 한다.
;일부 dll 이나 필수 파일 등등…
SetOutPath"$SYSDIR"
;windows\system32 에 설치할 로컬 파일 경로를 지정한다.
File"C\FMS\release\FLogo.ax"
;dll 이나 ocx, ax 와 같이 레지스트리에 등록이 필요한 경우 (cmd : regsvr32.exe)
RegDLL"$SYSDIR\FLogo.ax"
;바로 가기를 등록한다.
;바탕화면에 바로 가기 등록
CreateShortCut"$DESKTOP\Freemont Encoder.lnk" "$INSTDIR\FreemontEncoder.exe"
;시작 – 프로그램에 바로 가기 등록
CreateDirectory"$SMPROGRAMS\Freemont"
CreateShortCut"$SMPROGRAMS\Freemont\Freemont Encoder\Freemont Encoder.lnk""$INSTDIR\Freemont Encoder.exe"
CreateShortCut"$SMPROGRAMS\Freemont\Freemont Encoder\Uninstall.lnk""$INSTDIR\uninstall.exe"
SectionEnd
; 종료 섹션
Section -FinishSection
;종료 섹션은 특별한 일이 없는 이상 아래와 같이 설치하는 프로그램에 대한 정보를 레지스트리에 저장한다.
WriteRegStrHKLM "Software\${APPNAME}" "" "$INSTDIR"
WriteRegStrHKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\${APPNAME}""DisplayName" "${APPNAME}"
WriteRegStrHKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\${APPNAME}""UninstallString" "$INSTDIR\uninstall.exe"
WriteUninstaller"$INSTDIR\uninstall.exe"
SectionEnd
; Modern install component descriptions
!insertmacro MUI_FUNCTION_DESCRIPTION_BEGIN
!insertmacroMUI_DESCRIPTION_TEXT ${Section1} ""
!insertmacro MUI_FUNCTION_DESCRIPTION_END
; 삭제 섹션
Section Uninstall
;설치 정보 레지스트리를 삭제한다
DeleteRegKeyHKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\${APPNAME}"
DeleteRegKeyHKLM "SOFTWARE\${APPNAME}"
;파일 삭제
;삭제 파일 삭제
Delete"$INSTDIR\uninstall.exe"
;바로 가기 삭제
Delete"$DESKTOP\Freemont Encoder.lnk"
Delete"$SMPROGRAMS\Freemont\Freemont Encoder.lnk"
Delete"$SMPROGRAMS\Freemont\Uninstall.lnk"
;설치 파일 삭제
Delete"$INSTDIR\Freemont Encoder.exe"
Delete"$INSTDIR\config.ini"
;windows\system32 에 설치된 파일에 대한 레지스트리 삭제 (cmd : regsvr32/u)
UnRegDLL"$SYSDIR\FLogo.ax"
;레지스트리에서 삭제된 파일 삭제
Delete"$SYSDIR\FLogo.ax"
;바로 가기 및 설치 디렉토리 삭제
RMDir"$SMPROGRAMS\Freemont\Freemont Encoder"
RMDir"$INSTDIR\"
SectionEnd
; 배포 프로그램 초기화 함수
Function .onInit
;설치 언어 선택 페이지를 표시한다.
!insertmacroMUI_LANGDLL_DISPLAY
FunctionEnd
[출처] NSIS - 설치 스크립트 설명 (INT) |작성자 예산계원