PackageIdFromFullName 함수(appmodel.h)

지정된 패키지 전체 이름의 패키지 식별자(ID)를 가져옵니다.

구문

LONG PackageIdFromFullName(
  [in]            PCWSTR       packageFullName,
  [in]            const UINT32 flags,
  [in, out]       UINT32       *bufferLength,
  [out, optional] BYTE         *buffer
);

매개 변수

[in] packageFullName

형식: PCWSTR

패키지의 전체 이름입니다.

[in] flags

형식: const UINT32

패키지 정보를 검색하는 방법을 지정하는 패키지 상수 입니다. PACKAGE_INFORMATION_* 플래그가 지원됩니다.

[in, out] bufferLength

형식: UINT32*

입력에서 버퍼 크기(바이트)입니다. 출력에서 반환된 데이터의 크기(바이트)입니다.

[out, optional] buffer

형식: BYTE*

PACKAGE_ID 구조체로 표현되는 패키지 ID입니다.

반환 값

형식: LONG

함수가 성공하면 ERROR_SUCCESS 반환합니다. 그렇지 않으면 함수는 오류 코드를 반환합니다. 가능한 오류 코드에는 다음이 포함됩니다.

반환 코드 설명
ERROR_INSUFFICIENT_BUFFER
버퍼가 데이터를 저장할 만큼 크지 않습니다. 필요한 크기는 bufferLength로 지정됩니다.
ERROR_NOT_FOUND
패키지가 사용자에 대해 설치되지 않았습니다.

설명

flagsPACKAGE_INFORMATION_BASIC 지정하면 다음 필드가 검색됩니다.

  • name
  • processorArchitecture
  • publisherId
  • resourceId
  • version
flagsPACKAGE_INFORMATION_FULL 지정하면 다음 필드가 검색됩니다.
  • name
  • processorArchitecture
  • publisher
  • publisherId
  • resourceId
  • version
PACKAGE_INFORMATION_FULL 대한 요청은 packageFullName에 해당하는 패키지가 설치되어 있고 현재 사용자가 액세스할 수 있는 경우에만 성공합니다. 패키지 전체 이름이 구문상 올바르지만 현재 사용자에 대해 설치되고 액세스할 수 있는 패키지에 해당하지 않는 경우 함수는 ERROR_NOT_FOUND 반환합니다.

문자열 크기 제한에 대한 자세한 내용은 ID 상수를 참조하세요.

예제

#define _UNICODE 1
#define UNICODE 1

#include <Windows.h>
#include <appmodel.h>
#include <malloc.h>
#include <stdio.h>

int ShowUsage();
void FullNameToId(__in PCWSTR fullName, __in const UINT32 flags);
void ShowPackageId(__in const PACKAGE_ID * packageId);

int ShowUsage()
{
    wprintf(L"Usage: PackageIdFromFullName <[flags]fullname> [<[flags]fullname>...]\n"
            L"flags:\n"
            L"    ? = Basic information (PACKAGE_INFORMATION_BASIC)\n"
            L"    * = Full information (PACKAGE_INFORMATION_FULL)\n"
            L"Default = Basic\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)
    {
        PCWSTR fullName = argv[i];
        UINT32 flags = PACKAGE_INFORMATION_BASIC;
        if (*fullName != L'\0')
        {
            if (*fullName == L'?')
            {
                flags = PACKAGE_INFORMATION_BASIC;
                ++fullName;
            }
            else if (*fullName == L'*')
            {
                flags = PACKAGE_INFORMATION_FULL;
                ++fullName;
            }
        }
        FullNameToId(fullName, flags);
    }

    return 0;
}

void FullNameToId(__in PCWSTR fullName, __in const UINT32 flags)
{
    wprintf(L"FullName: %s%s\n", fullName, ((flags & PACKAGE_INFORMATION_FULL) == 0 ? L"  [BASIC]" : L"  [FULL]"));
    UINT32 length = 0;
    LONG rc = PackageIdFromFullName(fullName, flags, &length, NULL);
    if (rc == ERROR_SUCCESS)
    {
        wprintf(L"PackageIdFromFullName unexpected succeeded\n");
        return;
    }
    else if (rc != ERROR_INSUFFICIENT_BUFFER)
    {
        wprintf(L"Error %d in PackageIdFromFullName\n", rc);
        return;
    }

    BYTE * buffer = (PBYTE) malloc(length);
    if (buffer == NULL)
    {
        wprintf(L"Error allocating memory\n");
        return;
    }

    rc = PackageIdFromFullName(fullName, flags, &length, buffer);
    if (rc != ERROR_SUCCESS)
        wprintf(L"Error %d converting Package Full Name to Id\n", rc);
    else
    {
        ShowPackageId((PACKAGE_ID *) buffer);
    }

    free(buffer);
}

void ShowPackageId(__in const PACKAGE_ID * packageId)
{
    wprintf(L"    Name        : %s\n", packageId->name);
    if (packageId->publisher != NULL)
        wprintf(L"    Publisher   : %s\n", packageId->publisher);
    if (packageId->publisherId != NULL)
        wprintf(L"    PublisherId : %s\n", packageId->publisherId);
    wprintf(L"    Version     : %hu.%hu.%hu.%hu\n",
            packageId->version.Major,
            packageId->version.Minor,
            packageId->version.Build,
            packageId->version.Revision);
    wprintf(L"    Architecture: %u\n", packageId->processorArchitecture);
    if (packageId->resourceId != NULL)
        wprintf(L"    Resource    : %s\n", packageId->resourceId);
}

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 8 [데스크톱 앱 | UWP 앱]
지원되는 최소 서버 Windows Server 2012 [데스크톱 앱 | UWP 앱]
대상 플랫폼 Windows
헤더 appmodel.h
라이브러리 Kernel32.lib
DLL Kernel32.dll

참고 항목

GetCurrentPackageId

GetPackageId

PackageFamilyNameFromFullName

PackageFamilyNameFromId

PackageFullNameFromId

PackageNameAndPublisherIdFromFamilyName