| 1 | // Licensed to the .NET Foundation under one or more agreements. | 
|---|
| 2 | // The .NET Foundation licenses this file to you under the MIT license. | 
|---|
| 3 | // See the LICENSE file in the project root for more information. | 
|---|
| 4 |  | 
|---|
| 5 | /***************************************************************************** | 
|---|
| 6 | **                                                                         ** | 
|---|
| 7 | ** Cor.h - general header for the Runtime.                                 ** | 
|---|
| 8 | **                                                                         ** | 
|---|
| 9 | *****************************************************************************/ | 
|---|
| 10 |  | 
|---|
| 11 |  | 
|---|
| 12 | #ifndef _COR_H_ | 
|---|
| 13 | #define _COR_H_ | 
|---|
| 14 |  | 
|---|
| 15 | //***************************************************************************** | 
|---|
| 16 | // Required includes | 
|---|
| 17 | #include <ole2.h>                       // Definitions of OLE types. | 
|---|
| 18 | #include <specstrings.h> | 
|---|
| 19 | #include "corerror.h" | 
|---|
| 20 |  | 
|---|
| 21 | //***************************************************************************** | 
|---|
| 22 |  | 
|---|
| 23 | #if defined(_MSC_VER) && !defined(USE_DEPRECATED_CLR_API_WITHOUT_WARNING) | 
|---|
| 24 | #define DEPRECATED_CLR_API_MESG "This API has been deprecated. Refer to http://go.microsoft.com/fwlink/?LinkId=143720 for more details." | 
|---|
| 25 | #define DECLARE_DEPRECATED __declspec(deprecated(DEPRECATED_CLR_API_MESG)) | 
|---|
| 26 | #define DEPRECATED_CLR_STDAPI EXTERN_C DECLARE_DEPRECATED HRESULT STDAPICALLTYPE | 
|---|
| 27 | #define DEPRECATED_CLR_STDAPI_(type) EXTERN_C DECLARE_DEPRECATED type STDAPICALLTYPE | 
|---|
| 28 | #else // _MSC_VER && !USE_DEPRECATED_CLR_API_WITHOUT_WARNING | 
|---|
| 29 | #define DECLARE_DEPRECATED | 
|---|
| 30 | #define DEPRECATED_CLR_STDAPI STDAPI | 
|---|
| 31 | #define DEPRECATED_CLR_STDAPI_(type) STDAPI_(type) | 
|---|
| 32 | #endif // _MSC_VER && !USE_DEPRECATED_CLR_API_WITHOUT_WARNING | 
|---|
| 33 |  | 
|---|
| 34 | #ifdef __cplusplus | 
|---|
| 35 | extern "C"{ | 
|---|
| 36 | #endif | 
|---|
| 37 |  | 
|---|
| 38 | // {BED7F4EA-1A96-11d2-8F08-00A0C9A6186D} | 
|---|
| 39 | EXTERN_GUID(LIBID_ComPlusRuntime, 0xbed7f4ea, 0x1a96, 0x11d2, 0x8f, 0x8, 0x0, 0xa0, 0xc9, 0xa6, 0x18, 0x6d); | 
|---|
| 40 |  | 
|---|
| 41 | // {90883F05-3D28-11D2-8F17-00A0C9A6186D} | 
|---|
| 42 | EXTERN_GUID(GUID_ExportedFromComPlus, 0x90883f05, 0x3d28, 0x11d2, 0x8f, 0x17, 0x0, 0xa0, 0xc9, 0xa6, 0x18, 0x6d); | 
|---|
| 43 |  | 
|---|
| 44 | // {0F21F359-AB84-41e8-9A78-36D110E6D2F9} | 
|---|
| 45 | EXTERN_GUID(GUID_ManagedName, 0xf21f359, 0xab84, 0x41e8, 0x9a, 0x78, 0x36, 0xd1, 0x10, 0xe6, 0xd2, 0xf9); | 
|---|
| 46 |  | 
|---|
| 47 | // {54FC8F55-38DE-4703-9C4E-250351302B1C} | 
|---|
| 48 | EXTERN_GUID(GUID_Function2Getter, 0x54fc8f55, 0x38de, 0x4703, 0x9c, 0x4e, 0x25, 0x3, 0x51, 0x30, 0x2b, 0x1c); | 
|---|
| 49 |  | 
|---|
| 50 | // CLSID_CorMetaDataDispenserRuntime: {1EC2DE53-75CC-11d2-9775-00A0C9B4D50C} | 
|---|
| 51 | //  Dispenser coclass for version 1.5 and 2.0 meta data.  To get the "latest" bind | 
|---|
| 52 | //  to CLSID_MetaDataDispenser. | 
|---|
| 53 | EXTERN_GUID(CLSID_CorMetaDataDispenserRuntime, 0x1ec2de53, 0x75cc, 0x11d2, 0x97, 0x75, 0x0, 0xa0, 0xc9, 0xb4, 0xd5, 0xc); | 
|---|
| 54 |  | 
|---|
| 55 | // {CD2BC5C9-F452-4326-B714-F9C539D4DA58} | 
|---|
| 56 | EXTERN_GUID(GUID_DispIdOverride, 0xcd2bc5c9, 0xf452, 0x4326, 0xb7, 0x14, 0xf9, 0xc5, 0x39, 0xd4, 0xda, 0x58); | 
|---|
| 57 |  | 
|---|
| 58 | // {B64784EB-D8D4-4d9b-9ACD-0E30806426F7} | 
|---|
| 59 | EXTERN_GUID(GUID_ForceIEnumerable, 0xb64784eb, 0xd8d4, 0x4d9b, 0x9a, 0xcd, 0x0e, 0x30, 0x80, 0x64, 0x26, 0xf7); | 
|---|
| 60 |  | 
|---|
| 61 | // {2941FF83-88D8-4F73-B6A9-BDF8712D000D} | 
|---|
| 62 | EXTERN_GUID(GUID_PropGetCA, 0x2941ff83, 0x88d8, 0x4f73, 0xb6, 0xa9, 0xbd, 0xf8, 0x71, 0x2d, 0x00, 0x0d); | 
|---|
| 63 |  | 
|---|
| 64 | // {29533527-3683-4364-ABC0-DB1ADD822FA2} | 
|---|
| 65 | EXTERN_GUID(GUID_PropPutCA, 0x29533527, 0x3683, 0x4364, 0xab, 0xc0, 0xdb, 0x1a, 0xdd, 0x82, 0x2f, 0xa2); | 
|---|
| 66 |  | 
|---|
| 67 | // CLSID_CLR_v1_MetaData: {005023CA-72B1-11D3-9FC4-00C04F79A0A3} | 
|---|
| 68 | //  Used to generate v1 metadata (for v1.0 and v1.1 CLR compatibility). | 
|---|
| 69 | EXTERN_GUID(CLSID_CLR_v1_MetaData, 0x005023ca, 0x72b1, 0x11d3, 0x9f, 0xc4, 0x0, 0xc0, 0x4f, 0x79, 0xa0, 0xa3); | 
|---|
| 70 |  | 
|---|
| 71 | // CLSID_CLR_v2_MetaData: {EFEA471A-44FD-4862-9292-0C58D46E1F3A} | 
|---|
| 72 | EXTERN_GUID(CLSID_CLR_v2_MetaData, 0xefea471a, 0x44fd, 0x4862, 0x92, 0x92, 0xc, 0x58, 0xd4, 0x6e, 0x1f, 0x3a); | 
|---|
| 73 |  | 
|---|
| 74 |  | 
|---|
| 75 | // CLSID_CorMetaDataRuntime: | 
|---|
| 76 | // This will can always be used to generate the "latest" metadata available. | 
|---|
| 77 | #define CLSID_CorMetaDataRuntime CLSID_CLR_v2_MetaData | 
|---|
| 78 |  | 
|---|
| 79 |  | 
|---|
| 80 | // {30FE7BE8-D7D9-11D2-9F80-00C04F79A0A3} | 
|---|
| 81 | EXTERN_GUID(MetaDataCheckDuplicatesFor, 0x30fe7be8, 0xd7d9, 0x11d2, 0x9f, 0x80, 0x0, 0xc0, 0x4f, 0x79, 0xa0, 0xa3); | 
|---|
| 82 |  | 
|---|
| 83 | // {DE3856F8-D7D9-11D2-9F80-00C04F79A0A3} | 
|---|
| 84 | EXTERN_GUID(MetaDataRefToDefCheck, 0xde3856f8, 0xd7d9, 0x11d2, 0x9f, 0x80, 0x0, 0xc0, 0x4f, 0x79, 0xa0, 0xa3); | 
|---|
| 85 |  | 
|---|
| 86 | // {E5D71A4C-D7DA-11D2-9F80-00C04F79A0A3} | 
|---|
| 87 | EXTERN_GUID(MetaDataNotificationForTokenMovement, 0xe5d71a4c, 0xd7da, 0x11d2, 0x9f, 0x80, 0x0, 0xc0, 0x4f, 0x79, 0xa0, 0xa3); | 
|---|
| 88 |  | 
|---|
| 89 | // {2eee315c-d7db-11d2-9f80-00c04f79a0a3} | 
|---|
| 90 | EXTERN_GUID(MetaDataSetUpdate, 0x2eee315c, 0xd7db, 0x11d2, 0x9f, 0x80, 0x0, 0xc0, 0x4f, 0x79, 0xa0, 0xa3); | 
|---|
| 91 | #define MetaDataSetENC MetaDataSetUpdate | 
|---|
| 92 |  | 
|---|
| 93 | // Use this guid in SetOption to indicate if the import enumerator should skip over | 
|---|
| 94 | // delete items or not. The default is yes. | 
|---|
| 95 | // | 
|---|
| 96 | // {79700F36-4AAC-11d3-84C3-009027868CB1} | 
|---|
| 97 | EXTERN_GUID(MetaDataImportOption, 0x79700f36, 0x4aac, 0x11d3, 0x84, 0xc3, 0x0, 0x90, 0x27, 0x86, 0x8c, 0xb1); | 
|---|
| 98 |  | 
|---|
| 99 | // Use this guid in the SetOption if compiler wants to have MetaData API to take reader/writer lock | 
|---|
| 100 | // | 
|---|
| 101 | // {F7559806-F266-42ea-8C63-0ADB45E8B234} | 
|---|
| 102 | EXTERN_GUID(MetaDataThreadSafetyOptions, 0xf7559806, 0xf266, 0x42ea, 0x8c, 0x63, 0xa, 0xdb, 0x45, 0xe8, 0xb2, 0x34); | 
|---|
| 103 |  | 
|---|
| 104 | // Use this guid in the SetOption if compiler wants error when some tokens are emitted out of order | 
|---|
| 105 | // {1547872D-DC03-11d2-9420-0000F8083460} | 
|---|
| 106 | EXTERN_GUID(MetaDataErrorIfEmitOutOfOrder, 0x1547872d, 0xdc03, 0x11d2, 0x94, 0x20, 0x0, 0x0, 0xf8, 0x8, 0x34, 0x60); | 
|---|
| 107 |  | 
|---|
| 108 | // Use this guid in the SetOption to indicate if the tlbimporter should generate the | 
|---|
| 109 | // TCE adapters for COM connection point containers. | 
|---|
| 110 | // {DCC9DE90-4151-11d3-88D6-00902754C43A} | 
|---|
| 111 | EXTERN_GUID(MetaDataGenerateTCEAdapters, 0xdcc9de90, 0x4151, 0x11d3, 0x88, 0xd6, 0x0, 0x90, 0x27, 0x54, 0xc4, 0x3a); | 
|---|
| 112 |  | 
|---|
| 113 | // Use this guid in the SetOption to specifiy a non-default namespace for typelib import. | 
|---|
| 114 | // {F17FF889-5A63-11d3-9FF2-00C04FF7431A} | 
|---|
| 115 | EXTERN_GUID(MetaDataTypeLibImportNamespace, 0xf17ff889, 0x5a63, 0x11d3, 0x9f, 0xf2, 0x0, 0xc0, 0x4f, 0xf7, 0x43, 0x1a); | 
|---|
| 116 |  | 
|---|
| 117 | // Use this guid in the SetOption to specify the behavior of UnmarkAll. See CorLinkerOptions. | 
|---|
| 118 | // {47E099B6-AE7C-4797-8317-B48AA645B8F9} | 
|---|
| 119 | EXTERN_GUID(MetaDataLinkerOptions, 0x47e099b6, 0xae7c, 0x4797, 0x83, 0x17, 0xb4, 0x8a, 0xa6, 0x45, 0xb8, 0xf9); | 
|---|
| 120 |  | 
|---|
| 121 | // Use this guid in the SetOption to specify the runtime version stored in the CLR metadata. | 
|---|
| 122 | // {47E099B7-AE7C-4797-8317-B48AA645B8F9} | 
|---|
| 123 | EXTERN_GUID(MetaDataRuntimeVersion, 0x47e099b7, 0xae7c, 0x4797, 0x83, 0x17, 0xb4, 0x8a, 0xa6, 0x45, 0xb8, 0xf9); | 
|---|
| 124 |  | 
|---|
| 125 | // Use this guid in the SetOption to specify the behavior of the merger. | 
|---|
| 126 | // {132D3A6E-B35D-464e-951A-42EFB9FB6601} | 
|---|
| 127 | EXTERN_GUID(MetaDataMergerOptions, 0x132d3a6e, 0xb35d, 0x464e, 0x95, 0x1a, 0x42, 0xef, 0xb9, 0xfb, 0x66, 0x1); | 
|---|
| 128 |  | 
|---|
| 129 | // Use this guid in SetOption to disable optimizing module-local refs to defs | 
|---|
| 130 | // {a55c0354-e91b-468b-8648-7cc31035d533} | 
|---|
| 131 | EXTERN_GUID(MetaDataPreserveLocalRefs, 0xa55c0354, 0xe91b, 0x468b, 0x86, 0x48, 0x7c, 0xc3, 0x10, 0x35, 0xd5, 0x33); | 
|---|
| 132 |  | 
|---|
| 133 | interface IMetaDataImport; | 
|---|
| 134 | interface IMetaDataAssemblyEmit; | 
|---|
| 135 | interface IMetaDataAssemblyImport; | 
|---|
| 136 | interface IMetaDataEmit; | 
|---|
| 137 | interface ICeeGen; | 
|---|
| 138 |  | 
|---|
| 139 |  | 
|---|
| 140 | typedef UNALIGNED void const *UVCP_CONSTANT; | 
|---|
| 141 |  | 
|---|
| 142 |  | 
|---|
| 143 | // Constant for connection id and task id | 
|---|
| 144 | #define INVALID_CONNECTION_ID   0x0 | 
|---|
| 145 | #define INVALID_TASK_ID         0x0 | 
|---|
| 146 | #define MAX_CONNECTION_NAME     MAX_PATH | 
|---|
| 147 |  | 
|---|
| 148 | //***************************************************************************** | 
|---|
| 149 | //***************************************************************************** | 
|---|
| 150 | // | 
|---|
| 151 | // D L L   P U B L I C   E N T R Y    P O I N T   D E C L A R A T I O N S | 
|---|
| 152 | // | 
|---|
| 153 | //***************************************************************************** | 
|---|
| 154 | //***************************************************************************** | 
|---|
| 155 |  | 
|---|
| 156 | BOOL STDMETHODCALLTYPE _CorDllMain(HINSTANCE hInst, DWORD dwReason, LPVOID lpReserved); | 
|---|
| 157 | __int32 STDMETHODCALLTYPE _CorExeMain(); | 
|---|
| 158 | __int32 STDMETHODCALLTYPE _CorExeMainInternal(); | 
|---|
| 159 | __int32 STDMETHODCALLTYPE _CorExeMain2( // Executable exit code. | 
|---|
| 160 | PBYTE   pUnmappedPE,                // -> memory mapped code | 
|---|
| 161 | DWORD   cUnmappedPE,                // Size of memory mapped code | 
|---|
| 162 | _In_ LPWSTR  pImageNameIn,          // -> Executable Name | 
|---|
| 163 | _In_ LPWSTR  pLoadersFileName,      // -> Loaders Name | 
|---|
| 164 | _In_ LPWSTR  pCmdLine);             // -> Command Line | 
|---|
| 165 |  | 
|---|
| 166 | STDAPI _CorValidateImage(PVOID *ImageBase, LPCWSTR FileName); | 
|---|
| 167 | STDAPI_(VOID) _CorImageUnloading(PVOID ImageBase); | 
|---|
| 168 |  | 
|---|
| 169 | DEPRECATED_CLR_STDAPI          CoInitializeEE(DWORD fFlags); | 
|---|
| 170 | DEPRECATED_CLR_STDAPI_(void)   CoUninitializeEE(BOOL fFlags); | 
|---|
| 171 | DEPRECATED_CLR_STDAPI_(void)   CoEEShutDownCOM(void); | 
|---|
| 172 |  | 
|---|
| 173 |  | 
|---|
| 174 |  | 
|---|
| 175 | #define MAIN_CLR_MODULE_NAME_W        W("coreclr") | 
|---|
| 176 | #define MAIN_CLR_MODULE_NAME_A         "coreclr" | 
|---|
| 177 |  | 
|---|
| 178 | #define MAIN_CLR_DLL_NAME_W           MAKEDLLNAME_W(MAIN_CLR_MODULE_NAME_W) | 
|---|
| 179 | #define MAIN_CLR_DLL_NAME_A           MAKEDLLNAME_A(MAIN_CLR_MODULE_NAME_A) | 
|---|
| 180 |  | 
|---|
| 181 |  | 
|---|
| 182 |  | 
|---|
| 183 | #define MSCOREE_SHIM_W               MAIN_CLR_DLL_NAME_W | 
|---|
| 184 | #define MSCOREE_SHIM_A               MAIN_CLR_DLL_NAME_A | 
|---|
| 185 |  | 
|---|
| 186 | #define SWITCHOUT_HANDLE_VALUE ((HANDLE)(LONG_PTR)-2) | 
|---|
| 187 |  | 
|---|
| 188 |  | 
|---|
| 189 | // | 
|---|
| 190 | // CoInitializeCor flags. | 
|---|
| 191 | // | 
|---|
| 192 | typedef enum tagCOINITCOR | 
|---|
| 193 | { | 
|---|
| 194 | COINITCOR_DEFAULT       = 0x0           // Default initialization mode. | 
|---|
| 195 | } COINITICOR; | 
|---|
| 196 |  | 
|---|
| 197 | // | 
|---|
| 198 | // CoInitializeEE flags. | 
|---|
| 199 | // | 
|---|
| 200 | typedef enum tagCOINITEE | 
|---|
| 201 | { | 
|---|
| 202 | COINITEE_DEFAULT        = 0x0,          // Default initialization mode. | 
|---|
| 203 | COINITEE_DLL            = 0x1,          // Initialization mode for loading DLL. | 
|---|
| 204 | COINITEE_MAIN           = 0x2           // Initialize prior to entering the main routine | 
|---|
| 205 | } COINITIEE; | 
|---|
| 206 |  | 
|---|
| 207 | // | 
|---|
| 208 | // CoInitializeEE flags. | 
|---|
| 209 | // | 
|---|
| 210 | typedef enum tagCOUNINITEE | 
|---|
| 211 | { | 
|---|
| 212 | COUNINITEE_DEFAULT      = 0x0,          // Default uninitialization mode. | 
|---|
| 213 | COUNINITEE_DLL          = 0x1           // Uninitialization mode for unloading DLL. | 
|---|
| 214 | } COUNINITIEE; | 
|---|
| 215 |  | 
|---|
| 216 | //***************************************************************************** | 
|---|
| 217 | //***************************************************************************** | 
|---|
| 218 | // | 
|---|
| 219 | // I L   &   F I L E   F O R M A T   D E C L A R A T I O N S | 
|---|
| 220 | // | 
|---|
| 221 | //***************************************************************************** | 
|---|
| 222 | //***************************************************************************** | 
|---|
| 223 |  | 
|---|
| 224 |  | 
|---|
| 225 | // | 
|---|
| 226 | #ifndef _WINDOWS_UPDATES_ | 
|---|
| 227 | #include <corhdr.h> | 
|---|
| 228 | #endif // <windows.h> updates | 
|---|
| 229 |  | 
|---|
| 230 | //***************************************************************************** | 
|---|
| 231 | //***************************************************************************** | 
|---|
| 232 | // | 
|---|
| 233 | // D L L   P U B L I C   E N T R Y    P O I N T   D E C L A R A T I O N S | 
|---|
| 234 | // | 
|---|
| 235 | //***************************************************************************** | 
|---|
| 236 | //***************************************************************************** | 
|---|
| 237 |  | 
|---|
| 238 | DEPRECATED_CLR_STDAPI          CoInitializeCor(DWORD fFlags); | 
|---|
| 239 | DEPRECATED_CLR_STDAPI_(void)   CoUninitializeCor(void); | 
|---|
| 240 |  | 
|---|
| 241 | // | 
|---|
| 242 | //***************************************************************************** | 
|---|
| 243 | //***************************************************************************** | 
|---|
| 244 |  | 
|---|
| 245 | // CLSID_Cor: {bee00000-ee77-11d0-a015-00c04fbbb884} | 
|---|
| 246 | EXTERN_GUID(CLSID_Cor, 0xbee00010, 0xee77, 0x11d0, 0xa0, 0x15, 0x00, 0xc0, 0x4f, 0xbb, 0xb8, 0x84); | 
|---|
| 247 |  | 
|---|
| 248 | // CLSID_CorMetaDataDispenser: {E5CB7A31-7512-11d2-89CE-0080C792E5D8} | 
|---|
| 249 | //  This is the "Master Dispenser", always guaranteed to be the most recent | 
|---|
| 250 | //  dispenser on the machine. | 
|---|
| 251 | EXTERN_GUID(CLSID_CorMetaDataDispenser, 0xe5cb7a31, 0x7512, 0x11d2, 0x89, 0xce, 0x0, 0x80, 0xc7, 0x92, 0xe5, 0xd8); | 
|---|
| 252 |  | 
|---|
| 253 |  | 
|---|
| 254 | // CLSID_CorMetaDataDispenserReg: {435755FF-7397-11d2-9771-00A0C9B4D50C} | 
|---|
| 255 | //  Dispenser coclass for version 1.0 meta data.  To get the "latest" bind | 
|---|
| 256 | //  to CLSID_CorMetaDataDispenser. | 
|---|
| 257 | EXTERN_GUID(CLSID_CorMetaDataDispenserReg, 0x435755ff, 0x7397, 0x11d2, 0x97, 0x71, 0x0, 0xa0, 0xc9, 0xb4, 0xd5, 0xc); | 
|---|
| 258 |  | 
|---|
| 259 |  | 
|---|
| 260 | // CLSID_CorMetaDataReg: {87F3A1F5-7397-11d2-9771-00A0C9B4D50C} | 
|---|
| 261 | // For COM+ Meta Data, Data Driven Registration | 
|---|
| 262 | EXTERN_GUID(CLSID_CorMetaDataReg, 0x87f3a1f5, 0x7397, 0x11d2, 0x97, 0x71, 0x0, 0xa0, 0xc9, 0xb4, 0xd5, 0xc); | 
|---|
| 263 |  | 
|---|
| 264 |  | 
|---|
| 265 | interface IMetaDataDispenser; | 
|---|
| 266 |  | 
|---|
| 267 | //------------------------------------- | 
|---|
| 268 | //--- IMetaDataError | 
|---|
| 269 | //------------------------------------- | 
|---|
| 270 | // {B81FF171-20F3-11d2-8DCC-00A0C9B09C19} | 
|---|
| 271 | EXTERN_GUID(IID_IMetaDataError, 0xb81ff171, 0x20f3, 0x11d2, 0x8d, 0xcc, 0x0, 0xa0, 0xc9, 0xb0, 0x9c, 0x19); | 
|---|
| 272 |  | 
|---|
| 273 | //--- | 
|---|
| 274 | #undef  INTERFACE | 
|---|
| 275 | #define INTERFACE IMetaDataError | 
|---|
| 276 | DECLARE_INTERFACE_(IMetaDataError, IUnknown) | 
|---|
| 277 | { | 
|---|
| 278 | STDMETHOD(OnError)(HRESULT hrError, mdToken token) PURE; | 
|---|
| 279 | }; | 
|---|
| 280 |  | 
|---|
| 281 | //------------------------------------- | 
|---|
| 282 | //--- IMapToken | 
|---|
| 283 | //------------------------------------- | 
|---|
| 284 | // IID_IMapToken: {06A3EA8B-0225-11d1-BF72-00C04FC31E12} | 
|---|
| 285 | EXTERN_GUID(IID_IMapToken, 0x6a3ea8b, 0x225, 0x11d1, 0xbf, 0x72, 0x0, 0xc0, 0x4f, 0xc3, 0x1e, 0x12); | 
|---|
| 286 |  | 
|---|
| 287 | //--- | 
|---|
| 288 | #undef  INTERFACE | 
|---|
| 289 | #define INTERFACE IMapToken | 
|---|
| 290 | DECLARE_INTERFACE_(IMapToken, IUnknown) | 
|---|
| 291 | { | 
|---|
| 292 | STDMETHOD(Map)(mdToken tkImp, mdToken tkEmit) PURE; | 
|---|
| 293 | }; | 
|---|
| 294 |  | 
|---|
| 295 | //------------------------------------- | 
|---|
| 296 | //--- IMetaDataDispenser | 
|---|
| 297 | //------------------------------------- | 
|---|
| 298 | // {809C652E-7396-11D2-9771-00A0C9B4D50C} | 
|---|
| 299 | EXTERN_GUID(IID_IMetaDataDispenser, 0x809c652e, 0x7396, 0x11d2, 0x97, 0x71, 0x00, 0xa0, 0xc9, 0xb4, 0xd5, 0x0c); | 
|---|
| 300 |  | 
|---|
| 301 | //--- | 
|---|
| 302 | #undef  INTERFACE | 
|---|
| 303 | #define INTERFACE IMetaDataDispenser | 
|---|
| 304 | DECLARE_INTERFACE_(IMetaDataDispenser, IUnknown) | 
|---|
| 305 | { | 
|---|
| 306 | STDMETHOD(DefineScope)(                 // Return code. | 
|---|
| 307 | REFCLSID    rclsid,                 // [in] What version to create. | 
|---|
| 308 | DWORD       dwCreateFlags,          // [in] Flags on the create. | 
|---|
| 309 | REFIID      riid,                   // [in] The interface desired. | 
|---|
| 310 | IUnknown    **ppIUnk) PURE;         // [out] Return interface on success. | 
|---|
| 311 |  | 
|---|
| 312 | STDMETHOD(OpenScope)(                   // Return code. | 
|---|
| 313 | LPCWSTR     szScope,                // [in] The scope to open. | 
|---|
| 314 | DWORD       dwOpenFlags,            // [in] Open mode flags. | 
|---|
| 315 | REFIID      riid,                   // [in] The interface desired. | 
|---|
| 316 | IUnknown    **ppIUnk) PURE;         // [out] Return interface on success. | 
|---|
| 317 |  | 
|---|
| 318 | STDMETHOD(OpenScopeOnMemory)(           // Return code. | 
|---|
| 319 | LPCVOID     pData,                  // [in] Location of scope data. | 
|---|
| 320 | ULONG       cbData,                 // [in] Size of the data pointed to by pData. | 
|---|
| 321 | DWORD       dwOpenFlags,            // [in] Open mode flags. | 
|---|
| 322 | REFIID      riid,                   // [in] The interface desired. | 
|---|
| 323 | IUnknown    **ppIUnk) PURE;         // [out] Return interface on success. | 
|---|
| 324 | }; | 
|---|
| 325 |  | 
|---|
| 326 | //------------------------------------- | 
|---|
| 327 | //--- IMetaDataEmit | 
|---|
| 328 | //------------------------------------- | 
|---|
| 329 | // {BA3FEE4C-ECB9-4e41-83B7-183FA41CD859} | 
|---|
| 330 | EXTERN_GUID(IID_IMetaDataEmit, 0xba3fee4c, 0xecb9, 0x4e41, 0x83, 0xb7, 0x18, 0x3f, 0xa4, 0x1c, 0xd8, 0x59); | 
|---|
| 331 |  | 
|---|
| 332 | //--- | 
|---|
| 333 | #undef  INTERFACE | 
|---|
| 334 | #define INTERFACE IMetaDataEmit | 
|---|
| 335 | DECLARE_INTERFACE_(IMetaDataEmit, IUnknown) | 
|---|
| 336 | { | 
|---|
| 337 | STDMETHOD(SetModuleProps)(              // S_OK or error. | 
|---|
| 338 | LPCWSTR     szName) PURE;           // [IN] If not NULL, the name of the module to set. | 
|---|
| 339 |  | 
|---|
| 340 | STDMETHOD(Save)(                        // S_OK or error. | 
|---|
| 341 | LPCWSTR     szFile,                 // [IN] The filename to save to. | 
|---|
| 342 | DWORD       dwSaveFlags) PURE;      // [IN] Flags for the save. | 
|---|
| 343 |  | 
|---|
| 344 | STDMETHOD(SaveToStream)(                // S_OK or error. | 
|---|
| 345 | IStream     *pIStream,              // [IN] A writable stream to save to. | 
|---|
| 346 | DWORD       dwSaveFlags) PURE;      // [IN] Flags for the save. | 
|---|
| 347 |  | 
|---|
| 348 | STDMETHOD(GetSaveSize)(                 // S_OK or error. | 
|---|
| 349 | CorSaveSize fSave,                  // [IN] cssAccurate or cssQuick. | 
|---|
| 350 | DWORD       *pdwSaveSize) PURE;     // [OUT] Put the size here. | 
|---|
| 351 |  | 
|---|
| 352 | STDMETHOD(DefineTypeDef)(               // S_OK or error. | 
|---|
| 353 | LPCWSTR     szTypeDef,              // [IN] Name of TypeDef | 
|---|
| 354 | DWORD       dwTypeDefFlags,         // [IN] CustomAttribute flags | 
|---|
| 355 | mdToken     tkExtends,              // [IN] extends this TypeDef or typeref | 
|---|
| 356 | mdToken     rtkImplements[],        // [IN] Implements interfaces | 
|---|
| 357 | mdTypeDef   *ptd) PURE;             // [OUT] Put TypeDef token here | 
|---|
| 358 |  | 
|---|
| 359 | STDMETHOD(DefineNestedType)(            // S_OK or error. | 
|---|
| 360 | LPCWSTR     szTypeDef,              // [IN] Name of TypeDef | 
|---|
| 361 | DWORD       dwTypeDefFlags,         // [IN] CustomAttribute flags | 
|---|
| 362 | mdToken     tkExtends,              // [IN] extends this TypeDef or typeref | 
|---|
| 363 | mdToken     rtkImplements[],        // [IN] Implements interfaces | 
|---|
| 364 | mdTypeDef   tdEncloser,             // [IN] TypeDef token of the enclosing type. | 
|---|
| 365 | mdTypeDef   *ptd) PURE;             // [OUT] Put TypeDef token here | 
|---|
| 366 |  | 
|---|
| 367 | STDMETHOD(SetHandler)(                  // S_OK. | 
|---|
| 368 | IUnknown    *pUnk) PURE;            // [IN] The new error handler. | 
|---|
| 369 |  | 
|---|
| 370 | STDMETHOD(DefineMethod)(                // S_OK or error. | 
|---|
| 371 | mdTypeDef   td,                     // Parent TypeDef | 
|---|
| 372 | LPCWSTR     szName,                 // Name of member | 
|---|
| 373 | DWORD       dwMethodFlags,          // Member attributes | 
|---|
| 374 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of CLR signature | 
|---|
| 375 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 376 | ULONG       ulCodeRVA, | 
|---|
| 377 | DWORD       dwImplFlags, | 
|---|
| 378 | mdMethodDef *pmd) PURE;             // Put member token here | 
|---|
| 379 |  | 
|---|
| 380 | STDMETHOD(DefineMethodImpl)(            // S_OK or error. | 
|---|
| 381 | mdTypeDef   td,                     // [IN] The class implementing the method | 
|---|
| 382 | mdToken     tkBody,                 // [IN] Method body - MethodDef or MethodRef | 
|---|
| 383 | mdToken     tkDecl) PURE;           // [IN] Method declaration - MethodDef or MethodRef | 
|---|
| 384 |  | 
|---|
| 385 | STDMETHOD(DefineTypeRefByName)(         // S_OK or error. | 
|---|
| 386 | mdToken     tkResolutionScope,      // [IN] ModuleRef, AssemblyRef or TypeRef. | 
|---|
| 387 | LPCWSTR     szName,                 // [IN] Name of the TypeRef. | 
|---|
| 388 | mdTypeRef   *ptr) PURE;             // [OUT] Put TypeRef token here. | 
|---|
| 389 |  | 
|---|
| 390 | STDMETHOD(DefineImportType)(            // S_OK or error. | 
|---|
| 391 | IMetaDataAssemblyImport *pAssemImport,  // [IN] Assembly containing the TypeDef. | 
|---|
| 392 | const void  *pbHashValue,           // [IN] Hash Blob for Assembly. | 
|---|
| 393 | ULONG       cbHashValue,            // [IN] Count of bytes. | 
|---|
| 394 | IMetaDataImport *pImport,           // [IN] Scope containing the TypeDef. | 
|---|
| 395 | mdTypeDef   tdImport,               // [IN] The imported TypeDef. | 
|---|
| 396 | IMetaDataAssemblyEmit *pAssemEmit,  // [IN] Assembly into which the TypeDef is imported. | 
|---|
| 397 | mdTypeRef   *ptr) PURE;             // [OUT] Put TypeRef token here. | 
|---|
| 398 |  | 
|---|
| 399 | STDMETHOD(DefineMemberRef)(             // S_OK or error | 
|---|
| 400 | mdToken     tkImport,               // [IN] ClassRef or ClassDef importing a member. | 
|---|
| 401 | LPCWSTR     szName,                 // [IN] member's name | 
|---|
| 402 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of CLR signature | 
|---|
| 403 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 404 | mdMemberRef *pmr) PURE;             // [OUT] memberref token | 
|---|
| 405 |  | 
|---|
| 406 | STDMETHOD(DefineImportMember)(          // S_OK or error. | 
|---|
| 407 | IMetaDataAssemblyImport *pAssemImport,  // [IN] Assembly containing the Member. | 
|---|
| 408 | const void  *pbHashValue,           // [IN] Hash Blob for Assembly. | 
|---|
| 409 | ULONG       cbHashValue,            // [IN] Count of bytes. | 
|---|
| 410 | IMetaDataImport *pImport,           // [IN] Import scope, with member. | 
|---|
| 411 | mdToken     mbMember,               // [IN] Member in import scope. | 
|---|
| 412 | IMetaDataAssemblyEmit *pAssemEmit,  // [IN] Assembly into which the Member is imported. | 
|---|
| 413 | mdToken     tkParent,               // [IN] Classref or classdef in emit scope. | 
|---|
| 414 | mdMemberRef *pmr) PURE;             // [OUT] Put member ref here. | 
|---|
| 415 |  | 
|---|
| 416 | STDMETHOD(DefineEvent) ( | 
|---|
| 417 | mdTypeDef   td,                     // [IN] the class/interface on which the event is being defined | 
|---|
| 418 | LPCWSTR     szEvent,                // [IN] Name of the event | 
|---|
| 419 | DWORD       dwEventFlags,           // [IN] CorEventAttr | 
|---|
| 420 | mdToken     tkEventType,            // [IN] a reference (mdTypeRef or mdTypeRef) to the Event class | 
|---|
| 421 | mdMethodDef mdAddOn,                // [IN] required add method | 
|---|
| 422 | mdMethodDef mdRemoveOn,             // [IN] required remove method | 
|---|
| 423 | mdMethodDef mdFire,                 // [IN] optional fire method | 
|---|
| 424 | mdMethodDef rmdOtherMethods[],      // [IN] optional array of other methods associate with the event | 
|---|
| 425 | mdEvent     *pmdEvent) PURE;        // [OUT] output event token | 
|---|
| 426 |  | 
|---|
| 427 | STDMETHOD(SetClassLayout) ( | 
|---|
| 428 | mdTypeDef   td,                     // [IN] typedef | 
|---|
| 429 | DWORD       dwPackSize,             // [IN] packing size specified as 1, 2, 4, 8, or 16 | 
|---|
| 430 | COR_FIELD_OFFSET rFieldOffsets[],   // [IN] array of layout specification | 
|---|
| 431 | ULONG       ulClassSize) PURE;      // [IN] size of the class | 
|---|
| 432 |  | 
|---|
| 433 | STDMETHOD(DeleteClassLayout) ( | 
|---|
| 434 | mdTypeDef   td) PURE;               // [IN] typedef whose layout is to be deleted. | 
|---|
| 435 |  | 
|---|
| 436 | STDMETHOD(SetFieldMarshal) ( | 
|---|
| 437 | mdToken     tk,                     // [IN] given a fieldDef or paramDef token | 
|---|
| 438 | PCCOR_SIGNATURE pvNativeType,       // [IN] native type specification | 
|---|
| 439 | ULONG       cbNativeType) PURE;     // [IN] count of bytes of pvNativeType | 
|---|
| 440 |  | 
|---|
| 441 | STDMETHOD(DeleteFieldMarshal) ( | 
|---|
| 442 | mdToken     tk) PURE;               // [IN] given a fieldDef or paramDef token | 
|---|
| 443 |  | 
|---|
| 444 | STDMETHOD(DefinePermissionSet) ( | 
|---|
| 445 | mdToken     tk,                     // [IN] the object to be decorated. | 
|---|
| 446 | DWORD       dwAction,               // [IN] CorDeclSecurity. | 
|---|
| 447 | void const  *pvPermission,          // [IN] permission blob. | 
|---|
| 448 | ULONG       cbPermission,           // [IN] count of bytes of pvPermission. | 
|---|
| 449 | mdPermission *ppm) PURE;            // [OUT] returned permission token. | 
|---|
| 450 |  | 
|---|
| 451 | STDMETHOD(SetRVA)(                      // S_OK or error. | 
|---|
| 452 | mdMethodDef md,                     // [IN] Method for which to set offset | 
|---|
| 453 | ULONG       ulRVA) PURE;            // [IN] The offset | 
|---|
| 454 |  | 
|---|
| 455 | STDMETHOD(GetTokenFromSig)(             // S_OK or error. | 
|---|
| 456 | PCCOR_SIGNATURE pvSig,              // [IN] Signature to define. | 
|---|
| 457 | ULONG       cbSig,                  // [IN] Size of signature data. | 
|---|
| 458 | mdSignature *pmsig) PURE;           // [OUT] returned signature token. | 
|---|
| 459 |  | 
|---|
| 460 | STDMETHOD(DefineModuleRef)(             // S_OK or error. | 
|---|
| 461 | LPCWSTR     szName,                 // [IN] DLL name | 
|---|
| 462 | mdModuleRef *pmur) PURE;            // [OUT] returned | 
|---|
| 463 |  | 
|---|
| 464 | // <TODO>@FUTURE:  This should go away once everyone starts using SetMemberRefProps.</TODO> | 
|---|
| 465 | STDMETHOD(SetParent)(                   // S_OK or error. | 
|---|
| 466 | mdMemberRef mr,                     // [IN] Token for the ref to be fixed up. | 
|---|
| 467 | mdToken     tk) PURE;               // [IN] The ref parent. | 
|---|
| 468 |  | 
|---|
| 469 | STDMETHOD(GetTokenFromTypeSpec)(        // S_OK or error. | 
|---|
| 470 | PCCOR_SIGNATURE pvSig,              // [IN] TypeSpec Signature to define. | 
|---|
| 471 | ULONG       cbSig,                  // [IN] Size of signature data. | 
|---|
| 472 | mdTypeSpec *ptypespec) PURE;        // [OUT] returned TypeSpec token. | 
|---|
| 473 |  | 
|---|
| 474 | STDMETHOD(SaveToMemory)(                // S_OK or error. | 
|---|
| 475 | void        *pbData,                // [OUT] Location to write data. | 
|---|
| 476 | ULONG       cbData) PURE;           // [IN] Max size of data buffer. | 
|---|
| 477 |  | 
|---|
| 478 | STDMETHOD(DefineUserString)(            // Return code. | 
|---|
| 479 | LPCWSTR szString,                   // [IN] User literal string. | 
|---|
| 480 | ULONG       cchString,              // [IN] Length of string. | 
|---|
| 481 | mdString    *pstk) PURE;            // [OUT] String token. | 
|---|
| 482 |  | 
|---|
| 483 | STDMETHOD(DeleteToken)(                 // Return code. | 
|---|
| 484 | mdToken     tkObj) PURE;            // [IN] The token to be deleted | 
|---|
| 485 |  | 
|---|
| 486 | STDMETHOD(SetMethodProps)(              // S_OK or error. | 
|---|
| 487 | mdMethodDef md,                     // [IN] The MethodDef. | 
|---|
| 488 | DWORD       dwMethodFlags,          // [IN] Method attributes. | 
|---|
| 489 | ULONG       ulCodeRVA,              // [IN] Code RVA. | 
|---|
| 490 | DWORD       dwImplFlags) PURE;      // [IN] Impl flags. | 
|---|
| 491 |  | 
|---|
| 492 | STDMETHOD(SetTypeDefProps)(             // S_OK or error. | 
|---|
| 493 | mdTypeDef   td,                     // [IN] The TypeDef. | 
|---|
| 494 | DWORD       dwTypeDefFlags,         // [IN] TypeDef flags. | 
|---|
| 495 | mdToken     tkExtends,              // [IN] Base TypeDef or TypeRef. | 
|---|
| 496 | mdToken     rtkImplements[]) PURE;  // [IN] Implemented interfaces. | 
|---|
| 497 |  | 
|---|
| 498 | STDMETHOD(SetEventProps)(               // S_OK or error. | 
|---|
| 499 | mdEvent     ev,                     // [IN] The event token. | 
|---|
| 500 | DWORD       dwEventFlags,           // [IN] CorEventAttr. | 
|---|
| 501 | mdToken     tkEventType,            // [IN] A reference (mdTypeRef or mdTypeRef) to the Event class. | 
|---|
| 502 | mdMethodDef mdAddOn,                // [IN] Add method. | 
|---|
| 503 | mdMethodDef mdRemoveOn,             // [IN] Remove method. | 
|---|
| 504 | mdMethodDef mdFire,                 // [IN] Fire method. | 
|---|
| 505 | mdMethodDef rmdOtherMethods[]) PURE;// [IN] Array of other methods associate with the event. | 
|---|
| 506 |  | 
|---|
| 507 | STDMETHOD(SetPermissionSetProps)(       // S_OK or error. | 
|---|
| 508 | mdToken     tk,                     // [IN] The object to be decorated. | 
|---|
| 509 | DWORD       dwAction,               // [IN] CorDeclSecurity. | 
|---|
| 510 | void const  *pvPermission,          // [IN] Permission blob. | 
|---|
| 511 | ULONG       cbPermission,           // [IN] Count of bytes of pvPermission. | 
|---|
| 512 | mdPermission *ppm) PURE;            // [OUT] Permission token. | 
|---|
| 513 |  | 
|---|
| 514 | STDMETHOD(DefinePinvokeMap)(            // Return code. | 
|---|
| 515 | mdToken     tk,                     // [IN] FieldDef or MethodDef. | 
|---|
| 516 | DWORD       dwMappingFlags,         // [IN] Flags used for mapping. | 
|---|
| 517 | LPCWSTR     szImportName,           // [IN] Import name. | 
|---|
| 518 | mdModuleRef mrImportDLL) PURE;      // [IN] ModuleRef token for the target DLL. | 
|---|
| 519 |  | 
|---|
| 520 | STDMETHOD(SetPinvokeMap)(               // Return code. | 
|---|
| 521 | mdToken     tk,                     // [IN] FieldDef or MethodDef. | 
|---|
| 522 | DWORD       dwMappingFlags,         // [IN] Flags used for mapping. | 
|---|
| 523 | LPCWSTR     szImportName,           // [IN] Import name. | 
|---|
| 524 | mdModuleRef mrImportDLL) PURE;      // [IN] ModuleRef token for the target DLL. | 
|---|
| 525 |  | 
|---|
| 526 | STDMETHOD(DeletePinvokeMap)(            // Return code. | 
|---|
| 527 | mdToken     tk) PURE;               // [IN] FieldDef or MethodDef. | 
|---|
| 528 |  | 
|---|
| 529 | // New CustomAttribute functions. | 
|---|
| 530 | STDMETHOD(DefineCustomAttribute)(       // Return code. | 
|---|
| 531 | mdToken     tkOwner,                // [IN] The object to put the value on. | 
|---|
| 532 | mdToken     tkCtor,                 // [IN] Constructor of the CustomAttribute type (MemberRef/MethodDef). | 
|---|
| 533 | void const  *pCustomAttribute,      // [IN] The custom value data. | 
|---|
| 534 | ULONG       cbCustomAttribute,      // [IN] The custom value data length. | 
|---|
| 535 | mdCustomAttribute *pcv) PURE;       // [OUT] The custom value token value on return. | 
|---|
| 536 |  | 
|---|
| 537 | STDMETHOD(SetCustomAttributeValue)(     // Return code. | 
|---|
| 538 | mdCustomAttribute pcv,              // [IN] The custom value token whose value to replace. | 
|---|
| 539 | void const  *pCustomAttribute,      // [IN] The custom value data. | 
|---|
| 540 | ULONG       cbCustomAttribute) PURE;// [IN] The custom value data length. | 
|---|
| 541 |  | 
|---|
| 542 | STDMETHOD(DefineField)(                 // S_OK or error. | 
|---|
| 543 | mdTypeDef   td,                     // Parent TypeDef | 
|---|
| 544 | LPCWSTR     szName,                 // Name of member | 
|---|
| 545 | DWORD       dwFieldFlags,           // Member attributes | 
|---|
| 546 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of CLR signature | 
|---|
| 547 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 548 | DWORD       dwCPlusTypeFlag,        // [IN] flag for value type. selected ELEMENT_TYPE_* | 
|---|
| 549 | void const  *pValue,                // [IN] constant value | 
|---|
| 550 | ULONG       cchValue,               // [IN] size of constant value (string, in wide chars). | 
|---|
| 551 | mdFieldDef  *pmd) PURE;             // [OUT] Put member token here | 
|---|
| 552 |  | 
|---|
| 553 | STDMETHOD(DefineProperty)( | 
|---|
| 554 | mdTypeDef   td,                     // [IN] the class/interface on which the property is being defined | 
|---|
| 555 | LPCWSTR     szProperty,             // [IN] Name of the property | 
|---|
| 556 | DWORD       dwPropFlags,            // [IN] CorPropertyAttr | 
|---|
| 557 | PCCOR_SIGNATURE pvSig,              // [IN] the required type signature | 
|---|
| 558 | ULONG       cbSig,                  // [IN] the size of the type signature blob | 
|---|
| 559 | DWORD       dwCPlusTypeFlag,        // [IN] flag for value type. selected ELEMENT_TYPE_* | 
|---|
| 560 | void const  *pValue,                // [IN] constant value | 
|---|
| 561 | ULONG       cchValue,               // [IN] size of constant value (string, in wide chars). | 
|---|
| 562 | mdMethodDef mdSetter,               // [IN] optional setter of the property | 
|---|
| 563 | mdMethodDef mdGetter,               // [IN] optional getter of the property | 
|---|
| 564 | mdMethodDef rmdOtherMethods[],      // [IN] an optional array of other methods | 
|---|
| 565 | mdProperty  *pmdProp) PURE;         // [OUT] output property token | 
|---|
| 566 |  | 
|---|
| 567 | STDMETHOD(DefineParam)( | 
|---|
| 568 | mdMethodDef md,                     // [IN] Owning method | 
|---|
| 569 | ULONG       ulParamSeq,             // [IN] Which param | 
|---|
| 570 | LPCWSTR     szName,                 // [IN] Optional param name | 
|---|
| 571 | DWORD       dwParamFlags,           // [IN] Optional param flags | 
|---|
| 572 | DWORD       dwCPlusTypeFlag,        // [IN] flag for value type. selected ELEMENT_TYPE_* | 
|---|
| 573 | void const  *pValue,                // [IN] constant value | 
|---|
| 574 | ULONG       cchValue,               // [IN] size of constant value (string, in wide chars). | 
|---|
| 575 | mdParamDef  *ppd) PURE;             // [OUT] Put param token here | 
|---|
| 576 |  | 
|---|
| 577 | STDMETHOD(SetFieldProps)(               // S_OK or error. | 
|---|
| 578 | mdFieldDef  fd,                     // [IN] The FieldDef. | 
|---|
| 579 | DWORD       dwFieldFlags,           // [IN] Field attributes. | 
|---|
| 580 | DWORD       dwCPlusTypeFlag,        // [IN] Flag for the value type, selected ELEMENT_TYPE_* | 
|---|
| 581 | void const  *pValue,                // [IN] Constant value. | 
|---|
| 582 | ULONG       cchValue) PURE;         // [IN] size of constant value (string, in wide chars). | 
|---|
| 583 |  | 
|---|
| 584 | STDMETHOD(SetPropertyProps)(            // S_OK or error. | 
|---|
| 585 | mdProperty  pr,                     // [IN] Property token. | 
|---|
| 586 | DWORD       dwPropFlags,            // [IN] CorPropertyAttr. | 
|---|
| 587 | DWORD       dwCPlusTypeFlag,        // [IN] Flag for value type, selected ELEMENT_TYPE_* | 
|---|
| 588 | void const  *pValue,                // [IN] Constant value. | 
|---|
| 589 | ULONG       cchValue,               // [IN] size of constant value (string, in wide chars). | 
|---|
| 590 | mdMethodDef mdSetter,               // [IN] Setter of the property. | 
|---|
| 591 | mdMethodDef mdGetter,               // [IN] Getter of the property. | 
|---|
| 592 | mdMethodDef rmdOtherMethods[]) PURE;// [IN] Array of other methods. | 
|---|
| 593 |  | 
|---|
| 594 | STDMETHOD(SetParamProps)(               // Return code. | 
|---|
| 595 | mdParamDef  pd,                     // [IN] Param token. | 
|---|
| 596 | LPCWSTR     szName,                 // [IN] Param name. | 
|---|
| 597 | DWORD       dwParamFlags,           // [IN] Param flags. | 
|---|
| 598 | DWORD       dwCPlusTypeFlag,        // [IN] Flag for value type. selected ELEMENT_TYPE_*. | 
|---|
| 599 | void const  *pValue,                // [OUT] Constant value. | 
|---|
| 600 | ULONG       cchValue) PURE;         // [IN] size of constant value (string, in wide chars). | 
|---|
| 601 |  | 
|---|
| 602 | // Specialized Custom Attributes for security. | 
|---|
| 603 | STDMETHOD(DefineSecurityAttributeSet)(  // Return code. | 
|---|
| 604 | mdToken     tkObj,                  // [IN] Class or method requiring security attributes. | 
|---|
| 605 | COR_SECATTR rSecAttrs[],            // [IN] Array of security attribute descriptions. | 
|---|
| 606 | ULONG       cSecAttrs,              // [IN] Count of elements in above array. | 
|---|
| 607 | ULONG       *pulErrorAttr) PURE;    // [OUT] On error, index of attribute causing problem. | 
|---|
| 608 |  | 
|---|
| 609 | STDMETHOD(ApplyEditAndContinue)(        // S_OK or error. | 
|---|
| 610 | IUnknown    *pImport) PURE;         // [IN] Metadata from the delta PE. | 
|---|
| 611 |  | 
|---|
| 612 | STDMETHOD(TranslateSigWithScope)( | 
|---|
| 613 | IMetaDataAssemblyImport *pAssemImport, // [IN] importing assembly interface | 
|---|
| 614 | const void  *pbHashValue,           // [IN] Hash Blob for Assembly. | 
|---|
| 615 | ULONG       cbHashValue,            // [IN] Count of bytes. | 
|---|
| 616 | IMetaDataImport *import,            // [IN] importing interface | 
|---|
| 617 | PCCOR_SIGNATURE pbSigBlob,          // [IN] signature in the importing scope | 
|---|
| 618 | ULONG       cbSigBlob,              // [IN] count of bytes of signature | 
|---|
| 619 | IMetaDataAssemblyEmit *pAssemEmit,  // [IN] emit assembly interface | 
|---|
| 620 | IMetaDataEmit *emit,                // [IN] emit interface | 
|---|
| 621 | PCOR_SIGNATURE pvTranslatedSig,     // [OUT] buffer to hold translated signature | 
|---|
| 622 | ULONG       cbTranslatedSigMax, | 
|---|
| 623 | ULONG       *pcbTranslatedSig) PURE;// [OUT] count of bytes in the translated signature | 
|---|
| 624 |  | 
|---|
| 625 | STDMETHOD(SetMethodImplFlags)(          // [IN] S_OK or error. | 
|---|
| 626 | mdMethodDef md,                     // [IN] Method for which to set ImplFlags | 
|---|
| 627 | DWORD       dwImplFlags) PURE; | 
|---|
| 628 |  | 
|---|
| 629 | STDMETHOD(SetFieldRVA)(                 // [IN] S_OK or error. | 
|---|
| 630 | mdFieldDef  fd,                     // [IN] Field for which to set offset | 
|---|
| 631 | ULONG       ulRVA) PURE;            // [IN] The offset | 
|---|
| 632 |  | 
|---|
| 633 | STDMETHOD(Merge)(                       // S_OK or error. | 
|---|
| 634 | IMetaDataImport *pImport,           // [IN] The scope to be merged. | 
|---|
| 635 | IMapToken   *pHostMapToken,         // [IN] Host IMapToken interface to receive token remap notification | 
|---|
| 636 | IUnknown    *pHandler) PURE;        // [IN] An object to receive to receive error notification. | 
|---|
| 637 |  | 
|---|
| 638 | STDMETHOD(MergeEnd)() PURE;             // S_OK or error. | 
|---|
| 639 |  | 
|---|
| 640 | // This interface is sealed.  Do not change, add, or remove anything.  Instead, derive a new iterface. | 
|---|
| 641 |  | 
|---|
| 642 | };      // IMetaDataEmit | 
|---|
| 643 |  | 
|---|
| 644 | //------------------------------------- | 
|---|
| 645 | //--- IMetaDataEmit2 | 
|---|
| 646 | //------------------------------------- | 
|---|
| 647 | // {F5DD9950-F693-42e6-830E-7B833E8146A9} | 
|---|
| 648 | EXTERN_GUID(IID_IMetaDataEmit2, 0xf5dd9950, 0xf693, 0x42e6, 0x83, 0xe, 0x7b, 0x83, 0x3e, 0x81, 0x46, 0xa9); | 
|---|
| 649 |  | 
|---|
| 650 | //--- | 
|---|
| 651 | #undef  INTERFACE | 
|---|
| 652 | #define INTERFACE IMetaDataEmit2 | 
|---|
| 653 | DECLARE_INTERFACE_(IMetaDataEmit2, IMetaDataEmit) | 
|---|
| 654 | { | 
|---|
| 655 | STDMETHOD(DefineMethodSpec)( | 
|---|
| 656 | mdToken     tkParent,               // [IN] MethodDef or MemberRef | 
|---|
| 657 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of COM+ signature | 
|---|
| 658 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 659 | mdMethodSpec *pmi) PURE;            // [OUT] method instantiation token | 
|---|
| 660 |  | 
|---|
| 661 | STDMETHOD(GetDeltaSaveSize)(            // S_OK or error. | 
|---|
| 662 | CorSaveSize fSave,                  // [IN] cssAccurate or cssQuick. | 
|---|
| 663 | DWORD       *pdwSaveSize) PURE;     // [OUT] Put the size here. | 
|---|
| 664 |  | 
|---|
| 665 | STDMETHOD(SaveDelta)(                   // S_OK or error. | 
|---|
| 666 | LPCWSTR     szFile,                 // [IN] The filename to save to. | 
|---|
| 667 | DWORD       dwSaveFlags) PURE;      // [IN] Flags for the save. | 
|---|
| 668 |  | 
|---|
| 669 | STDMETHOD(SaveDeltaToStream)(           // S_OK or error. | 
|---|
| 670 | IStream     *pIStream,              // [IN] A writable stream to save to. | 
|---|
| 671 | DWORD       dwSaveFlags) PURE;      // [IN] Flags for the save. | 
|---|
| 672 |  | 
|---|
| 673 | STDMETHOD(SaveDeltaToMemory)(           // S_OK or error. | 
|---|
| 674 | void        *pbData,                // [OUT] Location to write data. | 
|---|
| 675 | ULONG       cbData) PURE;           // [IN] Max size of data buffer. | 
|---|
| 676 |  | 
|---|
| 677 | STDMETHOD(DefineGenericParam)(          // S_OK or error. | 
|---|
| 678 | mdToken      tk,                    // [IN] TypeDef or MethodDef | 
|---|
| 679 | ULONG        ulParamSeq,            // [IN] Index of the type parameter | 
|---|
| 680 | DWORD        dwParamFlags,          // [IN] Flags, for future use (e.g. variance) | 
|---|
| 681 | LPCWSTR      szname,                // [IN] Name | 
|---|
| 682 | DWORD        reserved,              // [IN] For future use (e.g. non-type parameters) | 
|---|
| 683 | mdToken      rtkConstraints[],      // [IN] Array of type constraints (TypeDef,TypeRef,TypeSpec) | 
|---|
| 684 | mdGenericParam *pgp) PURE;          // [OUT] Put GenericParam token here | 
|---|
| 685 |  | 
|---|
| 686 | STDMETHOD(SetGenericParamProps)(        // S_OK or error. | 
|---|
| 687 | mdGenericParam gp,                  // [IN] GenericParam | 
|---|
| 688 | DWORD        dwParamFlags,          // [IN] Flags, for future use (e.g. variance) | 
|---|
| 689 | LPCWSTR      szName,                // [IN] Optional name | 
|---|
| 690 | DWORD        reserved,              // [IN] For future use (e.g. non-type parameters) | 
|---|
| 691 | mdToken      rtkConstraints[]) PURE;// [IN] Array of type constraints (TypeDef,TypeRef,TypeSpec) | 
|---|
| 692 |  | 
|---|
| 693 | STDMETHOD(ResetENCLog)() PURE;          // S_OK or error. | 
|---|
| 694 |  | 
|---|
| 695 | }; | 
|---|
| 696 |  | 
|---|
| 697 | //------------------------------------- | 
|---|
| 698 | //--- IMetaDataImport | 
|---|
| 699 | //------------------------------------- | 
|---|
| 700 | // {7DAC8207-D3AE-4c75-9B67-92801A497D44} | 
|---|
| 701 | EXTERN_GUID(IID_IMetaDataImport, 0x7dac8207, 0xd3ae, 0x4c75, 0x9b, 0x67, 0x92, 0x80, 0x1a, 0x49, 0x7d, 0x44); | 
|---|
| 702 |  | 
|---|
| 703 | //--- | 
|---|
| 704 | #undef  INTERFACE | 
|---|
| 705 | #define INTERFACE IMetaDataImport | 
|---|
| 706 | DECLARE_INTERFACE_(IMetaDataImport, IUnknown) | 
|---|
| 707 | { | 
|---|
| 708 | STDMETHOD_(void, CloseEnum)(HCORENUM hEnum) PURE; | 
|---|
| 709 | STDMETHOD(CountEnum)(HCORENUM hEnum, ULONG *pulCount) PURE; | 
|---|
| 710 | STDMETHOD(ResetEnum)(HCORENUM hEnum, ULONG ulPos) PURE; | 
|---|
| 711 | STDMETHOD(EnumTypeDefs)(HCORENUM *phEnum, mdTypeDef rTypeDefs[], | 
|---|
| 712 | ULONG cMax, ULONG *pcTypeDefs) PURE; | 
|---|
| 713 | STDMETHOD(EnumInterfaceImpls)(HCORENUM *phEnum, mdTypeDef td, | 
|---|
| 714 | mdInterfaceImpl rImpls[], ULONG cMax, | 
|---|
| 715 | ULONG* pcImpls) PURE; | 
|---|
| 716 | STDMETHOD(EnumTypeRefs)(HCORENUM *phEnum, mdTypeRef rTypeRefs[], | 
|---|
| 717 | ULONG cMax, ULONG* pcTypeRefs) PURE; | 
|---|
| 718 |  | 
|---|
| 719 | STDMETHOD(FindTypeDefByName)(           // S_OK or error. | 
|---|
| 720 | LPCWSTR     szTypeDef,              // [IN] Name of the Type. | 
|---|
| 721 | mdToken     tkEnclosingClass,       // [IN] TypeDef/TypeRef for Enclosing class. | 
|---|
| 722 | mdTypeDef   *ptd) PURE;             // [OUT] Put the TypeDef token here. | 
|---|
| 723 |  | 
|---|
| 724 | STDMETHOD(GetScopeProps)(               // S_OK or error. | 
|---|
| 725 | _Out_writes_to_opt_(cchName, *pchName) | 
|---|
| 726 | LPWSTR      szName,                 // [OUT] Put the name here. | 
|---|
| 727 | ULONG       cchName,                // [IN] Size of name buffer in wide chars. | 
|---|
| 728 | ULONG       *pchName,               // [OUT] Put size of name (wide chars) here. | 
|---|
| 729 | GUID        *pmvid) PURE;           // [OUT, OPTIONAL] Put MVID here. | 
|---|
| 730 |  | 
|---|
| 731 | STDMETHOD(GetModuleFromScope)(          // S_OK. | 
|---|
| 732 | mdModule    *pmd) PURE;             // [OUT] Put mdModule token here. | 
|---|
| 733 |  | 
|---|
| 734 | STDMETHOD(GetTypeDefProps)(             // S_OK or error. | 
|---|
| 735 | mdTypeDef   td,                     // [IN] TypeDef token for inquiry. | 
|---|
| 736 | _Out_writes_to_opt_(cchTypeDef, *pchTypeDef) | 
|---|
| 737 | LPWSTR      szTypeDef,              // [OUT] Put name here. | 
|---|
| 738 | ULONG       cchTypeDef,             // [IN] size of name buffer in wide chars. | 
|---|
| 739 | ULONG       *pchTypeDef,            // [OUT] put size of name (wide chars) here. | 
|---|
| 740 | DWORD       *pdwTypeDefFlags,       // [OUT] Put flags here. | 
|---|
| 741 | mdToken     *ptkExtends) PURE;      // [OUT] Put base class TypeDef/TypeRef here. | 
|---|
| 742 |  | 
|---|
| 743 | STDMETHOD(GetInterfaceImplProps)(       // S_OK or error. | 
|---|
| 744 | mdInterfaceImpl iiImpl,             // [IN] InterfaceImpl token. | 
|---|
| 745 | mdTypeDef   *pClass,                // [OUT] Put implementing class token here. | 
|---|
| 746 | mdToken     *ptkIface) PURE;        // [OUT] Put implemented interface token here. | 
|---|
| 747 |  | 
|---|
| 748 | STDMETHOD(GetTypeRefProps)(             // S_OK or error. | 
|---|
| 749 | mdTypeRef   tr,                     // [IN] TypeRef token. | 
|---|
| 750 | mdToken     *ptkResolutionScope,    // [OUT] Resolution scope, ModuleRef or AssemblyRef. | 
|---|
| 751 | _Out_writes_to_opt_(cchName, *pchName) | 
|---|
| 752 | LPWSTR      szName,                 // [OUT] Name of the TypeRef. | 
|---|
| 753 | ULONG       cchName,                // [IN] Size of buffer. | 
|---|
| 754 | ULONG       *pchName) PURE;         // [OUT] Size of Name. | 
|---|
| 755 |  | 
|---|
| 756 | STDMETHOD(ResolveTypeRef)(mdTypeRef tr, REFIID riid, IUnknown **ppIScope, mdTypeDef *ptd) PURE; | 
|---|
| 757 |  | 
|---|
| 758 | STDMETHOD(EnumMembers)(                 // S_OK, S_FALSE, or error. | 
|---|
| 759 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 760 | mdTypeDef   cl,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 761 | mdToken     rMembers[],             // [OUT] Put MemberDefs here. | 
|---|
| 762 | ULONG       cMax,                   // [IN] Max MemberDefs to put. | 
|---|
| 763 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 764 |  | 
|---|
| 765 | STDMETHOD(EnumMembersWithName)(         // S_OK, S_FALSE, or error. | 
|---|
| 766 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 767 | mdTypeDef   cl,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 768 | LPCWSTR     szName,                 // [IN] Limit results to those with this name. | 
|---|
| 769 | mdToken     rMembers[],             // [OUT] Put MemberDefs here. | 
|---|
| 770 | ULONG       cMax,                   // [IN] Max MemberDefs to put. | 
|---|
| 771 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 772 |  | 
|---|
| 773 | STDMETHOD(EnumMethods)(                 // S_OK, S_FALSE, or error. | 
|---|
| 774 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 775 | mdTypeDef   cl,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 776 | mdMethodDef rMethods[],             // [OUT] Put MethodDefs here. | 
|---|
| 777 | ULONG       cMax,                   // [IN] Max MethodDefs to put. | 
|---|
| 778 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 779 |  | 
|---|
| 780 | STDMETHOD(EnumMethodsWithName)(         // S_OK, S_FALSE, or error. | 
|---|
| 781 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 782 | mdTypeDef   cl,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 783 | LPCWSTR     szName,                 // [IN] Limit results to those with this name. | 
|---|
| 784 | mdMethodDef rMethods[],             // [OU] Put MethodDefs here. | 
|---|
| 785 | ULONG       cMax,                   // [IN] Max MethodDefs to put. | 
|---|
| 786 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 787 |  | 
|---|
| 788 | STDMETHOD(EnumFields)(                  // S_OK, S_FALSE, or error. | 
|---|
| 789 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 790 | mdTypeDef   cl,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 791 | mdFieldDef  rFields[],              // [OUT] Put FieldDefs here. | 
|---|
| 792 | ULONG       cMax,                   // [IN] Max FieldDefs to put. | 
|---|
| 793 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 794 |  | 
|---|
| 795 | STDMETHOD(EnumFieldsWithName)(          // S_OK, S_FALSE, or error. | 
|---|
| 796 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 797 | mdTypeDef   cl,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 798 | LPCWSTR     szName,                 // [IN] Limit results to those with this name. | 
|---|
| 799 | mdFieldDef  rFields[],              // [OUT] Put MemberDefs here. | 
|---|
| 800 | ULONG       cMax,                   // [IN] Max MemberDefs to put. | 
|---|
| 801 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 802 |  | 
|---|
| 803 |  | 
|---|
| 804 | STDMETHOD(EnumParams)(                  // S_OK, S_FALSE, or error. | 
|---|
| 805 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 806 | mdMethodDef mb,                     // [IN] MethodDef to scope the enumeration. | 
|---|
| 807 | mdParamDef  rParams[],              // [OUT] Put ParamDefs here. | 
|---|
| 808 | ULONG       cMax,                   // [IN] Max ParamDefs to put. | 
|---|
| 809 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 810 |  | 
|---|
| 811 | STDMETHOD(EnumMemberRefs)(              // S_OK, S_FALSE, or error. | 
|---|
| 812 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 813 | mdToken     tkParent,               // [IN] Parent token to scope the enumeration. | 
|---|
| 814 | mdMemberRef rMemberRefs[],          // [OUT] Put MemberRefs here. | 
|---|
| 815 | ULONG       cMax,                   // [IN] Max MemberRefs to put. | 
|---|
| 816 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 817 |  | 
|---|
| 818 | STDMETHOD(EnumMethodImpls)(             // S_OK, S_FALSE, or error | 
|---|
| 819 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 820 | mdTypeDef   td,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 821 | mdToken     rMethodBody[],          // [OUT] Put Method Body tokens here. | 
|---|
| 822 | mdToken     rMethodDecl[],          // [OUT] Put Method Declaration tokens here. | 
|---|
| 823 | ULONG       cMax,                   // [IN] Max tokens to put. | 
|---|
| 824 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 825 |  | 
|---|
| 826 | STDMETHOD(EnumPermissionSets)(          // S_OK, S_FALSE, or error. | 
|---|
| 827 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 828 | mdToken     tk,                     // [IN] if !NIL, token to scope the enumeration. | 
|---|
| 829 | DWORD       dwActions,              // [IN] if !0, return only these actions. | 
|---|
| 830 | mdPermission rPermission[],         // [OUT] Put Permissions here. | 
|---|
| 831 | ULONG       cMax,                   // [IN] Max Permissions to put. | 
|---|
| 832 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 833 |  | 
|---|
| 834 | STDMETHOD(FindMember)( | 
|---|
| 835 | mdTypeDef   td,                     // [IN] given typedef | 
|---|
| 836 | LPCWSTR     szName,                 // [IN] member name | 
|---|
| 837 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of CLR signature | 
|---|
| 838 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 839 | mdToken     *pmb) PURE;             // [OUT] matching memberdef | 
|---|
| 840 |  | 
|---|
| 841 | STDMETHOD(FindMethod)( | 
|---|
| 842 | mdTypeDef   td,                     // [IN] given typedef | 
|---|
| 843 | LPCWSTR     szName,                 // [IN] member name | 
|---|
| 844 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of CLR signature | 
|---|
| 845 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 846 | mdMethodDef *pmb) PURE;             // [OUT] matching memberdef | 
|---|
| 847 |  | 
|---|
| 848 | STDMETHOD(FindField)( | 
|---|
| 849 | mdTypeDef   td,                     // [IN] given typedef | 
|---|
| 850 | LPCWSTR     szName,                 // [IN] member name | 
|---|
| 851 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of CLR signature | 
|---|
| 852 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 853 | mdFieldDef  *pmb) PURE;             // [OUT] matching memberdef | 
|---|
| 854 |  | 
|---|
| 855 | STDMETHOD(FindMemberRef)( | 
|---|
| 856 | mdTypeRef   td,                     // [IN] given typeRef | 
|---|
| 857 | LPCWSTR     szName,                 // [IN] member name | 
|---|
| 858 | PCCOR_SIGNATURE pvSigBlob,          // [IN] point to a blob value of CLR signature | 
|---|
| 859 | ULONG       cbSigBlob,              // [IN] count of bytes in the signature blob | 
|---|
| 860 | mdMemberRef *pmr) PURE;             // [OUT] matching memberref | 
|---|
| 861 |  | 
|---|
| 862 | STDMETHOD (GetMethodProps)( | 
|---|
| 863 | mdMethodDef mb,                     // The method for which to get props. | 
|---|
| 864 | mdTypeDef   *pClass,                // Put method's class here. | 
|---|
| 865 | _Out_writes_to_opt_(cchMethod, *pchMethod) | 
|---|
| 866 | LPWSTR      szMethod,               // Put method's name here. | 
|---|
| 867 | ULONG       cchMethod,              // Size of szMethod buffer in wide chars. | 
|---|
| 868 | ULONG       *pchMethod,             // Put actual size here | 
|---|
| 869 | DWORD       *pdwAttr,               // Put flags here. | 
|---|
| 870 | PCCOR_SIGNATURE *ppvSigBlob,        // [OUT] point to the blob value of meta data | 
|---|
| 871 | ULONG       *pcbSigBlob,            // [OUT] actual size of signature blob | 
|---|
| 872 | ULONG       *pulCodeRVA,            // [OUT] codeRVA | 
|---|
| 873 | DWORD       *pdwImplFlags) PURE;    // [OUT] Impl. Flags | 
|---|
| 874 |  | 
|---|
| 875 | STDMETHOD(GetMemberRefProps)(           // S_OK or error. | 
|---|
| 876 | mdMemberRef mr,                     // [IN] given memberref | 
|---|
| 877 | mdToken     *ptk,                   // [OUT] Put classref or classdef here. | 
|---|
| 878 | _Out_writes_to_opt_(cchMember, *pchMember) | 
|---|
| 879 | LPWSTR      szMember,               // [OUT] buffer to fill for member's name | 
|---|
| 880 | ULONG       cchMember,              // [IN] the count of char of szMember | 
|---|
| 881 | ULONG       *pchMember,             // [OUT] actual count of char in member name | 
|---|
| 882 | PCCOR_SIGNATURE *ppvSigBlob,        // [OUT] point to meta data blob value | 
|---|
| 883 | ULONG       *pbSig) PURE;           // [OUT] actual size of signature blob | 
|---|
| 884 |  | 
|---|
| 885 | STDMETHOD(EnumProperties)(              // S_OK, S_FALSE, or error. | 
|---|
| 886 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 887 | mdTypeDef   td,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 888 | mdProperty  rProperties[],          // [OUT] Put Properties here. | 
|---|
| 889 | ULONG       cMax,                   // [IN] Max properties to put. | 
|---|
| 890 | ULONG       *pcProperties) PURE;    // [OUT] Put # put here. | 
|---|
| 891 |  | 
|---|
| 892 | STDMETHOD(EnumEvents)(                  // S_OK, S_FALSE, or error. | 
|---|
| 893 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 894 | mdTypeDef   td,                     // [IN] TypeDef to scope the enumeration. | 
|---|
| 895 | mdEvent     rEvents[],              // [OUT] Put events here. | 
|---|
| 896 | ULONG       cMax,                   // [IN] Max events to put. | 
|---|
| 897 | ULONG       *pcEvents) PURE;        // [OUT] Put # put here. | 
|---|
| 898 |  | 
|---|
| 899 | STDMETHOD(GetEventProps)(               // S_OK, S_FALSE, or error. | 
|---|
| 900 | mdEvent     ev,                     // [IN] event token | 
|---|
| 901 | mdTypeDef   *pClass,                // [OUT] typedef containing the event declarion. | 
|---|
| 902 | LPCWSTR     szEvent,                // [OUT] Event name | 
|---|
| 903 | ULONG       cchEvent,               // [IN] the count of wchar of szEvent | 
|---|
| 904 | ULONG       *pchEvent,              // [OUT] actual count of wchar for event's name | 
|---|
| 905 | DWORD       *pdwEventFlags,         // [OUT] Event flags. | 
|---|
| 906 | mdToken     *ptkEventType,          // [OUT] EventType class | 
|---|
| 907 | mdMethodDef *pmdAddOn,              // [OUT] AddOn method of the event | 
|---|
| 908 | mdMethodDef *pmdRemoveOn,           // [OUT] RemoveOn method of the event | 
|---|
| 909 | mdMethodDef *pmdFire,               // [OUT] Fire method of the event | 
|---|
| 910 | mdMethodDef rmdOtherMethod[],       // [OUT] other method of the event | 
|---|
| 911 | ULONG       cMax,                   // [IN] size of rmdOtherMethod | 
|---|
| 912 | ULONG       *pcOtherMethod) PURE;   // [OUT] total number of other method of this event | 
|---|
| 913 |  | 
|---|
| 914 | STDMETHOD(EnumMethodSemantics)(         // S_OK, S_FALSE, or error. | 
|---|
| 915 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 916 | mdMethodDef mb,                     // [IN] MethodDef to scope the enumeration. | 
|---|
| 917 | mdToken     rEventProp[],           // [OUT] Put Event/Property here. | 
|---|
| 918 | ULONG       cMax,                   // [IN] Max properties to put. | 
|---|
| 919 | ULONG       *pcEventProp) PURE;     // [OUT] Put # put here. | 
|---|
| 920 |  | 
|---|
| 921 | STDMETHOD(GetMethodSemantics)(          // S_OK, S_FALSE, or error. | 
|---|
| 922 | mdMethodDef mb,                     // [IN] method token | 
|---|
| 923 | mdToken     tkEventProp,            // [IN] event/property token. | 
|---|
| 924 | DWORD       *pdwSemanticsFlags) PURE; // [OUT] the role flags for the method/propevent pair | 
|---|
| 925 |  | 
|---|
| 926 | STDMETHOD(GetClassLayout) ( | 
|---|
| 927 | mdTypeDef   td,                     // [IN] give typedef | 
|---|
| 928 | DWORD       *pdwPackSize,           // [OUT] 1, 2, 4, 8, or 16 | 
|---|
| 929 | COR_FIELD_OFFSET rFieldOffset[],    // [OUT] field offset array | 
|---|
| 930 | ULONG       cMax,                   // [IN] size of the array | 
|---|
| 931 | ULONG       *pcFieldOffset,         // [OUT] needed array size | 
|---|
| 932 | ULONG       *pulClassSize) PURE;        // [OUT] the size of the class | 
|---|
| 933 |  | 
|---|
| 934 | STDMETHOD(GetFieldMarshal) ( | 
|---|
| 935 | mdToken     tk,                     // [IN] given a field's memberdef | 
|---|
| 936 | PCCOR_SIGNATURE *ppvNativeType,     // [OUT] native type of this field | 
|---|
| 937 | ULONG       *pcbNativeType) PURE;   // [OUT] the count of bytes of *ppvNativeType | 
|---|
| 938 |  | 
|---|
| 939 | STDMETHOD(GetRVA)(                      // S_OK or error. | 
|---|
| 940 | mdToken     tk,                     // Member for which to set offset | 
|---|
| 941 | ULONG       *pulCodeRVA,            // The offset | 
|---|
| 942 | DWORD       *pdwImplFlags) PURE;    // the implementation flags | 
|---|
| 943 |  | 
|---|
| 944 | STDMETHOD(GetPermissionSetProps) ( | 
|---|
| 945 | mdPermission pm,                    // [IN] the permission token. | 
|---|
| 946 | DWORD       *pdwAction,             // [OUT] CorDeclSecurity. | 
|---|
| 947 | void const  **ppvPermission,        // [OUT] permission blob. | 
|---|
| 948 | ULONG       *pcbPermission) PURE;   // [OUT] count of bytes of pvPermission. | 
|---|
| 949 |  | 
|---|
| 950 | STDMETHOD(GetSigFromToken)(             // S_OK or error. | 
|---|
| 951 | mdSignature mdSig,                  // [IN] Signature token. | 
|---|
| 952 | PCCOR_SIGNATURE *ppvSig,            // [OUT] return pointer to token. | 
|---|
| 953 | ULONG       *pcbSig) PURE;          // [OUT] return size of signature. | 
|---|
| 954 |  | 
|---|
| 955 | STDMETHOD(GetModuleRefProps)(           // S_OK or error. | 
|---|
| 956 | mdModuleRef mur,                    // [IN] moduleref token. | 
|---|
| 957 | _Out_writes_to_opt_(cchName, *pchName) | 
|---|
| 958 | LPWSTR      szName,                 // [OUT] buffer to fill with the moduleref name. | 
|---|
| 959 | ULONG       cchName,                // [IN] size of szName in wide characters. | 
|---|
| 960 | ULONG       *pchName) PURE;         // [OUT] actual count of characters in the name. | 
|---|
| 961 |  | 
|---|
| 962 | STDMETHOD(EnumModuleRefs)(              // S_OK or error. | 
|---|
| 963 | HCORENUM    *phEnum,                // [IN|OUT] pointer to the enum. | 
|---|
| 964 | mdModuleRef rModuleRefs[],          // [OUT] put modulerefs here. | 
|---|
| 965 | ULONG       cmax,                   // [IN] max memberrefs to put. | 
|---|
| 966 | ULONG       *pcModuleRefs) PURE;    // [OUT] put # put here. | 
|---|
| 967 |  | 
|---|
| 968 | STDMETHOD(GetTypeSpecFromToken)(        // S_OK or error. | 
|---|
| 969 | mdTypeSpec typespec,                // [IN] TypeSpec token. | 
|---|
| 970 | PCCOR_SIGNATURE *ppvSig,            // [OUT] return pointer to TypeSpec signature | 
|---|
| 971 | ULONG       *pcbSig) PURE;          // [OUT] return size of signature. | 
|---|
| 972 |  | 
|---|
| 973 | STDMETHOD(GetNameFromToken)(            // Not Recommended! May be removed! | 
|---|
| 974 | mdToken     tk,                     // [IN] Token to get name from.  Must have a name. | 
|---|
| 975 | MDUTF8CSTR  *pszUtf8NamePtr) PURE;  // [OUT] Return pointer to UTF8 name in heap. | 
|---|
| 976 |  | 
|---|
| 977 | STDMETHOD(EnumUnresolvedMethods)(       // S_OK, S_FALSE, or error. | 
|---|
| 978 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 979 | mdToken     rMethods[],             // [OUT] Put MemberDefs here. | 
|---|
| 980 | ULONG       cMax,                   // [IN] Max MemberDefs to put. | 
|---|
| 981 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 982 |  | 
|---|
| 983 | STDMETHOD(GetUserString)(               // S_OK or error. | 
|---|
| 984 | mdString    stk,                    // [IN] String token. | 
|---|
| 985 | _Out_writes_to_opt_(cchString, *pchString) | 
|---|
| 986 | LPWSTR      szString,               // [OUT] Copy of string. | 
|---|
| 987 | ULONG       cchString,              // [IN] Max chars of room in szString. | 
|---|
| 988 | ULONG       *pchString) PURE;       // [OUT] How many chars in actual string. | 
|---|
| 989 |  | 
|---|
| 990 | STDMETHOD(GetPinvokeMap)(               // S_OK or error. | 
|---|
| 991 | mdToken     tk,                     // [IN] FieldDef or MethodDef. | 
|---|
| 992 | DWORD       *pdwMappingFlags,       // [OUT] Flags used for mapping. | 
|---|
| 993 | _Out_writes_to_opt_(cchImportName, *pchImportName) | 
|---|
| 994 | LPWSTR      szImportName,           // [OUT] Import name. | 
|---|
| 995 | ULONG       cchImportName,          // [IN] Size of the name buffer. | 
|---|
| 996 | ULONG       *pchImportName,         // [OUT] Actual number of characters stored. | 
|---|
| 997 | mdModuleRef *pmrImportDLL) PURE;    // [OUT] ModuleRef token for the target DLL. | 
|---|
| 998 |  | 
|---|
| 999 | STDMETHOD(EnumSignatures)(              // S_OK or error. | 
|---|
| 1000 | HCORENUM    *phEnum,                // [IN|OUT] pointer to the enum. | 
|---|
| 1001 | mdSignature rSignatures[],          // [OUT] put signatures here. | 
|---|
| 1002 | ULONG       cmax,                   // [IN] max signatures to put. | 
|---|
| 1003 | ULONG       *pcSignatures) PURE;    // [OUT] put # put here. | 
|---|
| 1004 |  | 
|---|
| 1005 | STDMETHOD(EnumTypeSpecs)(               // S_OK or error. | 
|---|
| 1006 | HCORENUM    *phEnum,                // [IN|OUT] pointer to the enum. | 
|---|
| 1007 | mdTypeSpec  rTypeSpecs[],           // [OUT] put TypeSpecs here. | 
|---|
| 1008 | ULONG       cmax,                   // [IN] max TypeSpecs to put. | 
|---|
| 1009 | ULONG       *pcTypeSpecs) PURE;     // [OUT] put # put here. | 
|---|
| 1010 |  | 
|---|
| 1011 | STDMETHOD(EnumUserStrings)(             // S_OK or error. | 
|---|
| 1012 | HCORENUM    *phEnum,                // [IN/OUT] pointer to the enum. | 
|---|
| 1013 | mdString    rStrings[],             // [OUT] put Strings here. | 
|---|
| 1014 | ULONG       cmax,                   // [IN] max Strings to put. | 
|---|
| 1015 | ULONG       *pcStrings) PURE;       // [OUT] put # put here. | 
|---|
| 1016 |  | 
|---|
| 1017 | STDMETHOD(GetParamForMethodIndex)(      // S_OK or error. | 
|---|
| 1018 | mdMethodDef md,                     // [IN] Method token. | 
|---|
| 1019 | ULONG       ulParamSeq,             // [IN] Parameter sequence. | 
|---|
| 1020 | mdParamDef  *ppd) PURE;             // [IN] Put Param token here. | 
|---|
| 1021 |  | 
|---|
| 1022 | STDMETHOD(EnumCustomAttributes)(        // S_OK or error. | 
|---|
| 1023 | HCORENUM    *phEnum,                // [IN, OUT] COR enumerator. | 
|---|
| 1024 | mdToken     tk,                     // [IN] Token to scope the enumeration, 0 for all. | 
|---|
| 1025 | mdToken     tkType,                 // [IN] Type of interest, 0 for all. | 
|---|
| 1026 | mdCustomAttribute rCustomAttributes[], // [OUT] Put custom attribute tokens here. | 
|---|
| 1027 | ULONG       cMax,                   // [IN] Size of rCustomAttributes. | 
|---|
| 1028 | ULONG       *pcCustomAttributes) PURE;  // [OUT, OPTIONAL] Put count of token values here. | 
|---|
| 1029 |  | 
|---|
| 1030 | STDMETHOD(GetCustomAttributeProps)(     // S_OK or error. | 
|---|
| 1031 | mdCustomAttribute cv,               // [IN] CustomAttribute token. | 
|---|
| 1032 | mdToken     *ptkObj,                // [OUT, OPTIONAL] Put object token here. | 
|---|
| 1033 | mdToken     *ptkType,               // [OUT, OPTIONAL] Put AttrType token here. | 
|---|
| 1034 | void const  **ppBlob,               // [OUT, OPTIONAL] Put pointer to data here. | 
|---|
| 1035 | ULONG       *pcbSize) PURE;         // [OUT, OPTIONAL] Put size of date here. | 
|---|
| 1036 |  | 
|---|
| 1037 | STDMETHOD(FindTypeRef)( | 
|---|
| 1038 | mdToken     tkResolutionScope,      // [IN] ModuleRef, AssemblyRef or TypeRef. | 
|---|
| 1039 | LPCWSTR     szName,                 // [IN] TypeRef Name. | 
|---|
| 1040 | mdTypeRef   *ptr) PURE;             // [OUT] matching TypeRef. | 
|---|
| 1041 |  | 
|---|
| 1042 | STDMETHOD(GetMemberProps)( | 
|---|
| 1043 | mdToken     mb,                     // The member for which to get props. | 
|---|
| 1044 | mdTypeDef   *pClass,                // Put member's class here. | 
|---|
| 1045 | _Out_writes_to_opt_(cchMember, *pchMember) | 
|---|
| 1046 | LPWSTR      szMember,               // Put member's name here. | 
|---|
| 1047 | ULONG       cchMember,              // Size of szMember buffer in wide chars. | 
|---|
| 1048 | ULONG       *pchMember,             // Put actual size here | 
|---|
| 1049 | DWORD       *pdwAttr,               // Put flags here. | 
|---|
| 1050 | PCCOR_SIGNATURE *ppvSigBlob,        // [OUT] point to the blob value of meta data | 
|---|
| 1051 | ULONG       *pcbSigBlob,            // [OUT] actual size of signature blob | 
|---|
| 1052 | ULONG       *pulCodeRVA,            // [OUT] codeRVA | 
|---|
| 1053 | DWORD       *pdwImplFlags,          // [OUT] Impl. Flags | 
|---|
| 1054 | DWORD       *pdwCPlusTypeFlag,      // [OUT] flag for value type. selected ELEMENT_TYPE_* | 
|---|
| 1055 | UVCP_CONSTANT *ppValue,             // [OUT] constant value | 
|---|
| 1056 | ULONG       *pcchValue) PURE;       // [OUT] size of constant string in chars, 0 for non-strings. | 
|---|
| 1057 |  | 
|---|
| 1058 | STDMETHOD(GetFieldProps)( | 
|---|
| 1059 | mdFieldDef  mb,                     // The field for which to get props. | 
|---|
| 1060 | mdTypeDef   *pClass,                // Put field's class here. | 
|---|
| 1061 | _Out_writes_to_opt_(cchField, *pchField) | 
|---|
| 1062 | LPWSTR      szField,                // Put field's name here. | 
|---|
| 1063 | ULONG       cchField,               // Size of szField buffer in wide chars. | 
|---|
| 1064 | ULONG       *pchField,              // Put actual size here | 
|---|
| 1065 | DWORD       *pdwAttr,               // Put flags here. | 
|---|
| 1066 | PCCOR_SIGNATURE *ppvSigBlob,        // [OUT] point to the blob value of meta data | 
|---|
| 1067 | ULONG       *pcbSigBlob,            // [OUT] actual size of signature blob | 
|---|
| 1068 | DWORD       *pdwCPlusTypeFlag,      // [OUT] flag for value type. selected ELEMENT_TYPE_* | 
|---|
| 1069 | UVCP_CONSTANT *ppValue,             // [OUT] constant value | 
|---|
| 1070 | ULONG       *pcchValue) PURE;       // [OUT] size of constant string in chars, 0 for non-strings. | 
|---|
| 1071 |  | 
|---|
| 1072 | STDMETHOD(GetPropertyProps)(            // S_OK, S_FALSE, or error. | 
|---|
| 1073 | mdProperty  prop,                   // [IN] property token | 
|---|
| 1074 | mdTypeDef   *pClass,                // [OUT] typedef containing the property declarion. | 
|---|
| 1075 | LPCWSTR     szProperty,             // [OUT] Property name | 
|---|
| 1076 | ULONG       cchProperty,            // [IN] the count of wchar of szProperty | 
|---|
| 1077 | ULONG       *pchProperty,           // [OUT] actual count of wchar for property name | 
|---|
| 1078 | DWORD       *pdwPropFlags,          // [OUT] property flags. | 
|---|
| 1079 | PCCOR_SIGNATURE *ppvSig,            // [OUT] property type. pointing to meta data internal blob | 
|---|
| 1080 | ULONG       *pbSig,                 // [OUT] count of bytes in *ppvSig | 
|---|
| 1081 | DWORD       *pdwCPlusTypeFlag,      // [OUT] flag for value type. selected ELEMENT_TYPE_* | 
|---|
| 1082 | UVCP_CONSTANT *ppDefaultValue,      // [OUT] constant value | 
|---|
| 1083 | ULONG       *pcchDefaultValue,      // [OUT] size of constant string in chars, 0 for non-strings. | 
|---|
| 1084 | mdMethodDef *pmdSetter,             // [OUT] setter method of the property | 
|---|
| 1085 | mdMethodDef *pmdGetter,             // [OUT] getter method of the property | 
|---|
| 1086 | mdMethodDef rmdOtherMethod[],       // [OUT] other method of the property | 
|---|
| 1087 | ULONG       cMax,                   // [IN] size of rmdOtherMethod | 
|---|
| 1088 | ULONG       *pcOtherMethod) PURE;   // [OUT] total number of other method of this property | 
|---|
| 1089 |  | 
|---|
| 1090 | STDMETHOD(GetParamProps)(               // S_OK or error. | 
|---|
| 1091 | mdParamDef  tk,                     // [IN]The Parameter. | 
|---|
| 1092 | mdMethodDef *pmd,                   // [OUT] Parent Method token. | 
|---|
| 1093 | ULONG       *pulSequence,           // [OUT] Parameter sequence. | 
|---|
| 1094 | _Out_writes_to_opt_(cchName, *pchName) | 
|---|
| 1095 | LPWSTR      szName,                 // [OUT] Put name here. | 
|---|
| 1096 | ULONG       cchName,                // [OUT] Size of name buffer. | 
|---|
| 1097 | ULONG       *pchName,               // [OUT] Put actual size of name here. | 
|---|
| 1098 | DWORD       *pdwAttr,               // [OUT] Put flags here. | 
|---|
| 1099 | DWORD       *pdwCPlusTypeFlag,      // [OUT] Flag for value type. selected ELEMENT_TYPE_*. | 
|---|
| 1100 | UVCP_CONSTANT *ppValue,             // [OUT] Constant value. | 
|---|
| 1101 | ULONG       *pcchValue) PURE;       // [OUT] size of constant string in chars, 0 for non-strings. | 
|---|
| 1102 |  | 
|---|
| 1103 | STDMETHOD(GetCustomAttributeByName)(    // S_OK or error. | 
|---|
| 1104 | mdToken     tkObj,                  // [IN] Object with Custom Attribute. | 
|---|
| 1105 | LPCWSTR     szName,                 // [IN] Name of desired Custom Attribute. | 
|---|
| 1106 | const void  **ppData,               // [OUT] Put pointer to data here. | 
|---|
| 1107 | ULONG       *pcbData) PURE;         // [OUT] Put size of data here. | 
|---|
| 1108 |  | 
|---|
| 1109 | STDMETHOD_(BOOL, IsValidToken)(         // True or False. | 
|---|
| 1110 | mdToken     tk) PURE;               // [IN] Given token. | 
|---|
| 1111 |  | 
|---|
| 1112 | STDMETHOD(GetNestedClassProps)(         // S_OK or error. | 
|---|
| 1113 | mdTypeDef   tdNestedClass,          // [IN] NestedClass token. | 
|---|
| 1114 | mdTypeDef   *ptdEnclosingClass) PURE; // [OUT] EnclosingClass token. | 
|---|
| 1115 |  | 
|---|
| 1116 | STDMETHOD(GetNativeCallConvFromSig)(    // S_OK or error. | 
|---|
| 1117 | void const  *pvSig,                 // [IN] Pointer to signature. | 
|---|
| 1118 | ULONG       cbSig,                  // [IN] Count of signature bytes. | 
|---|
| 1119 | ULONG       *pCallConv) PURE;       // [OUT] Put calling conv here (see CorPinvokemap). | 
|---|
| 1120 |  | 
|---|
| 1121 | STDMETHOD(IsGlobal)(                    // S_OK or error. | 
|---|
| 1122 | mdToken     pd,                     // [IN] Type, Field, or Method token. | 
|---|
| 1123 | int         *pbGlobal) PURE;        // [OUT] Put 1 if global, 0 otherwise. | 
|---|
| 1124 |  | 
|---|
| 1125 | // This interface is sealed.  Do not change, add, or remove anything.  Instead, derive a new iterface. | 
|---|
| 1126 |  | 
|---|
| 1127 | };      // IMetaDataImport | 
|---|
| 1128 |  | 
|---|
| 1129 | //------------------------------------- | 
|---|
| 1130 | //--- IMetaDataImport2 | 
|---|
| 1131 | //------------------------------------- | 
|---|
| 1132 | // {FCE5EFA0-8BBA-4f8e-A036-8F2022B08466} | 
|---|
| 1133 | EXTERN_GUID(IID_IMetaDataImport2, 0xfce5efa0, 0x8bba, 0x4f8e, 0xa0, 0x36, 0x8f, 0x20, 0x22, 0xb0, 0x84, 0x66); | 
|---|
| 1134 |  | 
|---|
| 1135 | //--- | 
|---|
| 1136 | #undef  INTERFACE | 
|---|
| 1137 | #define INTERFACE IMetaDataImport2 | 
|---|
| 1138 | DECLARE_INTERFACE_(IMetaDataImport2, IMetaDataImport) | 
|---|
| 1139 | { | 
|---|
| 1140 | STDMETHOD(EnumGenericParams)( | 
|---|
| 1141 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 1142 | mdToken      tk,                    // [IN] TypeDef or MethodDef whose generic parameters are requested | 
|---|
| 1143 | mdGenericParam rGenericParams[],    // [OUT] Put GenericParams here. | 
|---|
| 1144 | ULONG       cMax,                   // [IN] Max GenericParams to put. | 
|---|
| 1145 | ULONG       *pcGenericParams) PURE; // [OUT] Put # put here. | 
|---|
| 1146 |  | 
|---|
| 1147 | STDMETHOD(GetGenericParamProps)(        // S_OK or error. | 
|---|
| 1148 | mdGenericParam gp,                  // [IN] GenericParam | 
|---|
| 1149 | ULONG        *pulParamSeq,          // [OUT] Index of the type parameter | 
|---|
| 1150 | DWORD        *pdwParamFlags,        // [OUT] Flags, for future use (e.g. variance) | 
|---|
| 1151 | mdToken      *ptOwner,              // [OUT] Owner (TypeDef or MethodDef) | 
|---|
| 1152 | DWORD       *reserved,              // [OUT] For future use (e.g. non-type parameters) | 
|---|
| 1153 | _Out_writes_to_opt_(cchName, *pchName) | 
|---|
| 1154 | LPWSTR       wzname,                // [OUT] Put name here | 
|---|
| 1155 | ULONG        cchName,               // [IN] Size of buffer | 
|---|
| 1156 | ULONG        *pchName) PURE;        // [OUT] Put size of name (wide chars) here. | 
|---|
| 1157 |  | 
|---|
| 1158 | STDMETHOD(GetMethodSpecProps)( | 
|---|
| 1159 | mdMethodSpec mi,                    // [IN] The method instantiation | 
|---|
| 1160 | mdToken *tkParent,                  // [OUT] MethodDef or MemberRef | 
|---|
| 1161 | PCCOR_SIGNATURE *ppvSigBlob,        // [OUT] point to the blob value of meta data | 
|---|
| 1162 | ULONG       *pcbSigBlob) PURE;      // [OUT] actual size of signature blob | 
|---|
| 1163 |  | 
|---|
| 1164 | STDMETHOD(EnumGenericParamConstraints)( | 
|---|
| 1165 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 1166 | mdGenericParam tk,                  // [IN] GenericParam whose constraints are requested | 
|---|
| 1167 | mdGenericParamConstraint rGenericParamConstraints[],    // [OUT] Put GenericParamConstraints here. | 
|---|
| 1168 | ULONG       cMax,                   // [IN] Max GenericParamConstraints to put. | 
|---|
| 1169 | ULONG       *pcGenericParamConstraints) PURE; // [OUT] Put # put here. | 
|---|
| 1170 |  | 
|---|
| 1171 | STDMETHOD(GetGenericParamConstraintProps)( // S_OK or error. | 
|---|
| 1172 | mdGenericParamConstraint gpc,       // [IN] GenericParamConstraint | 
|---|
| 1173 | mdGenericParam *ptGenericParam,     // [OUT] GenericParam that is constrained | 
|---|
| 1174 | mdToken      *ptkConstraintType) PURE; // [OUT] TypeDef/Ref/Spec constraint | 
|---|
| 1175 |  | 
|---|
| 1176 | STDMETHOD(GetPEKind)(                   // S_OK or error. | 
|---|
| 1177 | DWORD* pdwPEKind,                   // [OUT] The kind of PE (0 - not a PE) | 
|---|
| 1178 | DWORD* pdwMAchine) PURE;            // [OUT] Machine as defined in NT header | 
|---|
| 1179 |  | 
|---|
| 1180 | STDMETHOD(GetVersionString)(            // S_OK or error. | 
|---|
| 1181 | _Out_writes_to_opt_(ccBufSize, *pccBufSize) | 
|---|
| 1182 | LPWSTR      pwzBuf,                 // [OUT] Put version string here. | 
|---|
| 1183 | DWORD       ccBufSize,              // [IN] size of the buffer, in wide chars | 
|---|
| 1184 | DWORD       *pccBufSize) PURE;      // [OUT] Size of the version string, wide chars, including terminating nul. | 
|---|
| 1185 |  | 
|---|
| 1186 | STDMETHOD(EnumMethodSpecs)( | 
|---|
| 1187 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 1188 | mdToken      tk,                    // [IN] MethodDef or MemberRef whose MethodSpecs are requested | 
|---|
| 1189 | mdMethodSpec rMethodSpecs[],        // [OUT] Put MethodSpecs here. | 
|---|
| 1190 | ULONG       cMax,                   // [IN] Max tokens to put. | 
|---|
| 1191 | ULONG       *pcMethodSpecs) PURE;   // [OUT] Put actual count here. | 
|---|
| 1192 |  | 
|---|
| 1193 | }; // IMetaDataImport2 | 
|---|
| 1194 |  | 
|---|
| 1195 | //------------------------------------- | 
|---|
| 1196 | //--- IMetaDataFilter | 
|---|
| 1197 | //------------------------------------- | 
|---|
| 1198 | // {D0E80DD1-12D4-11d3-B39D-00C04FF81795} | 
|---|
| 1199 | EXTERN_GUID(IID_IMetaDataFilter, 0xd0e80dd1, 0x12d4, 0x11d3, 0xb3, 0x9d, 0x0, 0xc0, 0x4f, 0xf8, 0x17, 0x95); | 
|---|
| 1200 |  | 
|---|
| 1201 | //--- | 
|---|
| 1202 | #undef  INTERFACE | 
|---|
| 1203 | #define INTERFACE IMetaDataFilter | 
|---|
| 1204 | DECLARE_INTERFACE_(IMetaDataFilter, IUnknown) | 
|---|
| 1205 | { | 
|---|
| 1206 | STDMETHOD(UnmarkAll)() PURE; | 
|---|
| 1207 | STDMETHOD(MarkToken)(mdToken tk) PURE; | 
|---|
| 1208 | STDMETHOD(IsTokenMarked)(mdToken tk, BOOL *pIsMarked) PURE; | 
|---|
| 1209 | }; | 
|---|
| 1210 |  | 
|---|
| 1211 |  | 
|---|
| 1212 | //------------------------------------- | 
|---|
| 1213 | //--- IHostFilter | 
|---|
| 1214 | //------------------------------------- | 
|---|
| 1215 | // {D0E80DD3-12D4-11d3-B39D-00C04FF81795} | 
|---|
| 1216 | EXTERN_GUID(IID_IHostFilter, 0xd0e80dd3, 0x12d4, 0x11d3, 0xb3, 0x9d, 0x0, 0xc0, 0x4f, 0xf8, 0x17, 0x95); | 
|---|
| 1217 |  | 
|---|
| 1218 | //--- | 
|---|
| 1219 | #undef  INTERFACE | 
|---|
| 1220 | #define INTERFACE IHostFilter | 
|---|
| 1221 | DECLARE_INTERFACE_(IHostFilter, IUnknown) | 
|---|
| 1222 | { | 
|---|
| 1223 | STDMETHOD(MarkToken)(mdToken tk) PURE; | 
|---|
| 1224 | }; | 
|---|
| 1225 |  | 
|---|
| 1226 |  | 
|---|
| 1227 | //***************************************************************************** | 
|---|
| 1228 | // Assembly Declarations | 
|---|
| 1229 | //***************************************************************************** | 
|---|
| 1230 |  | 
|---|
| 1231 | typedef struct | 
|---|
| 1232 | { | 
|---|
| 1233 | DWORD       dwOSPlatformId;         // Operating system platform. | 
|---|
| 1234 | DWORD       dwOSMajorVersion;       // OS Major version. | 
|---|
| 1235 | DWORD       dwOSMinorVersion;       // OS Minor version. | 
|---|
| 1236 | } OSINFO; | 
|---|
| 1237 |  | 
|---|
| 1238 |  | 
|---|
| 1239 | typedef struct | 
|---|
| 1240 | { | 
|---|
| 1241 | USHORT      usMajorVersion;         // Major Version. | 
|---|
| 1242 | USHORT      usMinorVersion;         // Minor Version. | 
|---|
| 1243 | USHORT      usBuildNumber;          // Build Number. | 
|---|
| 1244 | USHORT      usRevisionNumber;       // Revision Number. | 
|---|
| 1245 | LPWSTR      szLocale;               // Locale. | 
|---|
| 1246 | ULONG       cbLocale;               // [IN/OUT] Size of the buffer in wide chars/Actual size. | 
|---|
| 1247 | DWORD       *rProcessor;            // Processor ID array. | 
|---|
| 1248 | ULONG       ulProcessor;            // [IN/OUT] Size of the Processor ID array/Actual # of entries filled in. | 
|---|
| 1249 | OSINFO      *rOS;                   // OSINFO array. | 
|---|
| 1250 | ULONG       ulOS;                   // [IN/OUT]Size of the OSINFO array/Actual # of entries filled in. | 
|---|
| 1251 | } ASSEMBLYMETADATA; | 
|---|
| 1252 |  | 
|---|
| 1253 |  | 
|---|
| 1254 | // {211EF15B-5317-4438-B196-DEC87B887693} | 
|---|
| 1255 | EXTERN_GUID(IID_IMetaDataAssemblyEmit, 0x211ef15b, 0x5317, 0x4438, 0xb1, 0x96, 0xde, 0xc8, 0x7b, 0x88, 0x76, 0x93); | 
|---|
| 1256 |  | 
|---|
| 1257 | //--- | 
|---|
| 1258 | #undef  INTERFACE | 
|---|
| 1259 | #define INTERFACE IMetaDataAssemblyEmit | 
|---|
| 1260 | DECLARE_INTERFACE_(IMetaDataAssemblyEmit, IUnknown) | 
|---|
| 1261 | { | 
|---|
| 1262 | STDMETHOD(DefineAssembly)(              // S_OK or error. | 
|---|
| 1263 | const void  *pbPublicKey,           // [IN] Public key of the assembly. | 
|---|
| 1264 | ULONG       cbPublicKey,            // [IN] Count of bytes in the public key. | 
|---|
| 1265 | ULONG       ulHashAlgId,            // [IN] Hash algorithm used to hash the files. | 
|---|
| 1266 | LPCWSTR     szName,                 // [IN] Name of the assembly. | 
|---|
| 1267 | const ASSEMBLYMETADATA *pMetaData,  // [IN] Assembly MetaData. | 
|---|
| 1268 | DWORD       dwAssemblyFlags,        // [IN] Flags. | 
|---|
| 1269 | mdAssembly  *pma) PURE;             // [OUT] Returned Assembly token. | 
|---|
| 1270 |  | 
|---|
| 1271 | STDMETHOD(DefineAssemblyRef)(           // S_OK or error. | 
|---|
| 1272 | const void  *pbPublicKeyOrToken,    // [IN] Public key or token of the assembly. | 
|---|
| 1273 | ULONG       cbPublicKeyOrToken,     // [IN] Count of bytes in the public key or token. | 
|---|
| 1274 | LPCWSTR     szName,                 // [IN] Name of the assembly being referenced. | 
|---|
| 1275 | const ASSEMBLYMETADATA *pMetaData,  // [IN] Assembly MetaData. | 
|---|
| 1276 | const void  *pbHashValue,           // [IN] Hash Blob. | 
|---|
| 1277 | ULONG       cbHashValue,            // [IN] Count of bytes in the Hash Blob. | 
|---|
| 1278 | DWORD       dwAssemblyRefFlags,     // [IN] Flags. | 
|---|
| 1279 | mdAssemblyRef *pmdar) PURE;         // [OUT] Returned AssemblyRef token. | 
|---|
| 1280 |  | 
|---|
| 1281 | STDMETHOD(DefineFile)(                  // S_OK or error. | 
|---|
| 1282 | LPCWSTR     szName,                 // [IN] Name of the file. | 
|---|
| 1283 | const void  *pbHashValue,           // [IN] Hash Blob. | 
|---|
| 1284 | ULONG       cbHashValue,            // [IN] Count of bytes in the Hash Blob. | 
|---|
| 1285 | DWORD       dwFileFlags,            // [IN] Flags. | 
|---|
| 1286 | mdFile      *pmdf) PURE;            // [OUT] Returned File token. | 
|---|
| 1287 |  | 
|---|
| 1288 | STDMETHOD(DefineExportedType)(          // S_OK or error. | 
|---|
| 1289 | LPCWSTR     szName,                 // [IN] Name of the Com Type. | 
|---|
| 1290 | mdToken     tkImplementation,       // [IN] mdFile or mdAssemblyRef or mdExportedType | 
|---|
| 1291 | mdTypeDef   tkTypeDef,              // [IN] TypeDef token within the file. | 
|---|
| 1292 | DWORD       dwExportedTypeFlags,    // [IN] Flags. | 
|---|
| 1293 | mdExportedType   *pmdct) PURE;      // [OUT] Returned ExportedType token. | 
|---|
| 1294 |  | 
|---|
| 1295 | STDMETHOD(DefineManifestResource)(      // S_OK or error. | 
|---|
| 1296 | LPCWSTR     szName,                 // [IN] Name of the resource. | 
|---|
| 1297 | mdToken     tkImplementation,       // [IN] mdFile or mdAssemblyRef that provides the resource. | 
|---|
| 1298 | DWORD       dwOffset,               // [IN] Offset to the beginning of the resource within the file. | 
|---|
| 1299 | DWORD       dwResourceFlags,        // [IN] Flags. | 
|---|
| 1300 | mdManifestResource  *pmdmr) PURE;   // [OUT] Returned ManifestResource token. | 
|---|
| 1301 |  | 
|---|
| 1302 | STDMETHOD(SetAssemblyProps)(            // S_OK or error. | 
|---|
| 1303 | mdAssembly  pma,                    // [IN] Assembly token. | 
|---|
| 1304 | const void  *pbPublicKey,           // [IN] Public key of the assembly. | 
|---|
| 1305 | ULONG       cbPublicKey,            // [IN] Count of bytes in the public key. | 
|---|
| 1306 | ULONG       ulHashAlgId,            // [IN] Hash algorithm used to hash the files. | 
|---|
| 1307 | LPCWSTR     szName,                 // [IN] Name of the assembly. | 
|---|
| 1308 | const ASSEMBLYMETADATA *pMetaData,  // [IN] Assembly MetaData. | 
|---|
| 1309 | DWORD       dwAssemblyFlags) PURE;  // [IN] Flags. | 
|---|
| 1310 |  | 
|---|
| 1311 | STDMETHOD(SetAssemblyRefProps)(         // S_OK or error. | 
|---|
| 1312 | mdAssemblyRef ar,                   // [IN] AssemblyRefToken. | 
|---|
| 1313 | const void  *pbPublicKeyOrToken,    // [IN] Public key or token of the assembly. | 
|---|
| 1314 | ULONG       cbPublicKeyOrToken,     // [IN] Count of bytes in the public key or token. | 
|---|
| 1315 | LPCWSTR     szName,                 // [IN] Name of the assembly being referenced. | 
|---|
| 1316 | const ASSEMBLYMETADATA *pMetaData,  // [IN] Assembly MetaData. | 
|---|
| 1317 | const void  *pbHashValue,           // [IN] Hash Blob. | 
|---|
| 1318 | ULONG       cbHashValue,            // [IN] Count of bytes in the Hash Blob. | 
|---|
| 1319 | DWORD       dwAssemblyRefFlags) PURE; // [IN] Token for Execution Location. | 
|---|
| 1320 |  | 
|---|
| 1321 | STDMETHOD(SetFileProps)(                // S_OK or error. | 
|---|
| 1322 | mdFile      file,                   // [IN] File token. | 
|---|
| 1323 | const void  *pbHashValue,           // [IN] Hash Blob. | 
|---|
| 1324 | ULONG       cbHashValue,            // [IN] Count of bytes in the Hash Blob. | 
|---|
| 1325 | DWORD       dwFileFlags) PURE;      // [IN] Flags. | 
|---|
| 1326 |  | 
|---|
| 1327 | STDMETHOD(SetExportedTypeProps)(        // S_OK or error. | 
|---|
| 1328 | mdExportedType   ct,                // [IN] ExportedType token. | 
|---|
| 1329 | mdToken     tkImplementation,       // [IN] mdFile or mdAssemblyRef or mdExportedType. | 
|---|
| 1330 | mdTypeDef   tkTypeDef,              // [IN] TypeDef token within the file. | 
|---|
| 1331 | DWORD       dwExportedTypeFlags) PURE;   // [IN] Flags. | 
|---|
| 1332 |  | 
|---|
| 1333 | STDMETHOD(SetManifestResourceProps)(    // S_OK or error. | 
|---|
| 1334 | mdManifestResource  mr,             // [IN] ManifestResource token. | 
|---|
| 1335 | mdToken     tkImplementation,       // [IN] mdFile or mdAssemblyRef that provides the resource. | 
|---|
| 1336 | DWORD       dwOffset,               // [IN] Offset to the beginning of the resource within the file. | 
|---|
| 1337 | DWORD       dwResourceFlags) PURE;  // [IN] Flags. | 
|---|
| 1338 |  | 
|---|
| 1339 | };  // IMetaDataAssemblyEmit | 
|---|
| 1340 |  | 
|---|
| 1341 |  | 
|---|
| 1342 | // {EE62470B-E94B-424e-9B7C-2F00C9249F93} | 
|---|
| 1343 | EXTERN_GUID(IID_IMetaDataAssemblyImport, 0xee62470b, 0xe94b, 0x424e, 0x9b, 0x7c, 0x2f, 0x0, 0xc9, 0x24, 0x9f, 0x93); | 
|---|
| 1344 |  | 
|---|
| 1345 | //--- | 
|---|
| 1346 | #undef  INTERFACE | 
|---|
| 1347 | #define INTERFACE IMetaDataAssemblyImport | 
|---|
| 1348 | DECLARE_INTERFACE_(IMetaDataAssemblyImport, IUnknown) | 
|---|
| 1349 | { | 
|---|
| 1350 | STDMETHOD(GetAssemblyProps)(            // S_OK or error. | 
|---|
| 1351 | mdAssembly  mda,                    // [IN] The Assembly for which to get the properties. | 
|---|
| 1352 | const void  **ppbPublicKey,         // [OUT] Pointer to the public key. | 
|---|
| 1353 | ULONG       *pcbPublicKey,          // [OUT] Count of bytes in the public key. | 
|---|
| 1354 | ULONG       *pulHashAlgId,          // [OUT] Hash Algorithm. | 
|---|
| 1355 | _Out_writes_to_opt_(cchName, *pchName) LPWSTR  szName, // [OUT] Buffer to fill with assembly's simply name. | 
|---|
| 1356 | ULONG       cchName,                // [IN] Size of buffer in wide chars. | 
|---|
| 1357 | ULONG       *pchName,               // [OUT] Actual # of wide chars in name. | 
|---|
| 1358 | ASSEMBLYMETADATA *pMetaData,        // [OUT] Assembly MetaData. | 
|---|
| 1359 | DWORD       *pdwAssemblyFlags) PURE;    // [OUT] Flags. | 
|---|
| 1360 |  | 
|---|
| 1361 | STDMETHOD(GetAssemblyRefProps)(         // S_OK or error. | 
|---|
| 1362 | mdAssemblyRef mdar,                 // [IN] The AssemblyRef for which to get the properties. | 
|---|
| 1363 | const void  **ppbPublicKeyOrToken,  // [OUT] Pointer to the public key or token. | 
|---|
| 1364 | ULONG       *pcbPublicKeyOrToken,   // [OUT] Count of bytes in the public key or token. | 
|---|
| 1365 | _Out_writes_to_opt_(cchName, *pchName)LPWSTR szName, // [OUT] Buffer to fill with name. | 
|---|
| 1366 | ULONG       cchName,                // [IN] Size of buffer in wide chars. | 
|---|
| 1367 | ULONG       *pchName,               // [OUT] Actual # of wide chars in name. | 
|---|
| 1368 | ASSEMBLYMETADATA *pMetaData,        // [OUT] Assembly MetaData. | 
|---|
| 1369 | const void  **ppbHashValue,         // [OUT] Hash blob. | 
|---|
| 1370 | ULONG       *pcbHashValue,          // [OUT] Count of bytes in the hash blob. | 
|---|
| 1371 | DWORD       *pdwAssemblyRefFlags) PURE; // [OUT] Flags. | 
|---|
| 1372 |  | 
|---|
| 1373 | STDMETHOD(GetFileProps)(                // S_OK or error. | 
|---|
| 1374 | mdFile      mdf,                    // [IN] The File for which to get the properties. | 
|---|
| 1375 | _Out_writes_to_opt_(cchName, *pchName) LPWSTR      szName, // [OUT] Buffer to fill with name. | 
|---|
| 1376 | ULONG       cchName,                // [IN] Size of buffer in wide chars. | 
|---|
| 1377 | ULONG       *pchName,               // [OUT] Actual # of wide chars in name. | 
|---|
| 1378 | const void  **ppbHashValue,         // [OUT] Pointer to the Hash Value Blob. | 
|---|
| 1379 | ULONG       *pcbHashValue,          // [OUT] Count of bytes in the Hash Value Blob. | 
|---|
| 1380 | DWORD       *pdwFileFlags) PURE;    // [OUT] Flags. | 
|---|
| 1381 |  | 
|---|
| 1382 | STDMETHOD(GetExportedTypeProps)(        // S_OK or error. | 
|---|
| 1383 | mdExportedType   mdct,              // [IN] The ExportedType for which to get the properties. | 
|---|
| 1384 | _Out_writes_to_opt_(cchName, *pchName) LPWSTR      szName, // [OUT] Buffer to fill with name. | 
|---|
| 1385 | ULONG       cchName,                // [IN] Size of buffer in wide chars. | 
|---|
| 1386 | ULONG       *pchName,               // [OUT] Actual # of wide chars in name. | 
|---|
| 1387 | mdToken     *ptkImplementation,     // [OUT] mdFile or mdAssemblyRef or mdExportedType. | 
|---|
| 1388 | mdTypeDef   *ptkTypeDef,            // [OUT] TypeDef token within the file. | 
|---|
| 1389 | DWORD       *pdwExportedTypeFlags) PURE; // [OUT] Flags. | 
|---|
| 1390 |  | 
|---|
| 1391 | STDMETHOD(GetManifestResourceProps)(    // S_OK or error. | 
|---|
| 1392 | mdManifestResource  mdmr,           // [IN] The ManifestResource for which to get the properties. | 
|---|
| 1393 | _Out_writes_to_opt_(cchName, *pchName)LPWSTR      szName,  // [OUT] Buffer to fill with name. | 
|---|
| 1394 | ULONG       cchName,                // [IN] Size of buffer in wide chars. | 
|---|
| 1395 | ULONG       *pchName,               // [OUT] Actual # of wide chars in name. | 
|---|
| 1396 | mdToken     *ptkImplementation,     // [OUT] mdFile or mdAssemblyRef that provides the ManifestResource. | 
|---|
| 1397 | DWORD       *pdwOffset,             // [OUT] Offset to the beginning of the resource within the file. | 
|---|
| 1398 | DWORD       *pdwResourceFlags) PURE;// [OUT] Flags. | 
|---|
| 1399 |  | 
|---|
| 1400 | STDMETHOD(EnumAssemblyRefs)(            // S_OK or error | 
|---|
| 1401 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 1402 | mdAssemblyRef rAssemblyRefs[],      // [OUT] Put AssemblyRefs here. | 
|---|
| 1403 | ULONG       cMax,                   // [IN] Max AssemblyRefs to put. | 
|---|
| 1404 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 1405 |  | 
|---|
| 1406 | STDMETHOD(EnumFiles)(                   // S_OK or error | 
|---|
| 1407 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 1408 | mdFile      rFiles[],               // [OUT] Put Files here. | 
|---|
| 1409 | ULONG       cMax,                   // [IN] Max Files to put. | 
|---|
| 1410 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 1411 |  | 
|---|
| 1412 | STDMETHOD(EnumExportedTypes)(           // S_OK or error | 
|---|
| 1413 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 1414 | mdExportedType   rExportedTypes[],  // [OUT] Put ExportedTypes here. | 
|---|
| 1415 | ULONG       cMax,                   // [IN] Max ExportedTypes to put. | 
|---|
| 1416 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 1417 |  | 
|---|
| 1418 | STDMETHOD(EnumManifestResources)(       // S_OK or error | 
|---|
| 1419 | HCORENUM    *phEnum,                // [IN|OUT] Pointer to the enum. | 
|---|
| 1420 | mdManifestResource  rManifestResources[],   // [OUT] Put ManifestResources here. | 
|---|
| 1421 | ULONG       cMax,                   // [IN] Max Resources to put. | 
|---|
| 1422 | ULONG       *pcTokens) PURE;        // [OUT] Put # put here. | 
|---|
| 1423 |  | 
|---|
| 1424 | STDMETHOD(GetAssemblyFromScope)(        // S_OK or error | 
|---|
| 1425 | mdAssembly  *ptkAssembly) PURE;     // [OUT] Put token here. | 
|---|
| 1426 |  | 
|---|
| 1427 | STDMETHOD(FindExportedTypeByName)(      // S_OK or error | 
|---|
| 1428 | LPCWSTR     szName,                 // [IN] Name of the ExportedType. | 
|---|
| 1429 | mdToken     mdtExportedType,        // [IN] ExportedType for the enclosing class. | 
|---|
| 1430 | mdExportedType   *ptkExportedType) PURE; // [OUT] Put the ExportedType token here. | 
|---|
| 1431 |  | 
|---|
| 1432 | STDMETHOD(FindManifestResourceByName)(  // S_OK or error | 
|---|
| 1433 | LPCWSTR     szName,                 // [IN] Name of the ManifestResource. | 
|---|
| 1434 | mdManifestResource *ptkManifestResource) PURE;  // [OUT] Put the ManifestResource token here. | 
|---|
| 1435 |  | 
|---|
| 1436 | STDMETHOD_(void, CloseEnum)( | 
|---|
| 1437 | HCORENUM hEnum) PURE;               // Enum to be closed. | 
|---|
| 1438 |  | 
|---|
| 1439 | STDMETHOD(FindAssembliesByName)(        // S_OK or error | 
|---|
| 1440 | LPCWSTR  szAppBase,                 // [IN] optional - can be NULL | 
|---|
| 1441 | LPCWSTR  szPrivateBin,              // [IN] optional - can be NULL | 
|---|
| 1442 | LPCWSTR  szAssemblyName,            // [IN] required - this is the assembly you are requesting | 
|---|
| 1443 | IUnknown *ppIUnk[],                 // [OUT] put IMetaDataAssemblyImport pointers here | 
|---|
| 1444 | ULONG    cMax,                      // [IN] The max number to put | 
|---|
| 1445 | ULONG    *pcAssemblies) PURE;       // [OUT] The number of assemblies returned. | 
|---|
| 1446 | };  // IMetaDataAssemblyImport | 
|---|
| 1447 |  | 
|---|
| 1448 |  | 
|---|
| 1449 | //***************************************************************************** | 
|---|
| 1450 | // End Assembly Declarations | 
|---|
| 1451 | //***************************************************************************** | 
|---|
| 1452 |  | 
|---|
| 1453 | //***************************************************************************** | 
|---|
| 1454 | // MetaData Validator Declarations | 
|---|
| 1455 | //***************************************************************************** | 
|---|
| 1456 |  | 
|---|
| 1457 | // Specifies the type of the module, PE file vs. .obj file. | 
|---|
| 1458 | typedef enum | 
|---|
| 1459 | { | 
|---|
| 1460 | ValidatorModuleTypeInvalid      = 0x0, | 
|---|
| 1461 | ValidatorModuleTypeMin          = 0x00000001, | 
|---|
| 1462 | ValidatorModuleTypePE           = 0x00000001, | 
|---|
| 1463 | ValidatorModuleTypeObj          = 0x00000002, | 
|---|
| 1464 | ValidatorModuleTypeEnc          = 0x00000003, | 
|---|
| 1465 | ValidatorModuleTypeIncr         = 0x00000004, | 
|---|
| 1466 | ValidatorModuleTypeMax          = 0x00000004, | 
|---|
| 1467 | } CorValidatorModuleType; | 
|---|
| 1468 |  | 
|---|
| 1469 |  | 
|---|
| 1470 | // {4709C9C6-81FF-11D3-9FC7-00C04F79A0A3} | 
|---|
| 1471 | EXTERN_GUID(IID_IMetaDataValidate, 0x4709c9c6, 0x81ff, 0x11d3, 0x9f, 0xc7, 0x0, 0xc0, 0x4f, 0x79, 0xa0, 0xa3); | 
|---|
| 1472 |  | 
|---|
| 1473 | //--- | 
|---|
| 1474 | #undef  INTERFACE | 
|---|
| 1475 | #define INTERFACE IMetaDataValidate | 
|---|
| 1476 | DECLARE_INTERFACE_(IMetaDataValidate, IUnknown) | 
|---|
| 1477 | { | 
|---|
| 1478 | STDMETHOD(ValidatorInit)(               // S_OK or error. | 
|---|
| 1479 | DWORD       dwModuleType,           // [IN] Specifies the type of the module. | 
|---|
| 1480 | IUnknown    *pUnk) PURE;            // [IN] Validation error handler. | 
|---|
| 1481 |  | 
|---|
| 1482 | STDMETHOD(ValidateMetaData)(            // S_OK or error. | 
|---|
| 1483 | ) PURE; | 
|---|
| 1484 | };  // IMetaDataValidate | 
|---|
| 1485 |  | 
|---|
| 1486 | //***************************************************************************** | 
|---|
| 1487 | // End MetaData Validator Declarations | 
|---|
| 1488 | //***************************************************************************** | 
|---|
| 1489 |  | 
|---|
| 1490 | //***************************************************************************** | 
|---|
| 1491 | // IMetaDataDispenserEx declarations. | 
|---|
| 1492 | //***************************************************************************** | 
|---|
| 1493 |  | 
|---|
| 1494 | // {31BCFCE2-DAFB-11D2-9F81-00C04F79A0A3} | 
|---|
| 1495 | EXTERN_GUID(IID_IMetaDataDispenserEx, 0x31bcfce2, 0xdafb, 0x11d2, 0x9f, 0x81, 0x0, 0xc0, 0x4f, 0x79, 0xa0, 0xa3); | 
|---|
| 1496 |  | 
|---|
| 1497 | #undef  INTERFACE | 
|---|
| 1498 | #define INTERFACE IMetaDataDispenserEx | 
|---|
| 1499 | DECLARE_INTERFACE_(IMetaDataDispenserEx, IMetaDataDispenser) | 
|---|
| 1500 | { | 
|---|
| 1501 | STDMETHOD(SetOption)(                   // Return code. | 
|---|
| 1502 | REFGUID     optionid,               // [in] GUID for the option to be set. | 
|---|
| 1503 | const VARIANT *value) PURE;         // [in] Value to which the option is to be set. | 
|---|
| 1504 |  | 
|---|
| 1505 | STDMETHOD(GetOption)(                   // Return code. | 
|---|
| 1506 | REFGUID     optionid,               // [in] GUID for the option to be set. | 
|---|
| 1507 | VARIANT *pvalue) PURE;              // [out] Value to which the option is currently set. | 
|---|
| 1508 |  | 
|---|
| 1509 | STDMETHOD(OpenScopeOnITypeInfo)(        // Return code. | 
|---|
| 1510 | ITypeInfo   *pITI,                  // [in] ITypeInfo to open. | 
|---|
| 1511 | DWORD       dwOpenFlags,            // [in] Open mode flags. | 
|---|
| 1512 | REFIID      riid,                   // [in] The interface desired. | 
|---|
| 1513 | IUnknown    **ppIUnk) PURE;         // [out] Return interface on success. | 
|---|
| 1514 |  | 
|---|
| 1515 | STDMETHOD(GetCORSystemDirectory)(       // Return code. | 
|---|
| 1516 | _Out_writes_to_opt_(cchBuffer, *pchBuffer) | 
|---|
| 1517 | LPWSTR      szBuffer,              // [out] Buffer for the directory name | 
|---|
| 1518 | DWORD       cchBuffer,             // [in] Size of the buffer | 
|---|
| 1519 | DWORD*      pchBuffer) PURE;       // [OUT] Number of characters returned | 
|---|
| 1520 |  | 
|---|
| 1521 | STDMETHOD(FindAssembly)(                // S_OK or error | 
|---|
| 1522 | LPCWSTR  szAppBase,                 // [IN] optional - can be NULL | 
|---|
| 1523 | LPCWSTR  szPrivateBin,              // [IN] optional - can be NULL | 
|---|
| 1524 | LPCWSTR  szGlobalBin,               // [IN] optional - can be NULL | 
|---|
| 1525 | LPCWSTR  szAssemblyName,            // [IN] required - this is the assembly you are requesting | 
|---|
| 1526 | LPCWSTR  szName,                    // [OUT] buffer - to hold name | 
|---|
| 1527 | ULONG    cchName,                   // [IN] the name buffer's size | 
|---|
| 1528 | ULONG    *pcName) PURE;             // [OUT] the number of characters returend in the buffer | 
|---|
| 1529 |  | 
|---|
| 1530 | STDMETHOD(FindAssemblyModule)(          // S_OK or error | 
|---|
| 1531 | LPCWSTR  szAppBase,                 // [IN] optional - can be NULL | 
|---|
| 1532 | LPCWSTR  szPrivateBin,              // [IN] optional - can be NULL | 
|---|
| 1533 | LPCWSTR  szGlobalBin,               // [IN] optional - can be NULL | 
|---|
| 1534 | LPCWSTR  szAssemblyName,            // [IN] required - this is the assembly you are requesting | 
|---|
| 1535 | LPCWSTR  szModuleName,              // [IN] required - the name of the module | 
|---|
| 1536 | _Out_writes_to_opt_(cchName, *pcName) | 
|---|
| 1537 | LPWSTR   szName,                    // [OUT] buffer - to hold name | 
|---|
| 1538 | ULONG    cchName,                   // [IN]  the name buffer's size | 
|---|
| 1539 | ULONG    *pcName) PURE;             // [OUT] the number of characters returend in the buffer | 
|---|
| 1540 |  | 
|---|
| 1541 | }; | 
|---|
| 1542 |  | 
|---|
| 1543 | //***************************************************************************** | 
|---|
| 1544 | //***************************************************************************** | 
|---|
| 1545 | // | 
|---|
| 1546 | // Registration declarations.  Will be replace by Services' Registration | 
|---|
| 1547 | //  implementation. | 
|---|
| 1548 | // | 
|---|
| 1549 | //***************************************************************************** | 
|---|
| 1550 | //***************************************************************************** | 
|---|
| 1551 | // Various flags for use in installing a module or a composite | 
|---|
| 1552 | typedef enum | 
|---|
| 1553 | { | 
|---|
| 1554 | regNoCopy = 0x00000001,         // Don't copy files into destination | 
|---|
| 1555 | regConfig = 0x00000002,         // Is a configuration | 
|---|
| 1556 | regHasRefs = 0x00000004         // Has class references | 
|---|
| 1557 | } CorRegFlags; | 
|---|
| 1558 |  | 
|---|
| 1559 | typedef GUID CVID; | 
|---|
| 1560 |  | 
|---|
| 1561 | typedef struct { | 
|---|
| 1562 | short Major; | 
|---|
| 1563 | short Minor; | 
|---|
| 1564 | short Sub; | 
|---|
| 1565 | short Build; | 
|---|
| 1566 | } CVStruct; | 
|---|
| 1567 |  | 
|---|
| 1568 |  | 
|---|
| 1569 | //***************************************************************************** | 
|---|
| 1570 | //***************************************************************************** | 
|---|
| 1571 | // | 
|---|
| 1572 | // CeeGen interfaces for generating in-memory Common Language Runtime files | 
|---|
| 1573 | // | 
|---|
| 1574 | //***************************************************************************** | 
|---|
| 1575 | //***************************************************************************** | 
|---|
| 1576 |  | 
|---|
| 1577 | typedef void *HCEESECTION; | 
|---|
| 1578 |  | 
|---|
| 1579 | typedef enum  { | 
|---|
| 1580 | sdNone =        0, | 
|---|
| 1581 | sdReadOnly =    IMAGE_SCN_MEM_READ | IMAGE_SCN_CNT_INITIALIZED_DATA, | 
|---|
| 1582 | sdReadWrite =   sdReadOnly | IMAGE_SCN_MEM_WRITE, | 
|---|
| 1583 | sdExecute =     IMAGE_SCN_MEM_READ | IMAGE_SCN_CNT_CODE | IMAGE_SCN_MEM_EXECUTE | 
|---|
| 1584 | } CeeSectionAttr; | 
|---|
| 1585 |  | 
|---|
| 1586 | // | 
|---|
| 1587 | // Relocation types. | 
|---|
| 1588 | // | 
|---|
| 1589 |  | 
|---|
| 1590 | typedef enum  { | 
|---|
| 1591 | // generate only a section-relative reloc, nothing into .reloc section | 
|---|
| 1592 | srRelocAbsolute, | 
|---|
| 1593 |  | 
|---|
| 1594 | // generate a .reloc for a pointer sized location, | 
|---|
| 1595 | // This is transformed into BASED_HIGHLOW or BASED_DIR64 based on the platform | 
|---|
| 1596 | srRelocHighLow      = 3, | 
|---|
| 1597 |  | 
|---|
| 1598 | // generate a .reloc for the top 16-bits of a 32 bit number, where the | 
|---|
| 1599 | // bottom 16 bits are included in the next word in the .reloc table | 
|---|
| 1600 | srRelocHighAdj,     // Never Used | 
|---|
| 1601 |  | 
|---|
| 1602 | // generate a token map relocation, nothing into .reloc section | 
|---|
| 1603 | srRelocMapToken, | 
|---|
| 1604 |  | 
|---|
| 1605 | // relative address fixup | 
|---|
| 1606 | srRelocRelative, | 
|---|
| 1607 |  | 
|---|
| 1608 | // Generate only a section-relative reloc, nothing into .reloc | 
|---|
| 1609 | // section.  This reloc is relative to the file position of the | 
|---|
| 1610 | // section, not the section's virtual address. | 
|---|
| 1611 | srRelocFilePos, | 
|---|
| 1612 |  | 
|---|
| 1613 | // code relative address fixup | 
|---|
| 1614 | srRelocCodeRelative, | 
|---|
| 1615 |  | 
|---|
| 1616 | // generate a .reloc for a 64 bit address in an ia64 movl instruction | 
|---|
| 1617 | srRelocIA64Imm64, | 
|---|
| 1618 |  | 
|---|
| 1619 | // generate a .reloc for a 64 bit address | 
|---|
| 1620 | srRelocDir64, | 
|---|
| 1621 |  | 
|---|
| 1622 | // generate a .reloc for a 25-bit PC relative address in an ia64 br.call instruction | 
|---|
| 1623 | srRelocIA64PcRel25, | 
|---|
| 1624 |  | 
|---|
| 1625 | // generate a .reloc for a 64-bit PC relative address in an ia64 brl.call instruction | 
|---|
| 1626 | srRelocIA64PcRel64, | 
|---|
| 1627 |  | 
|---|
| 1628 | // generate a 30-bit section-relative reloc, used for tagged pointer values | 
|---|
| 1629 | srRelocAbsoluteTagged, | 
|---|
| 1630 |  | 
|---|
| 1631 |  | 
|---|
| 1632 | // A sentinel value to help ensure any additions to this enum are reflected | 
|---|
| 1633 | // in PEWriter.cpp's RelocName array. | 
|---|
| 1634 | srRelocSentinel, | 
|---|
| 1635 |  | 
|---|
| 1636 | // Flags that can be used with the above reloc types | 
|---|
| 1637 |  | 
|---|
| 1638 | // do not emit base reloc | 
|---|
| 1639 | srNoBaseReloc = 0x4000, | 
|---|
| 1640 |  | 
|---|
| 1641 | // pre-fixup contents of memory are ptr rather than a section offset | 
|---|
| 1642 | srRelocPtr = 0x8000, | 
|---|
| 1643 |  | 
|---|
| 1644 | // legal enums which include the Ptr flag | 
|---|
| 1645 | srRelocAbsolutePtr  = srRelocPtr + srRelocAbsolute, | 
|---|
| 1646 | srRelocHighLowPtr   = srRelocPtr + srRelocHighLow, | 
|---|
| 1647 | srRelocRelativePtr  = srRelocPtr + srRelocRelative, | 
|---|
| 1648 | srRelocIA64Imm64Ptr = srRelocPtr + srRelocIA64Imm64, | 
|---|
| 1649 | srRelocDir64Ptr     = srRelocPtr + srRelocDir64, | 
|---|
| 1650 |  | 
|---|
| 1651 | } CeeSectionRelocType; | 
|---|
| 1652 |  | 
|---|
| 1653 | typedef union  { | 
|---|
| 1654 | USHORT highAdj; | 
|---|
| 1655 | } ; | 
|---|
| 1656 |  | 
|---|
| 1657 | //------------------------------------- | 
|---|
| 1658 | //--- ICeeGen | 
|---|
| 1659 | //------------------------------------- | 
|---|
| 1660 | // {7ED1BDFF-8E36-11d2-9C56-00A0C9B7CC45} | 
|---|
| 1661 | EXTERN_GUID(IID_ICeeGen, 0x7ed1bdff, 0x8e36, 0x11d2, 0x9c, 0x56, 0x0, 0xa0, 0xc9, 0xb7, 0xcc, 0x45); | 
|---|
| 1662 |  | 
|---|
| 1663 | DECLARE_INTERFACE_(ICeeGen, IUnknown) | 
|---|
| 1664 | { | 
|---|
| 1665 | STDMETHOD (EmitString) ( | 
|---|
| 1666 | _In_ | 
|---|
| 1667 | LPWSTR lpString,                    // [IN] String to emit | 
|---|
| 1668 | ULONG *RVA) PURE;                   // [OUT] RVA for string emitted string | 
|---|
| 1669 |  | 
|---|
| 1670 | STDMETHOD (GetString) ( | 
|---|
| 1671 | ULONG RVA,                          // [IN] RVA for string to return | 
|---|
| 1672 | _Out_opt_ | 
|---|
| 1673 | LPWSTR *lpString) PURE;             // [OUT] Returned string | 
|---|
| 1674 |  | 
|---|
| 1675 | STDMETHOD (AllocateMethodBuffer) ( | 
|---|
| 1676 | ULONG cchBuffer,                    // [IN] Length of buffer to create | 
|---|
| 1677 | UCHAR **lpBuffer,                   // [OUT] Returned buffer | 
|---|
| 1678 | ULONG *RVA) PURE;                   // [OUT] RVA for method | 
|---|
| 1679 |  | 
|---|
| 1680 | STDMETHOD (GetMethodBuffer) ( | 
|---|
| 1681 | ULONG RVA,                          // [IN] RVA for method to return | 
|---|
| 1682 | UCHAR **lpBuffer) PURE;             // [OUT] Returned buffer | 
|---|
| 1683 |  | 
|---|
| 1684 | STDMETHOD (GetIMapTokenIface) ( | 
|---|
| 1685 | IUnknown **pIMapToken) PURE; | 
|---|
| 1686 |  | 
|---|
| 1687 | STDMETHOD (GenerateCeeFile) () PURE; | 
|---|
| 1688 |  | 
|---|
| 1689 | STDMETHOD (GetIlSection) ( | 
|---|
| 1690 | HCEESECTION *section) PURE; | 
|---|
| 1691 |  | 
|---|
| 1692 | STDMETHOD (GetStringSection) ( | 
|---|
| 1693 | HCEESECTION *section) PURE; | 
|---|
| 1694 |  | 
|---|
| 1695 | STDMETHOD (AddSectionReloc) ( | 
|---|
| 1696 | HCEESECTION section, | 
|---|
| 1697 | ULONG offset, | 
|---|
| 1698 | HCEESECTION relativeTo, | 
|---|
| 1699 | CeeSectionRelocType relocType) PURE; | 
|---|
| 1700 |  | 
|---|
| 1701 | // use these only if you have special section requirements not handled | 
|---|
| 1702 | // by other APIs | 
|---|
| 1703 | STDMETHOD (GetSectionCreate) ( | 
|---|
| 1704 | const char *name, | 
|---|
| 1705 | DWORD flags, | 
|---|
| 1706 | HCEESECTION *section) PURE; | 
|---|
| 1707 |  | 
|---|
| 1708 | STDMETHOD (GetSectionDataLen) ( | 
|---|
| 1709 | HCEESECTION section, | 
|---|
| 1710 | ULONG *dataLen) PURE; | 
|---|
| 1711 |  | 
|---|
| 1712 | STDMETHOD (GetSectionBlock) ( | 
|---|
| 1713 | HCEESECTION section, | 
|---|
| 1714 | ULONG len, | 
|---|
| 1715 | ULONG align=1, | 
|---|
| 1716 | void **ppBytes=0) PURE; | 
|---|
| 1717 |  | 
|---|
| 1718 | STDMETHOD (TruncateSection) ( | 
|---|
| 1719 | HCEESECTION section, | 
|---|
| 1720 | ULONG len) PURE; | 
|---|
| 1721 |  | 
|---|
| 1722 | STDMETHOD (GenerateCeeMemoryImage) ( | 
|---|
| 1723 | void **ppImage) PURE; | 
|---|
| 1724 |  | 
|---|
| 1725 | STDMETHOD (ComputePointer) ( | 
|---|
| 1726 | HCEESECTION section, | 
|---|
| 1727 | ULONG RVA,                          // [IN] RVA for method to return | 
|---|
| 1728 | UCHAR **lpBuffer) PURE;             // [OUT] Returned buffer | 
|---|
| 1729 |  | 
|---|
| 1730 | }; | 
|---|
| 1731 |  | 
|---|
| 1732 | //***************************************************************************** | 
|---|
| 1733 | //***************************************************************************** | 
|---|
| 1734 | // | 
|---|
| 1735 | // End of CeeGen declarations. | 
|---|
| 1736 | // | 
|---|
| 1737 | //***************************************************************************** | 
|---|
| 1738 |  | 
|---|
| 1739 | //********************************************************************** | 
|---|
| 1740 | //********************************************************************** | 
|---|
| 1741 | //--- IMetaDataTables | 
|---|
| 1742 | //------------------------------------- | 
|---|
| 1743 | // This API isn't big endian friendly since it indexes directly into the memory that | 
|---|
| 1744 | // is stored in little endian format. | 
|---|
| 1745 | // {D8F579AB-402D-4b8e-82D9-5D63B1065C68} | 
|---|
| 1746 | EXTERN_GUID(IID_IMetaDataTables, 0xd8f579ab, 0x402d, 0x4b8e, 0x82, 0xd9, 0x5d, 0x63, 0xb1, 0x6, 0x5c, 0x68); | 
|---|
| 1747 |  | 
|---|
| 1748 | DECLARE_INTERFACE_(IMetaDataTables, IUnknown) | 
|---|
| 1749 | { | 
|---|
| 1750 | STDMETHOD (GetStringHeapSize) ( | 
|---|
| 1751 | ULONG   *pcbStrings) PURE;          // [OUT] Size of the string heap. | 
|---|
| 1752 |  | 
|---|
| 1753 | STDMETHOD (GetBlobHeapSize) ( | 
|---|
| 1754 | ULONG   *pcbBlobs) PURE;            // [OUT] Size of the Blob heap. | 
|---|
| 1755 |  | 
|---|
| 1756 | STDMETHOD (GetGuidHeapSize) ( | 
|---|
| 1757 | ULONG   *pcbGuids) PURE;            // [OUT] Size of the Guid heap. | 
|---|
| 1758 |  | 
|---|
| 1759 | STDMETHOD (GetUserStringHeapSize) ( | 
|---|
| 1760 | ULONG   *pcbBlobs) PURE;            // [OUT] Size of the User String heap. | 
|---|
| 1761 |  | 
|---|
| 1762 | STDMETHOD (GetNumTables) ( | 
|---|
| 1763 | ULONG   *pcTables) PURE;            // [OUT] Count of tables. | 
|---|
| 1764 |  | 
|---|
| 1765 | STDMETHOD (GetTableIndex) ( | 
|---|
| 1766 | ULONG   token,                      // [IN] Token for which to get table index. | 
|---|
| 1767 | ULONG   *pixTbl) PURE;              // [OUT] Put table index here. | 
|---|
| 1768 |  | 
|---|
| 1769 | STDMETHOD (GetTableInfo) ( | 
|---|
| 1770 | ULONG   ixTbl,                      // [IN] Which table. | 
|---|
| 1771 | ULONG   *pcbRow,                    // [OUT] Size of a row, bytes. | 
|---|
| 1772 | ULONG   *pcRows,                    // [OUT] Number of rows. | 
|---|
| 1773 | ULONG   *pcCols,                    // [OUT] Number of columns in each row. | 
|---|
| 1774 | ULONG   *piKey,                     // [OUT] Key column, or -1 if none. | 
|---|
| 1775 | const char **ppName) PURE;          // [OUT] Name of the table. | 
|---|
| 1776 |  | 
|---|
| 1777 | STDMETHOD (GetColumnInfo) ( | 
|---|
| 1778 | ULONG   ixTbl,                      // [IN] Which Table | 
|---|
| 1779 | ULONG   ixCol,                      // [IN] Which Column in the table | 
|---|
| 1780 | ULONG   *poCol,                     // [OUT] Offset of the column in the row. | 
|---|
| 1781 | ULONG   *pcbCol,                    // [OUT] Size of a column, bytes. | 
|---|
| 1782 | ULONG   *pType,                     // [OUT] Type of the column. | 
|---|
| 1783 | const char **ppName) PURE;          // [OUT] Name of the Column. | 
|---|
| 1784 |  | 
|---|
| 1785 | STDMETHOD (GetCodedTokenInfo) ( | 
|---|
| 1786 | ULONG   ixCdTkn,                    // [IN] Which kind of coded token. | 
|---|
| 1787 | ULONG   *pcTokens,                  // [OUT] Count of tokens. | 
|---|
| 1788 | ULONG   **ppTokens,                 // [OUT] List of tokens. | 
|---|
| 1789 | const char **ppName) PURE;          // [OUT] Name of the CodedToken. | 
|---|
| 1790 |  | 
|---|
| 1791 | STDMETHOD (GetRow) ( | 
|---|
| 1792 | ULONG   ixTbl,                      // [IN] Which table. | 
|---|
| 1793 | ULONG   rid,                        // [IN] Which row. | 
|---|
| 1794 | void    **ppRow) PURE;              // [OUT] Put pointer to row here. | 
|---|
| 1795 |  | 
|---|
| 1796 | STDMETHOD (GetColumn) ( | 
|---|
| 1797 | ULONG   ixTbl,                      // [IN] Which table. | 
|---|
| 1798 | ULONG   ixCol,                      // [IN] Which column. | 
|---|
| 1799 | ULONG   rid,                        // [IN] Which row. | 
|---|
| 1800 | ULONG   *pVal) PURE;                // [OUT] Put the column contents here. | 
|---|
| 1801 |  | 
|---|
| 1802 | STDMETHOD (GetString) ( | 
|---|
| 1803 | ULONG   ixString,                   // [IN] Value from a string column. | 
|---|
| 1804 | const char **ppString) PURE;        // [OUT] Put a pointer to the string here. | 
|---|
| 1805 |  | 
|---|
| 1806 | STDMETHOD (GetBlob) ( | 
|---|
| 1807 | ULONG   ixBlob,                     // [IN] Value from a blob column. | 
|---|
| 1808 | ULONG   *pcbData,                   // [OUT] Put size of the blob here. | 
|---|
| 1809 | const void **ppData) PURE;          // [OUT] Put a pointer to the blob here. | 
|---|
| 1810 |  | 
|---|
| 1811 | STDMETHOD (GetGuid) ( | 
|---|
| 1812 | ULONG   ixGuid,                     // [IN] Value from a guid column. | 
|---|
| 1813 | const GUID **ppGUID) PURE;          // [OUT] Put a pointer to the GUID here. | 
|---|
| 1814 |  | 
|---|
| 1815 | STDMETHOD (GetUserString) ( | 
|---|
| 1816 | ULONG   ixUserString,               // [IN] Value from a UserString column. | 
|---|
| 1817 | ULONG   *pcbData,                   // [OUT] Put size of the UserString here. | 
|---|
| 1818 | const void **ppData) PURE;          // [OUT] Put a pointer to the UserString here. | 
|---|
| 1819 |  | 
|---|
| 1820 | STDMETHOD (GetNextString) ( | 
|---|
| 1821 | ULONG   ixString,                   // [IN] Value from a string column. | 
|---|
| 1822 | ULONG   *pNext) PURE;               // [OUT] Put the index of the next string here. | 
|---|
| 1823 |  | 
|---|
| 1824 | STDMETHOD (GetNextBlob) ( | 
|---|
| 1825 | ULONG   ixBlob,                     // [IN] Value from a blob column. | 
|---|
| 1826 | ULONG   *pNext) PURE;               // [OUT] Put the index of the netxt blob here. | 
|---|
| 1827 |  | 
|---|
| 1828 | STDMETHOD (GetNextGuid) ( | 
|---|
| 1829 | ULONG   ixGuid,                     // [IN] Value from a guid column. | 
|---|
| 1830 | ULONG   *pNext) PURE;               // [OUT] Put the index of the next guid here. | 
|---|
| 1831 |  | 
|---|
| 1832 | STDMETHOD (GetNextUserString) ( | 
|---|
| 1833 | ULONG   ixUserString,               // [IN] Value from a UserString column. | 
|---|
| 1834 | ULONG   *pNext) PURE;               // [OUT] Put the index of the next user string here. | 
|---|
| 1835 |  | 
|---|
| 1836 | // Interface is sealed. | 
|---|
| 1837 |  | 
|---|
| 1838 | }; | 
|---|
| 1839 | // This API isn't big endian friendly since it indexes directly into the memory that | 
|---|
| 1840 | // is stored in little endian format. | 
|---|
| 1841 | // {BADB5F70-58DA-43a9-A1C6-D74819F19B15} | 
|---|
| 1842 | EXTERN_GUID(IID_IMetaDataTables2, 0xbadb5f70, 0x58da, 0x43a9, 0xa1, 0xc6, 0xd7, 0x48, 0x19, 0xf1, 0x9b, 0x15); | 
|---|
| 1843 |  | 
|---|
| 1844 | DECLARE_INTERFACE_(IMetaDataTables2, IMetaDataTables) | 
|---|
| 1845 | { | 
|---|
| 1846 | STDMETHOD (GetMetaDataStorage) (        //@todo: name? | 
|---|
| 1847 | const void **ppvMd,                 // [OUT] put pointer to MD section here (aka, 'BSJB'). | 
|---|
| 1848 | ULONG   *pcbMd) PURE;               // [OUT] put size of the stream here. | 
|---|
| 1849 |  | 
|---|
| 1850 | STDMETHOD (GetMetaDataStreamInfo) (     // Get info about the MD stream. | 
|---|
| 1851 | ULONG   ix,                         // [IN] Stream ordinal desired. | 
|---|
| 1852 | const char **ppchName,              // [OUT] put pointer to stream name here. | 
|---|
| 1853 | const void **ppv,                   // [OUT] put pointer to MD stream here. | 
|---|
| 1854 | ULONG   *pcb) PURE;                 // [OUT] put size of the stream here. | 
|---|
| 1855 |  | 
|---|
| 1856 | }; // IMetaDataTables2 | 
|---|
| 1857 |  | 
|---|
| 1858 | #ifdef _DEFINE_META_DATA_META_CONSTANTS | 
|---|
| 1859 | #ifndef _META_DATA_META_CONSTANTS_DEFINED | 
|---|
| 1860 | #define _META_DATA_META_CONSTANTS_DEFINED | 
|---|
| 1861 | const unsigned int iRidMax          = 63; | 
|---|
| 1862 | const unsigned int iCodedToken      = 64;   // base of coded tokens. | 
|---|
| 1863 | const unsigned int iCodedTokenMax   = 95; | 
|---|
| 1864 | const unsigned int iSHORT           = 96;   // fixed types. | 
|---|
| 1865 | const unsigned int iUSHORT          = 97; | 
|---|
| 1866 | const unsigned int iLONG            = 98; | 
|---|
| 1867 | const unsigned int iULONG           = 99; | 
|---|
| 1868 | const unsigned int iBYTE            = 100; | 
|---|
| 1869 | const unsigned int iSTRING          = 101;  // pool types. | 
|---|
| 1870 | const unsigned int iGUID            = 102; | 
|---|
| 1871 | const unsigned int iBLOB            = 103; | 
|---|
| 1872 |  | 
|---|
| 1873 | inline int IsRidType(ULONG ix) { return ix <= iRidMax; } | 
|---|
| 1874 | inline int IsCodedTokenType(ULONG ix) { return (ix >= iCodedToken) && (ix <= iCodedTokenMax); } | 
|---|
| 1875 | inline int IsRidOrToken(ULONG ix) { return ix <= iCodedTokenMax; } | 
|---|
| 1876 | inline int IsHeapType(ULONG ix) { return ix >= iSTRING; } | 
|---|
| 1877 | inline int IsFixedType(ULONG ix) { return (ix < iSTRING) && (ix > iCodedTokenMax); } | 
|---|
| 1878 | #endif | 
|---|
| 1879 | #endif | 
|---|
| 1880 |  | 
|---|
| 1881 | //********************************************************************** | 
|---|
| 1882 | // End of IMetaDataTables. | 
|---|
| 1883 | //********************************************************************** | 
|---|
| 1884 |  | 
|---|
| 1885 | //------------------------------------- | 
|---|
| 1886 | //--- IMetaDataInfo | 
|---|
| 1887 | //------------------------------------- | 
|---|
| 1888 | // {7998EA64-7F95-48B8-86FC-17CAF48BF5CB} | 
|---|
| 1889 | EXTERN_GUID(IID_IMetaDataInfo, 0x7998EA64, 0x7F95, 0x48B8, 0x86, 0xFC, 0x17, 0xCA, 0xF4, 0x8B, 0xF5, 0xCB); | 
|---|
| 1890 |  | 
|---|
| 1891 | //--- | 
|---|
| 1892 | #undef  INTERFACE | 
|---|
| 1893 | #define INTERFACE IMetaDataInfo | 
|---|
| 1894 | DECLARE_INTERFACE_(IMetaDataInfo, IUnknown) | 
|---|
| 1895 | { | 
|---|
| 1896 | // Return Values: | 
|---|
| 1897 | //   S_OK               - All parameters are filled. | 
|---|
| 1898 | //   COR_E_NOTSUPPORTED - The API is not supported for this particular scope (e.g. .obj files, scope | 
|---|
| 1899 | //                        opened without whole file via code:IMetaDataDispenser::OpenScopeOnMemory, etc.). | 
|---|
| 1900 | //   E_INVALIDARG       - If NULL is passed as parameter. | 
|---|
| 1901 | STDMETHOD(GetFileMapping)( | 
|---|
| 1902 | const void ** ppvData,              // [out] Pointer to the start of the mapped file. | 
|---|
| 1903 | ULONGLONG *   pcbData,              // [out] Size of the mapped memory region. | 
|---|
| 1904 | DWORD *       pdwMappingType) PURE; // [out] Type of file mapping (code:CorFileMapping). | 
|---|
| 1905 | };  // class IMetaDataInfo | 
|---|
| 1906 |  | 
|---|
| 1907 |  | 
|---|
| 1908 | //------------------------------------- | 
|---|
| 1909 | //--- IMetaDataWinMDImport | 
|---|
| 1910 | //------------------------------------- | 
|---|
| 1911 | // {969EA0C5-964E-411B-A807-B0F3C2DFCBD4} | 
|---|
| 1912 | EXTERN_GUID(IID_IMetaDataWinMDImport, 0x969ea0c5, 0x964e, 0x411b, 0xa8, 0x7, 0xb0, 0xf3, 0xc2, 0xdf, 0xcb, 0xd4); | 
|---|
| 1913 |  | 
|---|
| 1914 | //--- | 
|---|
| 1915 | #undef  INTERFACE | 
|---|
| 1916 | #define INTERFACE IMetaDataWinMDImport | 
|---|
| 1917 | DECLARE_INTERFACE_(IMetaDataWinMDImport, IUnknown) | 
|---|
| 1918 | { | 
|---|
| 1919 | STDMETHOD(GetUntransformedTypeRefProps)( // S_OK or error. | 
|---|
| 1920 | mdTypeRef   tr,                         // [IN] TypeRef token. | 
|---|
| 1921 | mdToken     *ptkResolutionScope,        // [OUT] Resolution scope, ModuleRef or AssemblyRef. | 
|---|
| 1922 | _Out_writes_to_opt_(cchName, *pchName) | 
|---|
| 1923 | LPWSTR      szName,                     // [OUT] Name of the TypeRef. | 
|---|
| 1924 | ULONG       cchName,                    // [IN] Size of buffer. | 
|---|
| 1925 | ULONG       *pchName) PURE;             // [OUT] Size of Name. | 
|---|
| 1926 | };  // class IMetaDataWinMDImport | 
|---|
| 1927 |  | 
|---|
| 1928 | //********************************************************************** | 
|---|
| 1929 | // | 
|---|
| 1930 | // Predefined CustomAttribute and structures for these custom value | 
|---|
| 1931 | // | 
|---|
| 1932 | //********************************************************************** | 
|---|
| 1933 |  | 
|---|
| 1934 | // | 
|---|
| 1935 | // Native Link method custom value definitions. This is for N-direct support. | 
|---|
| 1936 | // | 
|---|
| 1937 |  | 
|---|
| 1938 | #define COR_NATIVE_LINK_CUSTOM_VALUE        L"COMPLUS_NativeLink" | 
|---|
| 1939 | #define COR_NATIVE_LINK_CUSTOM_VALUE_ANSI   "COMPLUS_NativeLink" | 
|---|
| 1940 |  | 
|---|
| 1941 | // count of chars for COR_NATIVE_LINK_CUSTOM_VALUE(_ANSI) | 
|---|
| 1942 | #define COR_NATIVE_LINK_CUSTOM_VALUE_CC     18 | 
|---|
| 1943 |  | 
|---|
| 1944 | #include <pshpack1.h> | 
|---|
| 1945 | typedef struct | 
|---|
| 1946 | { | 
|---|
| 1947 | BYTE        m_linkType;       // see CorNativeLinkType below | 
|---|
| 1948 | BYTE        m_flags;          // see CorNativeLinkFlags below | 
|---|
| 1949 | mdMemberRef m_entryPoint;     // member ref token giving entry point, format is lib:entrypoint | 
|---|
| 1950 | } COR_NATIVE_LINK; | 
|---|
| 1951 | #include <poppack.h> | 
|---|
| 1952 |  | 
|---|
| 1953 | typedef enum | 
|---|
| 1954 | { | 
|---|
| 1955 | nltNone         = 1,    // none of the keywords are specified | 
|---|
| 1956 | nltAnsi         = 2,    // ansi keyword specified | 
|---|
| 1957 | nltUnicode      = 3,    // unicode keyword specified | 
|---|
| 1958 | nltAuto         = 4,    // auto keyword specified | 
|---|
| 1959 | nltMaxValue     = 7,    // used so we can assert how many bits are required for this enum | 
|---|
| 1960 | } CorNativeLinkType; | 
|---|
| 1961 |  | 
|---|
| 1962 | typedef enum | 
|---|
| 1963 | { | 
|---|
| 1964 | nlfNone         = 0x00,     // no flags | 
|---|
| 1965 | nlfLastError    = 0x01,     // setLastError keyword specified | 
|---|
| 1966 | nlfNoMangle     = 0x02,     // nomangle keyword specified | 
|---|
| 1967 | nlfMaxValue     = 0x03,     // used so we can assert how many bits are required for this enum | 
|---|
| 1968 | } CorNativeLinkFlags; | 
|---|
| 1969 |  | 
|---|
| 1970 | // | 
|---|
| 1971 | // Base class for security custom attributes. | 
|---|
| 1972 | // | 
|---|
| 1973 |  | 
|---|
| 1974 | #define COR_BASE_SECURITY_ATTRIBUTE_CLASS L"System.Security.Permissions.SecurityAttribute" | 
|---|
| 1975 | #define COR_BASE_SECURITY_ATTRIBUTE_CLASS_ANSI "System.Security.Permissions.SecurityAttribute" | 
|---|
| 1976 |  | 
|---|
| 1977 | // | 
|---|
| 1978 | // Name of custom attribute used to indicate that per-call security checks should | 
|---|
| 1979 | // be disabled for P/Invoke calls. | 
|---|
| 1980 | // | 
|---|
| 1981 |  | 
|---|
| 1982 | #define COR_SUPPRESS_UNMANAGED_CODE_CHECK_ATTRIBUTE L"System.Security.SuppressUnmanagedCodeSecurityAttribute" | 
|---|
| 1983 | #define COR_SUPPRESS_UNMANAGED_CODE_CHECK_ATTRIBUTE_ANSI "System.Security.SuppressUnmanagedCodeSecurityAttribute" | 
|---|
| 1984 |  | 
|---|
| 1985 | // | 
|---|
| 1986 | // Name of custom attribute tagged on module to indicate it contains | 
|---|
| 1987 | // unverifiable code. | 
|---|
| 1988 | // | 
|---|
| 1989 |  | 
|---|
| 1990 | #define COR_UNVER_CODE_ATTRIBUTE L"System.Security.UnverifiableCodeAttribute" | 
|---|
| 1991 | #define COR_UNVER_CODE_ATTRIBUTE_ANSI "System.Security.UnverifiableCodeAttribute" | 
|---|
| 1992 |  | 
|---|
| 1993 | // | 
|---|
| 1994 | // Name of custom attribute indicating that a method requires a security object | 
|---|
| 1995 | // slot on the caller's stack. | 
|---|
| 1996 | // | 
|---|
| 1997 |  | 
|---|
| 1998 | #define COR_REQUIRES_SECOBJ_ATTRIBUTE W("System.Security.DynamicSecurityMethodAttribute") | 
|---|
| 1999 | #define COR_REQUIRES_SECOBJ_ATTRIBUTE_ANSI "System.Security.DynamicSecurityMethodAttribute" | 
|---|
| 2000 |  | 
|---|
| 2001 | #define COR_COMPILERSERVICE_DISCARDABLEATTRIBUTE L"System.Runtime.CompilerServices.DiscardableAttribute" | 
|---|
| 2002 | #define COR_COMPILERSERVICE_DISCARDABLEATTRIBUTE_ASNI "System.Runtime.CompilerServices.DiscardableAttribute" | 
|---|
| 2003 |  | 
|---|
| 2004 |  | 
|---|
| 2005 | #ifdef __cplusplus | 
|---|
| 2006 | } | 
|---|
| 2007 |  | 
|---|
| 2008 | //***************************************************************************** | 
|---|
| 2009 | //***************************************************************************** | 
|---|
| 2010 | // | 
|---|
| 2011 | // C O M +   s i g n a t u r e   s u p p o r t | 
|---|
| 2012 | // | 
|---|
| 2013 | //***************************************************************************** | 
|---|
| 2014 | //***************************************************************************** | 
|---|
| 2015 |  | 
|---|
| 2016 | #ifndef FORCEINLINE | 
|---|
| 2017 | #if _MSC_VER < 1200 | 
|---|
| 2018 | #define FORCEINLINE inline | 
|---|
| 2019 | #else | 
|---|
| 2020 | #define FORCEINLINE __forceinline | 
|---|
| 2021 | #endif | 
|---|
| 2022 | #endif | 
|---|
| 2023 |  | 
|---|
| 2024 |  | 
|---|
| 2025 | // We need a version that is FORCEINLINE on retail and NOINLINE on debug | 
|---|
| 2026 |  | 
|---|
| 2027 | #ifndef DEBUG_NOINLINE | 
|---|
| 2028 | #if defined(_DEBUG) | 
|---|
| 2029 | #define DEBUG_NOINLINE __declspec(noinline) | 
|---|
| 2030 | #else | 
|---|
| 2031 | #define DEBUG_NOINLINE | 
|---|
| 2032 | #endif | 
|---|
| 2033 | #endif | 
|---|
| 2034 |  | 
|---|
| 2035 | #ifndef DBG_NOINLINE_X86__RET_INLINE | 
|---|
| 2036 | #if defined(_DEBUG) && defined(_X86_) | 
|---|
| 2037 | #define DBG_NOINLINE_X86__RET_INLINE __declspec(noinline) | 
|---|
| 2038 | #else | 
|---|
| 2039 | #define DBG_NOINLINE_X86__RET_INLINE FORCEINLINE | 
|---|
| 2040 | #endif | 
|---|
| 2041 | #endif | 
|---|
| 2042 |  | 
|---|
| 2043 | #ifndef NOINLINE | 
|---|
| 2044 | #ifdef _MSC_VER | 
|---|
| 2045 | #define NOINLINE __declspec(noinline) | 
|---|
| 2046 | #elif defined __GNUC__ | 
|---|
| 2047 | #define NOINLINE __attribute__ ((noinline)) | 
|---|
| 2048 | #else | 
|---|
| 2049 | #define NOINLINE | 
|---|
| 2050 | #endif | 
|---|
| 2051 | #endif // !NOINLINE | 
|---|
| 2052 |  | 
|---|
| 2053 | // return true if it is a primitive type, i.e. only need to store CorElementType | 
|---|
| 2054 | FORCEINLINE int CorIsPrimitiveType(CorElementType elementtype) | 
|---|
| 2055 | { | 
|---|
| 2056 | return (elementtype < ELEMENT_TYPE_PTR || elementtype == ELEMENT_TYPE_I || elementtype == ELEMENT_TYPE_U); | 
|---|
| 2057 | } | 
|---|
| 2058 |  | 
|---|
| 2059 |  | 
|---|
| 2060 | // Return true if element type is a modifier, i.e. ELEMENT_TYPE_MODIFIER bits are | 
|---|
| 2061 | // turned on. For now, it is checking for ELEMENT_TYPE_PTR and ELEMENT_TYPE_BYREF | 
|---|
| 2062 | // as well. This will be removed when we turn on ELEMENT_TYPE_MODIFIER bits for | 
|---|
| 2063 | // these two enum members. | 
|---|
| 2064 | // | 
|---|
| 2065 | FORCEINLINE int CorIsModifierElementType(CorElementType elementtype) | 
|---|
| 2066 | { | 
|---|
| 2067 | if (elementtype == ELEMENT_TYPE_PTR || elementtype == ELEMENT_TYPE_BYREF) | 
|---|
| 2068 | return 1; | 
|---|
| 2069 | return  (elementtype & ELEMENT_TYPE_MODIFIER); | 
|---|
| 2070 | } | 
|---|
| 2071 |  | 
|---|
| 2072 | // Given a compress byte (*pData), return the size of the uncompressed data. | 
|---|
| 2073 | inline ULONG CorSigUncompressedDataSize( | 
|---|
| 2074 | PCCOR_SIGNATURE pData) | 
|---|
| 2075 | { | 
|---|
| 2076 | if ((*pData & 0x80) == 0) | 
|---|
| 2077 | return 1; | 
|---|
| 2078 | else if ((*pData & 0xC0) == 0x80) | 
|---|
| 2079 | return 2; | 
|---|
| 2080 | else | 
|---|
| 2081 | return 4; | 
|---|
| 2082 | } | 
|---|
| 2083 |  | 
|---|
| 2084 | ///////////////////////////////////////////////////////////////////////////////////////////// | 
|---|
| 2085 | // | 
|---|
| 2086 | // Given a compressed integer(*pData), expand the compressed int to *pDataOut. | 
|---|
| 2087 | // Return value is the number of bytes that the integer occupies in the compressed format | 
|---|
| 2088 | // It is caller's responsibility to ensure pDataOut has at least 4 bytes to be written to. | 
|---|
| 2089 | // | 
|---|
| 2090 | // This function returns -1 if pass in with an incorrectly compressed data, such as | 
|---|
| 2091 | // (*pBytes & 0xE0) == 0XE0. | 
|---|
| 2092 | ///////////////////////////////////////////////////////////////////////////////////////////// | 
|---|
| 2093 | inline ULONG CorSigUncompressBigData( | 
|---|
| 2094 | PCCOR_SIGNATURE & pData)    // [IN,OUT] compressed data | 
|---|
| 2095 | { | 
|---|
| 2096 | ULONG res; | 
|---|
| 2097 |  | 
|---|
| 2098 | // 1 byte data is handled in CorSigUncompressData | 
|---|
| 2099 | //  _ASSERTE(*pData & 0x80); | 
|---|
| 2100 |  | 
|---|
| 2101 | // Medium. | 
|---|
| 2102 | if ((*pData & 0xC0) == 0x80)  // 10?? ???? | 
|---|
| 2103 | { | 
|---|
| 2104 | res = (ULONG)((*pData++ & 0x3f) << 8); | 
|---|
| 2105 | res |= *pData++; | 
|---|
| 2106 | } | 
|---|
| 2107 | else // 110? ???? | 
|---|
| 2108 | { | 
|---|
| 2109 | res = (*pData++ & 0x1f) << 24; | 
|---|
| 2110 | res |= *pData++ << 16; | 
|---|
| 2111 | res |= *pData++ << 8; | 
|---|
| 2112 | res |= *pData++; | 
|---|
| 2113 | } | 
|---|
| 2114 | return res; | 
|---|
| 2115 | } | 
|---|
| 2116 | FORCEINLINE ULONG CorSigUncompressData( | 
|---|
| 2117 | PCCOR_SIGNATURE & pData)    // [IN,OUT] compressed data | 
|---|
| 2118 | { | 
|---|
| 2119 | // Handle smallest data inline. | 
|---|
| 2120 | if ((*pData & 0x80) == 0x00)        // 0??? ???? | 
|---|
| 2121 | return *pData++; | 
|---|
| 2122 | return CorSigUncompressBigData(pData); | 
|---|
| 2123 | } | 
|---|
| 2124 |  | 
|---|
| 2125 | inline HRESULT CorSigUncompressData(// return S_OK or E_BADIMAGEFORMAT if the signature is bad | 
|---|
| 2126 | PCCOR_SIGNATURE pData,          // [IN] compressed data | 
|---|
| 2127 | DWORD           len,            // [IN] length of the signature | 
|---|
| 2128 | ULONG *         pDataOut,       // [OUT] the expanded *pData | 
|---|
| 2129 | ULONG *         pDataLen)       // [OUT] length of the expanded *pData | 
|---|
| 2130 | { | 
|---|
| 2131 | HRESULT hr = S_OK; | 
|---|
| 2132 | BYTE const  *pBytes = reinterpret_cast<BYTE const*>(pData); | 
|---|
| 2133 |  | 
|---|
| 2134 | // Smallest. | 
|---|
| 2135 | if ((*pBytes & 0x80) == 0x00)       // 0??? ???? | 
|---|
| 2136 | { | 
|---|
| 2137 | if (len < 1) | 
|---|
| 2138 | { | 
|---|
| 2139 | *pDataOut = 0; | 
|---|
| 2140 | *pDataLen = 0; | 
|---|
| 2141 | hr = META_E_BAD_SIGNATURE; | 
|---|
| 2142 | } | 
|---|
| 2143 | else | 
|---|
| 2144 | { | 
|---|
| 2145 | *pDataOut = *pBytes; | 
|---|
| 2146 | *pDataLen = 1; | 
|---|
| 2147 | } | 
|---|
| 2148 | } | 
|---|
| 2149 | // Medium. | 
|---|
| 2150 | else if ((*pBytes & 0xC0) == 0x80)  // 10?? ???? | 
|---|
| 2151 | { | 
|---|
| 2152 | if (len < 2) | 
|---|
| 2153 | { | 
|---|
| 2154 | *pDataOut = 0; | 
|---|
| 2155 | *pDataLen = 0; | 
|---|
| 2156 | hr = META_E_BAD_SIGNATURE; | 
|---|
| 2157 | } | 
|---|
| 2158 | else | 
|---|
| 2159 | { | 
|---|
| 2160 | *pDataOut = (ULONG)(((*pBytes & 0x3f) << 8 | *(pBytes+1))); | 
|---|
| 2161 | *pDataLen = 2; | 
|---|
| 2162 | } | 
|---|
| 2163 | } | 
|---|
| 2164 | else if ((*pBytes & 0xE0) == 0xC0)      // 110? ???? | 
|---|
| 2165 | { | 
|---|
| 2166 | if (len < 4) | 
|---|
| 2167 | { | 
|---|
| 2168 | *pDataOut = 0; | 
|---|
| 2169 | *pDataLen = 0; | 
|---|
| 2170 | hr = META_E_BAD_SIGNATURE; | 
|---|
| 2171 | } | 
|---|
| 2172 | else | 
|---|
| 2173 | { | 
|---|
| 2174 | *pDataOut = (ULONG)(((*pBytes & 0x1f) << 24 | *(pBytes+1) << 16 | *(pBytes+2) << 8 | *(pBytes+3))); | 
|---|
| 2175 | *pDataLen = 4; | 
|---|
| 2176 | } | 
|---|
| 2177 | } | 
|---|
| 2178 | else // We don't recognize this encoding | 
|---|
| 2179 | { | 
|---|
| 2180 | *pDataOut = 0; | 
|---|
| 2181 | *pDataLen = 0; | 
|---|
| 2182 | hr = META_E_BAD_SIGNATURE; | 
|---|
| 2183 | } | 
|---|
| 2184 |  | 
|---|
| 2185 | return hr; | 
|---|
| 2186 | } | 
|---|
| 2187 |  | 
|---|
| 2188 | inline ULONG CorSigUncompressData(      // return number of bytes of that compressed data occupied in pData | 
|---|
| 2189 | PCCOR_SIGNATURE pData,              // [IN] compressed data | 
|---|
| 2190 | ULONG       *pDataOut)              // [OUT] the expanded *pData | 
|---|
| 2191 | { | 
|---|
| 2192 | ULONG dwSizeOfData = 0; | 
|---|
| 2193 |  | 
|---|
| 2194 | // We don't know how big the signature is, so we'll just say that it's big enough | 
|---|
| 2195 | if (FAILED(CorSigUncompressData(pData, 0xff, pDataOut, &dwSizeOfData))) | 
|---|
| 2196 | { | 
|---|
| 2197 | *pDataOut = 0; | 
|---|
| 2198 | return (ULONG)-1; | 
|---|
| 2199 | } | 
|---|
| 2200 |  | 
|---|
| 2201 | return dwSizeOfData; | 
|---|
| 2202 | } | 
|---|
| 2203 |  | 
|---|
| 2204 |  | 
|---|
| 2205 | #if !defined(SELECTANY) | 
|---|
| 2206 | #define SELECTANY extern __declspec(selectany) | 
|---|
| 2207 | #endif | 
|---|
| 2208 |  | 
|---|
| 2209 | SELECTANY const mdToken g_tkCorEncodeToken[4] ={mdtTypeDef, mdtTypeRef, mdtTypeSpec, mdtBaseType}; | 
|---|
| 2210 |  | 
|---|
| 2211 | // uncompress a token | 
|---|
| 2212 | inline mdToken CorSigUncompressToken(   // return the token. | 
|---|
| 2213 | PCCOR_SIGNATURE &pData)             // [IN,OUT] compressed data | 
|---|
| 2214 | { | 
|---|
| 2215 | mdToken tk; | 
|---|
| 2216 | mdToken tkType; | 
|---|
| 2217 |  | 
|---|
| 2218 | tk = CorSigUncompressData(pData); | 
|---|
| 2219 | tkType = g_tkCorEncodeToken[tk & 0x3]; | 
|---|
| 2220 | tk = TokenFromRid(tk >> 2, tkType); | 
|---|
| 2221 | return tk; | 
|---|
| 2222 | } | 
|---|
| 2223 |  | 
|---|
| 2224 |  | 
|---|
| 2225 | inline ULONG CorSigUncompressToken( // return number of bytes of that compressed data occupied in pData | 
|---|
| 2226 | PCCOR_SIGNATURE pData,          // [IN] compressed data | 
|---|
| 2227 | mdToken *       pToken)         // [OUT] the expanded *pData | 
|---|
| 2228 | { | 
|---|
| 2229 | ULONG   cb; | 
|---|
| 2230 | mdToken tk; | 
|---|
| 2231 | mdToken tkType; | 
|---|
| 2232 |  | 
|---|
| 2233 | cb = CorSigUncompressData(pData, (ULONG *)&tk); | 
|---|
| 2234 | tkType = g_tkCorEncodeToken[tk & 0x3]; | 
|---|
| 2235 | tk = TokenFromRid(tk >> 2, tkType); | 
|---|
| 2236 | *pToken = tk; | 
|---|
| 2237 | return cb; | 
|---|
| 2238 | } | 
|---|
| 2239 |  | 
|---|
| 2240 | inline HRESULT CorSigUncompressToken( | 
|---|
| 2241 | PCCOR_SIGNATURE pData,          // [IN] compressed data | 
|---|
| 2242 | DWORD           dwLen,          // [IN] Remaining length of sigature | 
|---|
| 2243 | mdToken *       pToken,         // [OUT] the expanded *pData | 
|---|
| 2244 | DWORD *         dwTokenLength)  // [OUT] The length of the token in the sigature | 
|---|
| 2245 | { | 
|---|
| 2246 | mdToken tk; | 
|---|
| 2247 | mdToken tkType; | 
|---|
| 2248 |  | 
|---|
| 2249 | HRESULT hr = CorSigUncompressData(pData, dwLen, (ULONG *)&tk, dwTokenLength); | 
|---|
| 2250 |  | 
|---|
| 2251 | if (SUCCEEDED(hr)) | 
|---|
| 2252 | { | 
|---|
| 2253 | tkType = g_tkCorEncodeToken[tk & 0x3]; | 
|---|
| 2254 | tk = TokenFromRid(tk >> 2, tkType); | 
|---|
| 2255 | *pToken = tk; | 
|---|
| 2256 | } | 
|---|
| 2257 | else | 
|---|
| 2258 | { | 
|---|
| 2259 | *pToken = mdTokenNil; | 
|---|
| 2260 | } | 
|---|
| 2261 | return hr; | 
|---|
| 2262 | } | 
|---|
| 2263 |  | 
|---|
| 2264 |  | 
|---|
| 2265 |  | 
|---|
| 2266 | FORCEINLINE ULONG CorSigUncompressCallingConv( | 
|---|
| 2267 | PCCOR_SIGNATURE & pData)    // [IN,OUT] Compressed data | 
|---|
| 2268 | { | 
|---|
| 2269 | return *pData++; | 
|---|
| 2270 | } | 
|---|
| 2271 |  | 
|---|
| 2272 | FORCEINLINE HRESULT CorSigUncompressCallingConv( | 
|---|
| 2273 | PCCOR_SIGNATURE pData,      // [IN] Signature | 
|---|
| 2274 | DWORD           dwLen,      // [IN] Length of signature | 
|---|
| 2275 | ULONG *         data)       // [OUT] Compressed data | 
|---|
| 2276 | { | 
|---|
| 2277 | if (dwLen > 0) | 
|---|
| 2278 | { | 
|---|
| 2279 | *data = *pData; | 
|---|
| 2280 | return S_OK; | 
|---|
| 2281 | } | 
|---|
| 2282 | else | 
|---|
| 2283 | { | 
|---|
| 2284 | *data = 0; | 
|---|
| 2285 | return META_E_BAD_SIGNATURE; | 
|---|
| 2286 | } | 
|---|
| 2287 | } | 
|---|
| 2288 |  | 
|---|
| 2289 |  | 
|---|
| 2290 | enum { | 
|---|
| 2291 | SIGN_MASK_ONEBYTE  = 0xffffffc0,        // Mask the same size as the missing bits. | 
|---|
| 2292 | SIGN_MASK_TWOBYTE  = 0xffffe000,        // Mask the same size as the missing bits. | 
|---|
| 2293 | SIGN_MASK_FOURBYTE = 0xf0000000,        // Mask the same size as the missing bits. | 
|---|
| 2294 | }; | 
|---|
| 2295 |  | 
|---|
| 2296 | // uncompress a signed integer | 
|---|
| 2297 | inline ULONG CorSigUncompressSignedInt( // return number of bytes of that compressed data occupied in pData | 
|---|
| 2298 | PCCOR_SIGNATURE pData,              // [IN] compressed data | 
|---|
| 2299 | int *           pInt)               // [OUT] the expanded *pInt | 
|---|
| 2300 | { | 
|---|
| 2301 | ULONG cb; | 
|---|
| 2302 | ULONG ulSigned; | 
|---|
| 2303 | ULONG iData; | 
|---|
| 2304 |  | 
|---|
| 2305 | cb = CorSigUncompressData(pData, &iData); | 
|---|
| 2306 | if (cb == (ULONG) -1) return cb; | 
|---|
| 2307 | ulSigned = iData & 0x1; | 
|---|
| 2308 | iData = iData >> 1; | 
|---|
| 2309 | if (ulSigned) | 
|---|
| 2310 | { | 
|---|
| 2311 | if (cb == 1) | 
|---|
| 2312 | { | 
|---|
| 2313 | iData |= SIGN_MASK_ONEBYTE; | 
|---|
| 2314 | } | 
|---|
| 2315 | else if (cb == 2) | 
|---|
| 2316 | { | 
|---|
| 2317 | iData |= SIGN_MASK_TWOBYTE; | 
|---|
| 2318 | } | 
|---|
| 2319 | else | 
|---|
| 2320 | { | 
|---|
| 2321 | iData |= SIGN_MASK_FOURBYTE; | 
|---|
| 2322 | } | 
|---|
| 2323 | } | 
|---|
| 2324 | *pInt = (int)iData; | 
|---|
| 2325 | return cb; | 
|---|
| 2326 | } | 
|---|
| 2327 |  | 
|---|
| 2328 |  | 
|---|
| 2329 | // uncompress encoded element type | 
|---|
| 2330 | FORCEINLINE CorElementType CorSigUncompressElementType( // Element type | 
|---|
| 2331 | PCCOR_SIGNATURE & pData)                            // [IN,OUT] Compressed data | 
|---|
| 2332 | { | 
|---|
| 2333 | return (CorElementType)*pData++; | 
|---|
| 2334 | } | 
|---|
| 2335 |  | 
|---|
| 2336 | inline ULONG CorSigUncompressElementType(   // Return number of bytes of that compressed data occupied in pData | 
|---|
| 2337 | PCCOR_SIGNATURE  pData,                 // [IN] Compressed data | 
|---|
| 2338 | CorElementType * pElementType)          // [OUT] The expanded *pData | 
|---|
| 2339 | { | 
|---|
| 2340 | *pElementType = (CorElementType)(*pData & 0x7f); | 
|---|
| 2341 | return 1; | 
|---|
| 2342 | } | 
|---|
| 2343 |  | 
|---|
| 2344 |  | 
|---|
| 2345 | ///////////////////////////////////////////////////////////////////////////////////////////// | 
|---|
| 2346 | // | 
|---|
| 2347 | // Given an uncompressed unsigned integer (iLen), Store it to pDataOut in a compressed format. | 
|---|
| 2348 | // Return value is the number of bytes that the integer occupies in the compressed format. | 
|---|
| 2349 | // It is caller's responsibilityt to ensure *pDataOut has at least 4 bytes to write to. | 
|---|
| 2350 | // | 
|---|
| 2351 | // Note that this function returns -1 if iLen is too big to be compressed. We currently can | 
|---|
| 2352 | // only represent to 0x1FFFFFFF. | 
|---|
| 2353 | // | 
|---|
| 2354 | ///////////////////////////////////////////////////////////////////////////////////////////// | 
|---|
| 2355 | inline ULONG CorSigCompressData(    // return number of bytes that compressed form of iLen will take | 
|---|
| 2356 | ULONG  iLen,                    // [IN] given uncompressed data | 
|---|
| 2357 | void * pDataOut)                // [OUT] buffer where iLen will be compressed and stored. | 
|---|
| 2358 | { | 
|---|
| 2359 | BYTE *pBytes = reinterpret_cast<BYTE *>(pDataOut); | 
|---|
| 2360 |  | 
|---|
| 2361 | if (iLen <= 0x7F) | 
|---|
| 2362 | { | 
|---|
| 2363 | *pBytes = BYTE(iLen); | 
|---|
| 2364 | return 1; | 
|---|
| 2365 | } | 
|---|
| 2366 |  | 
|---|
| 2367 | if (iLen <= 0x3FFF) | 
|---|
| 2368 | { | 
|---|
| 2369 | *pBytes     = BYTE((iLen >> 8) | 0x80); | 
|---|
| 2370 | *(pBytes+1) = BYTE(iLen & 0xff); | 
|---|
| 2371 | return 2; | 
|---|
| 2372 | } | 
|---|
| 2373 |  | 
|---|
| 2374 | if (iLen <= 0x1FFFFFFF) | 
|---|
| 2375 | { | 
|---|
| 2376 | *pBytes     = BYTE((iLen >> 24) | 0xC0); | 
|---|
| 2377 | *(pBytes+1) = BYTE((iLen >> 16) & 0xff); | 
|---|
| 2378 | *(pBytes+2) = BYTE((iLen >> 8)  & 0xff); | 
|---|
| 2379 | *(pBytes+3) = BYTE(iLen & 0xff); | 
|---|
| 2380 | return 4; | 
|---|
| 2381 | } | 
|---|
| 2382 | return (ULONG) -1; | 
|---|
| 2383 | } | 
|---|
| 2384 |  | 
|---|
| 2385 | // compress a token | 
|---|
| 2386 | // The least significant bit of the first compress byte will indicate the token type. | 
|---|
| 2387 | // | 
|---|
| 2388 | inline ULONG CorSigCompressToken(   // return number of bytes that compressed form of the token will take | 
|---|
| 2389 | mdToken  tk,                    // [IN] given token | 
|---|
| 2390 | void *   pDataOut)              // [OUT] buffer where the token will be compressed and stored. | 
|---|
| 2391 | { | 
|---|
| 2392 | RID     rid = RidFromToken(tk); | 
|---|
| 2393 | ULONG32 ulTyp = TypeFromToken(tk); | 
|---|
| 2394 |  | 
|---|
| 2395 | if (rid > 0x3FFFFFF) | 
|---|
| 2396 | // token is too big to be compressed | 
|---|
| 2397 | return (ULONG) -1; | 
|---|
| 2398 |  | 
|---|
| 2399 | rid = (rid << 2); | 
|---|
| 2400 |  | 
|---|
| 2401 | // TypeDef is encoded with low bits 00 | 
|---|
| 2402 | // TypeRef is encoded with low bits 01 | 
|---|
| 2403 | // TypeSpec is encoded with low bits 10 | 
|---|
| 2404 | // BaseType is encoded with low bit 11 | 
|---|
| 2405 | // | 
|---|
| 2406 | if (ulTyp == g_tkCorEncodeToken[1]) | 
|---|
| 2407 | { | 
|---|
| 2408 | // make the last two bits 01 | 
|---|
| 2409 | rid |= 0x1; | 
|---|
| 2410 | } | 
|---|
| 2411 | else if (ulTyp == g_tkCorEncodeToken[2]) | 
|---|
| 2412 | { | 
|---|
| 2413 | // make last two bits 0 | 
|---|
| 2414 | rid |= 0x2; | 
|---|
| 2415 | } | 
|---|
| 2416 | else if (ulTyp == g_tkCorEncodeToken[3]) | 
|---|
| 2417 | { | 
|---|
| 2418 | rid |= 0x3; | 
|---|
| 2419 | } | 
|---|
| 2420 | return CorSigCompressData((ULONG)rid, pDataOut); | 
|---|
| 2421 | } | 
|---|
| 2422 |  | 
|---|
| 2423 | // compress a signed integer | 
|---|
| 2424 | // The least significant bit of the first compress byte will be the signed bit. | 
|---|
| 2425 | // | 
|---|
| 2426 | inline ULONG CorSigCompressSignedInt(   // return number of bytes that compressed form of iData will take | 
|---|
| 2427 | int    iData,                       // [IN] given integer | 
|---|
| 2428 | void * pDataOut)                    // [OUT] buffer where iLen will be compressed and stored. | 
|---|
| 2429 | { | 
|---|
| 2430 | ULONG isSigned = 0; | 
|---|
| 2431 | BYTE *pBytes = reinterpret_cast<BYTE *>(pDataOut); | 
|---|
| 2432 |  | 
|---|
| 2433 | if (iData < 0) | 
|---|
| 2434 | isSigned = 0x1; | 
|---|
| 2435 |  | 
|---|
| 2436 | // Note that we cannot use code:CorSigCompressData to pack the iData value, because of negative values | 
|---|
| 2437 | // like: 0xffffe000 (-8192) which has to be encoded as 1 in 2 bytes, i.e. 0x81 0x00 | 
|---|
| 2438 | // However CorSigCompressedData would store value 1 as 1 byte: 0x01 | 
|---|
| 2439 | if ((iData & SIGN_MASK_ONEBYTE) == 0 || (iData & SIGN_MASK_ONEBYTE) == SIGN_MASK_ONEBYTE) | 
|---|
| 2440 | { | 
|---|
| 2441 | iData = (int)((iData & ~SIGN_MASK_ONEBYTE) << 1 | isSigned); | 
|---|
| 2442 | //_ASSERTE(iData <= 0x7f); | 
|---|
| 2443 | *pBytes = BYTE(iData); | 
|---|
| 2444 | return 1; | 
|---|
| 2445 | } | 
|---|
| 2446 | else if ((iData & SIGN_MASK_TWOBYTE) == 0 || (iData & SIGN_MASK_TWOBYTE) == SIGN_MASK_TWOBYTE) | 
|---|
| 2447 | { | 
|---|
| 2448 | iData = (int)((iData & ~SIGN_MASK_TWOBYTE) << 1 | isSigned); | 
|---|
| 2449 | //_ASSERTE(iData <= 0x3fff); | 
|---|
| 2450 | *pBytes       = BYTE((iData >> 8) | 0x80); | 
|---|
| 2451 | *(pBytes + 1) = BYTE(iData & 0xff); | 
|---|
| 2452 | return 2; | 
|---|
| 2453 | } | 
|---|
| 2454 | else if ((iData & SIGN_MASK_FOURBYTE) == 0 || (iData & SIGN_MASK_FOURBYTE) == SIGN_MASK_FOURBYTE) | 
|---|
| 2455 | { | 
|---|
| 2456 | iData = (int)((iData & ~SIGN_MASK_FOURBYTE) << 1 | isSigned); | 
|---|
| 2457 | //_ASSERTE(iData <= 0x1FFFFFFF); | 
|---|
| 2458 | *pBytes       = BYTE((iData >> 24) | 0xC0); | 
|---|
| 2459 | *(pBytes + 1) = BYTE((iData >> 16) & 0xff); | 
|---|
| 2460 | *(pBytes + 2) = BYTE((iData >> 8)  & 0xff); | 
|---|
| 2461 | *(pBytes + 3) = BYTE(iData & 0xff); | 
|---|
| 2462 | return 4; | 
|---|
| 2463 | } | 
|---|
| 2464 | // Out of compressable range | 
|---|
| 2465 | return (ULONG)-1; | 
|---|
| 2466 | } // CorSigCompressSignedInt | 
|---|
| 2467 |  | 
|---|
| 2468 |  | 
|---|
| 2469 | // uncompress encoded element type | 
|---|
| 2470 | inline ULONG CorSigCompressElementType( // return number of bytes of that compressed data occupied in pData | 
|---|
| 2471 | CorElementType et,                  // [OUT] the expanded *pData | 
|---|
| 2472 | void *         pData)               // [IN] compressed data | 
|---|
| 2473 | { | 
|---|
| 2474 | BYTE *pBytes = (BYTE *)(pData); | 
|---|
| 2475 |  | 
|---|
| 2476 | *pBytes = BYTE(et); | 
|---|
| 2477 | return 1; | 
|---|
| 2478 | } | 
|---|
| 2479 |  | 
|---|
| 2480 | // Compress a pointer (used for internal element types only, never for persisted | 
|---|
| 2481 | // signatures). | 
|---|
| 2482 | inline ULONG CorSigCompressPointer( // return number of bytes of that compressed data occupied | 
|---|
| 2483 | void * pvPointer,               // [IN] given uncompressed data | 
|---|
| 2484 | void * pData)                   // [OUT] buffer where iLen will be compressed and stored. | 
|---|
| 2485 | { | 
|---|
| 2486 | *((void * UNALIGNED *)pData) = pvPointer; | 
|---|
| 2487 | return sizeof(void *); | 
|---|
| 2488 | } | 
|---|
| 2489 |  | 
|---|
| 2490 | // Uncompress a pointer (see above for comments). | 
|---|
| 2491 | inline ULONG CorSigUncompressPointer(   // return number of bytes of that compressed data occupied | 
|---|
| 2492 | PCCOR_SIGNATURE pData,              // [IN] compressed data | 
|---|
| 2493 | void **         ppvPointer)         // [OUT] the expanded *pData | 
|---|
| 2494 | { | 
|---|
| 2495 | *ppvPointer = *(void * const UNALIGNED *)pData; | 
|---|
| 2496 | return sizeof(void *); | 
|---|
| 2497 | } | 
|---|
| 2498 |  | 
|---|
| 2499 | #endif  // __cplusplus | 
|---|
| 2500 |  | 
|---|
| 2501 | #undef DEPRECATED_CLR_STDAPI_ | 
|---|
| 2502 | #undef DEPRECATED_CLR_STDAPI | 
|---|
| 2503 | #undef DECLARE_DEPRECATED | 
|---|
| 2504 | #undef DEPRECATED_CLR_API_MESG | 
|---|
| 2505 |  | 
|---|
| 2506 | #endif // _COR_H_ | 
|---|
| 2507 | // EOF ======================================================================= | 
|---|
| 2508 |  | 
|---|