SP_FILE_COPY_PARAMS_W 结构 (setupapi.h)

SP_FILE_COPY_PARAMS 结构描述单个文件复制操作。

语法

typedef struct _SP_FILE_COPY_PARAMS_W {
  DWORD    cbSize;
  HSPFILEQ QueueHandle;
  PCWSTR   SourceRootPath;
  PCWSTR   SourcePath;
  PCWSTR   SourceFilename;
  PCWSTR   SourceDescription;
  PCWSTR   SourceTagfile;
  PCWSTR   TargetDirectory;
  PCWSTR   TargetFilename;
  DWORD    CopyStyle;
  HINF     LayoutInf;
  PCWSTR   SecurityDescriptor;
} SP_FILE_COPY_PARAMS_W, *PSP_FILE_COPY_PARAMS_W;

成员

cbSize

结构的大小(以字节为单位)。 将 设置为值: sizeof(SP_FILE_COPY_PARAMS)

QueueHandle

安装程序文件队列的句柄,由 SetupOpenFileQueue 返回。

SourceRootPath

指向此副本的源根的可选指针,例如 A:。

SourcePath

指向相对于 SourceRootPath 的路径的可选指针,可在其中找到文件。

SourceFilename

要复制的文件的文件名部分。

SourceDescription

指向磁盘提示期间要使用的源媒体说明的可选指针。

SourceTagfile

指向标记文件的可选指针,该文件在 SourceRootPath 中的状态指示源媒体的存在。 如果未指定,则文件本身将用作标记文件(如果需要)。

TargetDirectory

要在其中复制文件的目录。

TargetFilename

指向目标文件名称的可选指针。 如果未指定,目标文件的名称将与源文件相同。

CopyStyle

控制文件复制操作行为的标志。 这些标志可以是以下值的组合。

含义
SP_COPY_DELETESOURCE
复制成功后删除源文件。 如果删除失败,则不会通知调用方。
SP_COPY_REPLACEONLY
仅当这样做会覆盖目标路径中的文件时,才复制该文件。 不会通知调用方。
SP_COPY_NEWER_OR_SAME
检查要复制的每个文件,查看其版本资源是否指示其版本相同或不高于目标上的现有副本。

版本检查期间使用的文件版本信息是在VS_FIXEDFILEINFO结构的 dwFileVersionMSdwFileVersionLS 成员中指定的,由版本函数填充。 如果其中一个文件没有版本资源,或者它们具有相同的版本信息,则认为源文件较新。

如果源文件的版本或更新版本不相等,并且指定 了 CopyMsgHandler ,则会通知调用方并可以取消复制。 如果未指定 CopyMsgHandler ,则不会复制该文件。

SP_COPY_NEWER_ONLY
检查要复制的每个文件,查看其版本资源是否指示它不比目标上的现有副本新。 如果源文件较新,但在版本上不等于现有目标,则会复制该文件。
SP_COPY_NOOVERWRITE
检查目标文件是否存在,如果是,请通知可能否决副本的调用方。 如果未指定 CopyMsgHandler ,则不会覆盖该文件。
SP_COPY_NODECOMP
不要解压缩文件。 设置此标志后,不会为目标文件提供源名称的未压缩形式 ((如果适用) )。 例如,将 f:\x86\cmd.ex_ 复制到 \\install\temp 会导致目标文件 \\install\temp\cmd.ex_。 如果未指定SP_COPY_NODECOMP标志,则会解压缩文件,\\install\temp\cmd.exe 调用目标。 DestinationName 的文件名部分(如果指定)将被去除,并替换为源文件的文件名。 指定SP_COPY_NODECOMP时,无法检查任何语言或版本信息。
SP_COPY_LANGUAGEAWARE
检查要复制的每个文件,以查看其语言是否与目标上已有的任何现有文件的语言不同。 如果是这样,并且指定 了 CopyMsgHandler ,则会通知调用方,并可能会取消复制。 如果未指定 CopyMsgHandler ,则不会复制该文件。
SP_COPY_SOURCE_ABSOLUTE
SourceFile 是完整的源路径。 请勿在 INF 文件的 SourceDisksNames 部分中查找它。
SP_COPY_SOURCEPATH_ABSOLUTE
SourcePathRoot 是源文件的完整路径部分。 忽略文件所在的源媒体的 INF 文件的 SourceDisksNames 节中指定的相对源。 如果指定了SP_COPY_SOURCE_ABSOLUTE,则忽略此标志。
SP_COPY_FORCE_IN_USE
如果目标存在,则其行为就像正在使用一样,并在下次系统重新启动时将文件排队以供复制。
SP_COPY_IN_USE_NEEDS_REBOOT
如果在复制操作期间正在使用该文件,请提醒用户系统需要重新启动。
SP_COPY_NOSKIP
不要为用户提供跳过文件的选项。
SP_COPY_FORCE_NOOVERWRITE
检查目标文件是否存在,如果是,则不会覆盖该文件。 不会通知调用方。
SP_COPY_FORCE_NEWER
检查要复制的每个文件,以查看其版本资源是否 (或非映像文件的时间戳) 指示它并不比目标上的现有副本新。 如果要复制的文件不是较新的,则不会复制该文件。 不会通知调用方。
SP_COPY_WARNIFSKIP
如果用户尝试跳过文件,请警告他们跳过文件可能会影响安装。 (用于系统关键文件。)

LayoutInf

要用于获取源信息的 INF 的句柄。

SecurityDescriptor

可选的安全描述符字符串,指定要应用于文件的 ACL。

注解

注意

setupapi.h 标头将 SP_FILE_COPY_PARAMS 定义为别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将非特定编码别名的使用与非非特定编码的代码混合使用可能会导致不匹配,从而导致编译或运行时错误。 有关详细信息,请参阅 函数原型的约定

要求

要求
最低受支持的客户端 Windows XP [仅限桌面应用]
最低受支持的服务器 Windows Server 2003 [仅限桌面应用]
标头 setupapi.h

另请参阅

概述

结构