Mono-4.4.0-IntegrationGuide.txt 4.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. ---------------------------------Compiling runtime-------------------------------------
  2. - Retrieve mono sources using git:
  3. - (Windows only) 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
  4. - Clone mono from https://github.com/mono/mono (make sure to perform a RECURSIVE clone as there are sub-modules in the /external folder)
  5. - Checkout mono-4.4.0-branch
  6. - Checkout commit # febc509ab9a7d07734f5b694037bc2becbc97851 (later ones might, but might not work)
  7. - If on Windows:
  8. - Go to msvc/ folder to find mono.sln (Visual studio solution)
  9. - Open in VS2012 as is, or open in later VS and upgrade all projects to latest toolkit (v120 and v140 tested and working)
  10. - Expose "mono_class_bind_generic_parameters" to the public:
  11. - In mono/metadata/object-internals.h change:
  12. MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, gboolean is_dynamic) MONO_INTERNAL;
  13. to:
  14. MONO_API MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, mono_bool is_dynamic);
  15. then move it to:
  16. mono/metadata/object.h
  17. - In mono/metadata/reflection.c modify:
  18. MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, gboolean is_dynamic)
  19. to:
  20. MonoClass* mono_class_bind_generic_parameters (MonoClass *klass, int type_argc, MonoType **types, mono_bool is_dynamic)
  21. - (Windows only) Add "mono_class_bind_generic_parameters" entry to mono/msvc/mono.def file
  22. - (Windows only) Generate missing header files:
  23. - First compile "genmdesc" project for desired configuration (debug/release, 32/64 bit)
  24. - Then run "runmdesc x64\bin\Debug\genmdesc x64" located in /msvc folder
  25. - Replace folder path to genmdesc you generated in the previous step
  26. - Replace x64 with Win32 for 32-bit builds
  27. - 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.
  28. - Repeat the "genmdesc" step above for each configuration. Doing it once might be enough but be on the safe side.
  29. -----------------------------Compiling libraries & compiler -------------------------------------
  30. - Install Mono 4.2.3.4 (This is the latest binary release for Windows, you can use newer if there is one).
  31. - Add the "(InstallDir)\Mono\bin" to your PATH environment variable.
  32. - (Windows only)Install Cygwin 32-bit version using these command line parameters:
  33. setup-x86.exe -qnNdO -R "C:\cygwin" -s "http://cygwin.mirror.constant.com"
  34. -l "C:\cygwin\var\cache\setup" -P autoconf -P automake -P bison -P gcc-core -P gcc-g++ -P mingw64-i686-runtime
  35. -P mingw64-i686-binutils -P mingw64-i686-gcc-core -P mingw64-i686-gcc-g++ -P mingw64-i686-headers -P mingw64-i686-pthreads
  36. -P mingw64-i686-windows-default-manifest -P mingw64-i686-winpthreads -P w32api-headers -P w32api-runtime
  37. -P windows-default-manifest -P libtool -P make -P python -P gettext-devel -P gettext -P intltool -P libiconv
  38. -P pkg-config -P git -P wget -P curl
  39. - Go to your mono source directory (the one retrieved when compiling the runtime) in terminal (Cygwin or native) and enter these commands in order:
  40. - "./autogen.sh --prefix="(OutputDir)" --with-preview=yes"" (Replace (OutputDir) with a folder where you want to output the binaries, e.g. "C:\MonoInstall")
  41. - "./configure --host=i686-w64-mingw32" if Cygwin, "./configure" if native
  42. - "make"
  43. - "make install"
  44. - Your built mono should now be output to (OutputDir) folder. (If it's not in that folder, and if using Cygwin then check your Cygwin install folder under /usr/local)
  45. - Copy contents of (OutputDir)/include/mono/mono-2.0/mono to (BansheeRootDir)/Dependencies/Include/Mono
  46. - Make sure to modify "object.h" as you did above when building the binaries
  47. - Copy folder (OutputDir)/etc to (BansheeRootDir)/bin/Mono
  48. - 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
  49. - 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".
  50. - Copy the compiler (mcs executable) from (OutputDir)/lib/mono/4.5 to (BansheeRootDir)/bin/Mono/compiler