MsiSourceListGetInfoA 함수(msi.h)
MsiSourceListGetInfo 함수는 특정 컨텍스트에서 제품 또는 패치의 원본 목록에 대한 정보를 검색합니다.
구문
UINT MsiSourceListGetInfoA(
[in] LPCSTR szProductCodeOrPatchCode,
[in, optional] LPCSTR szUserSid,
[in] MSIINSTALLCONTEXT dwContext,
[in] DWORD dwOptions,
[in] LPCSTR szProperty,
[out, optional] LPSTR szValue,
[in, out, optional] LPDWORD pcchValue
);
매개 변수
[in] szProductCodeOrPatchCode
제품 또는 패치의 ProductCode 또는 패치 GUID입니다. null로 끝나는 문자열을 사용합니다. 문자열이 39자를 초과하면 함수가 실패하고 ERROR_INVALID_PARAMETER 반환합니다. 이 매개 변수는 NULL일 수 없습니다.
[in, optional] szUserSid
이 매개 변수는 제품 또는 패치가 포함된 사용자 계정을 지정하는 문자열 SID(보안 식별자)일 수 있습니다. SID의 유효성이 검사되거나 확인되지 않았습니다. 잘못된 SID는 ERROR_UNKNOWN_PRODUCT 반환하거나 ERROR_UNKNOWN_PATCH 수 있습니다. 컴퓨터 컨텍스트를 참조할 때 szUserSID 는 NULL 이어야 하며 dwContext 는 MSIINSTALLCONTEXT_MACHINE 합니다.
[in] dwContext
이 매개 변수는 제품 또는 패치 instance 컨텍스트를 지정합니다. 이 매개 변수는 다음 값 중 하나를 포함할 수 있습니다.
[in] dwOptions
dwOptions 값은 szProductCodeOrPatchCode의 의미를 지정합니다.
플래그 | 의미 |
---|---|
|
szProductCodeOrPatchCode 는 제품 코드 GUID입니다. |
|
szProductCodeOrPatchCode 는 패치 코드 GUID입니다. |
[in] szProperty
검색할 속성 값을 지정하는 null로 끝나는 문자열입니다. szProperty 매개 변수는 다음 값 중 하나일 수 있습니다.
[out, optional] szValue
정보를 수신하는 출력 버퍼입니다. 이 버퍼는 정보를 포함할 수 있을 만큼 커야 합니다. 버퍼가 너무 작으면 함수는 ERROR_MORE_DATA 반환하고 *pcchValue 를 종료 NULL 문자를 포함하지 않고 값의 TCHAR 수로 설정합니다.
szValue가 NULL로 설정되고 pcchValue가 유효한 포인터로 설정된 경우 함수는 ERROR_SUCCESS 반환하고 *pcchValue를 종료 NULL 문자를 포함하지 않고 값의 TCHAR 수로 설정합니다. 그런 다음 함수를 다시 호출하여 값을 검색할 수 있으며, szValue 버퍼는 *pcchValue + 1자를 포함할 만큼 충분히 큽니다.
szValue와 pcchValue가 모두 NULL로 설정된 경우 함수는 값을 검색하지 않고 값이 있는 경우 ERROR_SUCCESS 반환합니다.
[in, out, optional] pcchValue
szValue 버퍼의 TCHAR 수를 지정하는 변수에 대한 포인터입니다. 함수가 반환될 때 이 매개 변수는 함수가 지정된 버퍼에 값을 복사하는지 여부에 관계없이 요청된 값의 크기로 설정됩니다. 크기는 종료 null 문자를 포함하지 않고 요청된 값의 TCHAR 수로 반환됩니다.
이 매개 변수는 szValue가 NULL인 경우에만 NULL로 설정할 수 있습니다. 그렇지 않으면 함수가 ERROR_INVALID_PARAMETER 반환합니다.
반환 값
MsiSourceListGetInfo 함수는 다음 값을 반환합니다.
값 | 의미 |
---|---|
|
사용자에게 지정된 원본 목록을 읽을 수 있는 기능이 없습니다. 제품 또는 패치를 찾을 수 있는지 여부는 표시되지 않습니다. |
|
구성 데이터가 손상되었습니다. |
|
잘못된 매개 변수가 함수에 전달됩니다. |
|
제공된 버퍼가 요청된 데이터를 포함하기에 충분하지 않습니다. |
|
속성이 성공적으로 검색되었습니다. |
|
패치를 찾을 수 없습니다. |
|
제품을 찾을 수 없습니다. |
|
원본 속성을 찾을 수 없습니다. |
|
예기치 않은 내부 오류입니다. |
설명
관리자는 컴퓨터 컨텍스트 또는 자체 사용자별 컨텍스트(관리 또는 관리되지 않음)에 있는 제품 또는 패치 instance 설치를 수정할 수 있습니다. 사용자의 사용자별 관리 컨텍스트에 있는 제품 또는 패치 instance 설치를 수정할 수 있습니다. 관리자는 다른 사용자의 관리되지 않는 컨텍스트에 있는 제품 또는 패치 instance 다른 사용자의 설치를 수정할 수 없습니다.
관리자가 아닌 사용자는 다른 사용자의 사용자별 컨텍스트(관리 또는 관리되지 않음)에 있는 제품 또는 패치 instance 설치를 수정할 수 없습니다. 사용자별 관리되지 않는 컨텍스트에 있는 제품 또는 패치 instance 설치를 수정할 수 있습니다. 제품 또는 패치 원본을 검색할 수 있는 경우에만 컴퓨터 컨텍스트 또는 사용자별 관리 컨텍스트에서 제품 또는 패치 instance 설치를 수정할 수 있습니다. 사용자는 정책을 설정하여 원본을 찾아볼 수 있습니다. 자세한 내용은 DisableBrowse, AllowLockdownBrowse 및 AlwaysInstallElevated 정책을 참조하세요.
참고
msi.h 헤더는 MSiSourceListGetInfo를 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입에 대한 규칙을 참조하세요.
요구 사항
지원되는 최소 클라이언트 | Windows Server 2012, Windows 8, Windows Server 2008 R2 또는 Windows 7의 Windows Installer 5.0. Windows Server 2008 또는 Windows Vista의 Windows Installer 4.0 또는 Windows Installer 4.5. Windows Server 2003 또는 Windows XP의 Windows Installer 3.0 이상. Windows Installer 버전에 필요한 최소 Windows 서비스 팩에 대한 자세한 내용은 Windows Installer 런타임 요구 사항을 참조하세요. |
대상 플랫폼 | Windows |
헤더 | msi.h |
라이브러리 | Msi.lib |
DLL | Msi.dll |