当前位置:文档之家› Inno Setup使用教程

Inno Setup使用教程

Inno Setup使用教程
Inno Setup使用教程

Inno Setup使用教程

如何使用:

文档约定

创建安装程序

创建脚本

段内参数

一些常量

公共参数

安装脚本段

[Setup] 段

[Dirs] 段

[Files] 段

[Icons] 段

[INI] 段

[InstallDelete] 段

[Messages] 段

[Registry] 段

[Run] 段

[UninstallDelete] 段

[UninstallRun] 段

其它问题:

其它注意事项

在命令行执行编译器

安装命令行参数

文档约定

"Windows 95/NT 4+"

这是 Windows 95, 98, NT 4.0, 2000 以及更高版本的简称。

"Windows 98/NT 4+"

这是 Windows 98, NT 4.0, 2000 以及更高版本的简称。

"Windows NT"

无论何时提及 Windows NT,除非有其他说明,他总是包括 Windows 2000(亦即 NT 5.0)。

等宽字体

当你看见文档里的等宽字体,说明他是脚本文件的引用。

创建安装程序

安装程序是以脚本(script)的方式来创建的。(不要一看见“脚本”这个术语就害怕,你只需要花上几分钟的时间就可以掌握它的要领!)

该脚本文件的扩展名是“.iss”(意思是 Inno Setup Script)。脚本文件控制了安装程序的每一个外观界面。它指定了哪些文件要被复制及其位置,创建什么应用程序图标和为它们命名等等。

脚本文件通常可以用安装编译程序内建的编辑器来创建和编辑,完成以后写入脚本文件,下一步也是最后一步是在安装编译器的菜单里选择“编译”(Compile)。创建完成以后该干什么呢?准备运行这个基于该脚本的安装程序吧!默认情况下,这个文件被创建在脚本文件所在文件夹的“OUTPUT”子文件夹下。

要了解脚本文件是如何工作的,运行安装编译器,单击“文件\打开”选择一个位于 Inno Setup 文件夹

的 Samples 子文件夹下的示例脚本文件。(用这些示例文件作为你自己的脚本文件的模板可能示非常有用处的。)

参见

创建脚本

创建脚本

一个 Inno Setup 脚本是一个简单的 ASCII 文本文件。它的格式非常类似于 .INI 文件,如果你有这方面的经验你就会发现学习起来有多么的容易。

就象下面的示例所显示的,脚本文件包括“段”(sections)和“项”(entries)。段名的两边始终有一对中括号“[]”,在 [Setup] 段中的每一项包括一个关键字和他的值,关键字和值用等于号“=”连接在一起。下面的这个示例说明了脚本文件是如何被组织的:

[在这里添加段名,例如 Setup]

这是一个关键字=这是一个值

这是其它的关键字=这是其它的值

[在这里添加段名,例如 Files]

Source: "MYPROG.EXE"; DestDir: "{app}"

你也可以在你的脚本文件中加上注释(这些注释将会被安装编译器忽略),方法是在每一行注释的行首加上一个分号“;”,例如:

; 这是一行注释,我可以在这里写上提醒我的内容...

参见

段内参数

一些常量

[Setup] 段

[Dirs] 段

[Files] 段

[Icons] 段

[INI] 段

[InstallDelete] 段

[Messages] 段

[Registry] 段

[Run] 段

[UninstallDelete] 段

[UninstallRun] 段

段内参数

脚本文件中的所有的段,除了[Setup],都是以行位单位,每行分为若干个参数。下面是一个 [Files] 段的示例:

[Files]

Source: "MYPROG.EXE"; DestDir: "{app}"

Source: "MYPROG.HLP"; DestDir: "{app}"

Source: "README.TXT"; DestDir: "{app}"; Flags: isreadme

每一个参数都有一个名称,后面紧跟一个冒号,然后是它的值。除非有其它的说明,参数是可选的,如果参数没有指定则取它们的默认值。如果一行内有多个参数则用分号将其分开(还可以加一个空格符),他们可以按任何顺序排列出来。

参数的值多数情况下是用引号扩起来("),但使用引号也是可选的。然而如果这个参数的值里面的前导符号或者后缀符号是空格的话就必须加上引号了。另外需要说明的是使用内嵌的分号和引号,要插入一个引号则使用两个连续的引号来代替。例如,下面的示例:

"This "" contains "" embedded "" quotes"

""""

安装程序编译器将会视为:

This " contains " embedded " quotes

"

一些常量

多数的脚本项都可以在它们的内部嵌入“常量(constants)”,它们总是被一对大括号({ })扩起来的。当安装程序被启动的时候,这些常量将被转换成其真实的值,这依赖于用户的选择和系统配置,例如,{win} 这个常量在绝大多数的系统当中将被转换成“C:\WINDOWS”。

字符“{”被视为一个常量的起始标记,如果你想获得的是它的真实字符,那么你必须使用两个连续的“{”字符。

如果一个常量的后面紧跟着一个反斜杠,而此时这个常量被转换成其真实值的结尾也是一个反斜杠时,Inno Setup 会自动的删除一个反斜杠,这样处理的明显的好处是如果这个常量指向了“C:\”,{常量名}\file 就会被正确的转换成“C:\file”而不是“C:\\file”。然而如果你想要防止这种事情的发生,那么就要将反斜杠用大括号括起来,象这样:{app}{\}.

下面所列出的是目前已经被支持的常量。

目录常量

{app}

应用程序目录,这是用户在安装向导的选择安装目录页里面所选择的。

例如:如果你使用了 {app}\MYPROG.EXE 作为一项并且用户选择了“C:\MYPROG”作为应用程序的目录,那么安装程序就会将它转换成“C:\MYPROG\MYPROG.EXE”。

{win}

系统的 Windows 目录。例如:如果你使用了 {win}\MYPROG.INI 作为一项并且系统的 Windows 目录是“C:\WINDOWS”,那么安装程序就会将它转换成“C:\WINDOWS\MYPROG.INI”。

{sys}

系统的 Windows 系统(System)目录(在 Windows NT/2000 下是 System32)。例如:如果你使用了 {sys}\CTL3D32.DLL 作为一项并且系统的 Windows 系统目录是“C:\WINDOWS\SYSTEM”,那么安装程序就会将它转换成“C:\WINDOWS\SYSTEM\CTL3D32.DLL”。

{src}

这个文件夹指向安装程序所在的位置。

例如:如果你使用了 {src}\MYPROG.EXE 作为一项并且用户是从“S:\ ”安装的,那么安装程序就会将它转换成“S:\MYPROG.EXE”。

{sd}

系统驱动器,它是指 Windows 被安装到的那个驱动器,典型的是“C:”,对于 Windows NT/2000,这个常量同系统的环境变量“SystemDrive”是等效的。

{pf}

程序文件夹(Program Files),这个路径是系统的 Program Files 目录,典型的是“C:\Program Files”。{cf}

公共文件夹(Common Files),这个路径是系统的 Common Files 文件夹,典型的是

“C:\Program Files\Common Files”。

{tmp}

临时目录,这个目录并不是用户的 TEMP 环境变量指向的目录,而是安装程序在启动时在用户的临时目录下建立的一个子目录(它有一个类似于“

C:\WINDOWS\TEMP\IS-xxxxx.tmp”这样的名字),在安装程序退出时所有的文件和子目录将会被删除。对于在 [Run] 段里面要被执行且在安装以后又不需要的程序文件来说这个功能是非常有用的。{fonts}

字体目录,在 Windows 95/NT 4+ 下有一个专门为字体设立的目录(通常这个目录在 Windows 目录下且被命名为“FONTS”),这个常量就指向这个目录。对于 Windows NT 3.51,这个常量是和 {sys} 等效的,因为当时还没有字体目录。

{dao}

DAO 目录,当安装程序运行在 Windows 95/NT 4+ 上时,它被等效为 {

cf}\Microsoft Shared\DAO,当运行于 Windows NT 3.51 时,它被等效为 {

win}\MSAPPS\DAO.

外壳(Shell)文件夹常量

Inno Setup 还支持另外一套目录常量,这就是涉及到的外壳(shell)文件夹常量,它们具有和其它的目录常量相同的使用方法。然而,如果在脚本的 [Setup] 段里面放入了 MinVersion=4,3.51 这一行来表示允许支持 NT 3.51,那么将只有 {group} 这个外壳文件夹常量能被使用,并签只能用在 [Icons] 段。

下面的包含了“user”的常量涉及到当前登陆的用户私人文档(profile),而带有“

common”的常量会涉及到全部用户(All Users)的私人文档(profile)。当安装程序运行

在 Windows NT/2000 操作系统下并且用户不具有管理员的权限时,所有的带有“common”的常量会强迫同带有“user”的常量等效。

* 标记表示带有“common”的常量在 Windows 9x 操作系统下同带有“user”的常量等效。

{group}

程序组的路径,取决于用户在安装程序向导的“选择程序组”页的选择。对于 Windows NT,这个文件夹始终被建立在所有用户的私人文档(All Users profile),除非用户正在安装的这个应用程序不具有管理员的权限,那么在这种情况下它将被建立在用户的私人文档中(profile).

{sendto}

当前用户的“发送”的路径。(没有公共的“发送”文件夹。)

{userappdata} & {commonappdata}

应用程序数据(Application Data)文件夹的路径。

{userdesktop} & {commondesktop} *

桌面文件夹的路径,推荐桌面快捷方式使用 {userdesktop}.

{userdocs} & {commondocs}

“我的文档”文件夹的路径(或者对于 NT 4.0,是指私人文件夹).

{userfavorites} & {commonfavorites}

“收藏夹”的路径,这个常量的使用方法是需要 MinVersion 的设置至少为“4.1,4”,目前只

有 Windows 2000 支持 {commonfavorites},如果使用的是在这之前的版本的 Windows,那么它将会被转换成和{userfavorites} 相同的目录。

{userprograms} & {commonprograms} *

在开始菜单里面的程序文件夹的路径。

{userstartmenu} & {commonstartmenu} *

开始菜单的定级路径。

{userstartup} & {commonstartup} *

开始菜单里面的启动文件夹的路径。

{usertemplates} & {commontemplates}

模板(Templates)文件夹的路径,目前只有 Windows 2000 支持 {

commontemplates},如果使用的是在这之前的版本的 Windows ,它将会被转换成

和 {usertemplates} 相同的目录。

其他的常量

{\}

一个反斜杠字符,请参见本页前面提到的关于常量 {\} 和单字符 \ 在使用上有何不同的说明。

{%NAME}

内嵌一个环境变量,这个 NAME 是要使用的环境变量的名字。如果在用户的系统当中指定的环境变量不存在,这个常量就会被一个空的字符串所替代。

{computername}

安装程序正在运行的计算机的名称(就是“GetComputerName”函数的返回值)。

{groupname}

用户在安装程序向导的选择程序组页选择的程序组的名称,这个是不同于 {group} 的,它不包括路径。{hwnd}

(专门用途)传送安装程序背景窗口的窗口句柄。

{reg:HKxx\SubkeyName,ValueName|DefaultValue}

内嵌一个注册表值。

HKxx 指定根键(root key),参见 [Registry] 段文档所列出的根键。

SubkeyName 指定要读取的子键的名称。

ValueName 指定要读取的值的名称,要读取一个键的默认值就让 ValueName 为空。DefaultValue 如果指定的注册表值不存在或者它不是一个字符串类型(REG_SZ 或

者 REG_EXPAND_SZ),则嵌入这个值。

如果你希望包括一个逗号,竖线(字符“|”)或大括号闭弧“}”在常量里面,你必须通过“%-编码”形式用“%”后紧跟一个两位的16进制代码转译后替换原来的字符,一个逗号是“%2c”,一个竖线符是“%7c”,一个大括号闭弧是“%7d”。

DefaultValue 可以包括常量,然而,如上所诉内嵌的常量的大括号的闭弧

(“}”)必须被改成“%7d”才可以。

{srcexe}

安装程序的文件名全称(包括全程路径和文件名),例如“C:\SETUP.EXE”。

{username}

运行安装程序的用户的名称(函数 GetUserName 的返回值)。

公共参数

有俩个可选的参数可以在所有的段里面的任何项中使用,它们是:

MinVersion

说明:

该项处理所需的分别最低的 Windows 版本和 Windows NT 版本. 如果将某个版本号指定为 0 那么在该平台上就再也不会处理这项了,版本创建编号(Build numbers)和(或)服务包级别

(Service pack levels)也可以被包括在版本号当中。这个参数将会覆盖位于 [Setup] 段当中

的 MinVersion 关键字。

示例:

MinVersion: 4.0,4.0

OnlyBelowVersion

说明:

基本上是和 MinVersion 相反,该项所指定的最低的 Windows 版本和 Windows NT

版本将不会被处理,例如:如果你指定了 4.1,5.0 并且用户运行在 Windows 95 或 NT 4.0 下,那么该项将会被处理,但是如果用户运行在 Windows 98 (报告的版本信息是 4.1)或 Windows 2000 (报告的版本信息是 NT 5.0),则该项就不会被处理。使用“0”表示该版本号上限的限制。版本创建编号(Build numbers)和(或)服务包级别(Service pack levels)也可以包括在版本号当中。这个参数将会覆盖位于 [Setup] 段当中的 OnlyBelowVersion 关键字。

示例:

OnlyBelowVersion: 4.1,5.0

其它注意事项

安装程序是按照段内的排列顺序来处理所有的项的,[UninstallRun] 段是个例外,卸载时处理所有项的顺序是与安装程序相反的。

在这个示例中:

[INI]

Filename: "{win}\MYPROG.INI"; Section: "InstallSettings"; Flags: uninsdeletesectionifemp ty

Filename: "{win}\MYPROG.INI"; Section: "InstallSettings"; Key: "InstallPath"; String: "{a pp}"; Flags: uninsdeleteentry

安装程序首先记录下第一项的数据 uninsdeletesectionifempty 标记到卸载记录中。创建第二项的键,然后记录下 uninsdeleteentry 标记的数据到卸载记录中,当程序被卸载时,卸载程序将首先处

理 uninsdeleteentry 标记,删除该项,然后才是 uninsdeletesectionifempty 标记。

如果安装程序在用户的系统中检测到一个 Windows 共享版本,Windows 系统目录是写保护的,{sys} 目录常量将会被转变为用户的 Windows 目录替代系统目录。

在命令行执行编译器

脚本文件也可以在命令行被安装编译器编译。命令行的使用方法如下:

compiler /cc <脚本文件>

示例:

compil16 /cc c:\isetup\sample16\sample16.iss

compil32 /cc "c:\isetup\sample32\my script.iss"

在上面列出的例子中,带有空格的文件名必须用引号括起来。

在命令行运行安装编译器不支持正常的进程显示或任何错误消息。如果编译成功安装编译器将会返回一个退出代码 0,如果是 1 则表示有无效的命令行参数, 2 则表明编译失败。

安装命令行参数

安装程序本身接受三个不同的可选的命令行参数,这些参数能被用于系统管理员和其他程序调用安装程序。

/SP-

在安装程序开始时禁止“即将安装 ... ,继续吗?”的提示,当然,它将使 [Setup] 段

的 DisableStartupPrompt 关键字设置为 yes 无效

/DIR="x:\dirname"

替换在“选择目标文件夹”向导页显示的默认的目录名,必需要指定一个全程路径名。如果 [Setup] 段

的 DisableDirPage 关键字被设置为 yes, 那么该命令行参数将被忽略。

/GROUP="group name"

替换在“选择程序组”向导页显示的默认的程序组名,如果 [Setup] 段的 DisableProgramGroupPage 关键字被设置为 yes, 那么该命令行参数将被忽略。

安装脚本段

安装脚本段

[Setup] 段

[Dirs] 段

[Files] 段

[Icons] 段

[INI] 段

[InstallDelete] 段

[Messages] 段

[Registry] 段

[Run] 段

[UninstallDelete] 段

[UninstallRun] 段

其它问题:

其它注意事项

在命令行执行编译器

安装命令行参数

[Setup] 段

这个段包括了安装和卸载程序所使用的全局设置,并且有些关键字在你建立的安装程序中是必须要用到的。这个是 [Setup] 段的一个示例:

[Setup]

AppName=My Program

AppVerName=My Program version 1.4

DefaultDirName={pf}\My Program

DefaultGroupName=My Program

下面的这些关键字可以被放进 [Setup] 段中去:

(粗体字表示是必需的)

编译器相关

CompressLevel

DiskClusterSize

DiskSize

DiskSpanning

DontMergeDuplicateFilesOutputBaseFilename

OutputDir

ReserveBytes

SourceDir

UseSetupLdr

安装程序相关

功能关键字: 这些关键字影响到安装程序的操作,或是保存起来以备将来卸载时所用到。

AdminPrivilegesRequired

AllowNoIcons

AllowRootDirectory

AlwaysCreateUninstallIcon

AlwaysRestart

AlwaysUsePersonalGroup

AppName

AppId

AppMutex

AppPublisher

AppPublisherURL

AppSupportURL

AppUpdatesURL

AppVersion

AppVerName

ChangesAssociations

CreateAppDir

CreateUninstallRegKey

DefaultDirName

DefaultGroupName

DirExistsWarning

DisableAppendDir

DisableDirPage

DisableFinishedPage DisableProgramGroupPage DisableStartupPrompt EnableDirDoesntExistWarning ExtraDiskSpaceRequired

InfoAfterFile

InfoBeforeFile

LicenseFile

MessagesFile

MinVersion

OnlyBelowVersion

Password

Uninstallable

UninstallDisplayIcon

UninstallDisplayName

UninstallFilesDir

UninstallIconName

UninstallLogMode

UpdateUninstallAppName

UsePreviousAppDir

UsePreviousGroup

外观界面关键字:这些关键字决定了安装程序的外观样式。

AppCopyright

BackColor

BackColor2

BackColorDirection

BackSolid

WindowShowCaption

WindowStartMaximized

WindowResizable

WindowVisible

WizardImageBackColor

WizardImageFile

废弃的

Bits

DisableDirExistsWarning OverwriteUninstRegEntries

[Dirs] 段

这个段是可选的,而且通常对于大多数简单的应用程序来书不是必需的。这个段是用来创建除用户选择的应用程序目录以外的其它的附加的目录,它是被自动创建的。这个段所创建的子目录是可以脱离主应用程序而共同使用的目录。当然在 [Files] 段里面的文件被复制到某个目录之前你并不一定要创建它,然而在卸载程序的时候在 [Dirs] 和 [UninstallDelete] 段里面没有指定的目录就不会被删除。

这是一个 [Dirs] 段的示例:

[Dirs]

Name: "{app}\data"

Name: "{app}\bin"

上面的示例演示了在安装程序的应用程序目录被创建之后,在应用程序的下面建立两个子目录。

下面列出了支持的参数:

Name (必需的)

说明:

要被建立的目录的名称,通常它以一个目录常数开始。

示例:

Name: "{app}\MyDir"

Flags

说明:

“标记”,这个参数是一个附加的选项集合,可以多个选项共同使用,使用空格分开多个选项。下面列出了被支持的选项:

deleteafterinstall

告诉安装程序象平常一样建立目录,但是当安装程序结束(或被中止)之后这个目录是空的情况下将这个目录删除。如果释放脚本的 [Run] 段所执行的程序所需要的临时的数据时这个选项是很有用的。

uninsalwaysuninstall

告诉卸载程序试图删除这个目录而不管它是不是空的。通常卸载程序只会尝试删除在安装之前不存在的目录。

uninsneveruninstall

告诉卸载程序不要去删除这个目录。在默认情况下,在 [Dirs] 段里面指定的目录如果是空的卸载程序就会尝试将其删除。

示例:

Flags: uninsneveruninstall

公共参数

[Files] 段

这个段是可选的,但对于大多数安装程序来说是必不可少的。在这里定义了安装程序需要复制到用户的系统当中的全部文件。

在安装期间,卸载程序和数据被自动的复制到应用程序的目录当中去,因此你不必手工的将它们添加

到 [Files] 段。

这是一个 [Files] 段的示例:

[Files]

Source: "CTL3DV2.DLL"; DestDir: "{sys}"; CopyMode: onlyifdoesntexist; Flags: uninsneve runinstall

Source: "MYPROG.EXE"; DestDir: "{app}"

Source: "MYPROG.HLP"; DestDir: "{app}"

Source: "README.TXT"; DestDir: "{app}"; Flags: isreadme

下面列出了支持的参数:

Source (必需的)

说明:

“源文件”的名称,如果没有提供全程路径时编译器会根据安装程序的源目录的路径预先设定号路径。

允许通配符,根据通配符可以在一项里面简单的指定一组文件。当使用了通配符的时候,所有匹配的文件使用相同的可选项。

当标记(flag) external 被指定的时候,Source 必须是一个在发布介质或用户的系统中已经存在的文件(或带有通配符)的全程路径。(例如“{src}\license.ini”).

示例:

Source: "MYPROG.EXE"

DestDir (必需的)

说明:

这个是文件将要被安装到用户的系统当中去的目录。它几乎总是以一个目录常量开始的。如果指定的路径不存在于用户的系统中,它将会被自动的创建。

示例:

DestDir: "{app}"

DestName

说明:

这个常数为将要安装到用户的系统中的文件指定一个新的名字。在默认的情况下,安装程序使用的是

同 Source 参数一样的文件名,因此在多数情况下不需要指定该参数。

示例:

DestName: "MYPROG2.EXE"

CopyMode

默认:

normal

说明:

“复制模式”,指定文件复制的规则,必须是下列规则之一。

normal

这是最常使用的选项。如果文件已经存在于用户的系统当中并且比要复制的文件的版本更新时(由文件的版本信息决定),安装程序将会向用户提出询问是否要替换掉已经存在的文件。如果已经存在的文件不包含文件的版本信息,它将会被覆盖而不会向用户询问。

参见这个标题下面的注意中关于版本检查的重要说明。

onlyifdoesntexist

只有当用户的系统中的文件不存在时才复制文件。

alwaysoverwrite

总是覆盖已经存在的文件,甚至如果已经存在的文件比被安装的文件的版本更新的情况下也是如此。对于共享的系统文件永远也不要这样做!

alwaysskipifsameorolder

类似于 normal, 不同之处是如果遇到已经存在的文件不会向用户提出询问。当这个模式被使用时,更新的一经存在的文件时从来不会被替换的。

示例:

CopyMode: normal

Attribs

说明:

为文件指定附加的“属性”,它可以包括一个或多个属性,它们是:readonly, hidden, system. 如果没有指定这个参数,安装程序不会给文件指派任何特殊的属性。

示例:

Attribs: hidden system

FontInstall

说明:

告诉安装程序需要被安装的文件是一个字体文件,该值是被保存到注册表或 WIN.INI 文件中的字体名称,这个名称必须严格地和在资源管理器中双击字体文件看到的名称相对应。注意,安装程序会自动的在字体名称的末尾加上“(TrueType)”。

如果这个字体文件不是一个 TrueType 字体,你必须在 Flags 参数中指定 fontisnttruetype 标记。

建议在安装字体到 {fonts} 目录的时候使用复制模式参数 onlyifdoesntexist 和标记(flag)参

数 uninsneveruninstall.

示例:

Source: "OZHANDIN.TTF"; DestDir: "{fonts}"; FontInstall: "Oz Handicraft BT"; CopyMode: onlyifdoesntexist; Flags: uninsneveruninstall

Flags

说明:

“标记”,这个参数是一个附加的选项集合,可以多个选项共同使用,使用空格分开多个选项。下面列出了被支持的选项:

comparetimestampalso

(专门用途)如果要被复制到用户系统的文件已经存在于用户的系统当中并且它们具有相同的版本信息,告诉安装程序进行时间戳(文件的日期时间属性)的比较。在正常情况下安装程序不会覆盖已经存在的文件,但是当使用了这个标记的时候,如果已存在的文件的时间戳比它的版本信息还要旧,安装程序在安装文件时就会覆盖它。当复制模式不是 normal 或 alwaysskipifsameorolder 这两者之一时该标记不起作用。

confirmoverwrite

当文件已经存在每个文件在复制之前始终向用户提出询问。

deleteafterinstall

告诉安装程序象平常一样复制文件,但是当安装程序结束(或被中止)之后将这个文件删除。如果释放脚本的 [Run] 段所执行的程序所需要的临时的数据时这个选项是很有用的。

此标记不能和下列标记在一起组合使

用: isreadme, regserver, regtypelib, restartreplace, sharedfile, uninsneveruninstall.

external

此标记告诉 Inno Setup 不要将由 Source 参数指定的文件编译进安装程序文件中,在复制文件的时候由发布介质或用户的系统中已经存在文件代替。要获得更多详细的信息请参见 Source 参数的说明。

fontisnttruetype

如果 FontInstall 参数指定的是一个非 TrueType 字体则使用此标记。

isreadme

该文件是“自述(README)”文件,安装程序中只有一个文件能够使用此参数。当有一个文件使用了这个参数时,用户将被询问是否愿意在安装程序结束时查看自述文件,如果选择了是,安装程序将会根据文件的类型用默认的程序打开这个文件,基于这个原因,自述文件应该具有象 .txt, .wri 或 .doc. 这样的扩展名。

注意如果安装程序要重新启动用户的计算机(比如安装了一个带有 restartreplace 参数的文件或

在 [Setup] 段中的 AlwaysRestart

关键字的值为 yes),安装程序就不会向用户询问是否要查看自述文件。

overwritereadonly

始终覆盖一个只读(read-only)文件,如果没有这个参数,当一个已存在的只读文件要被覆盖时安装程序将会询问用户。

regserver

注册 OLE 服务器(或称作 ActiveX 控件)。如果设置了此标记,安装程序将查找并执

行 DLL/OCX 的 DllRegisterServer 输出,卸载程序调用 DllUnregisterServer. 当结合 sharedfile 标记一起使用,只有参照技术器的值归零时 DLL/OCX 才可能百取消登记(unregistered).

要获得更多的详细信息请参见此标题最后的注意。

regtypelib

注册类型库(.tlb). 卸载程序将会取消注册类型库(除非指定了 uninsneveruninstall 标记). 就

像 regserver 标记那样,如果结合 sharedfile 标记一起使用,这个文件只有参照计数器的值归零时才可能被卸载。

要获得更多的详细信息请参见此标题最后的注意。

restartreplace

此标记通常用于替换系统核心文件。如果文件已经预先存在并发现它已经被锁定结果导致安装程序无法替换该文件,安装程序就会注册此文件(对于 Windows 和 Windows NT 分别使用 WININIT.INI 和函数 MoveFileEx)在下次启动系统时被替换。当遇到这种情况,在安装过程结束时用户将被提示重新启动计算机。

要保持 Windows95/98 和 3.1 的兼容性,使用了此标记的项不应该使用长文件名,只能支持“8.3”格式的文件名。(Windows NT 和 2000 则没有此限制。)

重要提示:在 Windows NT/2000 下只有当用户具有管理员权限时使用 restartreplace 标记才可以成功的替换使用中的文件。如果用户没有管理员权限,将会显示如下的信息:

“RestartReplace failed: MoveFileEx failed; code 5.”,因此,当使用 restartreplace 标记时强烈建议让你的安装程序需要管理员权限,在 [Setup] 段里面设置 "AdminPrivilegesRequired=1"。

sharedfile

(仅 Windows 95/NT 4+)使用 Windows 的共享文件计数功能(位于注册表

的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\SharedDLLs). 这样会使应用程序之间能够共享一个文件,不用担心在不注意的情况下会删除文件。在每次安装共享文件的时候,与这个文件相对应的“参照计数器”的值就会加一,而每次应用程序被卸载的时候,参照计数器的值就会减一,如果参照计数器的值归零的时候,该共享文件就会被删除(在用户确认的情况下)。

绝大多数被安装到 Windows 系统目录下的文件都应当使用这个标记,包

括 .OCX 和 .DPL (Delphi 3 package)文件。不使用这个标记的仅有的一个例外是 MFC DLLs. 作为替代,应该在复制模式中使用 onlyifdoesntexist ,并结合 uninsneveruninstall 标记,或者是如果安装单独发布的 MFC DLL 的最近的版本,则使用复制模式 alwaysskipifsameorolder ,并结合使用标

记 uninsneveruninstall 和 restartreplace.

当安装程序被运行在一个 NT 3.51 系统时,被安装的带有此标记的文件就再也不会被删除了。

skipifsourcedoesntexist

只有当 external 标记也使用了的时候这个标记才会有用。它会告诉安装程序如果源文件不存在的话则无任何提示的(静静的)跳过该项,如果没有使用这个标记则会显示一个错误消息。

uninsneveruninstall

从来不会卸载这个文件。此标记应当被保守地使用,而且通常它是和复制模式 onlyifdoesntexist 在一起结合使用。意思是用于安装一个特别公共的共享文件,就像 CTL3DV2.DLL 或者一个 MFC DLL, 你不应该用卸载程序去删除这个文件的原因是以后其它的应用程序也要使用到它。

示例:

Flags: isreadme

公共参数

注意

如果安装程序正在安装一个已经存在于用户的系统当中的 16 位的 DLL 或者 EXE 文件,两个文件的版本信息是不会相比较的,已存在的文件将始终被覆盖(除非当复制模式的参数是 onlyifdoesntexist),这是由一个 Windows 的限制决定的,32 位的程序就像 Inno Setup 只能读取 32 位可执行文件的版本信息。

在安装程序的最后一步安装程序会注册所有的带有 regserver 或 regtypelib 标记的文件。然而,如

果 [Setup] 段关键字 AlwaysRestart 的值是 yes, 或如果有文件带有 restartreplace 标记,全部的文件将会在下次启动的时候注册(在 Windows 注册表的 RunOnce 创建一项)。

当带有 .HLP 扩展名(Windows 的帮助文件)的文件被卸载的时候,其对应的 .GID 和 .FTS 文件同样会被自动删除。

[Icons] 段

这个段是可选的,但对于大多数安装程序来说是必不可少的。它定义了所有的安装程序要在用户系统中创建的程序管理器/开始菜单的图标。它也能被用来在其它的位置创建应用程序图标(快捷方式),比如就像桌面。

卸载图标是由安装程序内部创建的,这样一来你就不需要在 [Icons] 段里面手工的添加它。默认情况下,安装程序运行在 Windows 95/NT 4+ 的时候是不创建卸载图标的――除了安装程序运行

于 Windows NT 3.51 的时候。要强制创建一个卸载图标,请使用 [Setup] 段里面

的 AlwaysCreateUninstallIcon 关键字。

这是 [Icons] 段的一个示例:

[Icons]

Name: "{group}\My Program"; Filename: "{app}\MYPROG.EXE"; WorkingDir: "{app}"

下面列出了支持的参数:

Name (必需的)

说明:

要创建的应用程序图标的名称和位置。此参数可以使用任何任何“外壳文件夹常量”和“目录常量”。

注意:记住 Windows 95/NT 4+ 的应用程序图标是作为文件直接存储的,这样一来普通文件所不允许使用的字符都不能用来作为应用程序图标的名称。

示例:

Name: "{group}\My Program"

Name: "{group}\Subfolder\My Program"

Name: "{userdesktop}\My Program"

Name: "{commonprograms}\My Program"

Filename (必需的)

说明:

应用程序图标的命令行文件名,它通常以一个目录常量开始。

示例:

Filename: "{app}\MYPROG.EXE"

Parameters

说明:

应用程序图标的可选的命令行参数,可以包括常量,在 Windows 95/NT 4+ 下运行时才可以包括引号。

示例:

Parameters: "/play filename.mid"

WorkingDir

说明:

应用程序图标的工作目录,应用程序启动的那个目录,如果没有指定该参数或该参数是空的,Windows 将使用一个默认的路径,它随着 Windows 的版本的不同而改变。这个参数可以包括常量。

示例:

WorkingDir: "{app}"

Comment

说明:

指定快捷方式的“注释”(或“描述”)栏的内容,它决定了在 Windows 2000 下的弹出信息,早期

的 Windows 版本忽略这个注释。

示例:

Comment: "This is my program"

IconFilename

说明:

要被显示的一个自定义的应用程序图标(位于用户的系统中)的文件名。它可以是一个包含图标的可执行文件映像(.exe, .dll)或一个 .ico 文件。如果没有指定该参数或该参速是空的,Windows 将会使用文件的默认图标。这个参数可以包括常量。

示例:

IconFilename: "{app}\myicon.ico"

IconIndex

默认:

说明:

由 IconFilename 指定的文件的以零开始的图标索引。

示例:

IconIndex: 0

Flags

说明:

“标记”,这个参数是一个附加的选项集合,可以多个选项共同使用,使用空格分开多个选项。下面列出了被支持的选项:

closeonexit

当设置了此标记时,安装程序将设置快捷方式的“退出时关闭”属性。这个标记仅对基于 MS-DOS 的应用程序有效(具体说就是是否具有 .pif 扩展名)。如果这个标记和 dontcloseonexit 标记都没有指定,安装程序就不会去改变“退出时关闭”的属性。

createonlyiffileexists

当设置了此标记时,安装程序只创建已存在的由 Filename 参数指定的文件的应用程序图标。

dontcloseonexit

类似于 closeonexit, 只是会导致安装程序不选定“退出时关闭”属性。

runmaximized

当设置了此标记时,安装程序将应用程序图标的“运行方式”设置为“最大化”,这样当程序被启动时以最大化的模式初始化。当安装在 Windows NT 3.51 上时该标记不起作用。

runminimized

当设置了此标记时,安装程序将应用程序图标的“运行方式”设置为“最小化”,这样当程序被启动时以最小化的模式初始化。

uninsneveruninstall

告诉卸载程序不要删除这个应用程序图标。

useapppaths

当设置了此标记时,在 Filename 参数里仅指定没有路径的文件名,以后安装程序将会从注册表

的 "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths" 键里面自动得到预先设定好的对应该文件名的路径名。

示例:

Flags: runminimized

公共参数

[INI] 段

此段时可选的,它定义了一些 .INI 文件项,在文件被复制以后安装程序在用户的系统中的设定。

这是 [INI] 段的一个示例:

[INI]

Filename: "{win}\MYPROG.INI"; Section: "InstallSettings"; Flags: uninsdeletesection Filename: "{win}\MYPROG.INI"; Section: "InstallSettings"; Key: "InstallPath"; String: "{a pp}"

下面列出了支持的参数:

Filename (必需的)

说明:

你想要安装程序修改的 .INI 文件的文件名,它可以包括常量。如果这个参数时空的,它将写入系统

的 Windows 目录的 WIN.INI 文件。

示例:

Filename: "{win}\MYPROG.INI"

Section (必需的)

说明:

要被创建的段的名称,可以包括常量。

示例:

Section: "Settings"

Key

说明:

要被设定的键的名称,可以包括常量。如果没有指定这个参数或这个参数是空的就不会创建任何键。

示例:

Key: "Version"

String

说明:

赋给键的值,可以使用常量。如果没有指定该参数不会创建该键。

示例:

String: "1.0"

Flags

说明:

“标记”,这个参数是一个附加的选项集合,可以多个选项共同使用,使用空格分开多个选项。下面列出了被支持的选项:

createkeyifdoesntexist

只有该键不存在是才能给改建赋值。

uninsdeleteentry

程序被卸载时删除该项,它可以结合 uninsdeletesectionifempty 标记一起使用。

uninsdeletesection

当程序被卸载时,删除该项所在的整个段。对于由 Windows 本身使用的段(例如一些在 WIN.INI 中的段)来说这明显不是一个好的主意,你应当将它用到自己的应用程序中的段。

uninsdeletesectionifempty

类似于 uninsdeletesection, 但是只能在该段中没有了键的时候才能删除。它可以结

合 uninsdeleteentry 标记一起使用。

示例:

Flags: uninsdeleteentry

公共参数

[InstallDelete] 段

它使用的是和 [UninstallDelete] 段相同的格式,不同的是它是在安装程序的第一步被处理的。[Messages] 段

[Messages] 段是用于定义安装程序和卸载程序所显示的消息。通常你不需要在你的脚本文件里面创

建 [Messages] 段,默认情况下所有的显示消息都由 Inno Setup 包含的文件 Default.isl 定义。(或由 [Setup] 段的关键字 MessagesFile 指定的任何文件).

相关主题
相关文档 最新文档