INF文件必须包含以下规则:
节(Sections)开始于由中括号([])扩起来的节名
必须包含版本信息节以表明自己属于win95还是winnt4格式。
值(Value)由%strkey%替代的表达式字符串表达组成,strkey必须在strings节中定义。如果出现%,则用%%替代。
Setup程序使用以下各节:
[Version] 必须包含在INF文件中,表明inf文件格式
[Version]
Signature="signature-name"
Class=class-name
ClassGUID=GUID
Provider=INF-creator
LayoutFile=filename.inf[,filename.inf]...
Signature-name
参数可以取值 $Windows NT$, $Chicago$, or $Windows 95$(引号括起来).如果不是以上这些字符串,则不被认可为inf文件。
Class-name
此参数用于安装设备驱动。详细信息见DDK Programmer's Guide.
GUID
此参数用于安装设备驱动。详细信息见DDK Programmer's Guide.
INF-creator
标示INF的创建者. 典型的情况,此值为inf文件的创建者所在组织
filename.inf
INF文件必须包含SourceDisksFiles 和 SourceDisksNames 节。这些文件的描述文件通常命名为 LAYOUT.INF. 如果文件名不是特别指定,SourceDisksNames 和 SourceDisksFiles 必须出现在当前inf文件中
以下为典型的例子:
[Version]
Signature="$Windows NT$"
Class=Mouse
ClassGUID={4D36E96F-E325-11CE-BFC1-08002BE10318}
Provider=%Provider%
LayoutFile=layout.inf
[Strings]
Provider="Corporation X"
[Install] 此节指定包含的安装指令节,每一个条目将会成为一节
[install-section-name]
LogConfig=log-config-section-name[,log-config-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]...
以上各条目并非全部必须。节名必须为可见字符。每个条目包含一到多个节。第一个命名之后的所有命名必须以,引导。条目指定了必须出现在INF文件中的各节。CopyFiles则可例外(如果没有任何文件被拷贝)。
如果安装驱动程序,仅仅使用LogConfig条目。详见DDK Programmer's Guide.
CopyFiles条目中可以包含特殊字符@ 以直接拷贝一个单一文件。文件将拷贝到DefaultDestDir, DestinationDirs节包含了DefaultDestDir的描述。如例子:
[MyInstall]
CopyFiles= @MyFile.exe
此文件将拷贝到缺省目标目录。
为适应不同平台,可以在install节后加上不同的后缀。可以出现defaultInstall.nt这样的节名。install-section-name可选的后缀:
Extension Platform
.Win Windows 95
.NT Windows NT (all platforms)
.NTx86 Windows NT (x86 only)
.NTMIPS Windows NT (MIPS only)
.NTAlpha Windows NT (Alpha only)
.NTPPC Windows NT (PowerPC only)
以下例子展示了如何出现两个copyfiles节:
[Ser_Inst]
CopyFiles=Ser_CopyFiles, mouclass_CopyFiles
[Ser_CopyFiles]
sermouse.sys
[mouclass_CopyFiles]
mouclass.sys
[Add Registry] 描述如何增加注册表项目。add-registry-section 节名必须处现在install节中的 AddReg 条目中。
[add-registry-section]
reg-root-string, [subkey], [value-name], [flags], [value]
[reg-root-string, [subkey], [value-name], [flags], [value]]
reg-root-string 注册表的根名:
HKCR HKEY_CLASSES_ROOT.
HKCU HKEY_CURRENT_USER.
HKLM HKEY_LOCAL_MACHINE.
HKU HKEY_USERS.
HKR 相关于 SetupInstallFromInfSection.节中指定的值
subkey
可选,例如 key1/key2/key3....
value-name
可选,标示subkey的值名称。对于字符串类型可以空,标示缺省字符串值
flag 值类型的标示
Value Meaning
FLG_ADDREG_BINVALUETYPE The value is "raw" data.
FLG_ADDREG_NOCLOBBER 如果注册表中出现不要覆盖此值.
FLG_ADDREG_DELVAL 从注册表中删除此键
FLG_ADDREG_APPEND 追加一个值到已存值中,仅仅支持REG_MULTI_SZ 值
FLG_ADDREG_TYPE_MASK Mask.
FLG_ADDREG_TYPE_SZ REG_SZ类型
FLG_ADDREG_TYPE_MULTI_SZ REG_MULTI_SZ.
FLG_ADDREG_TYPE_EXPAND_SZ REG_EXPAND_SZ.
FLG_ADDREG_TYPE_BINARY REG_BINARY.
FLG_ADDREG_TYPE_DWORD REG_DWORD.
FLG_ADDREG_TYPE_NONE REG_NONE.
Windows 95 安装程序将视扩展数据类型为REG_SZ or REG_BINARY.
value
可选. 16进值或者字符串
[CopyFiles] 此类节可以有多个,定义于install节中。
[file-list-section]
destination-file-name[,source-file-name][,temporary-file-name][,flag]
[destination-file-name[,source-file-name][,temporary-file-name]][,flag]
.
destination-file-name
目标文件名,如果没有给出源文件名,那么此名也是源文件名.
source-file-name
源文件名,如果没有给出目标文件名,那么此名也是目标文件名.
temporary-file-name
被忽略,setup函数自动处理临时文件.
flag
可选,用于控制文件如何被拷贝。你必须配置实际值
COPYFLG_WARN_IF_SKIP (0x00000001)
如果用户试图在发生一个错误后跳过将显示警告信息
COPYFLG_NOSKIP (0x00000002)
不允许用户跳过拷贝此文件
COPYFLG_NOVERSIONCHECK (0x00000004)
如果文件存在于目标目录,忽略
COPYFLG_FORCE_FILE_IN_USE (0x00000008)
替换被使用得文件?,当拷贝时文件被使用
COPYFLG_NO_OVERWRITE (0x00000010)
不覆盖目标文件中已存文件
COPYFLG_NO_VERSION_DIALOG (0x00000020)
如果目标文件已存且新则不覆盖也不出现对话框
COPYFLG_REPLACEONLY (0x00000040)
替换目标文件
[delete Registry] 描述如何增加注册表项目。del-registry-section 节名必须处现在install节中的 DelReg 条目中。
[del-registry-section]
reg-root-string, [subkey], [value-name], [flags], [value]
[reg-root-string, [subkey], [value-name], [flags], [value]]
reg-root-string 注册表的根名:
HKCR HKEY_CLASSES_ROOT.
HKCU HKEY_CURRENT_USER.
HKLM HKEY_LOCAL_MACHINE.
HKU HKEY_USERS.
HKR 相关于 SetupInstallFromInfSection.节中指定的值
subkey
value-name
可选,标示subkey的值名称。对于字符串类型可以空,标示缺省字符串值
[Delete Files] 此节指定需要被删除的文件,节名必须出现在install中的delfiles条目中
[file-list-section]
file-name[,,,flag]
flag
可选。
DELFLG_IN_USE (0x00000001)
当因为文件正被使用,SetupCommitFileQueue 取消, 将排队在系统重新启动时候被删除。
如果不使用此值,则安装时候被使用的文件不会被delete files指定节删除
DELFLG_IN_USE1 (0x00010000)
高字节版本的DELFLG_IN_USE. Setting DELFLG_IN_USE1 差别在于同样可适用于Copyfiles节和delete Files节即使COPYFLG_WARN_IF_SKIP 标志被使用。
[INI File to Registry] 此节指示那些ini文件中的条目将对应到注册表。
[ini-to-registry-section]
ini-file, ini-section, [ini-key],reg-root-string,subkey[,flags]
ini-file
ini文件名.
ini-section
ini文件的节
ini-key
条目
flags
指示当注册表存在对应的注册表项目是否是否覆盖旧值。
Bit value
0 0 缺省,不删除ini文件项目,当ini转移到注册表后
0 1 删除ini文件中的项目,当ini转移到注册表后
1 0 缺省,当注册表存在此子项,则不覆盖
1 1 覆盖
[Rename Files] 此类型节列出那些将样改名的文件。此节名必须出现在install节中
[rename-files-section-name]
new-file-name,old-file-name
new-file-name
新文件名
old-file-name
原来的文件名。此参数必须定义于 SourceDisksFiles 节中。
[Update INI Fields] 此节替换、增加、删除指定ini文件的条目。此节名必须存在于install节中。
[update-inifields-section-name]
ini-file,ini-section,profile-name,[old-field],[new-field],[flags]
参数说明见上
[Update INI File] 此节删除、替换或者新增INI 的项目. 节名必须处现在install节中的 UpdateInis 条目中
update-ini-section-name]
ini-file,ini-section,[old-ini-entry],[new-ini-entry],[flags]
ini-file
包含将要改变的条目的ini文件。
ini-section
节名
old-ini-entry
可选的,通常为key=value形式
new-ini-entry
可选。通常来自key=value. key 或者value可以为可替换的字符串。
flags
可选命令标志.
Value Meaning
0 缺省。如果old-ini-entry key 出现在INI file 条目中, 将被new-ini-entry替换。 值会被忽略,只要key匹配即可。为无条件增加新条目到ini文件,可设置 old-ini-entry为NULL。 为无条件从ini文件中删除old-ini-entry from,设置 new-ini-entry 为NULL。
1 如果 old-ini-entry 的key 和value 已经存在于 INI 文件,将被 new-ini-entry替换。 old-ini-entry 参数的key和value都必须匹配
2 如果old-ini-entry 参数没有出现在INI 文件中, 将不进行任何替换
若 old-ini-entry 的key存在于INI 文件且new-ini-entry的key存在于 INI 文件, INI 文件中匹配的 new-ini-entry 的key参数被删除, old-ini-entry 的key匹配参数被替换
3 类似2,但是,例外情况为:old-ini-entry 参数匹配基于key和value,并不限于key
可以使用通配符 (*)指代key和value的一部分和全部
ini文件名可以为字符串或者字符键。即%strkey% ,此 strkey 定义于[Strings]节,且必须是一个合法文件名。
Ini文件明应当包含目录,可以是直接目录,也可以是特定目录标示符。
可以拥有%dirid% 指定目录,dirid指定于 SetupSetDirectoryId节中. 当时用目录标示符,你应当使用反斜线号于一个目录路径中。举例:,你可以使用 %11%/card.ini 表示 CARD.INI 存在于System32 目录中。
以下为例子:
%11%/sample.ini, Section1,, Value1=2 ; 新增一个条目
%11%/sample.ini, Section2, Value3=*, ; 删除老条目
%11%/sample.ini, Section4, Value5=1, Value5=4 ;替换老条目
[Services]条目 此节条目列出增加和删除的服务列表。
[install-section-name.Services]
AddService=ServiceName,flag,service-install-section[,event-log-install-section]
DelService=ServiceName
ServiceName
将要安装/删除的服务名
flag
指定将如何增加服务。此参数仅用于AddService 键,取值为:
SPSVCINST_TAGTOFRONT (0x1)
将服务标签题见到服务所在组的前列
SPSVCINST_ASSOCSERVICE (0x2)
此增加的服务关联的服务.
service-install-section
服务安装节
event-log-install-section
时间记录安装节。
以下为例子:
[Ser_Inst.Services]
AddService = sermouse, 0x00000002, sermouse_Service_Inst, sermouse_EventLog_Inst ; Port Driver
AddService = mouclass,, mouclass_Service_Inst, mouclass_EventLog_Inst
; Class Driver
[Service Install] 此节列出将要安装的每一个服务信息
[install-section-name_ServiceInstallSection]
DisplayName=[name]
ServiceType=type-code
StartType=start-code
ErrorControl=error-control-level
ServiceBinary=path-to-service
LoadOrderGroup=[load-order-group-name]
Dependencies=+depend-on-group-name[[,depend-on-service-name]...]
StartName=[driver-object-name]
name
可选,友好的服务名称
type-code
驱动类型。为任何被theCreateService 函数认可的参数。
start-code
何时启动驱动程序。可为:
SERVICE_BOOT_START (0x0)
由操作系统loader启动。使用此值仅用于操作系统基本服务。
SERVICE_SYSTEM_START (0x1)
操作系统初始化式启动。
SERVICE_AUTO_START (0x2)
SCM在系统启动期间启动
SERVICE_DEMAND_START (0x3)
SCM根据需要启动
SERVICE_DISABLED (0x4)
此服务不可被启动
error-control-level
指定错误控制级别。
CRITICAL (0x3)
如果驱动装载失败,启动失败。如果启动不是在 “最后一次正确(LastKnownGood.)”控制集,切换到LastKnownGood。如果启动试图用于 LastKnownGood, 运行故障检查例程
SEVERE (0x2)
如果启动不是用于 LastKnownGood , 切换到LastKnownGood。如果启动试图LastKnownGood, 发生错误时继续启动。
NORMAL (0x1)
若初始化时失败,启动将继续,但显示警告信息
IGNORE (0x0)
若初始化时失败,启动将继续,无警告信息
path
二进制文件路径
load-order-group-name
可选. 指示服务处在的服务组中的次序: pointer, port, primary disk, and so forth.
+depend-on-group-name
可选,服务依赖的服务组,服务仅当该组的最后一个服务都启动后才启动
depend-on-service-name
可选。依赖的服务。
driver-object-name
可选。如果类型属于 Kernel driver或者file system driver,,此名用于I/O管理器装载的名称
例子:
[mouclass_Service_Inst]
DisplayName = %mouclass.SvcDesc%
ServiceType = 1 ; SERVICE_KERNEL_DRIVER
StartType = 1 ; SERVICE_SYSTEM_START
ErrorControl = 1 ; SERVICE_ERROR_NORMAL
ServiceBinary = %12%/mouclass.sys
LoadOrderGroup = Pointer Class
[DestinationDirs] 此节用于指定(copy file ,rename file等节中的目标目录)
[DestinationDirs]
file-list-section=drid[,subdir]
. .
[DefaultDestDir=drid[,subdir]]
file-list-section
Copy Files, Rename Files, 或者Delete Files 节名. drid
目录标示(DRID)。 安装程序在安装期间替换一个 DIRID采用实际的目录
DIRID %dirid% 为预先定义的目录
DIRID 可为以下值:
-01,0xffff 目录
01 SourceDrive:/path.
10 Windows directory.
11 System directory. (%windir%/system on Windows 95, %windir%/system32 on Windows NT)
12 Drivers directory.(%windir%/system32/drivers on Windows NT)
17 INF 文件目录
18 help目录
20 Fonts directory.
21 察看器目录
24 应用程序目录
25 共享目录Shared directory.
30 启动驱动器的根目录Root directory of the boot drive.
50 %windir%/system
51 假脱机目录Spool directory.
52 Spool drivers directory.
53 用户 Profile 目录
54 ntldr or OSLOADER.EXE 所在目录
subdir
子目录名
可选项 DefaultDestDir 提供缺省的目标目录。如果DefaultDestDir 未用于 DestinationDirs 节,缺省的目录设为 drid_system.
[SourceDisksFiles] 此节指定源安装盘上的文件
为了允许多操作系统分发源文件,你可构造针对特定平台的SourceDisksFiles 节举例来讲, 在 MIPS 平台上,所有安装功能在用到 SourceDisksFiles 节将首先查找 SourceDisksFiles.Mips 节。 如果安装功能未找到 SourceDisksFiles.Mips 节, 或者某个特定行未能在那里找到,安装功能将使用 SourceDisksFiles 节。此行为直接或间接影响安装功能处理 SourceDisksFiles节作为其进程的一部分。
大小写不敏感的前缀可为:
alpha
mips
ppc
x86
[SourceDisksFiles]
filename=disk-number[,subdir][,size]
filename
在源此盘上的文件名
disk-number
第几号源盘包含此文件。大于等于1,且定义于 SourceDisksNames 节
subdir
可选参数。在源盘上的子目录,缺省为源盘的跟目录
size
可选参数,文件的压缩尺寸
[SourceDisksFiles]
SRS01.x86 = 1 ;源文件SRS01.x86存在于安装盘一号盘的根目录
[SourceDisksNames] 指示源文件的磁盘名称
为了允许多操作系统分发源文件,你可构造针对特定平台的SourceDisksNames节举例来讲, 在 MIPS 平台上,所有安装功能在用到 SourceDisksNames节将首先查找 SourceDisksNames.Mips 节。 如果安装功能未找到 SourceDisksNames.Mips 节, 或者某个特定行未能在那里找到,安装功能将使用 SourceDisksNames节。此行为直接或间接影响安装功能处理 SourceDisksNames节作为其进程的一部分。
大小写不敏感的前缀可为:
alpha
mips
ppc
x86
[SourceDisksNames[.platform]]
disk-ordinal="disk-description"[,[disk-label],[unused,path]
.
platform
指示源文件应用的平台指示符。
disk-ordinal
磁盘序号
disk-description
“”包含的字符串,用于标示磁盘。
disk-label
磁盘卷标
unused
保留未用
path
可选参数,源文件的绝对路径,如果未用,则表示示根目录
如下例子中, write.exe 所有平台都一样,且存在于源盘1的/common 目录。圆盘1将所有平台都一致的文件存在于/common目录中。 CMD.EXE 文件特定于平台,磁盘2指示安装功能针对每一个平台的特定目录。HALNECMP.DLL 文件特定于MIPS 平台。
[SourceDisksNames]
1 = "Windows NT CD-ROM", Instd1,, /common
[SourceDisksNames.Alpha]
2 = "Windows NT CD-ROM", Instd1,, /alpha
[SourceDisksNames.Mips]
2 = "Windows NT CD-ROM", Instd1,, /mips
[SourceDisksNames.x86]
2 = "Windows NT CD-ROM", Instd1,, /x86
[SourceDisksNames.ppc]
2 = "Windows NT CD-ROM", Instd1,, /ppc
[SourceDisksFiles]
write.exe = 1
cmd.exe = 2
[SourceDisksFiles.Mips]
halnecmp.dll = 2
[EventLog Install] 该节往注册表中加入事件消息文件,也可利用此节移除事件消息文件。
[install-section-name_EventLogInstallSection]
AddReg=add-registry-section
DelReg=del-registry-section
add-registry-section
del-registry-section
事件消息节名
AddReg 指示哪节将作为增加事件的注册表项
DelReg 指示删除事件项
以下为典型的 EventLog 安装节:
[sermouse_EventLog_Inst]
AddReg=sermouse_EventLog_AddReg
[sermouse_EventLog_AddReg]
HKR,EventMessageFile,0x00020000,"%%SystemRoot%%/System32/IoLogMsg.dll/;%%SystemRoot%%/System32/drivers/sermouse.sys"
HKR,,TypesSupported,0x00010001,7
[Strings] 该节定义了1个或多个字符串关键字. 一个字符串key 展开一个可打印字符串
可以有针对特定语言的String节
[Strings[.langid]]
strings-key=value
langid
可选的指示string节所属语言的语言标示符. 举例, U.S. English 是 0409 以及Standard French 是 040c.
strings-key
由字符和数字组成的唯一名符
value
展开后的字符串内容
例子:
[Strings]
String0="Corporation X"
String1="Corporation X"
String2="CS2590 SCSI Adapter"
特定语言的例子:
[Strings.0409]
; American English strings
S1 = "Hello"
[Strings.0009]
; British English strings
; Note that 0009 is used instead of 0809 to make this the default
; for English languages other than U.S. English.
S1 = "Greetings"
[Strings]
; French strings
; Not specifying a langid makes this the default
S1 = "Bonjour"
注释
尽管此节通常处于inf文件的最后一节,但是定义的字符串Key可用于inf文件任何位置。安装程序将展开字符串
如果用到%,请使用%%。
Windows 95: 不可包含strings节,不支持多语言.
出处:http://blog.csdn.net/shanhe/archive/2004/12/25/229368.aspx