File: doc_compile_lib.h

package info (click to toggle)
angelscript 2.35.1%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 5,388 kB
  • sloc: cpp: 71,969; asm: 1,558; makefile: 665; xml: 214; javascript: 42; python: 22; ansic: 22; sh: 7
file content (221 lines) | stat: -rw-r--r-- 10,057 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
/**

\page doc_compile_lib Compile the library

In the sdk/angelscript/projects directory you'll find project files for many of the popular compilers. 
However, these project files are not always up to date with the latest version of the library. If you get 
any compiler or linker errors please make sure the project file include all the files in the 
sdk/angelscript/source directory, and that the project settings are set according to this article.

If you don't find a project file for your compiler, you can easily create your own project by adding
all the files in the sdk/angelscript/source directory, and configuring the project apropriately. If you
have a new compiler/target that hasn't been used with AngelScript before, you may need to edit the 
as_config.h file to make sure the library is compiled properly.

\see \ref doc_compile_platforms 



\section doc_compile_lib_1 Set compile time options

The code tries to contain compiler differences in as few places as possible. The header as_config.h 
was created for that purpose. There you will find some \#defines that allow different compilers 
to work. You'll probably not have to change this file, but if you're using a compiler not 
previously used and you're getting compiler errors it might be worth it to take a look at 
this file.

There are also a couple of other \#defines used in the code to alter the compilation. When 
compiling the library you might want to define ANGELSCRIPT_EXPORT so that library functions 
are exported. If you include the library source code directly in your application project you 
shouldn't have to define this flag.</p>

If AS_DEPRECATED is defined then some backwards compatibility is maintained, this can help 
you do the upgrade to the latest version a little more smoothly. There is no guarantee that 
the backwards compatibility will be maintained though so try to remove use of deprecated functions
as soon as possible.



\section doc_compile_lib_2 Linking with the library

There are four ways of compiling and linking with AngelScript in order to use it. I 
recommend linking with a static library. Note that all four ways are interchangable with 
only a small change in your code, i.e a defined flag before including the header file, and 
possibly a routine for manually loading the dll. The rest of your code should look exactly 
the same for each of the alternatives.



\subsection doc_compile_lib_2_1 1. Include library source files in project

You can take the source files for AngelScript and include them directly in your own 
project. The advantage of this is that you can be sure that the same compiler options are 
used for the library and the host applications, e.g. multi-threaded or single-threaded CRT. 
The disadvantage is that your project will be poluted with the library files.

The files that need to use the library should include the %angelscript.h header with no 
need for any special settings.

\code
// Include the library interface
#include "angelscript.h"

// ... Start using the library
\endcode



\subsection doc_compile_lib_2_2 2. Compile a static library and link into project

The most recommended way is to compile a static library that your project will link with. 
When compiling the static library you have to make sure that the correct compiler settings 
are used so that you don't get conflicts in linkage with the CRT functions. This happens 
if you for example compile the library with dynamically linked multi-threaded CRT and your
application with statically linked single-threaded CRT. (For Visual C++ you'll find these 
settings under Project -> Settings -> C/C++ -> Category: Code Generation)

To use the library you only need to include the %angelscript.h header file.

\code
// Include the library interface
#include "angelscript.h"

// ... Start using the library
\endcode



\subsection doc_compile_lib_2_3 3. Compile a dynamically loaded library with an import library

With Microsoft Visual C++ it is possible to compile a dynamically loaded library with an 
import library. The import library will then take care of the work needed to load the dll 
and bind the functions. A possible disadvantage of this method is that you are not able to 
give any user-friendly error messages in case loading the library fails.

To use the library you'll have to define ANGELSCRIPT_DLL_LIBRARY_IMPORT before including 
the %angelscript.h header file.

\code
// Include the library interface
#define ANGELSCRIPT_DLL_LIBRARY_IMPORT
#include "angelscript.h"

// ... Start using the library
\endcode




\subsection doc_compile_lib_2_4 4. Load the dynamically loaded library manually

If you want to use a dll, e.g. to share code between applications, I recommend loading the 
library manually as you can treat any failures to load or bind functions graciously.

To use manually loaded dll, you should define ANGELSCRIPT_DLL_MANUAL_IMPORT before including 
the %angelscript.h header file. This will insure that the header file doesn't declare the 
function prototypes, as you will most likely want to use these names for the function pointers.

\code
// Include the library interface
#define ANGELSCRIPT_DLL_MANUAL_IMPORT
#include "angelscript.h"

// Declare the function pointers
typedef asIScriptEngine * AS_CALL t_asCreateScriptEngine(int);
t_asCreateScriptEngine *asCreateScriptEngine = 0;

// ... Declare the rest of the functions

// Load the dll and bind the functions (error handling left out for clarity)
HMODULE dll = LoadLibrary("angelscript.dll");
asCreateScriptEngine = (t_asCreateScriptEngine*)GetProcAddress(dll, "_asCreateScriptEngine");

// ... Bind the other functions

// ... Start using the library
\endcode


\section doc_compile_platforms Considerations for specific platforms

As mentioned before, for most platforms the compilation of the library is as easy as including all 
source files and compiling them. However, on some platforms specific actions needs to be performed
to compile the library correctly.

\subsection doc_compile_win64 Windows 64bit

The MSVC compiler doesn't support inline assembler for the x86 64bit CPU family. To support this platform a
separate assembler file has been created: as_callfunc_x64_msvc_asm.asm.

To compile this file it is necessary to configure a custom build command with the following:

\code
ml64.exe /c  /nologo /Fo$(OutDir)\as_callfunc_x64_msvc_asm.obj /W3 /Zi /Ta $(InputDir)\$(InputFileName)
\endcode

\subsection doc_compile_msvc_sdk Microsoft Visual C++

While AngelScript doesn't use Microsoft's language extensions you may still face trouble compiling the library
if you disable the language extensions. This is because Microsoft's own SDK may have code that relies on the 
language extensions, e.g. in version 6.0a you might get compiler errors due to the existance of $ in the macro
definitions in the specstrings.h header from the Platform SDK. This particular problem was fixed by Microsoft 
in version 6.1 of their SDK, but there may be others so it might just easier to leave the language extensions
turned on.

\subsection doc_compile_gnuc GNUC based compilers

In order to properly intergrate with C++ without the need for wrappers AngelScript uses a lot of pointer casts.
Unfortunately it is not possible to always guarantee strict aliasing because of this, so on GNUC based compilers
it is necessary to disable compiler optimizations that assume strict aliasing.

Use the following compiler argument to disable this:

\code
-fno-strict-aliasing
\endcode

\subsection doc_compile_pocketpc Pocket PC with ARM CPU

The MSVC compiler doesn't support inline assembler for the ARM CPU, so a separate assembler file has been 
written with this code: as_callfunc_arm_msvc.asm.

In order to compile this file properly it is necessary to configure a custom build command with the following:

\code
armasm -g $(InputPath)
\endcode

\subsection doc_compile_marmalade Marmalade

Marmalade is a cross platform SDK created with mobile devices in mind. It functions by abstracting the underlying OS
with its own C runtime library even though it uses the common C++ compilers, e.g. MSVC on Windows, and GNUC on Linux and Mac.

When compiling AngelScript with Marmalade for iOS and Android scons must be used in order to properly 
compile the native ARM assembler routines. For Windows Phone you should be able to use MSVC normally.



\section doc_compile_size Size of the library

The size of the library depends on many different factors, such as compiler brand, compiler flags, and also what features 
of AngelScript that are included. However, to give an idea of how much space the library will take up on the disk and memory 
I've compiled the \ref doc_samples_asrun "asrun sample" in a few different ways and noted down the size.

<table>
<tr><td><b>Options</b></td><td><b>Size of binary on disk</b></td></tr>
<tr><td>32 bit / multithreaded dll / optimize for speed<br>Without including AngelScript</td><td>14KB</td></tr>
<tr><td>32 bit / multithreaded dll / optimize for speed<br>Using AngelScript and add-ons</td><td>796KB</td></tr>
<tr><td>32 bit / multithreaded dll / optimize for speed<br>AngelScript without compiler (AS_NO_COMPILER) and add-ons</td><td>453KB</td></tr>
<tr><td>32 bit / multithreaded static / optimize for speed<br>Using AngelScript but without add-ons</td><td>867KB</td></tr>
<tr><td>32 bit / multithreaded static / optimize for speed<br>Using AngelScript and add-ons</td><td>1015KB</td></tr>
<tr><td>64 bit / multithreaded static / optimize for speed<br>Using AngelScript and add-ons</td><td>1336KB</td></tr>
<tr><td>32 bit / multithreaded static / optimize for size<br>Using AngelScript and add-ons</td><td>797KB</td></tr>
<tr><td>32 bit / multithreaded dll / optimize for size<br>Using AngelScript and add-ons</td><td>582KB</td></tr>
</table>

Based on this we can draw the conclusion that the engine and VM takes up about 300KB when optimized for speed, 
the compiler adds another 350KB, and the add-ons yet another 150KB.

\note These tests were made with MSVC 2012 and version 2.30.2 of the library.

*/