Método IPropertyStorage::WritePropertyNames (propidl.h)

El método WritePropertyNames asigna nombres de cadena IPropertyStorage a una matriz especificada de identificadores de propiedad en el conjunto de propiedades actual.

Sintaxis

HRESULT WritePropertyNames(
  [in] ULONG             cpropid,
  [in] const PROPID []   rgpropid,
  [in] const LPOLESTR [] rglpwstrName
);

Parámetros

[in] cpropid

Tamaño de la entrada del rgpropid de la matriz. Puede ser cero. Sin embargo, hacer que no sea cero hace que este método se convierta en no operativo.

[in] rgpropid

Matriz de los identificadores de propiedad para los que se van a establecer los nombres.

[in] rglpwstrName

Matriz de nombres nuevos que se asignarán a los identificadores de propiedad correspondientes en la matriz rgpropid . Estos nombres no pueden superar los 255 caracteres (sin incluir el terminador NULL ).

Valor devuelto

Este método admite el valor devuelto estándar E_UNEXPECTED, además de lo siguiente:

Comentarios

Para obtener más información sobre los conjuntos de propiedades y la administración de memoria, vea Managing Property Sets.

IPropertyStorage::WritePropertyNames asigna nombres de cadena a identificadores de propiedad pasados al método en la matriz rgpropid . Asocia cada nombre de cadena en la matriz rglpwstrName con el identificador de propiedad respectivo en rgpropid. Es explícitamente válido definir un nombre para un identificador de propiedad que no está presente actualmente en el objeto de almacenamiento de propiedades.

También es válido cambiar la asignación de un nombre de cadena existente (determinado por una coincidencia que no distingue mayúsculas de minúsculas). Es decir, puede usar el método WritePropertyNames para asignar un nombre existente a un nuevo identificador de propiedad o para asignar un nuevo nombre a un identificador de propiedad que ya tiene un nombre en el diccionario. En cualquier caso, se elimina la asignación original. Los nombres de propiedad deben ser únicos (como son los identificadores de propiedad) dentro del conjunto de propiedades.

El almacenamiento de nombres de propiedad de cadena conserva el caso. A menos que PROPSETFLAG_CASE_SENSITIVE se pase a IPropertySetStorage::Create, los nombres de conjunto de propiedades no distinguen mayúsculas de minúsculas de forma predeterminada. Con los conjuntos de propiedades que no distinguen mayúsculas de minúsculas, las cadenas de nombre pasadas por el autor de la llamada se interpretan según la configuración regional del conjunto de propiedades, según lo especificado por la propiedad PID_LOCALE . Si el conjunto de propiedades no tiene ninguna propiedad de configuración regional, se asume el usuario actual de forma predeterminada. Los nombres de propiedad de cadena tienen una longitud limitada a 128 caracteres. Los nombres de propiedad que comienzan con los caracteres Unicode binarios 0x0001 a través de 0x001F están reservados para su uso futuro.

Si el valor de un elemento del parámetro de matriz rgpropid se establece en 0xffffffff (PID_ILLEGAL), IPropertyStorage::WritePropertyNames omite el nombre correspondiente. Por ejemplo, si se llama a este método con un parámetro cpropid de 3, pero el primer elemento de la matriz, rgpropid[1], se establece en PID_ILLEGAL, solo se escriben dos nombres de propiedad. Se omite el elemento rgpropid[1].

Requisitos

   
Cliente mínimo compatible Windows 2000 Professional [aplicaciones de escritorio | Aplicaciones para UWP]
Servidor mínimo compatible Windows 2000 Server [aplicaciones de escritorio | Aplicaciones para UWP]
Plataforma de destino Windows
Encabezado propidl.h (include Objbase.h, Propidlbase.h)
Library Uuid.lib
Archivo DLL Ole32.dll

Consulte también

IPropertyStorage

IPropertyStorage::ReadMultiple

IPropertyStorage::ReadPropertyNames

IPropertyStorage::WriteMultiple

Muestras

Ejemplo writeRead