Codes in FACILITY_ITF
These
HRESULTSs with facilities such as FACILITY_NULL and FACILITY_RPC have universal meaning
because they are defined at a single source: Microsoft. However,
HRESULTs in FACILITY_ITF are determined by the interface method (or function) from
which they are returned. That is, the same 32-bit value in FACILITY_ITF returned
from two different interface methods might have different meanings.
The reason
HRESULTs in FACILITY_ITF can have different meanings in different interfaces is that
HRESULTs are kept to an efficient data type size of 32 bits. Unfortunately 32 bits is
not large enough for the development of an allocation system for error codes
that avoid conflict between codes allocated by different non-communicating
programmers at different times in different places (unlike the handling of interface
IDs and CLSIDs). As a result, the 32-bit
HRESULT is structured in a way that Microsoft can define some universally-defined
error codes, while allowing other programmers to define new error codes without
fear of conflict. The status code convention is as follows:
- Status codes in facilities other than FACILITY_ITF can only be defined by Microsoft.
- Status codes in facility FACILITY_ITF are defined solely by the developer of
the interface or API that returns the status code. To avoid conflicting error
codes, whoever defines the interface is responsible for coordinating and
publishing the FACILITY_ITF status codes associated with that interface.
All the OLE-defined FACILITY_ITF codes have a code value in the range of
0x0000
0x01FF. While it is legal to use any codes in FACILITY_ITF, it is recommended
that only code values in the range of 0x0200
0xFFFF be used. This recommendation is made as a means of reducing confusion
with any OLE-defined errors.
It is also recommended that developers define new functions and interfaces to
return error codes as defined by OLE and in facilities other than FACILITY_ITF.
In particular, interfaces that have any chance of being remoted using RPC in
the future should define the FACILITY_RPC codes as legal. E_UNEXPECTED is a
specific error code that most developers will want to make universally legal.
- Software for developers
-
Delphi Components
.Net Components
Software for Android Developers
- More information resources
-
MegaDetailed.Net
Unix Manual Pages
Delphi Examples
- Databases for Amazon shops developers
-
Amazon Categories Database
Browse Nodes Database