MonoIntegrationGuide.txt 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. ---------------------------------Compiling runtime-------------------------------------
  2. - Grab Mono 5.4 (or newer) source code
  3. - From tarball: https://download.mono-project.com/sources/mono/
  4. - If on Windows, get the release from GitHub instead as tarballs don't seem to be configured for Windows builds
  5. - Optionally check it out from git repository: https://github.com/mono/mono
  6. - If on Windows, make sure your git client has this set: "git config --global core.autocrlf input" as otherwise you'll have problems with line endings during later steps
  7. - Expose "mono_class_bind_generic_parameters" to the public:
  8. - In mono/metadata/object-internals.h change:
  9. MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, gboolean is_dynamic) MONO_INTERNAL;
  10. to:
  11. MONO_API MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, mono_bool is_dynamic);
  12. then move it to:
  13. mono/metadata/object.h
  14. - In mono/metadata/reflection.c modify:
  15. MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, gboolean is_dynamic)
  16. to:
  17. MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, mono_bool is_dynamic)
  18. - (Windows only) Add "mono_class_bind_generic_parameters" entry to mono/msvc/mono.def file
  19. - Build
  20. - Install Mono binary release (whichever one is the latest).
  21. - (Windows only)Add the "(InstallDir)\Mono\bin" to your PATH environment variable.
  22. - If on Windows:
  23. - Go to msvc/ folder to find mono.sln (Visual studio solution)
  24. - Open in VS2012 as is, or open in later VS and upgrade all projects to latest toolkit (v120 and v140 tested and working)
  25. - Generate missing header files:
  26. - First compile "genmdesc" project for desired configuration (debug/release, 32/64 bit)
  27. - Then run "runmdesc x64\bin\Debug\genmdesc x64" located in /msvc folder
  28. - Replace folder path to genmdesc you generated in the previous step
  29. - Replace x64 with Win32 for 32-bit builds
  30. - Compile mono project with desired configuration (debug/release, 32/64 bit, SGen builds were not tested). You will receive mono-2.0.dll and mono-2.0.lib as output.
  31. - Repeat the "genmdesc" step above for each configuration. Doing it once might be enough but be on the safe side.
  32. - If on Linux/Mac:
  33. - "./autogen.sh --prefix="(OutputDir)" --disable-boehm --with-sgen-default-concurrent=no" (Replace (OutputDir) with a folder where you want to output the binaries, e.g. "C:\MonoInstall")
  34. - On Mac also add: "--disable-nls"
  35. - "./configure"
  36. - "make"
  37. - "make install"
  38. - Post build
  39. - (If using GDB only) Mono uses certain signals internally for normal operation. In order to avoid GDB triggering breakpoints when not required, put this in your .gdbinit file (in your $HOME path):
  40. - handle SIGXCPU SIG33 SIG35 SIG36 SIGPWR nostop noprint
  41. -----------------------------Compiling libraries & compiler -------------------------------------
  42. - If on Linux/Mac the compiler and libraries should already be compiled using the above steps
  43. - If on Windows:
  44. - Install Cygwin 32-bit version using these command line parameters:
  45. setup-x86.exe -qnNdO -R "C:\cygwin" -s "http://cygwin.mirror.constant.com"
  46. -l "C:\cygwin\var\cache\setup" -P autoconf -P automake -P bison -P gcc-core -P gcc-g++ -P mingw64-i686-runtime
  47. -P mingw64-i686-binutils -P mingw64-i686-gcc-core -P mingw64-i686-gcc-g++ -P mingw64-i686-headers -P mingw64-i686-pthreads
  48. -P mingw64-i686-windows-default-manifest -P mingw64-i686-winpthreads -P w32api-headers -P w32api-runtime
  49. -P windows-default-manifest -P libtool -P make -P python -P gettext-devel -P gettext -P intltool -P libiconv
  50. -P pkg-config -P git -P wget -P curl
  51. - Go to your mono source directory (the one retrieved when compiling the runtime) in terminal (Cygwin or native) and enter these commands in order:
  52. - "./autogen.sh --prefix="(OutputDir)" --with-preview=yes"" (Replace (OutputDir) with a folder where you want to output the binaries, e.g. "C:\MonoInstall")
  53. - "./configure --host=i686-w64-mingw32"
  54. - "make"
  55. - "make install"
  56. - Your built mono should now be output to (OutputDir) folder. (If it's not in that folder, check your Cygwin install folder under /usr/local)
  57. - Copy contents of (OutputDir)/include/mono/mono-2.0/mono to (BansheeRootDir)/Dependencies/Include/Mono
  58. - Make sure to modify "object.h" as you did above when building the binaries
  59. - Copy folder (OutputDir)/etc to (BansheeRootDir)/bin/Mono
  60. - Copy assembly folders (OutputDir)/lib/mono/4.0 and (OutputDir)/lib/mono/4.5 to (BansheeRootDir)/bin/Mono/lib/mono/4.0 and (BansheeRootDir)/bin/Mono/lib/mono/4.5, respectively
  61. - If you wish, you can clean up the assemblies within those folders are many might not be used. The minimum needed are "mscorlib.dll", "System.dll" and "System.Core.dll".
  62. - Copy the compiler (mcs executable) from (OutputDir)/lib/mono/4.5 to (BansheeRootDir)/bin/Mono/compiler