牵着老婆满街逛

严以律己,宽以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

INF文件格式说明

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 节,不支持多语言 .

posted on 2006-06-23 21:48 杨粼波 阅读(3213) 评论(0)  编辑 收藏 引用 所属分类: Windows编程


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理