Search code examples
c++winapimessage

Undefined WIN32 messages


I am getting strange input in my windows message callback.

Besides all the normal messages, like WM_SIZE, which work fine, there are some messages that do not appear in any table, like this one. And they are not defined as error codes, either.

The messages are: (decimal / hex)

  • 356 / 0164 (wParam: 0, lParam: 5760884)

  • 49291 / c08b (wParam: 4294967292 or 0, lParam: 0)

  • 49348 / c0c4 (wParam: 0, lParam: 0)

Does anybody know what they mean, or why I am gettting them?


Solution

  • Per the Win32 documentation:

    The following are the ranges of message numbers.

    Range                           Meaning
    
    0 through WM_USER–1             Messages reserved for use by the system.
    WM_USER through 0x7FFF          Integer messages for use by private window classes.
    WM_APP (0x8000) through 0xBFFF  Messages available for use by applications.
    0xC000 through 0xFFFF           String messages for use by applications.
    Greater than 0xFFFF             Reserved by the system.
    

    Message numbers in the first range (0 through WM_USER –1) are defined by the system. Values in this range that are not explicitly defined are reserved by the system.

    Message numbers in the second range (WM_USER through 0x7FFF) can be defined and used by an application to send messages within a private window class. These values cannot be used to define messages that are meaningful throughout an application because some predefined window classes already define values in this range. For example, predefined control classes such as BUTTON, EDIT, LISTBOX, and COMBOBOX may use these values. Messages in this range should not be sent to other applications unless the applications have been designed to exchange messages and to attach the same meaning to the message numbers.

    Message numbers in the third range (0x8000 through 0xBFFF) are available for applications to use as private messages. Messages in this range do not conflict with system messages.

    Message numbers in the fourth range (0xC000 through 0xFFFF) are defined at run time when an application calls the RegisterWindowMessage function to retrieve a message number for a string. All applications that register the same string can use the associated message number for exchanging messages. The actual message number, however, is not a constant and cannot be assumed to be the same between different sessions.

    Message numbers in the fifth range (greater than 0xFFFF) are reserved by the system.

    Where WM_USER is 0x0400.

    So,