荔园在线

荔园之美,在春之萌芽,在夏之绽放,在秋之收获,在冬之沉淀

[回到开始] [上一篇][下一篇]


发信人: agileboy (快乐笛子), 信区: WinNT
标  题: 扩展 Windows 安装程序
发信站: 荔园晨风BBS站 (Wed Jan  7 12:59:58 2004), 站内信件

文章比较长,有兴趣研究的朋友可以发信来索取。

________________________________________
扩展 Windows 安装程序
可以用三种方法扩展 Windows 安装:
?       从命令行使用 Rundll.exe 执行 Windows .inf 文件。
?       用户除了从“控制面板”的“添加/删除程序”对话框中安装软件之外,还可以
从 32 位程序代码安装可选的 Windows 软件组件。
?       在 Windows 桌面上创建图标,用户单击它就可以运行 .inf 文件;这样可以不
用开发安装程序代码。
从命令行执行 .inf 文件
可以使用 Windows 系统命令 Rundll.exe 或 Rundll32.exe 来执行 .inf 文件中
的 Install 节。命令行语法如下:
RunDll setupx.dll,InstallHinfSection <section> <reboot-mode> <inf-name>

<section> 参数是 .inf 文件中的 Install 节。例如,下面的命令行安装“游戏
”可选组件,如果安装决定必须重新启动计算机,那么它将在安装完成后询问用户
是否希望立即重新启动计算机。(<reboot-mode> 参数值的意义将在下面的“使用
重新启动方式参数”中介绍。)
RunDll setupx.dll,InstallHinfSection games 4 applets.inf
 注意
?       该命令假设有足够的磁盘空间安装所有文件。它不做任何磁盘空间检查。
?       调用 RUNDLL 或 RUNDLL32 后,安装应用程序还没有执行任何代码,因为一旦
Setupx.dll 有控制权,它可能会重新启动计算机。如果安装过程在代码调用
RUNDLL 或 RUNDLL32 后要运行其他代码,请使用 .inf 文件中的 RunOnce 列表。

?       不要用 RunOnce 列表运行正在安装的可选组件。
使用重新启动方式参数
有五个重新启动方式:
define HOW_NEVER_REBOOT 0
define HOW_ALWAYS_SILENT_REBOOT 1
define HOW_ALWAYS_PROMPT_REBOOT 2
define HOW_SILENT_REBOOT 3
define HOW_PROMPT_REBOOT 4
如果 <inf-name> 指定您自己的 .inf 文件,而不是 Windows .inf 文件,请把上
面显示的值加 128。在上面安装“游戏”可选组件的例子中,<reboot-mode> 设为
 4。这是因为 Applets.inf 是 Windows .inf 文件。如果安装的可选组件有自己
的 .inf 文件,则 <reboot-mode> 设为 132。如果将 <reboot-mode> 参数加
128,则要安装的所有文件必须与 .inf 文件在安装盘的同一文件夹中。
 注意
?       如果 .inf 文件是 Windows 95 .inf 文件,则 <reboot-mode> 的唯一推荐值是
 4,而对于您提供的 .inf 文件则为 132。使用上面显示的任何其他值可能会引起
不必要的计算机重新启动,或使计算机在需要时反而不重新启动。
下面列表说明每种重新启动方式:
NeverReboot
将 <reboot-mode> 设为 0 或 128。无论发生什么计算机都不重新启动。直到客户
端决定是否应重新启动计算机。对于安装程序,这表示 C:\Windows\Wininit.
ini 文件非零字节。
AlwaysSilentReboot
将 <reboot-mode> 设为 1 或 129。重新启动计算机时不提示用户,并且总是重新
启动计算机。
AlwaysPromptReboot
将 <reboot-mode> 设为 2 或 130。总提示用户是否需要重新启动计算机。安装不
决定重新启动计算机是否必要。
SilentReboot
将 <reboot-mode> 设为 3 或 131。如果安装程序决定需要重新启动计算机,则不
需要用户交互。
PromptReboot
将 <reboot-mode> 设为 4 或 132。如果安装程序决定需要重新启动计算机,会用
对话框提示用户。
返回到文件开始处
安装 32 位应用程序代码可选组件
在计算机上安装 Windows 后,可能有必要添加一个或多个 Windows 可选组件(例
如,“游戏”)。这种在安装程序开始安装 Windows 之后所发生的安装,称之为
“维护方式安装”。通常,维护方式安装是通过单击控制面板中的“添加/删除程
序”图标从 Windows 启动。然而,开发商和供应商还有其他方式来安装可选软件
组件:可以在 32 位应用程序中调用 CreateProcess 来安装可选软件组件。
 注意
?       下面介绍的安装可选组件的 CreateProcess 方法只能在 32 位应用程序中使用

要从 32 位应用程序中安装可选组件,请使用以下说明的几种方法。
检查注册表
首先,检查注册表(或查找文件)以查看当前是否已安装可选组件。所有当前安装
的可选组件信息的注册表主键位置如下:
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\SETUP\Opti
onalComponents]
在注册表键下有数值指向子键,每个子键包含已安装可选组件的信息以及安装新可
选组件所需要的信息。例如,假设希望作为可选组件安装“游戏”。要查看是否已
安装“游戏”,请在 OptionalComponents 主键中查找以下子项的值:
"Games"="Games"
然后打开可选组件主键下的 Games 主键以查找以下内容:
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\SETUP\Opti
onalComponents\Games]
"INF"="applets.inf"
"Section"="games"
"Installed"="0"
它表示该 Windows 计算机上没有安装“游戏”可选组件,因为“Installed”标志
为 0。
编写 CreateProcess 函数调用代码
要安装可选组件(例如“游戏”),请在通过 RUNDLL 运行 Setupx.dll 的
CreateProcess 调用中使用上面主键中的“INF”和“Section”值。安装组件时,
与控制面板中“添加/删除程序”安装组件的方式完全一样。CreateProcess 调用
中 lpCommandLine 参数的语法如下:
RunDll setupx.dll,InstallHinfSection <section> <reboot-mode>
<inf-name>
这些是在上述注册表键中找到的 <section> 和 <inf-name> 参数值。例如,下面
的 CreateProcess 调用安装“游戏”可选组件,并且 Windows 安装决定重新启动
计算机,询问用户是否希望完成安装后立即重新启动计算机。(<reboot-mode> 参
数值的意义在下面“使用重新启动方式参数”部分中介绍。)
RunDll setupx.dll,InstallHinfSection games 4 applets.inf
 注意
?       推荐在安装组件前检查磁盘可用空间。检查磁盘可用空间时,请考虑必须加入系
统交换文件所需的磁盘空间。
调用 CreateProcess 后,安装还没有执行任何代码,因为一旦 Setupx.dll 有控
制权,其代码可能会引起用户计算机的重新启动。如果安装过程需要在调用
CreateProcess 后运行其他代码,请使用 .inf 文件中的 RunOnce 列表。
 注意
?       不要用 RunOnce 列表运行正在安装的可选组件。
右键单击,开始运行 .inf 文件
安装会识别安装可选组件 .inf 文件中的特定安装节名 DefaultInstall。如果您
的 .inf 文件中使用了 [DefaultInstall] 节,则用户只要在 32 位 Windows 版
本的用户界面中右键单击 .inf 文件的文件图标,就可以运行
[DefaultInstall] 节。(用户右键单击 .inf 文件图标后,将出现弹出式菜单,
用户必须选择安装选项才能实际运行 [DefaultInstall] 节。
在 .inf 文件中使用 [DefaultInstall] 是安装可选组件的方便方法。这在开发应
用程序过程中特别有用。如果正打算编写安装应用程序,那么在开发安装应用程序
代码前您已经有了一个安装可选组件的方法。
以下是包含典型项目的 DefaultInstall 节示例:
[DefaultInstall]
CopyFiles=QCD.copy.prog, QCD.copy.hlp, QCD.copy.win, QCD.copy.sys, QCD.
copy.inf
UpdateInis=QCD.Links
AddReg=QCD.reg, QCD.run
Uninstall=FlexiCD_remove
相关主题


________________________________________
使用安装信息 (.inf) 文件操作文件夹和文件
可以采用多种方法使用 .inf 文件操纵文件和文件夹。主要的方法有:
?       在文件夹中创建文件夹和链接
?       创建和删除长文件名
?       设置文件和文件夹的属性
?       将文件复制到 Program Files 文件夹
在文件夹中创建文件夹和链接
组件安装完后外壳程序会在 Program Files 文件夹中创建一个文件夹或在文件夹
中创建链接。安装程序在 Setup.ini 文件中查找 [progman.groups] 节,然后对
它进行分析以便在文件夹中创建文件夹或链接。
如果安装的组件需要在 Program Files 文件夹中有文件夹或链接,请创建
UpdateInis 节,在 Setup.ini 文件中创建适当的条目。Setup.ini 文件使用以下
语法创建文件夹和链接。注意文件夹与“开始”菜单有关。
[progman.groups]
folder_1=Folder_1_Name
folder_2=Folder_2_Name
:
folder_n=Folder_n_Name

[folder_1]
Link-Name, .exe-name, Icon-file-name, Icon-index, profile
如果 profile 字段是 NULL,则链接将添加到文件夹中。
 注意
?       如果 .exe-name 是 NULL,则会在出现该项目时从组中删除。
?       如果文件夹或链接的说明中有空格,则必须在 Setup.ini 文件中使用双引号显
示。请参阅以下示例。
示例: 游戏
[Optional Components]
games
[games]
OptionDesc= %GAMES_DESC%
CopyFiles= wingames.files
UpdateInis= wingames.links
[wingames.files]
cards.dll
freecell.exe
freecell.hlp
mshearts.exe
mshearts.hlp
sol.exe
sol.hlp
winmine.exe
winmine.hlp
[wingames.links]
setup.ini, progman.groups,, "gamesfolder=%GAMES_DESC%" ;creates folder
setup.ini, gamesfolder,, """Solitaire Game"",SOL.EXE,,," ;creates link
setup.ini, gamesfolder,, "Minesweeper,WINMINE.EXE,,," ;creates link
setup.ini, gamesfolder,, ""Hearts Card Game"",MSHEARTS.EXE,,,";creates
link
setup.ini, gamesfolder,, "FreeCell,FREECELL.EXE,,," ;creates link
结果: “游戏”项将显示在安装程序的“可选组件”对话框中,并且选中“游戏
”项,将在 Program Files 文件夹中创建 Games 文件夹,包含指向“纸牌”、“
扫雷”、“红心大战”和“空当接龙”的链接。
创建和删除长文件名
重命名操作的注册表根分支如下:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RenameFiles

删除操作的注册表根分支如下:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\DeleteFiles

将重命名和删除操作的每个组添加到每个分支下的子键。每组操作都限制为重命名
或删除单个文件夹中的文件。每一个子键必须最少必须包含两个条目,以便实现重
命名或删除:要重命名或删除文件的文件夹路径,实际的重命名或删除操作。
每组操作中的第一个注册表键是文件夹条目。相关文件夹中用于重命名操作的每个
条目形式为 "old_short_name"="new_long_name,[attrib_flag]"。
可选的 attrib_flag 用于在重命名操作期间设置文件属性。该标志由以下值组成

1       READONLY
2       HIDDEN
3       SYSTEM
要设置文件或文件夹的多个属性,应同时添加标记。 例如,要设置 READONLY 和
 HIDDEN 属性,attrib_flag 应为 3。
下例是 AddReg 节,它设置 \Windows\System\Sample 文件夹的 SYSTEM 和
HIDDEN 属性:
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Sys,,,%11%
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Sys,SAMPLE,,
"SAMPLE,6"
 注意
?       应该使用全部大写字母以确保文件名保留了短文件名。
相关文件夹中执行删除操作的每个条目的形式为
"arbitrary_key_name"="long_name_to_delete"。
下例是 AddReg 节:
?       在 C:\Samples 文件夹中将 Oldname.txt 文件重命名为 New Long Name.txt。

?       在 Windows 文件夹中将 Myreadme.txt 文件重命名为 My Application
Readme.txt。
[MyAppShort2Long]
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Samples,,,C:
\Samples
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Samples,
oldname.txt,,"New
Long Name.txt"
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Win,,,%25%
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Win,
myreadme.txt,,"My App Readme.txt"
下例是 AddReg 节:
?       从 C: \Samples 文件夹中删除 New Long Name.txt。
?       从 Windows 文件夹中删除 My Application Readme.txt。
[MyAppDelLong]
HKLM,Software\Microsoft\Windows\CurrentVersion\DeleteFiles\Samples,,,C:
\Samples
HKLM,Software\Microsoft\Windows\CurrentVersion\DeleteFiles\Samples,
oldname.txt,,"New
Long Name.txt"
HKLM,Software\Microsoft\Windows\CurrentVersion\DeleteFiles\Win,,,%25%
HKLM,Software\Microsoft\Windows\CurrentVersion\DeleteFiles\Win,
myreadme.txt,,"My App Readme.txt"
重命名或删除并处理这些条目后,从注册表中删除这些条目。
 注意
?       在重命名操作期间,只有重命名文件后目标文件才能被删除。如果有两个相同的
重命名操作等待执行,将导致文件丢失。例如,假设有一个位图文件需要将
Picture.bmp 重命名为 Really Cool 3D Picture.bmp。第二次执行同样的重命名
操作时,Really Cool 3D Picture.bmp 已存在,所以在执行重命名操作前会将其
删除。该规则的例外情况是现有的目标文件名是文件夹。
设置文件和文件夹的属性
要设置文件或文件夹的属性,请使用相同的约定创建使用可选标志的长文件名。
详细信息,请参阅“创建和删除长文件名”部分。
将文件复制到 Program Files 文件夹
下例将三个文件复制到 Program Files\Accessories 文件夹,并创建指向其中一
个文件的链接:
[WordPadInstall
CopyFiles = WordPadCopyFiles
UpdateInis = WordPadInis
 [DestinationDirs]
WordPadCopyFiles = 24,%PROGRAMF%\%ACCESSOR%
[WordPadCopyFiles]
mswd6_32.wpc
wordpad.exe
write32.wpc
[WordPadInis]
setup.ini, progman.groups,, "group4=%APPS_DESC%" ;creates Accessories
folder (if not already there)
setup.ini, group4,, """%WORDPAD_LINK%"",
""%24%\%PROGRAMF%\%ACCESSOR%\WORDPAD.EXE""" ;creates link in Accessories
 folder
[Strings]
APPS_DESC = "Accessories"
WORDPAD_LINK = "WordPad"
; Folder names - note that the short versions must match the truncated
; 8-character names for the long versions, or else there are problems.
PROGRAMF = "Progra~1" ; first 6 chars of Program_Files, + "~1"
ACCESSOR = "Access~1" ; first 6 chars of Accessories, + "~1"
.inf 文件的限制
?       不能删除目录。
?       使用 RenFiles 时不能将文件移到其他位置。(RenFiles 命令只能重命名原处
的文件。)
?       不能复制文件。(CopyFiles 命令只能将文件从源盘复制到目标目录。)
相关主题


________________________________________
在 .inf 脚本中提供卸载功能
通过添加 Install 节可以在 .inf 文件中提供卸载功能,该功能将删除文件、注
册表项和快捷方式,然后将组件添加到可从“控制面板”的“添加/删除程序”对
话框卸载的程序列表中。可以在 IEAK 工具包的 \<IEAK program
folder>\Toolkit\inf\ 文件夹中找到示例。
要将组件添加到“添加/删除程序”对话框,在下列注册表项添加新键和值:
HKLM,SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\app-name,
"DisplayName",,"description"
HKLM,SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\app-name,
"UninstallString",,"command-line"
description
该字符串会显示在“添加/删除程序”对话框的列表框中。
command-line
,从“添加/删除程序”对话框中的列表框选择组件时将执行的命令。要在 .inf
文件中执行节,可以使用 Setupx.dll InstallHinfSection 条目(在后面介绍)

下例中的 AddReg 条目将 "My Test Application" 添加到“添加/删除程序”对话
框的列表框中,并执行 Test.inf 中的 Remove_TestApp Install 节:
HKLM,SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Test,
"DisplayName",,"My
Test Application"
HKLM,SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Test,
"UninstallString",,"RunDll
setupx.dll,InstallHinfSection Remove_TestApp 4 test.inf"
 注意
?       安装组件时,安装脚本必须将 .inf 文件复制到 Windows\Inf 文件夹。调用
Setupx.dll InstallHinfSection 条目时,这是搜索的默认位置。
?       卸载脚本应删除在 Uninstall 注册表键下创建的键,这样程序卸载后将不再出
现在“添加/删除程序”列表框中。
相关主题


________________________________________
组件下载服务的 .inf 示例文件
;下面的示例 .inf 文件执行以下操作:
; - 将文件复制到 Windows、System、Inf 和 Help 文件夹。
; - 生成若干注册表项(包括将已复制的
;文件重命名为长文件名的项}。
 - 在“帮助”菜单上创建链接。
; - 有卸载节,在控制面板的“添加/删除程序”
; 对话框注册卸载操作。
; - 使用可替代字符串使本地化工作更容易。
[Version]
Signature=$CHICAGO$
[DestinationDirs]
SampleCopy = 24,%PROGRAMF%\Sample
SampleDel = 24,%PROGRAMF%\Sample
SampleWinCopy = 25
SampleSysCopy = 11
SampleINFCopy = 17
SampleHLPCopy = 18
[DefaultInstall]
CopyFiles = SampleCopy, SampleWinCopy, SampleSysCopy, SampleINFCopy,
SampleHLPCopy AddReg = SampleRegisterApp, SampleRegUninstall,
SampleRenameFiles UpdateInis = SampleAddLinks
[RemoveSample]
DelFiles = SampleWinCopy, SampleSysCopy, SampleINFCopy, SampleHLPCopy
DelReg = SampleUnRegisterApp, SampleRegUninstall
AddReg = SampleRemoveLFNs
UpdateInis = SampleRemoveLinks
[SampleCopy]
sample.bmp
[SampleWinCopy]
sample.exe
[SampleSysCopy]
sample.dll
[SampleINFCopy]
sample.inf
[SampleHLPCopy]
sample.hlp
[SampleRegisterApp]
;生成专用注册表项(Sample.exe 专用):
HKLM,Software\Sample,Installed,,"1"
[SampleUnRegisterApp]
;删除注册表项(注意这将删除项的关键字):
HKLM,Software\Sample
[SampleRegUninstall]
;将条目添加到“控制面板”的“添加/删除程序”对话框以卸载程序:
HKLM,SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Sample,
"DisplayName",,"Sample
Application"
HKLM,SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Sample,
"UninstallString",,"RunDll
setupx.dll,InstallHinfSection RemoveSample 4 sample.inf"
[SampleRenameFiles]
;将 8.3 文件名重命名为长文件名:
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Sample,,,
"%24%\%PROGRAMF%\Sample"
HKLM,Software\Microsoft\Windows\CurrentVersion\RenameFiles\Sample,
sample.bmp,,"Sample
Bitmap.bmp"
[SampleRemoveLFNs]
;在卸载期间删除带有长文件名的文件:
HKLM,Software\Microsoft\Windows\CurrentVersion\DeleteFiles\Sample,,,
"%24%\%PROGRAMF%\Sample"
HKLM,Software\Microsoft\Windows\CurrentVersion\DeleteFiles\Sample,
sample.bmp,,"Sample
Bitmap.bmp"
[SampleAddLinks]
;在“开始”菜单上添加 Sample.exe 的快捷方式:

setup.ini, progman.groups,, "Sample=%SampleFolder%" ;creates folder
setup.ini, Sample,, """%SampleDesc%"", %25%\SAMPLE.EXE" ;creates link
[SampleRemoveLinks]
;卸载期间删除“开始”菜单上的 Sample.exe 的快捷方式:
setup.ini, progman.groups,, "Sample=%SampleFolder%" ;creates folder
setup.ini, Sample,, """%SampleDesc%""" ;deletes link
[SourceDisksNames]
99 = %DiskName%,Sample,0
[SourceDisksFiles]
sample.exe = 1,,13456
sample.dll = 1,,20987
sample.bmp = 1,,64098
sample.hlp = 1,,55441
sample.inf = 1,,5687
[Strings]
PROGRAMF = "PROGRA~1"
SampleFolder = "Samples"
SampleDesc = "Sample Application"
DiskName = "Sample Application Installation Disk"
相关主题


________________________________________
安装信息文件 (.inf) 定义
基本 .inf 文件包含以下节(更加复杂的 .inf 文件可能有其他的节)。粗体表示
的节名是保留关键字。斜体表示的节名是 .inf 作者创建的任意名称:
?       Version 节
?       Install 节
o       Copy File 节 (CopyFiles)
o       Rename Files 节 (RenFiles)
o       Delete Files 节 (DelFiles)
o       Update .ini File 节 (UpdateInis)
o       Update .ini Fields 节 (UpdateIniFields)
o       Add Registry 节 (AddReg)
o       Delete Registry 节 (DelReg)
o       Add Ini File to Registry 节 (Ini2Reg)
o       Update Config.sys 节 (UpdateCfgSys)
o       Update Autoexec.bat 节 (UpdateAutoBat)
?       DestinationDirs 节
?       SourceDisksNames 节
?       SourceDisksFiles 节
?       Strings 节
?       Optional Components 节
[Version]
用于确认 .inf 文件的基本版本信息。
[DefaultInstall]
默认情况下,会执行 Installation 节。包含指向其他节的指针,该节可用于指定
要复制和删除的文件、注册表的更新、.inf 文件的更新等。
[OtherInstall]
使用与 [DefaultInstall] 节相同的格式,但是必须明确地调用。有助于定义组件
卸载方式。
[DestinationDirs]
指定在硬盘上复制、删除或重命名节文件的位置(例如 \Windows 或
Windows\System)
[FileCopy/Delete/RenameSection(s)]      列出要复制、删除或重命名的文件。
[RegistryUpdateSection(s)]      指定在注册表中添加或删除的项目。
[IniFileUpdateSection(s)]       指定 .ini 文件的更新。链接将在该节中创建。
[SourceDisksNames]
列出包含文件的磁盘。
[SourceDisksFiles]
列出每个文件所在的特定磁盘。
[Strings]
列出上面所使用的可本地化字符串。
返回到文件开始处
Version 节
[Version]
Signature="$Chicago$"
LayoutFile=filename.inf
定义所有 Windows .inf 文件的标准头信息。注意如果签名不是 $Chicago$,
Windows 不会把 .inf 文件当作 Windows 识别的任何设备类型的 .inf 文件接受

注意签名字符串的识别不会区分大小写。例如,既可以用$Chicago$,也可以用
$CHICAGO$。
filename.inf
对包含安装该组件所需布局信息(源盘和文件)的 .inf 文件加以命名。该行是可
选的。如果未在别处给出,SourceDisksNames 和 SourceDisksFiles 节必须在该
 .inf 文件中给出。
下面显示的是一个典型的 Version 节示例:
[Version]
Signature="$CHICAGO$"
返回到文件开始处
Install 节
[install-section-name]
Copyfiles = file-list-section[,<file-list-section>]...
Renfiles = file-list-section[,file-list-section]...
Delfiles = file-list-section[,file-list-section]...
UpdateInis = update-ini-section[,update-ini-section]...
UpdateIniFields = update-inifields-section[,update-inifields-section]..
.
AddReg = add-registry-section[,add-registry-section]...
DelReg = del-registry-section[,del-registry-section]...
Ini2Reg = ini-to-registry-section[,ini-to-registry-section]...
UpdateCfgSys = update-config-section
UpdateAutoBat =update-autoexec-section
标识包含组件安装信息 .inf 文件中的其他节。
在 Install 节中,以上语法中所显示的项目类型并不全是必需的。如果已经使用
某一项目类型,则必须在 .inf 文件中指定该节的名称。(CopyFiles 条目是例外
,它可以使用文件名搭配 "@" 字符来复制单个文件,而不用指定节名。)节名必
须由可打印字符组成。
在任何一个 Install 节中,只能使用一种类型的项目。一个项目中可以列出多个
节名,但是在每个附加名称前必须有逗号。
install-section-name
如果命名 Install 节 [DefaultInstall],当右键单击 .inf 文件,然后单击“安
装”时,它将运行。这也是选择 .inf 文件作为使用 Cabpack 向导的安装选项时
会执行的节。
下面显示的是一个典型的 Install 节示例。它包含 Copyfiles 和 AddReg 项目,
这两个项目可以识别包含要安装哪些文件的信息的节。
[MyApplication]
Copyfiles=MyAppWinFiles, MyAppSysFiles, @SRSutil.exe
AddReg=MyAppRegEntries
请注意,在该示例中,通过将 [MyApplication] 节重命名为 [DefaultInstall],
右键单击 .inf 文件并单击“安装”命令时,将执行 Install 节。
CopyFiles 项目提供了一个特殊符号,允许直接从复制行复制单个文件。可以通过
在文件名前加上 @ 符号作为前缀来复制单个文件。使用该符号的复制文件的目标
目录为 DefaultDestDir,该目录在 DestinationDirs 节中定义。下面显示的是如
何复制单个文件的示例:
CopyFiles=FileSection1,@myfile.txt,@anotherfile.txt,LastSectionName
返回到文件开始处
Copy Files 节 (CopyFiles)
[CopyFiles-section-name]
destination-file-name[, source-file-name][,temporary-file-name][,flag]
[destination-file-name[,source-file-name][, temporary-file-name]][,
flag]
列出要从源盘复制到目标目录的文件名。在 .inf 文件的其他节中指定源盘和与每
个文件相关的目标目录。file-list-section 名必须出现在 Install 节的
CopyFiles 项目中。
请注意,可以在 Install 节本身的 CopyFiles 项目中指定复制单个文件,而不必
生成 CopyFiles 节。为此,请使用特殊字符 "@" 强制复制单个文件。在 Install
 节的参考主题中包含在 CopyFiles 类型的项目中使用 "@" 字符的示例。使用这
种方法复制单个文件稍微有点限制,因为在这种情况下源文件名和目标文件名必须
相同,并且不能使用临时文件。
destination-file-name
目标文件名。如果没有给出源文件名,那么它也是源文件名。
source-file-name
源文件名。文件复制操作的源文件名不一定要和目标文件名完全相同。
temporary-file-name
文件复制操作的临时文件名。安装程序将复制源文件,但给它临时文件名。下一次
启动操作系统时,将把临时文件名重命名为目标文件名。在将文件复制到已打开或
 Windows 正在使用的目标文件时,该功能十分有用。
flag
在安装过程中用于执行特殊操作的可选参数。通过添加标志值创建组合标志,可以
使用多个标志。可以使用以下有效标志:
1       在 CopyFiles 上:用户企图跳过文件时,发出警告。
1       在 DelFiles 上:如果文件正在使用,则在 Wininit.ini 中删除排队延迟,否
则不能删除当前使用的文件。
2       关键安装:不允许用户跳过文件。
4       忽略版本检查并且始终复制文件。这将会覆盖较新的文件。
8       强制重命名。安装程序将该文件作为正在使用的文件进行处理。只有文件已经存
在于用户的计算机上时才会发生这种情况。
16      如果文件已经在目标计算机上,则不会复制。
32      抑制版本冲突对话框,并且不会覆盖较新的文件。
下面是复制三个文件的示例:
[CopyTheseFilesSec]
file11 ;复制 file11
file21,file22,file23 ;复制file22,临时命名为 file 23
file31,file32 ;将 file 32 复制到 file31
该示例中使用的所有源文件名都必须在 SourceDisksFiles 节中定义,并且在
SourceDisksFiles 节中出现的逻辑盘号必须在 SourceDisksNames 节中定义。或
者,可以使用 Layout.inf 文件提供该信息。
返回到文件开始处
Rename Files 节 (RenFiles)
[rename-files-section-name]
new-file-name, old-file-name
.
.
列出要重命名的文件名。此节名必须出现在 .inf 文件 Install 节 Renfiles 项
目中。
new-file-name
新文件名。
old-file-name
旧文件名。
下面的示例将 file42 重命名为 file41、将 file52 重命名为 file51 以及将
file62 重命名为 file61:
[RenameOldFilesSec]
file41, file42
file51, file52
file61, file62
必须在 SourceDisksFiles 节中定义该示例中使用的所有旧文件名(file42、
file52 和 file62),必须在 SourceDisksNames 节中定义 SourceDisksFiles 节
中显示的逻辑盘号。
返回到文件开始处
Delete Files 节 (DelFiles)
[ file-list-section]
file-name[,,,flag]
.
.
在 DelFiles 节中列出要删除的文件名。file-list-section 名必须出现在
Install 节 Delfiles 项目中。
file-name
标识要删除的文件。
flag
如果安装过程中正在使用此文件,可选参数用于强制 Windows 删除此项目中命名
的文件。要指示 Windows 将文件删除操作进行排队,直到计算机重新启动,请将
 flag 参数的值设置为 1。 如果由于正在使用该文件而不能删除参数设置为
flag=1 的文件,那么设备安装完成后系统将重新启动。
如果不与 file-name 参数一起使用值为 1 的 flag 参数,在执行 DelFiles 节时
如果正在使用该文件,则不能从计算机上删除此文件。
以下是删除三个文件的示例:
[DeleteOldFilesSec]
file1
file2
file3
返回到文件开始处
Update .ini File 节 (UpdateInis)
[ update-ini-section-name]
ini-file,ini-section,[old-ini-entry], [new-ini-entry], [flags]
.
.
在给定的 .ini 文件中,替换、删除或添加整个项。节名
update-ini-section-name 必须出现在 .inf 文件 Install 节的 UpdateInis 项
目中。
ini-file
包含要更改条目的 .ini 文件名。关于指定 .ini 文件名的详细信息,请参阅以下
注释。
ini-section
包含要更改条目的节名。
old-ini-entry
可选。常用形式为 Key=Value。
new-ini-entry
可选。常用形式为 Key=Value。主项或值都可以指定可替代字符串。例如,在参数
 new-ini-entry 中指定的主项或值可能为 %String1%,替代 %String1% 的字符串
定义在 .inf 文件的 Strings 节。
flags
可选操作标记。可以是以下值之一:
0       默认。如果在 .inf 文件条目中有 old-ini-entry 主项,则用
new-ini-entry 替换该条目。注意 old-ini-entry 参数主项与 .inf 文件条目必
须匹配;每个条目的值都将忽略。
要无条件地将 new-ini-entry 添加到 .ini 文件中,请将 old-ini-entry 设置为
 NULL。要无条件地从 .inf 文件中删除 old-ini-entry,请将 new-ini-entry 设
置为 NULL。
1       如果 .inf 文件条目中有 old-ini-entry 的主项和值,则用 new-ini-entry 替
换该条目。请注意 old-ini-entry 参数和 .inf 文件条目的主项和值必须匹配才
能进行替换。作为对比,使用操作标志值为 0,只有主项与它匹配才能进行替换。

2       如果在 .inf 文件中不存在 old-ini-entry 参数主项,那么在 .ini 文件中不
执行任何操作。
如果在 .inf 文件条目中存在 old-ini-entry 参数主项以及 .ini 文件条目中存
在 new-ini-entry 参数主项,则会删除与 new-ini-entry 参数主项匹配的 .
inf 文件条目,并且按以下方法操作与 old-ini-entry 参数匹配的 .inf 文件条
目:用 new-ini-entry 参数主项替换 .inf 文件条目主项。
如果在 .inf 文件中有 old-ini-entry 参数主项,并且在 .ini 文件中没有
new-ini-entry 参数主项,那么将条目添加到由 new-ini-entry 参数主项和旧值
组成的 .inf 文件中。
请注意 old-ini-entry 参数和 .ini 文件项是否匹配取决于主项本身,而不是主
项和值。
3       除了 old-ini-entry 参数和 .inf 文件中条目是否匹配取决于主项和值,而不
仅是主项,其他方面与上面列出的标志参数值 2 一样。
指定主项和值时可以使用星号 (*) 通配符,可以正确地解释此符号。
ini-file 名必须是字符串或字符串主项。字符串主项的形式为 %strkey%,其中
strkey 是在 .inf 文件的 Strings 节中定义的。在任何情况下名称都必须是有效
文件名。
名称应包括文件所在文件夹的名称,但是文件夹名应以逻辑目录标识符 (LDID) 指
定,而不是实际名称。在安装期间安装程序将用实际名称替换 LDID。
LDID 的形式为 %ldid%,其中 ldid 是预定义标识符或在 DestinationDirs 节中
定义的标识符。注意常数 LDID_BOOT 和 LDID_BOOTHOST 被替换,在路径中加上反
斜线。例如,LDID_BOOT 用 C:\ 替换。但是在 .inf 文件中可以使用反斜线,也
可以不使用。例如,在引导驱动器的根中,可以使用“%30%boot.ini”和“
%30%\boot.ini”来引用 BOOT.ini。
下例说明 .inf 文件的 Update .ini File 节中的单个项目:
%11%\sample.ini, Section1,, Value1=2 ;添加新项目
%11%\sample.ini, Section2, Value3=*, ;删除旧项
%11%\sample.ini, Section4, Value5=1, Value5=4 ;替换旧项
.inf 文件“Update .ini File-type”节中的下列项目组与 SYSTEM.ini中的 Boot
 节一起进行操作。强制编入 .inf 文件项目的 flags 参数用于将条目 "comm.
drv=comm.drv" 添加到 Boot 节,除非在 Boot 节存在条目 "comm.
drv=*vcoscomm.drv" 或 "comm.drv=*r0dmdcom.drv",在这种情况下将保留现有的
条目,且不将条目 "comm.drv=comm.drv" 添加到 .ini 文件中。换句话说,执行
下面显示的四个 .inf 文件条目后,将有一个 "comm.drv=" 条目在 .inf 文件的
 Boot 节中:"comm.drv=*vcoscomm.drv"、"comm.drv=*r0dmdcom.drv" 或
"comm.drv=comm.drv"。
system.ini, boot, "comm.drv=*vcoscomm.drv","~CommDrvTemp~=*", 3
system.ini, boot, "comm.drv=*r0dmdcom.drv","~CommDrvTemp~=*", 3
system.ini, boot,,"comm.drv=comm.drv"
system.ini, boot, "~CommDrvTemp~=*","comm.drv=*", 3
返回到文件开始处
Update .ini Fields 节 (UpdateIniFields)
[ update-inifields-section-name ]
ini-file, ini-section, profile-name, [old-field], [new-field],[flags]
.
.
在给定 .ini 项的值中,替换、添加和删除字段。与 Update .ini File 节类型不
同,此节的类型将替换、添加或删除 .inf 文件条目中的部分值,而不是全部值。
节名 update-inifields-section-name 必须出现在 .inf 文件 Install 节的
UpdateIniFields 项目中。关于指定 .ini 文件名的详细信息,请参阅说明
Update .ini File 节类型的主题。
ini-section
包含要更改条目的 .ini 文件节名。
profile-name
要更改条目的名称。
old-field
要删除的“字段”值。
new-field
要添加原来没有的字段值。
flags
指定是否处理 old-field 和 new-field 参数,例如是否能有通配符或在 .inf 文
件末尾添加新字段时使用何种分隔符。可以是以下这些值中的任意值:
值      意义
0       (默认值)字段匹配时,逐字处理 "*" 字符,而不将它当作通配符。将新字段
添加到条目中时,使用空格 (" ") 作为分隔符。
1       字段匹配时,将 "*" 字符当作通配符处理。将新字段添加到条目中时,使用空
格 (" ") 作为分隔符。
2       字段匹配时,逐字处理 "*" 字符,而不将它当作通配符。将新字段添加到条目
中时,使用逗号 (",") 作为分隔符。
3       字段匹配时,将 "*" 字符当作通配符处理。将新字段添加到条目中时,使用逗
号 (",") 作为分隔符。
删除 .ini 文件行中的任何注释,因为在更改后这些字段可能不再适用。处理 .
inf 文件行的字段时,使用空格、制表符和逗号作为字段分隔符。但是在新字段添
加到这一行时,将使用空格作为分隔符。
返回到文件开始处
Add Registry 节 (AddReg)
[ add-registry-section]
reg-root-string, [subkey], [value-name], [flag], [value]
[reg-root-string, [subkey], [value-name], [flag], [value]]
.
.
将子项或值名添加到注册表,可以有选择地设置它的值。add-registry-section
名必须显示在 Install 节的 AddReg 类项目中。
reg-root-string
注册表根名。可以是以下值之一:
HKCR 与 HKEY_CLASSES_ROOT 相同
HKCU 与 HKEY_CURRENT_USER 相同
HKLM 与 HKEY_LOCAL_MACHINE 相同
HKU 与 HKEY_USERS 相同。
HKR 意味着与传递到 GenInstallEx 的关键值有关。
subkey
是可选的。标识要设置的子项。形式为 key1可以将该参数表示为可替代字符串。
例如可以使用%Subkey1%,在 .inf 文件的 Strings 节中定义要替代 %Subkey1%
的字符串。
value-name
可选。标识 subkey 的值名。对于字符串类型,如果 value-name 参数为空,那么
在 subkey 参数中指定的子项值将设置为 NULL 字符串。请注意,可以将
value-name 参数表示为可替代字符串。例如,可以使用 %Valname1%,在 .inf 文
件的 Strings 节定义替换 %Valname1% 的字符串。
flag
可选。确定值的类型,以及如果注册表项已经存在,是否需要替换注册表项。
值      意义
0       (默认) 值为 ANSI 字符串。如果存在,则替换注册表项。
1       值为十六进制数。如果存在,则替换注册表项。
2       值为 ANSI 字符串。如果存在,不替换注册表主项。
3       值为十六进制数。如果存在,不替换注册表主项。
value-name
可选。设置值。它可以是 ANSI 字符串、十六进制符号或 Intel 格式的数字。包
含二进制值的任何项目都可以用反斜线 (\) 符号扩展。也可以给出 %strkey% 形
式的字符串主项。必须在 .inf 文件的 Strings 节中定义 strkey。要在该行中使
用字符 %,请使用 %%。
至少需要两个字段;但是一个可以是空的。因此使用该形式时至少需要一个逗号。

在 AddReg-type 节的以下示例中,有两个项目将两个值名添加到注册表中。注意
 %25% 将扩展到计算机的 Windows 文件夹中。
[MyAppRegEntries]
HKLM,Software\MyApp,ProgramName,,"My Application"
HKLM,Software\MyApp,"Program Location",,"%25%\MyApp.exe"
返回到文件开始处
Delete Registry 节 (DelReg)
[ del-registry-section]
reg-root-string, subkey, [value-name]
[reg-root-string, subkey, [value-name]]
.
.
从注册表删除子项或值名。del-registry-section 名必须出现在 Install 节的
DelReg 项目中。
reg-root-string
注册表根名。可以是以下值之一:
HKCR 与 HKEY_CLASSES_ROOT 相同
HKCU 与 HKEY_CURRENT_USER 相同
HKLM 与 HKEY_LOCAL_MACHINE 相同
HKU 与 HKEY_USERS相同。
HKR 意味着与传递到 GenInstallEx 的关键值有关。
subkey
标识要删除的子项。形式为 key1\key2\key3...。可以将该参数表示为可替代字符
串。例如可以使用 %Subkey1%,在 .inf 文件的 Strings 节中定义要替代
%Subkey1% 的字符串。
value-name
可选。标识 subkey 的值名。请注意,可以将 value-name 参数表示为可替代字符
串。例如,可以使用 %Valname1%,在 .inf 文件的 Strings 节定义替换
%Valname1% 的字符串。
该节的类型可以包含任何数量的项目。每个项目都从注册表中删除一个子项或值名

Ini File to Registry 节 (Ini2Reg)
[ ini-to-registry-section]
ini-file, ini-section, [ini-key], reg-root-string, subkey[,flags]
.
.
将行和节从.ini 文件移动到注册表,在注册表中给定的主项下创建或代替注册表
项。节名 ini-to-registry-section 必须出现在 .inf 文件 Install 节的
Ini2Reg 项目中。
ini-file
包含要复制注册表项的 .ini 文件名。关于指定 .ini 文件名的详细信息,请参阅
关于 Update .ini File 节的参考主题。
ini-section
包含要复制注册表项 .inf 文件中的节名。
ini-key
要复制到注册表的 .inf 文件中的注册表项名。如果 ini-key 为空,则将整节转
换为指定的注册表项。
reg-root-string
注册表根名。可以是以下值之一:
HKCR 与 HKEY_CLASSES_ROOT 相同
HKCU 与 HKEY_CURRENT_USER 相同
HKLM 与 HKEY_LOCAL_MACHINE 相同
HKU 与 HKEY_USERS相同。
HKR 意味着与传递到 GenInstallEx 的关键值有关。
subkey
标识要接收该值的子项。形式为 key1\key2\key3...。
flags
指示转换为注册表后是否删除 .ini 主项,以及如果注册表主项已存在,是否覆盖
注册表中的值。可以是以下值之一:
值      意义
0       (默认值)将条目中的信息移到注册表后不从 .ini 文件中删除 .ini 条目。如
果注册表子项已存在,则不替换当前值。
1       将条目中的信息移到注册表后从 .ini 文件中删除 .ini 条目。如果注册表子项
已存在,则不替换当前值。
2       将条目中的信息移到注册表中后不从 .ini 文件中删除 .ini 条目。如果注册表
子项已存在,则用 .ini 文件条目的值替换当前值。
3       将条目中的信息移到注册表后从 .ini 文件中删除 .ini 条目。如果注册表子项
已存在,则用 .ini 文件条目的值替换当前值。
例如,假设在 Win.ini 文件中存在以下条目:
[Windows]
CursorBlinkRate=15
如果在 Control Panel\Desktop 下不存在 CursorBlinkRate 子项,那么 Ini
File to Registry 节中的下列项目将创建子项,并把它的值设置为 15,而且不更
改 WIN..ini 中原有的行:
win.ini,Windows,CursorBlinkRate,HKCU,"Control Panel\Desktop"
如果注册表子项已存在,则 .inf 文件项目将注册表子项的值设置为 15,并且不
更改 WIN..ini 中原有的行。
Update Config.sys 节 (UpdateCfgSys)
[update-config-section]
Buffers=legal-dos-buffer-value
DelKey=key
DevAddDev=driver-name,configkeyword[,flag][,param-string]
DevDelete=device-driver-name
DevRename=current-dev-name,new-dev-name
Files=legal-dos-files-value
PrefixPath=ldid[,ldid]
RemKey=key
Stacks=dos-stacks-values
提供命令,添加、删除或重命名 Config.sys 文件中的命令。节名
update-config-section-name 必须出现在 .inf 文件 Install 节的
UpdateConfigSys 项目中。
并不是前面所列语法中的所有项目类型都是必需的。Update Config.sys 节可以根
据需要包含 DevRename、DevDelete、DevAddDev、DelKey 和 RemKey,但是在一节
中只能使用项目 Buffers、Files 和 Stacks 一次。处理 Update Config.sys 节
时,安装程序将先处理所有的 DevRenames 项目,然后处理所有的 DevDelete 项
目,最后处理所有的 DevAddDev 项目。可在 Update Config.sys 节中使用的每种
项目的语法和意义将在显示在后面的主题中。
Buffers 项目
Buffers=legal-dos-buffer-value
设置文件缓冲区的数目。与 Stacks 项目一样,安装程序比较现有值与建议值,然
后将文件缓冲区设置为两者中的较大者。
legal-dos-buffers-value
合法的 MS-DOS 缓冲区值。
DelKey 项目
DelKey=key
在 Config.sys 文件中对带有指定主项的 Config.sys 命令加以注释。例如,下列
 .inf 文件项目中:
DelKey=Break
在 Config.sys 文件中对 Break=on 命令加以注释。
DelKey 项目和 RemKey 项目有相同的效果。在 .inf 文件的节中可以有多个
DelKey 和/或 RemKey 项目。
key
对 Config.sys 命令的主项加以注释。
DevAddDev 项目
DevAddDev=driver-name,configkeyword[,flag][,param-string]
将 device 或 install 命令添加到 CONFIG.SYS 文件中。
driver-name
要添加驱动器或可执行文件的名称。 安装程序将核实文件扩展名,确保扩展名是
 .sys 或 .exe。
configkeyword
命令名。可以是设备或安装程序。
flag
可选的位置标志。如果是 0,将命令放在文件末尾。如果是 1,则放在顶端。如果
没有给定标志,则默认为 0。
param-string
可选的命令参数。对给定的设备驱动程序或可执行文件必须有效。
DevDelete 项目
DevDelete=device-driver-name
从 Config.sys 文件中删除包含指定文件名的任何行。
device-driver-name
文件名或设备驱动程序名。安装程序在 Config.sys 文件中搜索此名称,并删除包
含该名称的任何命令行。因为 MS-DOS 不允许在 Config.sys 文件中省略文件扩展
名,所以每个 device-driver-name 都必须明确指定文件扩展名。
下例中,Update Config.sys 节的以下DevDelete 项目将删除命令的第 1 行和第
 3 行,但不删除 Config.sys 示例文件的第 2 行:
DevDelete=filename.sys
;; lines in Config.sys
Device=Filename.sys ;; line #1
Install=Filename.exe ;; line #2
Device=Filename.sys /d:b800 /I:3 ;; line #3
DevRename 项目
DevRename=current-dev-name,new-dev-name
重命名 Config.sys 文件中的设备驱动程序。
current-dev-name
要更改的设备驱动程序或可执行文件的名称。安装程序将在 Config.sys 文件中查
找 device 或 install 命令右边的名称。
new-dev-name
驱动程序或可执行文件的新名称。
Files 项目
Files=legal-dos-files-value
在 Config.sys 文件中设置可打开文件的最大数目。与 Stacks 项目一样,安装程
序比较现有值和建议值,然后将可打开的最多文件数设置为两者中的较大者。
legal-dos-files-value
合法的 MS-DOS 文件值。
PrefixPath 项目
PrefixPath=ldid[,ldid]
将与给定的 LDID 相关的路径附加到路径命令中。
ldid
可以是任何预定义 LDID 值或在 .inf 文件中定义的新值。关于所有预定义
LDID 值的定义,请参阅 DestinationDirs 节的“参考”主题。
RemKey 项目
RemKey=key
可在 Config.sys 文件中使用指定主项对 Config.sys 命令加以注释。例如,下列
 .inf 文件项目中:
RemKey=Break
在 Config.sys 文件中对 Break=on 命令加以注释。
RemKey 项目和 DelKey 项目具有相同的效果。在 .inf 文件的节中可以有多个
RemKey 和/或 DelKey 项目。
key
对 Config.sys 命令的主项加以注释。
Stacks 项目
Stacks=dos-stacks-values
在 Config.sys 文件中设置堆栈的数量和大小。安装程序会比较现有值与建议值,
然后把堆栈设置为两者中的较大者。例如,如果 Config.sys 文件包含
stacks=9,218,并且 .inf 文件包含 stacks=5,256,那么安装程序会把新值设置
为 stacks=9,256。
legal-dos-stacks-value
合法的 MS-DOS 堆栈值。
返回到文件开始处
Update Autoexec.bat 节 (UpdateAutoBat)
[ update-autoexec-section]
CmdAdd=command-name[,command-parameters]
CmdDelete=command-name
PrefixPath=ldid[,ldid]
RemOldPath=ldid[,ldid]
TmpDir=ldid[,subdir]
UnSet=env-var-name
提供命令,用于处理 Autoexec.bat 文件中的命令行。节名
update-ini-section-name 必须出现在 .inf 文件 Install 节的 UpdateInis 项
目中。
Update Autoexec.bat 节并不需要上面所列语法中的所有项目类型。该节可以根据
需要包含 CmdAdd、CmdDelete 和 UnSet 项目,但是在 .inf 文件中 PrefixPath
、RemOldPath 和 TmpDir 项目只能使用一次。每种项目类型的语法和意义将在本
主题之后介绍。
安装程序将在任何 CmdAdd 项目前处理所有的 CmdDelete 项目。
CmdAdd 项目
CmdAdd =command-name[,"command-parameters"]
将给定的命令以及可选命令参数添加到 Autoexec.bat 文件末尾。
command-name
可执行文件的名称,可以有扩展名,也可以没有。如果在 .inf 文件的
SourceDisksFiles 和 DestinationDirs 节中也定义了文件名,那么安装程序在把
它写入到 Autoexec.bat 文件之前会将正确的路径添加到文件名中。
command-parameters
用双引号引起来的字符串或象 %String1% 或 %Myparam% 的可替代字符串,应在
.inf 文件的 Strings 节定义替代 %String1% 和 %Myparam% 的字符串。安装程序
在把行附加到 Autoexec.bat 文件末尾之前,将字符串附加到 command-name。该
行的格式取决于所给可执行文件的命令行要求。
CmdDelete 项目
CmdDelete=command-name
从 Autoexec.bat 文件中删除包括给定命令名的任何命令行。安装程序将搜索给定
名称中带 .exe、.com 和 .bat 扩展名的文件,并删除所找到的文件。
command-name
无扩展名的可执行文件名。
PrefixPath 项目
PrefixPath=ldid[,ldid]...
将与给定的 LDID 相关的路径附加到路径命令中。
ldid
可以是任何预定义 LDID 值或在 .inf 文件中定义的新值。关于所有预定义
LDID 值的定义,请参阅 DestinationDirs 节的“参考”主题。
RemOldPath 项目
RemOldPath=ldid[,ldid]
从命令路径中删除与给定 LDID 相关的路径。例如,如果用户把新版本的 Windows
 安装到 C: \Newwin 并在 C:\Windows 中有旧版本,则下列 .inf 文件项将从路
径环境变量删除 C:\Windows:
RemOldPath=10
ldid
可以是任何预定义 LDID 值和在 .inf 文件中定义的新值。关于所有预定义
LDID 值的定义,请参阅 DestinationDirs 节的“参考”主题。
TmpDir 项目
TmpDir=ldid[,subdir]
如果不存在,可以在 LDID 给定的文件夹内创建临时文件夹。
ldid
可以是任何预定义 LDID 值或在 .inf 文件中定义的新值。关于所有预定义
LDID 值的定义,请参阅 DestinationDirs 节的“参考”主题。
subdir
路径名。如果 ldid\subdir 不存在,则创建它。
UnSet 项目
UnSet=env-var-name
从 Autoexec.bat 文件中删除包括给定环境变量名的任何 set 命令。
env-var-name
环境变量名。
返回到文件开始处
DestinationDirs 节
[DestinationDirs]
file-list-section =ldid[, subdir ]
.
.
[DefaultDestDir=ldid[, subdir ]]
DestinationDirs 节定义 file-list 节中指定操作(可以是 CopyFiles、
RenFiles 或 DelFiles 节)的目标目录。另外,可在 .inf 文件中的任何
CopyFiles、RenFiles 或 DelFiles 节指定默认目标文件夹,不需要在
DestinationDirs 节中明确地命名。
file-list-section
CopyFiles、RenFiles 或 DelFiles 节的名称。必须在 Install 节的 Copyfiles
、RenFiles 或 DelFiles 项目中引用该名称。
ldid
逻辑磁盘标识 (LDID)。可以是以下值之一:
00      Null LDID - 可用于创建新的 LDID
01      源驱动器:\pathname
10      Machine 文件夹(在基于服务器的安装时,映射 Windows 文件夹。
11      System 文件夹
12      IOSubsys 文件夹
13      Command 文件夹
17      Inffolder
18      Help 文件夹
20      Fonts
21      Viewers
22      VMM32
23      Color 文件夹
24      包含 Windows 文件夹的驱动器根目录
25      Windows 文件夹
26      Windows 的约定引导设备 (Winboot)
28      Host Winboot
30      启动盘的根文件夹
31      虚拟启动盘的主驱动器根文件夹
subdir
LDID 所命名的文件夹中要成为为目标文件夹中的子文件夹名。
可选 DefaultDestDir 项目为任何 CopyFiles 项目提供默认目标目录,可以使用
直接复制 (@file name) 符号或未在 DestinationDirs 节中指定的任何
CopyFiles、RenFiles 或 DelFiles 节。如果在 DestinationDirs 节中没有使用
 DefaultDestDir,则将默认文件夹设置为 LDID_WIN。
下例将 MoveMiniPort 节的目标文件夹设置为 Windows\Ilsybsys,将其他节的默
认文件夹设为启动盘上的 Bin 文件夹:
 [DestinationDirs]
MoveMiniPort=12 ;MoveMiniPort 节的目标文件夹是
; windows\iosubsys
DefaultDestDirs=30,bin ; 复制到 boot:\bin
返回到文件开始处
SourceDisksNames 节
[SourceDisksNames]
disk-ordinal="disk-description",disk-label,disk-serial-number
.
.
识别并命名包含文件复制和重命名操作的源文件的磁盘。
disk-ordinal
标识源盘的唯一号码。如果有多个源盘,则每个源盘都必须有唯一的序号。
disk-description
说明这张磁盘的内容或用途的字符串或字符串主项。安装程序向用户显示该字符串
以标识磁盘。此说明文字用双引号引起来。
disk-label
格式化源盘时设置的源盘卷标。
disk-serial-number
未使用。则值必须为 0。
下例标识一张源盘。根据字符串主项给出磁盘说明:
[SourceDisksNames]
55 = %ID1%, Instd1, 0
[Strings]
ID1="My Application Installation Disk 1"
返回到文件开始处
SourceDisksFiles 节
[SourceDisksFiles]
file name=disk-number[,subdir] [,file-size]
.
.
color=#000000 命名安装过程中使用的源文件,并识别包含文件的源盘。
color=#000000 filename
color=#000000 源盘上的文件名。
disk-number
color=#000000 包含文件的源盘序号。必须在 SourceDisksNames 节中定义序号,
而且必须是大于或等于 1 的值(0 是无效的盘号参数值)。
subdir
指定文件所在源盘上子文件夹的可选参数。如果没有使用该参数,则默认值是源盘
上的根文件夹。
file-size 可选参数,以字节为单位指定文件大小。
color=#000000 以下 SourceDisksFiles 节示例标识序列号为 1 的磁盘上的单个
源文件 SRS01.386:
[SourceDisksFiles]
SRS01.386 = 1
返回到文件开始处
Strings 节
[Strings]
strings-key=value
.
.
定义一个或多个字符串主项。字符串主项是由可打印字符串所表示的名称。尽管
Strings 节通常是 .inf 文件的最后一节,但是该节中所定义的字符串主项可能用
于 .inf 文件中使用相应字符串的任何地方。安装程序将把字符串主项扩展到给定
的字符串,并将它用于进一步的处理。必须使用百分号 (%) 将字符串主项包围起
来。
strings-key
由字符和数字组成的唯一名称。
value
由字母、数字或其他可打印字符组成的字符串。如果在项目类型中使用需要双引号
的相应字符串主项,则应该用双引号将它引起来。
Strings 节使面向国际市场的字符串翻译工作变得非常简单,您只需在 .inf 文件
的单独一节中使用 .inf 文件时,放置可在用户界面中显示的所有字符串。无论何
时,都应该使用字符串主项。
下例显示 .inf 示例文件的 Strings 节。
[Strings]
String0="My Application"
String1="My Application Readme File"
String2="CX2590 SCSI Adapter"
返回到文件开始处
Optional Components 节
[Optional Components]
install-section-name
[install-section-name]
.
.
列出用户单击“控制面板”上的“添加/删除程序”图标,单击“安装 Windows”
选项卡,然后单击“从磁盘安装”按钮时,显示的 Install 节 .
。在列表中 Install 节会当作复选框显示。
注意,用鼠标右键单击 .inf 文件并选择“安装”命令执行 .inf 文件时,将忽略
 Optional Components 节。以这种方式执行 .inf 文件时,将执行
[DefaultInstall] 节。如果通过 Setupx.dll InstallHinfSection 条目点执行
.inf 文件,也将忽略 Optional Components 节。通过 SETUPX 条目执行 .inf 文
件时,将执行在条目参数中指定的 Install 节。
Install 节与以前介绍的格式一样,可以将下面的主项添加到 Install 节以启动
“从磁盘安装”对话框中的界面:
OptionDesc=option-description
Tip=tip-description
InstallDefault=0 | 1 ; 是否在默认情况下安装此组件。1=Yes, 0=No.
IconIndex=icon-index
Parent=install-section-name
Needs=install-section-name, [install-section-name]
Include=inf-file, [inf-file]
option-description
列表框中当作组件名所使用的字符串值。option-description 参数可以是
%String1%,在 .inf 文件的 Strings 节中定义要替代 %String1% 的字符串。
tip-description
在列表框中选定组件时,在“说明”框中所显示的字符串值。tip-description 参
数最多可为 255 个字符,并且可以是 %String1%,在 .inf 文件的 Strings 节中
定义要替代 %String1% 的字符串。
icon-index
决定显示在组件名旁边的小图标的数值。有效值是:0 机器(基础和显示)
1 集成电路芯片
2 显示器
3 网线
4 Windows 标志
5 鼠标
6 键盘(3 键)
7 话筒
8 扬声器
9 硬盘
10 串口连接器
11 菱形框(默认值)
12 复选框
13 未选中的复选框
14 打印机
15 网卡
16 形如 0 的图符 17 与 0 形状相似,下面带共享的手形图符
18 未知(问号)
19 正在工作的图符
20 显示为灰色的复选框
21 拨号网络
22 直接电缆连接
23 公文包
24 Exchange
25 部分选中
26 附件组
27 多媒体组
28 快速查看
29 MSN
30 计算器
31 磁盘碎片整理程序
32 一般文档
33 磁盘整理程序
34 纸牌
35 超级终端
36 对象软件包
37 画图
38 屏幕保护
39 写字板
40 剪贴板查看程序
41 辅助选项
42 备份
43 位图文档
44 字符映射表
45 鼠标指针
46 网络监视器
47 电话拨号器
48 系统监视器
49 帮助手册
50 地球(区域设置)
51 音频压缩
52 CD 播放器
53 媒体播放机
54 声音方案
55 视频剪辑
56 视频压缩
57 音量控制
58 “乐曲”配音方案
59 “蛙鸣”配音方案
60 “金属声”配音方案
61 “幻想空间”配音方案
Parent
在可选组件界面中所显示的列表框可以包含子层。如果可选组件是子组件,则
Parent= keyword 定义父组件的 Install 节。
Needs
如果组件从属于其他组件,则这将定义该组件所需要的 Install 节。如果选中该
组件,系统将警告用户该组件需要在Needs= 行列出 Install 节中描述的组件。
注意在Needs= 行列出的 Install 节必须在同一个 .inf 文件中。但是,如果在
Needs= 行上列出其他 .inf 文件的从属组件,则必须在 Include= 行上指定 .inf
 文件。
Include
Include 项目允许您指定 .inf 文件,而安装程序在加载 .inf 文件时也必须把
.inf 文件调入内存,因为这些 .inf 文件包含除 .inf 文件中 Install 节外必须
运行的节。Needs 项目指定要在已包括的 .inf 文件中运行的节名。
下例定义两个可选组件安装节,每个安装节使用其他条目来指定界面元素和从属性

[Optional Components]
InstallMyToys
InstallGames
[InstallMyToys]
OptionDesc=%Toys_DESC%
Tip=%Tomytoysys_TIP%
IconIndex=35 ;Phone mini-icon for dialogs
Parent=MailApps
Needs=MSMAIL, MAPI, MicrosoftNetwork
Include=mos.inf, msmail.inf
CopyFiles=MyToysFiles
UpdateInis=MyToysLinks
AddReg=MyToysRegItems
[InstallOtherApps]
OptionDesc=%Other_DESC%
Tip=%Other_TIP%
IconIndex=4 ; windows mini icon for dialogs
CopyFiles=OtherFiles
UpdateInis=OtherLinks
AddReg=OtherRegItems
[Strings]
Toys_DESC="Mail Utilities"
Toys_TIP="Additional utilities for sending and organizing mail"
Other_DESC="Other Helpful Utilities"
Other_TIP="Calculator, disk checker and performance monitor"
返回到文件开始处
相关主题


________________________________________
使用 RunOnce 技术
执行 .inf 文件向 RunOnce 注册表项添加条目后,可以运行任意程序。RunOnce
条目在计算机下次重启动,用户登录系统(如果可以系统登录)时执行。
Runonce 注册表主项允许您同时在 Windows 中启动多个程序,并指定是否应“无
提示”运行(不给用户提示)或作为用户所看到的程序或操作列表的一部分。随后
删除对程序的引用以便不再运行程序。
要无提示运行程序,请在以下注册表主项下添加
description-string=command-line 条目:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RunOnce
要在 Windows Runonce 管理器中同步运行程序,请在以下注册表主项下添加
description-string=command-line 条目:
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\RunOnce\Set
up
下面的例子说明导致一些问题的 AddReg 节:
?       无需用户界面启动 Myapp.exe(位于 Windows 文件夹)。
HKLM,Software\Microsoft\Windows\CurrentVersion\RunOnce,"SilentApp",,
"%25%\myapp.exe"
?       执行 Test.exe(位于系统文件夹中),显示消息“Windows 安装程序正安装下
列项目”:
HKLM,Software\Microsoft\Windows\CurrentVersion\RunOnce\Setup,"Test
Utility",,"%11%\test.exe"
 注意
?       安装程序注册表项下的说明字符串显示在用户界面中。
相关主题

--
HappyShow 下载地址:
校内:http://192.168.79.27
校外:http://www.onlinedown.net/soft/16492.htm
 HappyShow电影插件包下载:http://192.168.79.27
  HappyShow 电影插件包下载:http://happyshow.3322.org

※ 来源:·荔园晨风BBS站 bbs.szu.edu.cn·[FROM: 192.168.79.27]


[回到开始] [上一篇][下一篇]

荔园在线首页 友情链接:深圳大学 深大招生 荔园晨风BBS S-Term软件 网络书店