|  | /* | 
|  | * NDR Types | 
|  | * | 
|  | * Copyright 2006 Robert Shearman (for CodeWeavers) | 
|  | * | 
|  | * This library is free software; you can redistribute it and/or | 
|  | * modify it under the terms of the GNU Lesser General Public | 
|  | * License as published by the Free Software Foundation; either | 
|  | * version 2.1 of the License, or (at your option) any later version. | 
|  | * | 
|  | * This library is distributed in the hope that it will be useful, | 
|  | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
|  | * Lesser General Public License for more details. | 
|  | * | 
|  | * You should have received a copy of the GNU Lesser General Public | 
|  | * License along with this library; if not, write to the Free Software | 
|  | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA | 
|  | */ | 
|  |  | 
|  | #ifndef __NDRTYPES_H__ | 
|  | #define __NDRTYPES_H__ | 
|  |  | 
|  | typedef struct | 
|  | { | 
|  | unsigned short MustSize : 1; /* 0x0001 - client interpreter MUST size this | 
|  | *  parameter, other parameters may be skipped, using the value in | 
|  | *  NDR_PROC_PARTIAL_OIF_HEADER::constant_client_buffer_size instead. */ | 
|  | unsigned short MustFree : 1; /* 0x0002 - server interpreter MUST size this | 
|  | *  parameter, other parameters may be skipped, using the value in | 
|  | *  NDR_PROC_PARTIAL_OIF_HEADER::constant_server_buffer_size instead. */ | 
|  | unsigned short IsPipe : 1; /* 0x0004 - The parameter is a pipe handle. See | 
|  | *  http://msdn.microsoft.com/library/default.asp?url=/library/en-us/rpc/rpc/pipes.asp | 
|  | *  for more information on pipes. */ | 
|  | unsigned short IsIn : 1; /* 0x0008 - The parameter is an input */ | 
|  | unsigned short IsOut : 1; /* 0x0010 - The parameter is an output */ | 
|  | unsigned short IsReturn : 1; /* 0x0020 - The parameter is to be returned */ | 
|  | unsigned short IsBasetype : 1; /* 0x0040 - The parameter is simple and has the | 
|  | *  format defined by NDR_PARAM_OIF_BASETYPE rather than by | 
|  | *  NDR_PARAM_OIF_OTHER. */ | 
|  | unsigned short IsByValue : 1; /* 0x0080 - Set for compound types being sent by | 
|  | *  value. Can be of type: structure, union, transmit_as, represent_as, | 
|  | *  wire_marshal and SAFEARRAY. */ | 
|  | unsigned short IsSimpleRef : 1; /* 0x0100 - parameter that is a reference | 
|  | *  pointer to anything other than another pointer, and which has no | 
|  | *  allocate attributes. */ | 
|  | unsigned short IsDontCallFreeInst : 1; /*  0x0200 - Used for some represent_as types | 
|  | *  for when the free instance routine should not be called. */ | 
|  | unsigned short SaveForAsyncFinish : 1; /* 0x0400 - Unknown */ | 
|  | unsigned short Unused : 2; | 
|  | unsigned short ServerAllocSize : 3; /* 0xe000 - If non-zero | 
|  | *  specifies the size of the object in numbers of 8byte blocks needed. | 
|  | *  It will be stored on the server's stack rather than using an allocate | 
|  | *  call. */ | 
|  | } PARAM_ATTRIBUTES; | 
|  |  | 
|  | typedef struct | 
|  | { | 
|  | unsigned char ServerMustSize : 1; /* 0x01 - the server must perform a | 
|  | *  sizing pass. */ | 
|  | unsigned char ClientMustSize : 1; /* 0x02 - the client must perform a | 
|  | *  sizing pass. */ | 
|  | unsigned char HasReturn : 1; /* 0x04 - procedure has a return value. */ | 
|  | unsigned char HasPipes : 1; /* 0x08 - the pipe package should be used. */ | 
|  | unsigned char Unused : 1; /* 0x10 - not used */ | 
|  | unsigned char HasAsyncUuid : 1; /* 0x20 - indicates an asynchronous DCOM | 
|  | *  procedure. */ | 
|  | unsigned char HasExtensions : 1; /* 0x40 - indicates that Win2000 | 
|  | *  extensions are in use. */ | 
|  | unsigned char HasAsyncHandle : 1; /* 0x80 - indicates an asynchronous RPC | 
|  | *  procedure. */ | 
|  | } INTERPRETER_OPT_FLAGS, *PINTERPRETER_OPT_FLAGS; | 
|  |  | 
|  | typedef struct | 
|  | { | 
|  | unsigned char HasNewCorrDesc : 1; /* 0x01 - indicates new correlation | 
|  | *  descriptors in use. */ | 
|  | unsigned char ClientCorrCheck : 1; /* 0x02 - client needs correlation | 
|  | *  check. */ | 
|  | unsigned char ServerCorrCheck : 1; /* 0x04 - server needs correlation | 
|  | *  check. */ | 
|  | unsigned char HasNotify : 1; /* 0x08 - should call MIDL [notify] | 
|  | *  routine @ NotifyIndex. */ | 
|  | unsigned char HasNotify2 : 1; /* 0x10 - should call MIDL [notify_flag] routine @ | 
|  | *  NotifyIndex. */ | 
|  | unsigned char Unused : 3; | 
|  | } INTERPRETER_OPT_FLAGS2, *PINTERPRETER_OPT_FLAGS2; | 
|  |  | 
|  | /* Win2000 extensions */ | 
|  | typedef struct | 
|  | { | 
|  | /* size in bytes of all following extensions */ | 
|  | unsigned char Size; | 
|  |  | 
|  | INTERPRETER_OPT_FLAGS2 Flags2; | 
|  |  | 
|  | /* client cache size hint */ | 
|  | unsigned short ClientCorrHint; | 
|  |  | 
|  | /* server cache size hint */ | 
|  | unsigned short ServerCorrHint; | 
|  |  | 
|  | /* index of routine in MIDL_STUB_DESC::NotifyRoutineTable to call if | 
|  | * HasNotify or HasNotify2 flag set */ | 
|  | unsigned short NotifyIndex; | 
|  | } NDR_PROC_HEADER_EXTS; | 
|  |  | 
|  | typedef struct | 
|  | { | 
|  | /* size in bytes of all following extensions */ | 
|  | unsigned char Size; | 
|  |  | 
|  | INTERPRETER_OPT_FLAGS2 Flags2; | 
|  |  | 
|  | /* client cache size hint */ | 
|  | unsigned short ClientCorrHint; | 
|  |  | 
|  | /* server cache size hint */ | 
|  | unsigned short ServerCorrHint; | 
|  |  | 
|  | /* index of routine in MIDL_STUB_DESC::NotifyRoutineTable to call if | 
|  | * HasNotify or HasNotify2 flag set */ | 
|  | unsigned short NotifyIndex; | 
|  |  | 
|  | /* needed only on IA64 to cope with float/register loading */ | 
|  | unsigned short FloatArgMask; | 
|  | } NDR_PROC_HEADER_EXTS64; | 
|  |  | 
|  | typedef enum | 
|  | { | 
|  | FC_BYTE = 0x01, /* 0x01 */ | 
|  | FC_CHAR, /* 0x02 */ | 
|  | FC_SMALL, /* 0x03 */ | 
|  | FC_USMALL, /* 0x04 */ | 
|  | FC_WCHAR, /* 0x05 */ | 
|  | FC_SHORT, /* 0x06 */ | 
|  | FC_USHORT, /* 0x07 */ | 
|  | FC_LONG, /* 0x08 */ | 
|  | FC_ULONG, /* 0x09 */ | 
|  | FC_FLOAT, /* 0x0a */ | 
|  | FC_HYPER, /* 0x0b */ | 
|  | FC_DOUBLE, /* 0x0c */ | 
|  | FC_ENUM16, /* 0x0d */ | 
|  | FC_ENUM32, /* 0x0e */ | 
|  | FC_IGNORE, /* 0x0f */ | 
|  | FC_ERROR_STATUS_T, /* 0x10 */ | 
|  |  | 
|  | FC_RP, /* 0x11 */ /* reference pointer */ | 
|  | FC_UP, /* 0x12 */ /* unique pointer */ | 
|  | FC_OP, /* 0x13 */ /* object pointer */ | 
|  | FC_FP, /* 0x14 */ /* full pointer */ | 
|  |  | 
|  | FC_STRUCT, /* 0x15 */ /* simple structure */ | 
|  | FC_PSTRUCT, /* 0x16 */ /* simple structure w/ pointers */ | 
|  | FC_CSTRUCT, /* 0x17 */ /* conformant structure */ | 
|  | FC_CPSTRUCT, /* 0x18 */ /* conformant structure w/ pointers */ | 
|  | FC_CVSTRUCT, /* 0x19 */ /* conformant varying struct */ | 
|  | FC_BOGUS_STRUCT, /* 0x1a */ /* complex structure */ | 
|  |  | 
|  | FC_CARRAY, /* 0x1b */ /* conformant array */ | 
|  | FC_CVARRAY, /* 0x1c */ /* conformant varying array */ | 
|  | FC_SMFARRAY, /* 0x1d */ /* small (<64K) fixed array */ | 
|  | FC_LGFARRAY, /* 0x1e */ /* large (>= 64k) fixed array */ | 
|  | FC_SMVARRAY, /* 0x1f */ /* small (<64k) varying array */ | 
|  | FC_LGVARRAY, /* 0x20 */ /* large (>= 64k) varying array */ | 
|  | FC_BOGUS_ARRAY, /* 0x21 */ /* complex array */ | 
|  | } FORMAT_CHARACTER; | 
|  |  | 
|  | /* flags for all handle types */ | 
|  | #define HANDLE_PARAM_IS_VIA_PTR 0x80 | 
|  | #define HANDLE_PARAM_IS_IN      0x40 | 
|  | #define HANDLE_PARAM_IS_OUT     0x20 | 
|  | #define HANDLE_PARAM_IS_RETURN  0x10 | 
|  |  | 
|  | /* flags for context handles */ | 
|  | #define NDR_STRICT_CONTEXT_HANDLE           0x08 | 
|  | #define NDR_CONTEXT_HANDLE_NOSERIALIZE      0x04 | 
|  | #define NDR_CONTEXT_HANDLE_SERIALIZE        0x02 | 
|  | #define NDR_CONTEXT_HANDLE_CANNOT_BE_NULL   0x01 | 
|  |  | 
|  | #endif |