64

Could you please explain to me the WINAPI word in the WinMain() function?

In the simplest way..

#include <windows.h>

int -->WINAPI<-- WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, 
    LPSTR lpCmdLine, int nCmdShow)
{
    MessageBox(NULL, "Goodbye, cruel world!", "Note", MB_OK);
    return 0;
}

Is it just some Windows funky mode?

What does it do? Or rather what is this C++ feature I haven't encountered yet?

Community
  • 1
  • 1
Pyjong
  • 3,095
  • 4
  • 32
  • 50

4 Answers4

71

WINAPI is a macro that evaluates to __stdcall, a Microsoft-specific keyword that specifies a calling convention where the callee cleans the stack. The function's caller and callee need to agree on a calling convention to avoid corrupting the stack.

bk1e
  • 23,871
  • 6
  • 54
  • 65
  • 5
    so why is it in this specific place? couldn't they give the macro one line above? – Pyjong Feb 27 '10 at 18:31
  • 11
    The calling convention keyword goes between the return type and the function name because that's how someone working on a C compiler defined it many years ago. I don't know the reasoning behind the syntax, or even which compiler was the first to support specifying calling conventions (cdecl, pascal, fortran, etc.). Microsoft? Borland? Lattice? Something else? – bk1e Feb 28 '10 at 03:45
10

WINAPI is a macro that expands to __stdcall which means that the callee cleans the stack.

Rich Turner
  • 10,800
  • 1
  • 51
  • 68
Brian R. Bondy
  • 339,232
  • 124
  • 596
  • 636
10

This is a macro definition intended to denote the Windows calling convention. From MSDN:

The way the name is decorated depends on the language and how the compiler is instructed to make the function available, that is, the calling convention. The standard inter-process calling convention for Windows used by DLLs is known as the WinAPI convention. It is defined in Windows header files as WINAPI, which is in turn defined using the Win32 declarator __stdcall.

bobbymcr
  • 23,769
  • 3
  • 56
  • 67
2

It's Windows-specific. It specifies the calling convention. WinMain gets called by Windows, and this ensures that the caller and callee agree on the calling convention.

Jerry Coffin
  • 476,176
  • 80
  • 629
  • 1,111