Pyrogenesis  trunk
wstartup.h
Go to the documentation of this file.
1 /* Copyright (c) 2010 Wildfire Games
2  *
3  * Permission is hereby granted, free of charge, to any person obtaining
4  * a copy of this software and associated documentation files (the
5  * "Software"), to deal in the Software without restriction, including
6  * without limitation the rights to use, copy, modify, merge, publish,
7  * distribute, sublicense, and/or sell copies of the Software, and to
8  * permit persons to whom the Software is furnished to do so, subject to
9  * the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included
12  * in all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
17  * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
18  * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
19  * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
20  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21  */
22 
23 /*
24  * windows-specific startup code
25  */
26 
27 // linking with this component should automatically arrange for winit's
28 // functions to be called at the appropriate times.
29 //
30 // the current implementation manages to trigger initialization in-between
31 // calls to CRT init and the static C++ ctors. that means wpthread etc.
32 // APIs are safe to use from ctors, and winit initializers are allowed
33 // to use non-stateless CRT functions such as atexit.
34 //
35 // IMPORTANT NOTE: if compiling this into a static lib and not using VC8's
36 // "use library dependency inputs" linking mode, the object file will be
37 // discarded because it does not contain any symbols that resolve another
38 // module's undefined external(s). for a discussion of this topic, see:
39 // http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=144087
40 // workaround: in the main EXE project, reference a symbol from this module,
41 // thus forcing it to be linked in. example:
42 // #pragma comment(linker, "/include:_wstartup_InitAndRegisterShutdown")
43 // (doing that in this module isn't sufficient, because it would only
44 // affect the librarian and its generation of the static lib that holds
45 // this file. instead, the process of linking the main EXE must be fixed.)