2193 lines
54 KiB
C
2193 lines
54 KiB
C
/****************************************************************************
|
|
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 <type><declarator> = <initializing expression> "
|
|
}
|
|
|
|
,{
|
|
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 */
|
|
|