The reference entries in the MAPI Programmer's Reference document only those return values that require some handling by client applications or service providers. Return values that indicate common error conditions and can be deduced by checking for failure are not included in the documentation. For example, many interface methods can return MAPI_E_INVALID_PARAMETER if a caller specifies the wrong value for an input parameter. This value is typically not listed in the set of expected return values because there is no need to look specifically for MAPI_E_INVALID_PARAMETER and no need to process it differently from any other error. On the other hand, some service providers do not support event notification and will return MAPI_E_NO_SUPPORT to the Advise method made by clients through IMAPISession. Because clients need to explicitly check for this value and provide code for handling the condition that it represents should it occur, MAPI_E_NO_SUPPORT is included in the list of return values for IMAPISession::Advise.
The following table describes error values that are commonly returned from methods and functions and require explicit handling on the part of a client or service provider. These values fall into four categories: values that indicate invalid input data, values that indicate resource problems, values that indicate character set incompatibility, and values that indicate failure of an unknown origin.
Return value | Description |
---|---|
MAPI_E_INVALID_PARAMETER | One or more of the parameters passed into the method or functions were not valid. |
MAPI_E_UNKNOWN_FLAGS | One or more values for a flags parameter were not valid. |
MAPI_E_DISK_ERROR | There was a problem writing to or reading from disk. |
MAPI_E_NOT_ENOUGH_DISK | Not enough disk space was available to complete the operation. |
MAPI_E_NOT_ENOUGH_MEMORY | Not enough memory was available to complete the operation. |
MAPI_E_NOT_ENOUGH_RESOURCES | Not enough system resources were available to complete the operation. |
MAPI_E_BAD_CHARWIDTH | An incompatibility exists in the character sets supported by the caller and the implementation. |
MAPI_E_CALL_FAILED | An error of unexpected or unknown origin occurred. |
The constants that represent MAPI return values are listed in the MAPICODE.H header file. Some of the constants map to Win32 errors; the mapping of these constants to numeric values can be found in the Win32 header file, WINERROR.H.
Errors regarding invalid data passed in by a caller can be determined through either the parameter validation API functions provided by MAPI or a set of macros. For more information on how to use the MAPI parameter validation model in your programs, see Validating Parameters to Interface Methods.
Character set incompatibility arises when either of the following situations occurs: