/**************************************************************************** ZZZ - error in all cases AZZ - no error when : app_config AZM - no error when : app_config + ms_ext ACZ - no error when : app_config + c_ext ACM - no error when : app_config + c_ext + ms_ext ZCZ - no error when : c_ext ZCM - no error when : c_ext + ms_ext ZZM - no error when : ms_ext Therefore: The following are the configurations -ms_ext on: ZZM | ZCM | ACM | AZM ---------- -c_ext on: ZCM | ZCZ | ACM | ACZ ---------- -ms_ext or -c_ext on: ZZM | ZCM | ACM | AZM | ZCZ | ACZ -------------------- -app_config on : AZZ | AZM | ACZ | ACM ---------------- ****************************************************************************/ #define ERR_ALWAYS ( ZZZ ) #define MS_EXT_SET ( ZZM | ZCM | ACM | AZM ) #define C_EXT_SET ( ZCM | ZCZ | ACM | ACZ ) #define MS_OR_C_EXT_SET ( MS_EXT_SET | C_EXT_SET ) #define APP_CONFIG_SET ( AZZ | AZM | ACZ | ACM ) const ERRDB ErrorDataBase[] = { { CHECK_ERR( NO_INPUT_FILE) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"missing source-file name" } ,{ CHECK_ERR( INPUT_OPEN) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"cannot open input file" } ,{ CHECK_ERR( INPUT_READ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"error while reading input file" } ,{ CHECK_ERR( PREPROCESSOR_ERROR) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"error returned by the C preprocessor" } ,{ CHECK_ERR( PREPROCESSOR_EXEC) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"cannot execute C preprocessor" } ,{ CHECK_ERR( NO_PREPROCESSOR) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"cannot find C preprocessor" } ,{ CHECK_ERR( PREPROCESSOR_INVALID ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"invalid C preprocessor executable" } ,{ CHECK_ERR( SWITCH_REDEFINED) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, 1 ) ,"switch specified more than once on command line :" } ,{ CHECK_ERR( UNKNOWN_SWITCH) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, NOWARN ) ,"unknown switch" } ,{ CHECK_ERR( UNKNOWN_ARGUMENT) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, 1 ) ,"unknown argument ignored" } ,{ CHECK_ERR( UNIMPLEMENTED_SWITCH) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, 1 ) ,"switch not implemented" } ,{ CHECK_ERR( MISSING_ARG) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"argument(s) missing for switch" } ,{ CHECK_ERR( ILLEGAL_ARGUMENT) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"argument illegal for switch /" } ,{ CHECK_ERR( BAD_SWITCH_SYNTAX) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"illegal syntax for switch" } ,{ CHECK_ERR( NO_CPP_OVERRIDES) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, 1 ) ,"/no_cpp overrides /cpp_cmd and /cpp_opt" } ,{ CHECK_ERR( NO_WARN_OVERRIDES) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, 1 ) ,"/W0 or /no_warn overrides warning-level switch" } ,{ CHECK_ERR( INTERMEDIATE_FILE_CREATE) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"cannot create intermediate file" } ,{ CHECK_ERR( SERVER_AUX_FILE_NOT_SPECIFIED) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"must specify /server(aux/all) with cswtch" } ,{ CHECK_ERR( OUT_OF_SYSTEM_FILE_HANDLES) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"out of system file handles" } ,{ CHECK_ERR( BOTH_CSWTCH_SSWTCH) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"cannot specify both /cswtch and /sswtch" } ,{ CHECK_ERR( CANNOT_OPEN_RESP_FILE) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"cannot open response file" } ,{ CHECK_ERR( ILLEGAL_CHAR_IN_RESP_FILE) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"illegal character(s) found in response file" } ,{ CHECK_ERR( MISMATCHED_PREFIX_PAIR) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"mismatch in argument pair for switch" } ,{ CHECK_ERR( NESTED_RESP_FILE) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"nested invocation of response files is illegal" } ,{ CHECK_ERR( ABSTRACT_DECL ) MAKE_E_MASK( C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"must specify /c_ext for abstract declarators" } ,{ CHECK_ERR( ACTUAL_DECLARATION ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"instantiation of data is illegal; you must use \"extern\" or \"static\"" } ,{ CHECK_ERR( C_STACK_OVERFLOW) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"compiler stack overflow" } ,{ CHECK_ERR( DUPLICATE_DEFINITION) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"redefinition" } ,{ CHECK_ERR( NO_HANDLE_DEFINED_FOR_PROC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 2 ) ,"[auto_handle] binding will be used" } ,{ CHECK_ERR( OUT_OF_MEMORY) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"out of memory" } ,{ CHECK_ERR( RECURSIVE_DEF) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"recursive definition" } ,{ CHECK_ERR( REDUNDANT_IMPORT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 2 ) ,"import ignored; file already imported :" } ,{ CHECK_ERR( SPARSE_ENUM ) MAKE_E_MASK( MS_OR_C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"sparse enums require /c_ext or /ms_ext" } ,{ CHECK_ERR( UNDEFINED_SYMBOL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"undefined symbol" } ,{ CHECK_ERR( UNDEFINED_TYPE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"type used in ACF file not defined in IDL file" } ,{ CHECK_ERR( UNRESOLVED_TYPE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"unresolved type declaration" } ,{ CHECK_ERR( WCHAR_CONSTANT_NOT_OSF ) MAKE_E_MASK( MS_OR_C_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"use of wide-character constants requires /ms_ext or /c_ext" } ,{ CHECK_ERR( WCHAR_STRING_NOT_OSF ) MAKE_E_MASK( MS_OR_C_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"use of wide character strings requires /ms_ext or /c_ext" } ,{ CHECK_ERR( WCHAR_T_ILLEGAL) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"inconsistent redefinition of type wchar_t" } ,{ CHECK_ERR( TYPELIB_NOT_LOADED ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"importlib not found" } ,{ CHECK_ERR( TWO_LIBRARIES ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"two library blocks" } ,{ CHECK_ERR( NO_IDISPATCH ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"the dispinterface statement requires a definition for IDispatch" } ,{ CHECK_ERR( ERR_TYPELIB ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"error accessing type library" } ,{ CHECK_ERR( ERR_TYPEINFO ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"error accessing type info" } ,{ CHECK_ERR( ERR_TYPELIB_GENERATION ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"error generating type library" } ,{ CHECK_ERR( DUPLICATE_IID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"duplicate id" } ,{ CHECK_ERR( BAD_ENTRY_VALUE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal or missing value for entry attribute" } ,{ CHECK_ERR( ASSUMING_CHAR) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 5 ) ,"error recovery assumes" } ,{ CHECK_ERR( DISCARDING_CHAR) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 5 ) ,"error recovery discards" } ,{ CHECK_ERR( BENIGN_SYNTAX_ERROR) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"syntax error" } ,{ CHECK_ERR( SYNTAX_ERROR) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"cannot recover from earlier syntax errors; aborting compilation" } ,{ CHECK_ERR( UNKNOWN_PRAGMA_OPTION) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"unknown pragma option" } ,{ CHECK_ERR( UNIMPLEMENTED_FEATURE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"feature not implemented" } ,{ CHECK_ERR( UNIMPLEMENTED_TYPE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"type not implemented" } ,{ CHECK_ERR( EXPR_DEREF_ON_NON_POINTER) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"non-pointer used in a dereference operation" } ,{ CHECK_ERR( EXPR_DIV_BY_ZERO) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"expression has a divide by zero" } ,{ CHECK_ERR( EXPR_INCOMPATIBLE_TYPES) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"expression uses incompatible types" } ,{ CHECK_ERR( EXPR_INDEXING_NON_ARRAY ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"non-array expression uses index operator" } ,{ CHECK_ERR( EXPR_LHS_NON_COMPOSITE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"left-hand side of expression does not evaluate to struct/union/enum" } ,{ CHECK_ERR( EXPR_NOT_CONSTANT) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"constant expression expected" } ,{ CHECK_ERR( EXPR_NOT_EVALUATABLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"expression cannot be evaluated at compile time" } ,{ CHECK_ERR( EXPR_NOT_IMPLEMENTED ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"expression not implemented" } ,{ CHECK_ERR( NO_PTR_DEFAULT_ON_INTERFACE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"no [pointer_default] attribute specified, assuming [unique] for all unattributed pointers" } ,{ CHECK_ERR( DERIVES_FROM_PTR_TO_CONF ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[out] only parameter cannot be a pointer to an open structure" } ,{ CHECK_ERR( DERIVES_FROM_UNSIZED_STRING ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[out] only parameter cannot be an unsized string" } ,{ CHECK_ERR( NON_PTR_OUT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[out] parameter is not a pointer" } ,{ CHECK_ERR( OPEN_STRUCT_AS_PARAM) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"open structure cannot be a parameter" } ,{ CHECK_ERR( OUT_CONTEXT_GENERIC_HANDLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[out] context handle/generic handle must be specified as a pointer to that handle type" } ,{ CHECK_ERR( CTXT_HDL_TRANSMIT_AS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"context handle must not derive from a type that has the [transmit_as] attribute" } ,{ CHECK_ERR( PARAM_IS_ELIPSIS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"cannot specify a variable number of arguments to a remote procedure" } ,{ CHECK_ERR( VOID_PARAM_WITH_NAME) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"named parameter cannot be \"void\"" } ,{ CHECK_ERR( HANDLE_NOT_FIRST ) MAKE_E_MASK( MS_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"only the first parameter can be a binding handle; you must specify the /ms_ext switch" } ,{ CHECK_ERR( PROC_PARAM_COMM_STATUS) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"cannot use [comm_status] on both a parameter and a return type" } ,{ CHECK_ERR( LOCAL_ATTR_ON_PROC) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"[local] attribute on a procedure requires /ms_ext" } ,{ CHECK_ERR( ILLEGAL_USE_OF_PROPERTY_ATTRIBUTE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"property attributes may only be used with procedures" } ,{ CHECK_ERR( MULTIPLE_PROPERTY_ATTRIBUTES ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"a procedure may not have more than one property attribute" } ,{ CHECK_ERR( CONFORMANT_ARRAY_NOT_LAST) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"field deriving from a conformant array must be the last member of the structure" } ,{ CHECK_ERR( DUPLICATE_CASE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"duplicate [case] label" } ,{ CHECK_ERR( NO_UNION_DEFAULT) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"no [default] case specified for discriminated union" } ,{ CHECK_ERR( ATTRIBUTE_ID_UNRESOLVED) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"attribute expression cannot be resolved" } ,{ CHECK_ERR( ATTR_MUST_BE_INT) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"attribute expression must be of integral, non-hyper type" } ,{ CHECK_ERR( BYTE_COUNT_INVALID) MAKE_E_MASK( MS_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"[byte_count] requires /ms_ext" } ,{ CHECK_ERR( BYTE_COUNT_NOT_OUT_PTR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[byte_count] can be applied only to out parameters of pointer type" } ,{ CHECK_ERR( BYTE_COUNT_ON_CONF ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[byte_count] cannot be specified on a pointer to a conformant array or structure" } ,{ CHECK_ERR( BYTE_COUNT_PARAM_NOT_IN ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter specifying the byte count is not [in]" } ,{ CHECK_ERR( BYTE_COUNT_PARAM_NOT_INTEGRAL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter specifying the byte count is not an integral type" } ,{ CHECK_ERR( BYTE_COUNT_WITH_SIZE_ATTR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"[byte_count] cannot be specified on a parameter with size attributes" } ,{ CHECK_ERR( CASE_EXPR_NOT_CONST) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[case] expression is not constant" } ,{ CHECK_ERR( CASE_EXPR_NOT_INT) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[case] expression is not of integral type" } ,{ CHECK_ERR( CONTEXT_HANDLE_VOID_PTR ) MAKE_E_MASK( MS_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"specifying [context_handle] on a type other than void * requires /ms_ext" } ,{ CHECK_ERR( ERROR_STATUS_T_REPEATED) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"cannot specify more than one parameter with each of comm_status/fault_status" } ,{ CHECK_ERR( E_STAT_T_MUST_BE_PTR_TO_E ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"comm_status/fault_status parameter must be an [out] only pointer parameter" } ,{ CHECK_ERR( ENDPOINT_SYNTAX) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"endpoint syntax error" } ,{ CHECK_ERR( INAPPLICABLE_ATTRIBUTE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"inapplicable attribute" } ,{ CHECK_ERR( ALLOCATE_INVALID) MAKE_E_MASK( MS_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"[allocate] requires /ms_ext" } ,{ CHECK_ERR( INVALID_ALLOCATE_MODE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"invalid [allocate] mode" } ,{ CHECK_ERR( INVALID_SIZE_ATTR_ON_STRING) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"length attributes cannot be applied with string attribute" } ,{ CHECK_ERR( LAST_AND_LENGTH) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[last_is] and [length_is] cannot be specified at the same time" } ,{ CHECK_ERR( MAX_AND_SIZE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[max_is] and [size_is] cannot be specified at the same time" } ,{ CHECK_ERR( NO_SWITCH_IS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"no [switch_is] attribute specified at use of union" } ,{ CHECK_ERR( NO_UUID_SPECIFIED) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"no [uuid] specified" } ,{ CHECK_ERR( UUID_LOCAL_BOTH_SPECIFIED) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 2 ) ,"[uuid] ignored on [local] interface" } ,{ CHECK_ERR( SIZE_LENGTH_TYPE_MISMATCH ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"type mismatch between length and size attribute expressions" } ,{ CHECK_ERR( STRING_NOT_ON_BYTE_CHAR) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[string] attribute must be specified \"byte\" \"char\" or \"wchar_t\" array or pointer" } ,{ CHECK_ERR( SWITCH_TYPE_MISMATCH ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"mismatch between the type of the [switch_is] expression and the switch type of the union" } ,{ CHECK_ERR( TRANSMIT_AS_CTXT_HANDLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[transmit_as] must not be applied to a type that derives from a context handle" } ,{ CHECK_ERR( TRANSMIT_AS_NON_RPCABLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[transmit_as] must specify a transmissible type" } ,{ CHECK_ERR( TRANSMIT_AS_POINTER ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"transmitted type must not be a pointer or derive from a pointer" } ,{ CHECK_ERR( TRANSMIT_TYPE_CONF ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"presented type must not derive from a conformant/varying array, its pointer equivalent or a conformant/varying structure" } ,{ CHECK_ERR( UUID_FORMAT) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[uuid] format is incorrect" } ,{ CHECK_ERR( UUID_NOT_HEX) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"uuid is not a hex number" } ,{ CHECK_ERR( OPTIONAL_PARAMS_MUST_BE_LAST) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"optional parameters must come at the end of the parameter list" } ,{ CHECK_ERR( DLLNAME_REQUIRED ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[dllname] required when [entry] is used:" } ,{ CHECK_ERR( INVALID_USE_OF_BINDABLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[bindable] is invalid without [propget], [propput], or [propputref]" } ,{ CHECK_ERR( ACF_INTERFACE_MISMATCH) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"interface name specified in the ACF file does not match that specified in the IDL file" } ,{ CHECK_ERR( CONFLICTING_ATTR) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"duplicated attribute" } ,{ CHECK_ERR( INVALID_COMM_STATUS_PARAM ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter with [comm_status] or [fault_status] attribute must be a pointer to type error_status_t" } ,{ CHECK_ERR( LOCAL_PROC_IN_ACF) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"a [local] procedure cannot be specified in ACF file" } ,{ CHECK_ERR( TYPE_HAS_NO_HANDLE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"specified type is not defined as a handle" } ,{ CHECK_ERR( UNDEFINED_PROC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"procedure undefined" } ,{ CHECK_ERR( UNDEF_PARAM_IN_IDL) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"this parameter does not exist in the IDL file" } ,{ CHECK_ERR( ARRAY_BOUNDS_CONSTRUCT_BAD ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"this array bounds construct is not supported" } ,{ CHECK_ERR( ILLEGAL_ARRAY_BOUNDS) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"array bound specification is illegal" } ,{ CHECK_ERR( ILLEGAL_CONFORMANT_ARRAY) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"pointer to a conformant array or an array that contains a conformant array is not supported" } ,{ CHECK_ERR( UNSIZED_ARRAY) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"pointee / array does not derive any size" } ,{ CHECK_ERR( NOT_FIXED_ARRAY) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"only fixed arrays and SAFEARRAYs are legal in a type library" } ,{ CHECK_ERR( SAFEARRAY_USE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"SAFEARRAYs are only legal inside a library block" } ,{ CHECK_ERR( CHAR_CONST_NOT_TERMINATED ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"badly formed character constant" } ,{ CHECK_ERR( EOF_IN_COMMENT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"end of file found in comment" } ,{ CHECK_ERR( EOF_IN_STRING ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"end of file found in string" } ,{ CHECK_ERR( ID_TRUNCATED ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 4 ) ,"identifier length exceeds 31 characters" } ,{ CHECK_ERR( NEWLINE_IN_STRING ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"end of line found in string" } ,{ CHECK_ERR( STRING_TOO_LONG ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"string constant exceeds limit of 255 characters" } ,{ CHECK_ERR( IDENTIFIER_TOO_LONG ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"identifier exceeds limit of 255 characters and has been truncated" } ,{ CHECK_ERR( CONSTANT_TOO_BIG ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"constant too big" } ,{ CHECK_ERR( ERROR_OPENING_FILE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"error in opening file" } ,{ CHECK_ERR( ERR_BIND ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"error binding to function" } ,{ CHECK_ERR( ERR_INIT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"error initializing OLE" } ,{ CHECK_ERR( ERR_LOAD ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"error loading library" } ,{ CHECK_ERR( UNIQUE_FULL_PTR_OUT_ONLY ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[out] only parameter must not derive from a top-level [unique] or [ptr] pointer/array" } ,{ CHECK_ERR( BAD_ATTR_NON_RPC_UNION ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"attribute is not applicable to this non-rpcable union" } ,{ CHECK_ERR( SIZE_SPECIFIER_CANT_BE_OUT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"expression used for a size attribute must not derive from an [out] only parameter" } ,{ CHECK_ERR( LENGTH_SPECIFIER_CANT_BE_OUT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"expression used for a length attribute for an [in] parameter cannot derive from an [out] only parameter" } ,{ CHECK_ERR( BAD_CON_INT ) MAKE_E_MASK( C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"use of \"int\" needs /c_ext" } ,{ CHECK_ERR( BAD_CON_FIELD_VOID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"struct/union field must not be \"void\"" } ,{ CHECK_ERR( BAD_CON_ARRAY_VOID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"array element must not be \"void\"" } ,{ CHECK_ERR( BAD_CON_MSC_CDECL ) MAKE_E_MASK( C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"use of type qualifiers and/or modifiers needs /c_ext" } ,{ CHECK_ERR( BAD_CON_FIELD_FUNC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"struct/union field must not derive from a function" } ,{ CHECK_ERR( BAD_CON_ARRAY_FUNC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"array element must not be a function" } ,{ CHECK_ERR( BAD_CON_PARAM_FUNC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter must not be a function" } ,{ CHECK_ERR( BAD_CON_BIT_FIELDS ) MAKE_E_MASK( C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"struct/union with bit fields needs /c_ext" } ,{ CHECK_ERR( BAD_CON_BIT_FIELD_NON_ANSI) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 4 ) ,"bit field specification on a type other that \"int\" is a non-ANSI-compatible extension" } ,{ CHECK_ERR( BAD_CON_BIT_FIELD_NOT_INTEGRAL) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"bit field specification can be applied only to simple, integral types" } ,{ CHECK_ERR( BAD_CON_CTXT_HDL_FIELD ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"struct/union field must not derive from handle_t or a context_handle" } ,{ CHECK_ERR( BAD_CON_CTXT_HDL_ARRAY ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"array element must not derive from handle_t or a context-handle" } ,{ CHECK_ERR( BAD_CON_NON_RPC_UNION ) MAKE_E_MASK( C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"this specification of union needs /c_ext" } ,{ CHECK_ERR( NON_RPC_PARAM_INT ) MAKE_E_MASK( MS_OR_C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter deriving from an \"int\" must have size specifier \"small\", \"short\", or \"long\" with the \"int\"" } ,{ CHECK_ERR( NON_RPC_PARAM_VOID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"type of the parameter cannot derive from void or void *" } ,{ CHECK_ERR( NON_RPC_PARAM_BIT_FIELDS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter deriving from a struct/union containing bit fields is not supported" } ,{ CHECK_ERR( NON_RPC_PARAM_CDECL ) MAKE_E_MASK( C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"use of a parameter deriving from a type containing type-modifiers/type-qualifiers needs /c_ext" } ,{ CHECK_ERR( NON_RPC_PARAM_FUNC_PTR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter must not derive from a pointer to a function" } ,{ CHECK_ERR( NON_RPC_UNION ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter must not derive from a non-rpcable union" } ,{ CHECK_ERR( NON_RPC_RTYPE_INT ) MAKE_E_MASK( MS_OR_C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"return type derives from an \"int\". You must use size specifiers with the \"int\"" } ,{ CHECK_ERR( NON_RPC_RTYPE_VOID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"return type must not derive from a void pointer" } ,{ CHECK_ERR( NON_RPC_RTYPE_BIT_FIELDS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"return type must not derive from a struct/union containing bit-fields" } ,{ CHECK_ERR( NON_RPC_RTYPE_UNION ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"return type must not derive from a non-rpcable union" } ,{ CHECK_ERR( NON_RPC_RTYPE_FUNC_PTR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"return type must not derive from a pointer to a function" } ,{ CHECK_ERR( COMPOUND_INITS_NOT_SUPPORTED ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"compound initializers are not supported" } ,{ CHECK_ERR( ACF_IN_IDL_NEEDS_APP_CONFIG ) MAKE_E_MASK( APP_CONFIG_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"ACF attributes in the IDL file need the /app_config switch" } ,{ CHECK_ERR( SINGLE_LINE_COMMENT ) MAKE_E_MASK( MS_OR_C_EXT_SET , C_MSG, CLASS_WARN, 1 ) ,"single line comment needs /ms_ext or /c_ext" } ,{ CHECK_ERR( VERSION_FORMAT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[version] format is incorrect" } ,{ CHECK_ERR( SIGNED_ILLEGAL ) MAKE_E_MASK( MS_OR_C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"\"signed\" needs /ms_ext or /c_ext" } ,{ CHECK_ERR( ASSIGNMENT_TYPE_MISMATCH ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"mismatch in assignment type" } ,{ CHECK_ERR( ILLEGAL_OSF_MODE_DECL ) MAKE_E_MASK( MS_OR_C_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"declaration must be of the form: const = " } ,{ CHECK_ERR( OSF_DECL_NEEDS_CONST ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"declaration must have \"const\"" } ,{ CHECK_ERR( COMP_DEF_IN_PARAM_LIST ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"struct/union/enum must not be defined in a parameter type specification" } ,{ CHECK_ERR( ALLOCATE_NOT_ON_PTR_TYPE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[allocate] attribute must be applied only on non-void pointer types" } ,{ CHECK_ERR( ARRAY_OF_UNIONS_ILLEGAL ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"array or equivalent pointer construct cannot derive from a non-encapsulated union" } ,{ CHECK_ERR( BAD_CON_E_STAT_T_FIELD ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field must not derive from an error_status_t type" } ,{ CHECK_ERR( CASE_LABELS_MISSING_IN_UNION ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"union has at least one arm without a case label" } ,{ CHECK_ERR( BAD_CON_PARAM_RT_IGNORE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"parameter or return type must not derive from a type that has [ignore] applied to it" } ,{ CHECK_ERR( MORE_THAN_ONE_PTR_ATTR ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"pointer already has a pointer-attribute applied to it" } ,{ CHECK_ERR( RECURSION_THRU_REF ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field/parameter must not derive from a structure that is recursive through a ref pointer" } ,{ CHECK_ERR( BAD_CON_FIELD_VOID_PTR ) MAKE_E_MASK( C_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"use of field deriving from a void pointer needs /c_ext" } ,{ CHECK_ERR( INVALID_OSF_ATTRIBUTE ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"use of this attribute needs /ms_ext" } ,{ CHECK_ERR( INVALID_NEWTLB_ATTRIBUTE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"this attribute only allowed with new format type libraries" } ,{ CHECK_ERR( WCHAR_T_INVALID_OSF ) MAKE_E_MASK( MS_OR_C_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"use of wchar_t needs /ms_ext or /c_ext" } ,{ CHECK_ERR( BAD_CON_UNNAMED_FIELD ) MAKE_E_MASK( MS_OR_C_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"unnamed fields need /ms_ext or /c_ext" } ,{ CHECK_ERR( BAD_CON_UNNAMED_FIELD_NO_STRUCT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"unnamed fields can derive only from struct/union types" } ,{ CHECK_ERR( BAD_CON_UNION_FIELD_CONF ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field of a union cannot derive from a conformant/varying array or its pointer equivalent" } ,{ CHECK_ERR( PTR_WITH_NO_DEFAULT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"no [pointer_default] attribute specified, assuming [ptr] for all unattributed pointers in interface" } ,{ CHECK_ERR( RHS_OF_ASSIGN_NOT_CONST ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"initializing expression must resolve to a constant expression" } ,{ CHECK_ERR( SWITCH_IS_TYPE_IS_WRONG ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"attribute expression must be of type integer, char, boolean or enum" } ,{ CHECK_ERR( ILLEGAL_CONSTANT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"illegal constant" } ,{ CHECK_ERR( IGNORE_UNIMPLEMENTED_ATTRIBUTE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"attribute not implemented; ignored" } ,{ CHECK_ERR( BAD_CON_REF_RT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"return type must not derive from a [ref] pointer" } ,{ CHECK_ERR( ATTRIBUTE_ID_MUST_BE_VAR ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"attribute expression must be a variable name or a pointer dereference expression in this mode. You must specify the /ms_ext switch" } ,{ CHECK_ERR( RECURSIVE_UNION ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter must not derive from a recursive non-encapsulated union" } ,{ CHECK_ERR( BINDING_HANDLE_IS_OUT_ONLY ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"binding-handle parameter cannot be [out] only" } ,{ CHECK_ERR( PTR_TO_HDL_UNIQUE_OR_FULL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"pointer to a handle cannot be [unique] or [ptr]" } ,{ CHECK_ERR( HANDLE_T_NO_TRANSMIT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter that is not a binding handle must not derive from handle_t" } ,{ CHECK_ERR( UNEXPECTED_END_OF_FILE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"unexpected end of file found" } ,{ CHECK_ERR( HANDLE_T_XMIT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"type deriving from handle_t must not have [transmit_as] applied to it" } ,{ CHECK_ERR( CTXT_HDL_GENERIC_HDL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[context_handle] must not be applied to a type that has [handle] applied to it" } ,{ CHECK_ERR( GENERIC_HDL_VOID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[handle] must not be specified on a type deriving from void or void *" } ,{ CHECK_ERR( NO_EXPLICIT_IN_OUT_ON_PARAM ) MAKE_E_MASK( MS_OR_C_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter must have either [in], [out] or [in,out] in this mode. You must specify /ms_ext or /c_ext" } ,{ CHECK_ERR( TRANSMIT_AS_VOID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[transmit_as] must not be specified on \"void\"" } ,{ CHECK_ERR( VOID_NON_FIRST_PARAM ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"\"void\" must be specified on the first and only parameter specification" } ,{ CHECK_ERR( SWITCH_IS_ON_NON_UNION ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[switch_is] must be specified only on a type deriving from a non-encapsulated union" } ,{ CHECK_ERR( STRINGABLE_STRUCT_NOT_SUPPORTED ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"stringable structures are not implemented in this version" } ,{ CHECK_ERR( SWITCH_TYPE_TYPE_BAD ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"switch type can only be integral, char, boolean or enum" } ,{ CHECK_ERR( GENERIC_HDL_HANDLE_T ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[handle] must not be specified on a type deriving from handle_t" } ,{ CHECK_ERR( HANDLE_T_CANNOT_BE_OUT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"parameter deriving from handle_t must not be an [out] parameter" } ,{ CHECK_ERR( SIZE_LENGTH_SW_UNIQUE_OR_FULL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 2 ) ,"attribute expression derives from [unique] or [ptr] pointer dereference" } ,{ CHECK_ERR( CPP_QUOTE_NOT_OSF ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"\"cpp_quote\" requires /ms_ext" } ,{ CHECK_ERR( QUOTED_UUID_NOT_OSF ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"quoted uuid requires /ms_ext" } ,{ CHECK_ERR( RETURN_OF_UNIONS_ILLEGAL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"return type cannot derive from a non-encapsulated union" } ,{ CHECK_ERR( RETURN_OF_CONF_STRUCT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"return type cannot derive from a conformant structure" } ,{ CHECK_ERR( XMIT_AS_GENERIC_HANDLE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[transmit_as] must not be applied to a type deriving from a generic handle" } ,{ CHECK_ERR( GENERIC_HANDLE_XMIT_AS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[handle] must not be applied to a type that has [transmit_as] applied to it" } ,{ CHECK_ERR( INVALID_CONST_TYPE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"type specified for the const declaration is invalid" } ,{ CHECK_ERR( INVALID_SIZEOF_OPERAND ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"operand to the sizeof operator is not supported" } ,{ CHECK_ERR( NAME_ALREADY_USED ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"this name already used as a const identifier name" } ,{ CHECK_ERR( ERROR_STATUS_T_ILLEGAL ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"inconsistent redefinition of type error_status_t" } ,{ CHECK_ERR( CASE_VALUE_OUT_OF_RANGE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"[case] value out of range of switch type" } ,{ CHECK_ERR( WCHAR_T_NEEDS_MS_EXT_TO_RPC ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"parameter deriving from wchar_t needs /ms_ext" } ,{ CHECK_ERR( INTERFACE_ONLY_CALLBACKS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"this interface has only callbacks" } ,{ CHECK_ERR( REDUNDANT_ATTRIBUTE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"redundantly specified attribute; ignored" } ,{ CHECK_ERR( CTXT_HANDLE_USED_AS_IMPLICIT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"context handle type used for an implicit handle" } ,{ CHECK_ERR( CONFLICTING_ALLOCATE_OPTIONS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"conflicting options specified for [allocate]" } ,{ CHECK_ERR( ERROR_WRITING_FILE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"error while writing to file" } ,{ CHECK_ERR( NO_SWITCH_TYPE_AT_DEF ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"no switch type found at definition of union, using the [switch_is] type" } ,{ CHECK_ERR( ERRORS_PASS1_NO_PASS2 ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"semantic check incomplete due to previous errors" } ,{ CHECK_ERR( HANDLES_WITH_CALLBACK ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"handle parameter or return type is not supported on a [callback] procedure" } ,{ CHECK_ERR( PTR_NOT_FULLY_IMPLEMENTED ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"[ptr] does not support aliasing in this version" } ,{ CHECK_ERR( PARAM_ALREADY_CTXT_HDL ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"parameter already defined as a context handle" } ,{ CHECK_ERR( CTXT_HDL_HANDLE_T ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[context_handle] must not derive from handle_t" } ,{ CHECK_ERR( ARRAY_SIZE_EXCEEDS_64K ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"array size exceeds 65536 bytes" } ,{ CHECK_ERR( STRUCT_SIZE_EXCEEDS_64K ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"struct size exceeds 65536 bytes" } ,{ CHECK_ERR( NE_UNION_FIELD_NE_UNION ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field of a non-encapsulated union cannot be another non-encapsulated union" } ,{ CHECK_ERR( PTR_ATTRS_ON_EMBEDDED_ARRAY ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"pointer attribute(s) applied on an embedded array; ignored" } ,{ CHECK_ERR( ALLOCATE_ON_TRANSMIT_AS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[allocate] is illegal on a type that has [transmit_as] applied to it" } ,{ CHECK_ERR( SWITCH_TYPE_REQD_THIS_IMP_MODE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[switch_type] must be specified in this import mode" } ,{ CHECK_ERR( IMPLICIT_HDL_ASSUMED_GENERIC ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"[implicit_handle] type undefined; assuming generic handle" } ,{ CHECK_ERR( E_STAT_T_ARRAY_ELEMENT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"array element must not derive from error_status_t" } ,{ CHECK_ERR( ALLOCATE_ON_HANDLE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[allocate] illegal on a type deriving from a primitive/generic/context handle" } ,{ CHECK_ERR( TRANSMIT_AS_ON_E_STAT_T ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"transmitted or presented type must not derive from error_status_t" } ,{ CHECK_ERR( IGNORE_ON_DISCRIMINANT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"discriminant of a union must not derive from a field with [ignore] applied to it" } ,{ CHECK_ERR( NOCODE_WITH_SERVER_STUBS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 4 ) ,"[nocode] ignored for server side since \"/server none\" not specified" } ,{ CHECK_ERR( NO_REMOTE_PROCS_NO_STUBS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"no remote procedures specified in non-[local] interface; no client/server stubs will be generated" } ,{ CHECK_ERR( TWO_DEFAULT_CASES ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"too many default cases specified for encapsulated union" } ,{ CHECK_ERR( TWO_DEFAULT_INTERFACES ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"too many default interfaces specified for coclass" } ,{ CHECK_ERR( DEFAULTVTABLE_REQUIRES_SOURCE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"items with [defaultvtable] must also have [source]" } ,{ CHECK_ERR( UNION_NO_FIELDS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"union specification with no fields is illegal" } ,{ CHECK_ERR( VALUE_OUT_OF_RANGE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"value out of range" } ,{ CHECK_ERR( CTXT_HDL_NON_PTR ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[context_handle] must be applied on a pointer type" } ,{ CHECK_ERR( NON_RPC_RTYPE_HANDLE_T ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"return type must not derive from handle_t" } ,{ CHECK_ERR( GEN_HDL_CTXT_HDL ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[handle] must not be applied to a type deriving from a context handle" } ,{ CHECK_ERR( NON_RPC_FIELD_INT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field deriving from an \"int\" must have size specifier \"small\", \"short\", or \"long\" with the \"int\"" } ,{ CHECK_ERR( NON_RPC_FIELD_PTR_TO_VOID ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field must not derive from a void or void *" } ,{ CHECK_ERR( NON_RPC_FIELD_BIT_FIELDS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field must not derive from a struct containing bit-fields" } ,{ CHECK_ERR( NON_RPC_FIELD_NON_RPC_UNION ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field must not derive from a non-rpcable union" } ,{ CHECK_ERR( NON_RPC_FIELD_FUNC_PTR ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"field must not derive from a pointer to a function" } ,{ CHECK_ERR( PROC_PARAM_FAULT_STATUS) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"cannot use [fault_status] on both a parameter and a return type" } ,{ CHECK_ERR( NON_OI_BIG_RETURN ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"return type too complicated for /Oi modes, using /Os" } ,{ CHECK_ERR( NON_OI_BIG_GEN_HDL ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"generic handle type too large for /Oi modes, using /Os" } ,{ CHECK_ERR( ALLOCATE_IN_OUT_PTR ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 4 ) ,"[allocate(all_nodes)] on an [in,out] parameter may orphan the original memory" } ,{ CHECK_ERR( REF_PTR_IN_UNION) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"cannot have a [ref] pointer as a union arm" } ,{ CHECK_ERR( NON_OI_CTXT_HDL ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"return of context handles not supported for /Oi modes, using /Os" } ,{ CHECK_ERR( NON_OI_ERR_STATS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"use of [comm_status] or [fault_status] not supported for /Oi, using /Os" } ,{ CHECK_ERR( NON_OI_UNK_REP_AS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"use of an unknown type for [represent_as] or [user_marshal] not supported for /Oi modes, using /Os" } ,{ CHECK_ERR( NON_OI_XXX_AS_ON_RETURN ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"array types with [transmit_as] or [represent_as] not supported on return type for /Oi modes, using /Os" } ,{ CHECK_ERR( NON_OI_XXX_AS_BY_VALUE ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"array types with [transmit_as] or [represent_as] not supported pass-by-value for /Oi modes, using /Os" } ,{ CHECK_ERR( CALLBACK_NOT_OSF ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"[callback] requires /ms_ext" } ,{ CHECK_ERR( CIRCULAR_INTERFACE_DEPENDENCY ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"circular interface dependency" } ,{ CHECK_ERR( NOT_VALID_AS_BASE_INTF ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"only IUnknown may be used as the root interface" } ,{ CHECK_ERR( IID_IS_NON_POINTER ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[IID_IS] may only be applied to pointers to interfaces" } ,{ CHECK_ERR( INTF_NON_POINTER ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"interfaces may only be used in pointer-to-interface constructs" } ,{ CHECK_ERR( PTR_INTF_NO_GUID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"interface pointers must have a UUID/IID" } ,{ CHECK_ERR( OUTSIDE_OF_INTERFACE ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"definitions and declarations outside of interface body requires /ms_ext" } ,{ CHECK_ERR( MULTIPLE_INTF_NON_OSF ) MAKE_E_MASK( MS_EXT_SET , C_MSG, CLASS_ERROR, NOWARN ) ,"multiple interfaces in one file requires /ms_ext" } ,{ CHECK_ERR( CONFLICTING_INTF_HANDLES ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"only one of [implicit_handle], [auto_handle], or [explicit_handle] allowed" } ,{ CHECK_ERR( IMPLICIT_HANDLE_NON_HANDLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[implicit_handle] references a type which is not a handle" } ,{ CHECK_ERR( OBJECT_PROC_MUST_BE_WIN32 ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[object] procs may only be used with \"/env win32\" or \"/env powermac\"" } ,{ CHECK_ERR( NON_OI_16BIT_CALLBACK ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"[callback] with -env dos/win16 not supported for /Oi modes, using /Os" } ,{ CHECK_ERR( NON_OI_TOPLEVEL_FLOAT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"float/double not supported as top-level parameter for /Oi modes, using /Os" } ,{ CHECK_ERR( CTXT_HDL_MUST_BE_DIRECT_RETURN ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"pointers to context handles may not be used as return values" } ,{ CHECK_ERR( OBJECT_PROC_NON_HRESULT_RETURN ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"procedures in an object interface must return an HRESULT" } ,{ CHECK_ERR( DUPLICATE_UUID ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"duplicate UUID. Same as" } ,{ CHECK_ERR( ILLEGAL_INTERFACE_DERIVATION ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"[object] interfaces must derive from another [object] interface such as IUnknown" } ,{ CHECK_ERR( ILLEGAL_BASE_INTERFACE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"interfaces must derive from another interface" } ,{ CHECK_ERR( IID_IS_EXPR_NON_POINTER ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[IID_IS] expression must be a pointer to IID structure" } ,{ CHECK_ERR( CALL_AS_NON_LOCAL_PROC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[call_as] type must be a [local] procedure" } ,{ CHECK_ERR( CALL_AS_UNSPEC_IN_OBJECT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"undefined [call_as] must not be used in an object interface" } ,{ CHECK_ERR( ENCODE_AUTO_HANDLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[auto_handle] may not be used with [encode] or [decode]" } ,{ CHECK_ERR( RPC_PROC_IN_ENCODE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"normal procs are not allowed in an interface with [encode] or [decode]" } ,{ CHECK_ERR( ENCODE_CONF_OR_VAR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"top-level conformance or variance not allowed with [encode] or [decode]" } ,{ CHECK_ERR( CONST_ON_OUT_PARAM ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"[out] parameters may not have \"const\"" } ,{ CHECK_ERR( CONST_ON_RETVAL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"return values may not have \"const\"" } ,{ CHECK_ERR( INVALID_USE_OF_RETVAL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"invalid use of \"retval\" attribute" } ,{ CHECK_ERR( MULTIPLE_CALLING_CONVENTIONS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"multiple calling conventions illegal" } ,{ CHECK_ERR( INAPPROPRIATE_ON_OBJECT_PROC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"attribute illegal on [object] procedure" } ,{ CHECK_ERR( NON_INTF_PTR_PTR_OUT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"[out] interface pointers must use double indirection" } ,{ CHECK_ERR( CALL_AS_USED_MULTIPLE_TIMES ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"procedure used twice as the caller in [call_as]" } ,{ CHECK_ERR( OBJECT_CALL_AS_LOCAL ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"[call_as] target must have [local] in an object interface" } ,{ CHECK_ERR( CODE_NOCODE_CONFLICT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"[code] and [nocode] may not be used together" } ,{ CHECK_ERR( MAYBE_NO_OUT_RETVALS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[maybe] or [async] procedures may not have a return value or [out] params" } ,{ CHECK_ERR( FUNC_NON_POINTER ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"pointer to function must be used" } ,{ CHECK_ERR( FUNC_NON_RPC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"functions may not be passed in an RPC operation" } ,{ CHECK_ERR( NON_OI_RETVAL_64BIT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"hyper/double not supported as return value for /Oi modes, using /Os" } ,{ CHECK_ERR( MISMATCHED_PRAGMA_POP ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"#pragma pack( pop ) without matching #pragma pack( push )" } ,{ CHECK_ERR( WRONG_TYPE_IN_STRING_STRUCT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"stringable structure fields must be byte/char/wchar_t" } ,{ CHECK_ERR( NON_OI_NOTIFY ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"[notify] not supported for /Oi modes, using /Os" } ,{ CHECK_ERR( HANDLES_WITH_OBJECT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"handle parameter or return type is not supported on a procedure in an [object] interface" } ,{ CHECK_ERR( NON_ANSI_MULTI_CONF_ARRAY ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 1 ) ,"ANSI C only allows the leftmost array bound to be unspecified" } ,{ CHECK_ERR( NON_OI_NOTIFY ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"by-value union parameters not supported for /Oi modes, using /Os" } ,{ CHECK_ERR( OBJECT_WITH_VERSION ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"[version] attribute is ignored on an [object] interface" } ,{ CHECK_ERR( SIZING_ON_FIXED_ARRAYS ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[size_is] or [max_is] attribute is invalid on a fixed array" } ,{ CHECK_ERR( PICKLING_INVALID_IN_OBJECT ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_ERROR, NOWARN ) ,"[encode] or [decode] are invalid in an [object] interface" } ,{ CHECK_ERR( TYPE_PICKLING_INVALID_IN_OSF ) MAKE_E_MASK( MS_EXT_SET, C_MSG, CLASS_ERROR, NOWARN ) ,"[encode] or [decode] on a type requires /ms_ext" } ,{ CHECK_ERR( INT_NOT_SUPPORTED_ON_INT16 ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"\"int\" not supported on /env win16 or /env dos" } ,{ CHECK_ERR( BSTRING_NOT_ON_PLAIN_PTR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[bstring] may only be applied to a pointer to \"char\" or \"wchar_t\"" } ,{ CHECK_ERR( INVALID_ON_OBJECT_PROC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"attribute invalid on a proc in an [object] interface :" } ,{ CHECK_ERR( INVALID_ON_OBJECT_INTF ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"attribute invalid on an [object] interface :" } ,{ CHECK_ERR( STACK_TOO_BIG ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 2 ) ,"too many parameters or stack too big for /Oi modes, using /Os" } ,{ CHECK_ERR( NO_ATTRS_ON_ACF_TYPEDEF ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 2 ) ,"no attributes on ACF file typedef, so no effect" } ,{ CHECK_ERR( NON_OI_WRONG_CALL_CONV ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"calling conventions other than __stdcall or __cdecl not supported for /Oi modes, using /Os" } ,{ CHECK_ERR( TOO_MANY_DELEGATED_PROCS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"More than 64 delegated methods not supported" } ,{ CHECK_ERR( NO_MAC_AUTO_HANDLES ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"auto handles not supported with -env mac or -env powermac" } ,{ CHECK_ERR( ILLEGAL_IN_MKTYPLIB_MODE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"statements outside library block are illegal in mktyplib compatability mode" } ,{ CHECK_ERR( ILLEGAL_USE_OF_MKTYPLIB_SYNTAX) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal syntax unless using mktyplib compatibility mode" } ,{ CHECK_ERR( ILLEGAL_SU_DEFINITION) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal definition, must use typedef in mktyplib compatibility mode" } ,{ CHECK_ERR( INTF_EXPLICIT_PTR_ATTR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"explicit pointer attribute [ptr] [ref] ignored for interface pointers" } ,{ CHECK_ERR( NO_OI_ON_MPPC ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"Oi modes not implemented for PowerMac, switching to Os" } ,{ CHECK_ERR( ILLEGAL_EXPRESSION_TYPE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal expression type used in attribute" } ,{ CHECK_ERR( ILLEGAL_PIPE_TYPE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal type used in pipe" } ,{ CHECK_ERR( REQUIRES_OI2 ) MAKE_E_MASK( ERR_ALWAYS , C_MSG, CLASS_WARN, 2 ) ,"procedure uses pipes, using /Oicf" } ,{ CHECK_ERR( CONFLICTING_OPTIMIZATION_REQUIREMENTS ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"procedure's parameters are too complex to include pipes - simplify other parameters or don't use pipes" } ,{ CHECK_ERR( ILLEGAL_PIPE_EMBEDDING ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"pipe cannot be a members of a struct or a union, nor an array element" } ,{ CHECK_ERR( ILLEGAL_PIPE_CONTEXT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"invalid pipe usage" } ,{ CHECK_ERR( CMD_REQUIRES_I2 ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"feature requires the advanced interpreted optimization option, use -Oicf :" } ,{ CHECK_ERR( REQUIRES_I2 ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 3 ) ,"feature requires the advanced interpreted optimization option, use -Oicf :" } #if defined(TARGET_RKK) ,{ CHECK_ERR( CMD_REQUIRES_NT40 ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"feature invalid for the specified target system, use -target NT40 :" } ,{ CHECK_ERR( CMD_REQUIRES_NT351 ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"feature invalid for the specified target system, use -target NT351 :" } ,{ CHECK_ERR( REQUIRES_NT40 ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"feature invalid for the specified target system, use -target NT40" } ,{ CHECK_ERR( REQUIRES_NT351 ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"feature invalid for the specified target system, use -target NT351" } #endif // TARGET_RKK ,{ CHECK_ERR( CMD_OI1_PHASED_OUT ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, 1 ) ,"the optimization option is being phased out, use -Oic :" } ,{ CHECK_ERR( CMD_OI2_OBSOLETE ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_WARN, 1 ) ,"the optimization option is being phased out, use -Oicf :" } ,{ CHECK_ERR( OI1_PHASED_OUT ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"the optimization option is being phased out, use -ic" } ,{ CHECK_ERR( OI2_OBSOLETE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_WARN, 1 ) ,"the optimization option is being phased out, use -icf" } ,{ CHECK_ERR( ILLEGAL_ARG_VALUE) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal argument value" } ,{ CHECK_ERR( CONSTANT_TYPE_MISMATCH ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal expression type in constant" } ,{ CHECK_ERR( ENUM_TYPE_MISMATCH ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"illegal expression type in enum" } ,{ CHECK_ERR( UNSATISFIED_FORWARD ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"unsatisfied forward declaration" } ,{ CHECK_ERR( CONTRADICTORY_SWITCHES ) MAKE_E_MASK( ERR_ALWAYS, D_MSG, CLASS_ERROR, NOWARN ) ,"switches are contradictory " } ,{ CHECK_ERR( NO_SWITCH_IS_HOOKOLE ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"MIDL cannot generate HOOKOLE information for the non-rpcable union" } ,{ CHECK_ERR( NO_CASE_EXPR ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"no case expression found for union" } ,{ CHECK_ERR( USER_MARSHAL_IN_OI ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"[user_marshal] and [wire_marshal] not supported with -Oi and -Oic flags, use -Os or -Oicf" } ,{ CHECK_ERR( PIPES_WITH_PICKLING ) MAKE_E_MASK( ERR_ALWAYS, C_MSG, CLASS_ERROR, NOWARN ) ,"pipes can't be used with data serialization, i.e. [encode] and/or [decode]" } }; /* end of array of structs initialization */