Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

361 lines
16 KiB

//////////////////////////////////////////////////////////////////////////////////////////////
//
// Copyright (C) 1998, 1999, 2000 Microsoft Corporation. All rights reserved.
//
// File : AppMan.h
//
// Content : Include file containing the IApplicationManager and IApplicationEntry
// interfaces needed to use the Windows Application Manager
//
//////////////////////////////////////////////////////////////////////////////////////////////
#ifndef __IAPPMAN_
#define __IAPPMAN_
#ifdef __cplusplus
extern "C" {
#endif // _cplusplus
//
// Get a few important things defined properly before proceeding
//
#undef EXPORT
#ifdef WIN32
#define EXPORT __declspec(dllexport)
#else // WIN32
#define EXPORT __export
#endif // WIN32
#if defined( _WIN32 ) && !defined( _NO_COM )
#define COM_NO_WINDOWS_H
#include <objbase.h>
#else // defined( _WIN32 ) && !defined( _NO_COM )
#include "windows.h"
#include "ole2.h"
#define IUnknown void
#endif // defined( _WIN32 ) && !defined( _NO_COM )
//
// GUID definition for the IApplicationManager interface
//
// CLSID_ApplicationManager = {553C75D7-C0B6-480d-92CC-F936D75FD87C}
// IID_ApplicationManager = {6084A2E8-3FB7-4d1c-B14B-6ADBAAF7CECE}
// IID_ApplicationEntry = {7BA2201F-4DE7-4ef7-BBA3-C69A716B8CD9}
//
DEFINE_GUID(CLSID_ApplicationManager, 0x553c75d7, 0xc0b6, 0x480d, 0x92, 0xcc, 0xf9, 0x36, 0xd7, 0x5f, 0xd8, 0x7c);
DEFINE_GUID(IID_ApplicationManager, 0x6084a2e8, 0x3fb7, 0x4d1c, 0xb1, 0x4b, 0x6a, 0xdb, 0xaa, 0xf7, 0xce, 0xce);
DEFINE_GUID(IID_ApplicationEntry, 0x7ba2201f, 0x4de7, 0x4ef7, 0xbb, 0xa3, 0xc6, 0x9a, 0x71, 0x6b, 0x8c, 0xd9);
//
// These defines are used in conjunction with the APP_PROPERTY_STATE and the
// IApplicationEntry->SetProperty() and IApplicationEntry->GetProperty() methods
//
#define APP_STATE_INSTALLING 0x00000001
#define APP_STATE_READY 0x00000002
#define APP_STATE_DOWNSIZING 0x00000004
#define APP_STATE_DOWNSIZED 0x00000008
#define APP_STATE_REINSTALLING 0x00000010
#define APP_STATE_UNINSTALLING 0x00000020
#define APP_STATE_UNINSTALLED 0x00000040
#define APP_STATE_SELFTESTING 0x00000080
#define APP_STATE_UNSTABLE 0x00000100
#define APP_STATE_MASK 0x000001ff
//
// These defines are used in conjunction with the APP_PROPERTY_CATEGORY and the
// IApplicationEntry->SetProperty() and IApplicationEntry->GetProperty() methods. More
// categories will be supported in version 2.
//
#define APP_CATEGORY_NONE 0x00000000
#define APP_CATEGORY_ENTERTAINMENT 0x00000001
#define APP_CATEGORY_DEMO 0x01000000
#define APP_CATEGORY_PATCH 0x02000000
#define APP_CATEGORY_DATA 0x04000000
#define APP_CATEGORY_ALL 0x0700ffff
//
// These defines are used as the dwPropertyDefine parameter of the
// IApplicationEntry->SetProperty() and IApplicationEntry->GetProperty() methods
//
#define APP_PROPERTY_GUID 0x00000001
#define APP_PROPERTY_COMPANYNAME 0x00000002
#define APP_PROPERTY_SIGNATURE 0x00000003
#define APP_PROPERTY_VERSIONSTRING 0x00000004
#define APP_PROPERTY_ROOTPATH 0x00000005
#define APP_PROPERTY_SETUPROOTPATH 0x00000006
#define APP_PROPERTY_STATE 0x00000007
#define APP_PROPERTY_CATEGORY 0x00000008
#define APP_PROPERTY_ESTIMATEDINSTALLKILOBYTES 0x00000009
#define APP_PROPERTY_EXECUTECMDLINE 0x0000000c
#define APP_PROPERTY_DEFAULTSETUPEXECMDLINE 0x0000001a
#define APP_PROPERTY_DOWNSIZECMDLINE 0x0000000d
#define APP_PROPERTY_REINSTALLCMDLINE 0x0000000e
#define APP_PROPERTY_UNINSTALLCMDLINE 0x0000000f
#define APP_PROPERTY_SELFTESTCMDLINE 0x00000010
#define APP_PROPERTY_INSTALLDATE 0x00000013
#define APP_PROPERTY_LASTUSEDDATE 0x00000014
#define APP_PROPERTY_TITLEURL 0x00000015
#define APP_PROPERTY_PUBLISHERURL 0x00000016
#define APP_PROPERTY_DEVELOPERURL 0x00000017
#define APP_PROPERTY_XMLINFOFILE 0x00000019
//
// Defines used as OR mask modifiers for the APP_PROPERTY_xxx string based properties.
// The default is APP_PROPERTY_STR_UNICODE.
//
// Used as OR masks for the dwPropertyDefines parameter of:
// IApplicationEntry->GetProperty()
// IApplicationEntry->SetProperty()
//
// Used alone for the dwStringDefine parameters of:
// IApplicationManager->EnumDevices()
// IApplicationEntry->GetTemporarySpace()
// IApplicationEntry->RemoveTemporarySpace()
// IApplicationEntry->EnumTemporarySpaces()
//
#define APP_PROPERTY_STR_ANSI 0x40000000
#define APP_PROPERTY_STR_UNICODE 0x80000000
#ifndef _UNICODE
#define APP_PROPERTY_TSTR APP_PROPERTY_STR_UNICODE
#else // _UNICODE
#define APP_PROPERTY_TSTR APP_PROPERTY_STR_ANSI
#endif // _UNICODE
//
// Association specific defines. Associations are used to inherit root paths from
// existing applications.
//
// APP_ASSOCIATION_CHILD : OR mask used only in the dwAssociationType
// parameter of the
// IApplicationEntry->EnumAssociations(...) method.
// This bit means that the IApplicationEntry object
// is a child in the relationship
// APP_ASSOCIATION_PARENT : OR mask used obly in the dwAssociationType
// parameter of the
// IApplicationEntry->EnumAssociations(...) method.
// This bit means that the IApplicationEntry object
// is the parent in the relationship
// APP_ASSOCIATION_INHERITBOTHPATHS : Inherit both the APP_PROPERTY_ROOTPATH and
// APP_PROPERTYSETUPROOTPATH of the parent
// application.
// APP_ASSOCIATION_INHERITAPPROOTPATH : Inherit the APP_PROPERTY_ROOTPATH of the parent
// application. Get a unique
// APP_PROPERTY_SETUPROOTPATH.
// APP_ASSOCIATION_INHERITSETUPROOTPATH : Inherit the APP_PROPERTY_SETUPROOTPATH of the
// parent application. Get a unique
// APP_PROPERTY_ROOTPATH.
//
#define APP_ASSOCIATION_CHILD 0x40000000
#define APP_ASSOCIATION_PARENT 0x80000000
#define APP_ASSOCIATION_INHERITBOTHPATHS 0x00000001
#define APP_ASSOCIATION_INHERITAPPROOTPATH 0x00000002
#define APP_ASSOCIATION_INHERITSETUPROOTPATH 0x00000004
//
// Defines used for the dwRunFlags parameter of the IApplicationEntry->Run(...) method. These
// defines determine whether the Run(...) method should wait for the application to terminate
// before returning.
//
#define APP_RUN_NOBLOCK 0x00000000
#define APP_RUN_BLOCK 0x00000001
//
// String lenght defines (in characters, not bytes)
//
// MAX_COMPANYNAME_CHARCOUNT --> APP_PROPERTY_COMPANYNAME
// MAX_SIGNATYRE_CHARCOUNT --> APP_PROPERTY_SIGNATURE
// MAX_VERSIONSTRING_CHARCOUNT --> APP_PROPERTY_VERSIONSTRING
// MAX_PATH_CHARCOUNT --> APP_PROPERTY_ROOTPATH
// APP_PROPERTY_SETUPROOTPATH
// APP_PROPERTY_XMLINFOFILE
// APP_PROPERTY_TITLEURL
// APP_PROPERTY_PUBLISHERURL
// APP_PROPERTY_DEVELOPERURL
// MAX_CMDLINE_CHARCOUNT --> APP_PROPERTY_EXECUTECMDLINE
// APP_PROPERTY_DEFAULTSETUPEXECMDLINE
// APP_PROPERTY_DOWNSIZECMDLINE
// APP_PROPERTY_REINSTALLCMDLINE
// APP_PROPERTY_UNINSTALLCMDLINE
// APP_PROPERTY_SELFTESTCMDLINE
//
//
#define MAX_COMPANYNAME_CHARCOUNT 64
#define MAX_SIGNATURE_CHARCOUNT 64
#define MAX_VERSIONSTRING_CHARCOUNT 16
#define MAX_PATH_CHARCOUNT 255
#define MAX_CMDLINE_CHARCOUNT 255
//
// Application Manager specific COM error codes
//
#define APPMAN_E_NOTINITIALIZED 0x85670001
#define APPMAN_E_INVALIDPROPERTYSIZE 0x85670005
#define APPMAN_E_INVALIDDATA 0x85670006
#define APPMAN_E_INVALIDPROPERTY 0x85670007
#define APPMAN_E_READONLYPROPERTY 0x85670008
#define APPMAN_E_PROPERTYNOTSET 0x85670009
#define APPMAN_E_OVERFLOW 0x8567000a
#define APPMAN_E_INVALIDPROPERTYVALUE 0x8567000c
#define APPMAN_E_ACTIONINPROGRESS 0x8567000d
#define APPMAN_E_ACTIONNOTINITIALIZED 0x8567000e
#define APPMAN_E_REQUIREDPROPERTIESMISSING 0x8567000f
#define APPMAN_E_APPLICATIONALREADYEXISTS 0x85670010
#define APPMAN_E_APPLICATIONALREADYLOCKED 0x85670011
#define APPMAN_E_NODISKSPACEAVAILABLE 0x85670012
#define APPMAN_E_UNKNOWNAPPLICATION 0x85670014
#define APPMAN_E_INVALIDPARAMETERS 0x85670015
#define APPMAN_E_OBJECTLOCKED 0x85670017
#define APPMAN_E_INVALIDINDEX 0x85670018
#define APPMAN_E_REGISTRYCORRUPT 0x85670019
#define APPMAN_E_CANNOTASSOCIATE 0x8567001a
#define APPMAN_E_INVALIDASSOCIATION 0x8567001b
#define APPMAN_E_ALREADYASSOCIATED 0x8567001c
#define APPMAN_E_APPLICATIONREQUIRED 0x8567001d
#define APPMAN_E_INVALIDEXECUTECMDLINE 0x8567001e
#define APPMAN_E_INVALIDDOWNSIZECMDLINE 0x8567001f
#define APPMAN_E_INVALIDREINSTALLCMDLINE 0x85670020
#define APPMAN_E_INVALIDUNINSTALLCMDLINE 0x85670021
#define APPMAN_E_INVALIDSELFTESTCMDLINE 0x85670022
#define APPMAN_E_PARENTAPPNOTREADY 0x85670023
#define APPMAN_E_INVALIDSTATE 0x85670024
#define APPMAN_E_INVALIDROOTPATH 0x85670025
#define APPMAN_E_CACHEOVERRUN 0x85670026
#define APPMAN_E_REINSTALLDX 0x85670028
#define APPMAN_E_APPNOTEXECUTABLE 0x85670029
//////////////////////////////////////////////////////////////////////////////////////////////
//
// Interface definitions
//
//////////////////////////////////////////////////////////////////////////////////////////////
#if defined( _WIN32 ) && !defined( _NO_COM )
//
// IApplicationEntry Interface
//
// STDMETHOD (QueryInterface) (REFIID RefIID, LPVOID * lppVoidObject);
// STDMETHOD_(ULONG, AddRef) (void);
// STDMETHOD_(ULONG, Release) (void);
// STDMETHOD (Clear) (void);
// STDMETHOD (GetProperty) (const DWORD dwPropertyDefine, LPVOID lpData, const DWORD dwDataLenInBytes);
// STDMETHOD (SetProperty) (const DWORD dwPropertyDefine, LPCVOID lpData, const DWORD dwDataLenInBytes);
// STDMETHOD (InitializeInstall) (void);
// STDMETHOD (FinalizeInstall) (void);
// STDMETHOD (InitializeDownsize) (void);
// STDMETHOD (FinalizeDownsize) (void);
// STDMETHOD (InitializeReInstall) (void);
// STDMETHOD (FinalizeReInstall) (void);
// STDMETHOD (InitializeUnInstall) (void);
// STDMETHOD (FinalizeUnInstall) (void);
// STDMETHOD (InitializeSelfTest) (void);
// STDMETHOD (FinalizeSelfTest) (void);
// STDMETHOD (Abort) (void);
// STDMETHOD (Run) (const DWORD dwRunFlags, const DWORD dwStringMask, LPVOID lpData, const DWORD dwDataLenInBytes);
// STDMETHOD (AddAssociation) (const DWORD dwAssociationDefine, const IApplicationEntry * lpApplicationEntry);
// STDMETHOD (RemoveAssociation) (const DWORD dwAssociationDefine, const IApplicationEntry * lpApplicationEntry);
// STDMETHOD (EnumAssociations) (const DWORD dwZeroBasedIndex, LPDWORD lpdwAssociationDefineMask, IApplicationEntry * lpApplicationEntry);
// STDMETHOD (GetTemporarySpace) (const DWORD dwSpaceInKilobytes, const DWORD dwStringDefine, LPVOID lpData, const DWORD dwDataLen);
// STDMETHOD (RemoveTemporarySpace) (const DWORD dwStringDefine, LPVOID lpData, const DWORD dwDataLen);
// STDMETHOD (EnumTemporarySpaces) (const DWORD dwZeroBasedIndex, LPDWORD lpdwSpaceInKilobytes, const DWORD dwStringDefine, LPVOID lpData, const DWORD dwDataLen);
//
#undef INTERFACE
#define INTERFACE IApplicationEntry
DECLARE_INTERFACE_( IApplicationEntry, IUnknown )
{
//
// IUnknown interfaces
//
STDMETHOD (QueryInterface) (THIS_ REFIID, LPVOID *) PURE;
STDMETHOD_(ULONG, AddRef) (THIS) PURE;
STDMETHOD_(ULONG, Release) (THIS) PURE;
//
// IApplicationEntry interface methods
//
STDMETHOD (Clear) (THIS) PURE;
STDMETHOD (GetProperty) (THIS_ const DWORD, LPVOID, const DWORD) PURE;
STDMETHOD (SetProperty) (THIS_ const DWORD, LPCVOID, const DWORD) PURE;
STDMETHOD (InitializeInstall) (THIS) PURE;
STDMETHOD (FinalizeInstall) (THIS) PURE;
STDMETHOD (InitializeDownsize) (THIS) PURE;
STDMETHOD (FinalizeDownsize) (THIS) PURE;
STDMETHOD (InitializeReInstall) (THIS) PURE;
STDMETHOD (FinalizeReInstall) (THIS) PURE;
STDMETHOD (InitializeUnInstall) (THIS) PURE;
STDMETHOD (FinalizeUnInstall) (THIS) PURE;
STDMETHOD (InitializeSelfTest) (THIS) PURE;
STDMETHOD (FinalizeSelfTest) (THIS) PURE;
STDMETHOD (Abort) (THIS) PURE;
STDMETHOD (Run) (THIS_ const DWORD, const DWORD, LPVOID, const DWORD) PURE;
STDMETHOD (AddAssociation) (THIS_ const DWORD, const IApplicationEntry *) PURE;
STDMETHOD (RemoveAssociation) (THIS_ const DWORD, const IApplicationEntry *) PURE;
STDMETHOD (EnumAssociations) (THIS_ const DWORD, LPDWORD, IApplicationEntry *) PURE;
STDMETHOD (GetTemporarySpace) (THIS_ const DWORD, const DWORD, LPVOID, const DWORD) PURE;
STDMETHOD (RemoveTemporarySpace) (THIS_ const DWORD, LPVOID, const DWORD) PURE;
STDMETHOD (EnumTemporarySpaces) (THIS_ const DWORD, LPDWORD, const DWORD, LPVOID, const DWORD ) PURE;
};
//
// IApplicationManager Interface
//
// STDMETHOD (QueryInterface) (REFIID RefIID, LPVOID * lppVoidObject);
// STDMETHOD_(ULONG, AddRef) (void);
// STDMETHOD_(ULONG, Release) (void);
// STDMETHOD (GetAdvancedMode) (LPDWORD lpdwAdvancedMode);
// STDMETHOD (GetAvailableSpace) (const DWORD dwCategoryDefine, LPDWORD lpdwMaximumSpaceInKilobytes, LPDWORD lpdwOptimalSpaceInKilobytes);
// STDMETHOD (CreateApplicationEntry) (IApplicationEntry ** lppObject);
// STDMETHOD (GetApplicationInfo) (IApplicationEntry * lpObject);
// STDMETHOD (EnumApplications) (const DWORD dwZeroBasedIndex, IApplicationEntry * lpObject);
// STDMETHOD (EnumDevices) (const DWORD dwZeroBasedIndex, LPDWORD lpdwAvailableSpaceInKilobytes, LPDWORD lpdwCategoryDefineExclusionMask, const DWORD dwStringDefine, LPVOID lpData, const DWORD dwDataLen);
//
#undef INTERFACE
#define INTERFACE IApplicationManager
DECLARE_INTERFACE_( IApplicationManager, IUnknown )
{
//
// IUnknown Interfaces
//
STDMETHOD (QueryInterface) (THIS_ REFIID, LPVOID *) PURE;
STDMETHOD_(ULONG, AddRef) (THIS) PURE;
STDMETHOD_(ULONG, Release) (THIS) PURE;
//
// IApplicationManager interface methods
//
STDMETHOD (GetAdvancedMode) (THIS_ LPDWORD) PURE;
STDMETHOD (GetAvailableSpace) (THIS_ const DWORD, LPDWORD, LPDWORD) PURE;
STDMETHOD (CreateApplicationEntry) (THIS_ IApplicationEntry **) PURE;
STDMETHOD (GetApplicationInfo) (THIS_ IApplicationEntry *) PURE;
STDMETHOD (EnumApplications) (THIS_ const DWORD, IApplicationEntry *) PURE;
STDMETHOD (EnumDevices) (THIS_ const DWORD, LPDWORD, LPDWORD, const DWORD, LPVOID, const DWORD) PURE;
};
#endif // defined( _WIN32 ) && !defined( _NO_COM )
#ifdef __cplusplus
}
#endif // _cplusplus
#endif // __IAPPMAN_