Catatan
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba masuk atau mengubah direktori.
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba mengubah direktori.
Mendapatkan nama paket dan pengidentifikasi penerbit (ID) untuk nama keluarga paket yang ditentukan.
Sintaks
LONG PackageNameAndPublisherIdFromFamilyName(
[in] PCWSTR packageFamilyName,
[in, out] UINT32 *packageNameLength,
[out, optional] PWSTR packageName,
[in, out] UINT32 *packagePublisherIdLength,
[out, optional] PWSTR packagePublisherId
);
Parameter
[in] packageFamilyName
Jenis: PCWSTR
Nama keluarga paket.
[in, out] packageNameLength
Jenis: UINT32*
Pada input, ukuran buffer packageName , dalam karakter. Pada output, ukuran nama paket yang dikembalikan, dalam karakter, termasuk null-terminator.
[out, optional] packageName
Jenis: PWSTR
Nama paket.
[in, out] packagePublisherIdLength
Jenis: UINT32*
Pada input, ukuran buffer packagePublishId , dalam karakter. Pada output, ukuran ID penerbit yang dikembalikan, dalam karakter, termasuk null-terminator.
[out, optional] packagePublisherId
Jenis: PWSTR
ID penerbit paket.
Nilai kembali
Jenis: LONG
Jika fungsi berhasil, fungsi akan mengembalikan ERROR_SUCCESS. Jika tidak, fungsi mengembalikan kode kesalahan. Kode kesalahan yang mungkin mencakup yang berikut ini.
Menampilkan kode | Deskripsi |
---|---|
|
Salah satu buffer tidak cukup besar untuk menyimpan data. Ukuran yang diperlukan ditentukan oleh packageNameLength dan packagePublisherIdLength. |
Keterangan
Untuk informasi tentang batas ukuran string, lihat Konstanta identitas.
Contoh
#define _UNICODE 1
#define UNICODE 1
#include <Windows.h>
#include <appmodel.h>
#include <malloc.h>
#include <stdio.h>
int ShowUsage();
void FamilyNameToNameAndPublisherId(__in PCWSTR familyName);
int ShowUsage()
{
wprintf(L"Usage: PackageNameAndPublisherIdFromFamilyName <familyname> [<familyname>...]\n");
return 1;
}
int __cdecl wmain(__in int argc, __in_ecount(argc) WCHAR * argv[])
{
if (argc <= 1)
return ShowUsage();
for (int i=1; i<argc; ++i)
FamilyNameToNameAndPublisherId(argv[i]);
return 0;
}
void FamilyNameToNameAndPublisherId(__in PCWSTR familyName)
{
wprintf(L"FamilyName: %s\n", familyName);
UINT32 nameLength = 0;
UINT32 publisherIdLength = 0;
LONG rc = PackageNameAndPublisherIdFromFamilyName(familyName, &nameLength, NULL, &publisherIdLength, NULL);
if (rc == ERROR_SUCCESS)
{
wprintf(L"PackageNameAndPublisherIdFromFamilyName unexpectedly succeeded\n");
return;
}
else if (rc != ERROR_INSUFFICIENT_BUFFER)
{
wprintf(L"Error %d in PackageNameAndPublisherIdFromFamilyName\n", rc);
return;
}
PWSTR name = (PWSTR) malloc(nameLength * sizeof(WCHAR));
if (name == NULL)
{
wprintf(L"Error allocating memory\n");
return;
}
PWSTR publisherId = (PWSTR) malloc(publisherIdLength * sizeof(WCHAR));
if (publisherId == NULL)
{
wprintf(L"Error allocating memory\n");
free(name);
return;
}
rc = PackageNameAndPublisherIdFromFamilyName(familyName, &nameLength, name, &publisherIdLength, publisherId);
if (rc != ERROR_SUCCESS)
wprintf(L"Error %d converting PackageFamilyName to Name and PublisherId\n", rc);
else
{
wprintf(L" Name = %s\n", name);
wprintf(L"Publisher Id = %s\n", publisherId);
}
free(name);
free(publisherId);
}
Persyaratan
Persyaratan | Nilai |
---|---|
Klien minimum yang didukung | Windows 8 [aplikasi desktop | Aplikasi UWP] |
Server minimum yang didukung | Windows Server 2012 [aplikasi desktop | Aplikasi UWP] |
Target Platform | Windows |
Header | appmodel.h |
Pustaka | Kernel32.lib |
DLL | Kernel32.dll |